Compare commits
	
		
			87 Commits
		
	
	
		
			v1.2.0
			...
			fd452f6643
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| fd452f6643 | |||
| c437a39e1d | |||
| 8b53b6e4d1 | |||
| ff42dfd3a4 | |||
| d8c5327180 | |||
| 42b26045a6 | |||
| d41f71f17d | |||
| c19c0bc80b | |||
| 86149d246a | |||
| 1e55b11eed | |||
| ce225b2888 | |||
| eb3d345c5a | |||
| 6cf4977a6c | |||
| ae226c9a84 | |||
| bf3b063e96 | |||
| e071877045 | |||
| af90f90156 | |||
| 389fa61fba | |||
| 16ef5bbb74 | |||
| a67197766e | |||
| 6cba7d6698 | |||
| ae414c5c99 | |||
| 9ab62d0545 | |||
| b44e55a92c | |||
| 53d86eb539 | |||
| 352b4d612f | |||
| 89925fe820 | |||
| 16b56a7084 | |||
| 62f8a662a0 | |||
| 39bbcd0d56 | |||
| 981b40d3b1 | |||
| 7bc4b9977d | |||
| 79860c7d39 | |||
| 99bab4a6ef | |||
| 8b01ee3c46 | |||
| 1feff0a25c | |||
| 9b42ad6d74 | |||
| 9639329df3 | |||
| 6cd686a17e | |||
| 3343f8ca28 | |||
| 3b8159b75f | |||
| 62e7580d3a | |||
| 11170006e9 | |||
| 37e3ca9360 | |||
| daca00603a | |||
| 1f5299ad1b | |||
| dfa260b87c | |||
| fc8b771026 | |||
| 0b77c074cf | |||
| 5007a1047a | |||
| 25860dc32a | |||
| d870599a60 | |||
| 9bd3e1cd8d | |||
| 681c0d09be | |||
| 25762b0c29 | |||
| 6afa08df82 | |||
| 0a995a3f2c | |||
| c607b20bad | |||
| 2e705627ac | |||
| 86a35fd668 | |||
| 8d4420528a | |||
| 3970b8d402 | |||
| 6522994a1f | |||
| 01a21032a5 | |||
| 4d7e7596b6 | |||
| 97b5300e48 | |||
| 8e7cc39000 | |||
| 1b70383448 | |||
| 64e1555d56 | |||
| a65c8d64b5 | |||
| fa2b801690 | |||
| 4e887b1ac2 | |||
| 126fc92fae | |||
| 2ef28273b0 | |||
| 04bf7d43ff | |||
| fb86dca332 | |||
| 7e380efd7d | |||
| b5e05864b6 | |||
| e2e5a1b8db | |||
| 2a2296685e | |||
| 0b298c6130 | |||
| f030ac62ae | |||
| 2734cc00fb | |||
| 3196c5021e | |||
| 72347ea9a2 | |||
| d13fe81ac5 | |||
| beba947c69 | 
| @@ -8,6 +8,9 @@ on: | |||||||
| jobs: | jobs: | ||||||
|   Windows-AMD64-Build: |   Windows-AMD64-Build: | ||||||
|     runs-on: windows-x86_64 |     runs-on: windows-x86_64 | ||||||
|  |     defaults: | ||||||
|  |       run: | ||||||
|  |         shell: powershell | ||||||
|     steps: |     steps: | ||||||
|       - name: Check out repository code |       - name: Check out repository code | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
| @@ -19,8 +22,9 @@ jobs: | |||||||
|       - name: Building/Compiling/Installing Project |       - name: Building/Compiling/Installing Project | ||||||
|         run: | |         run: | | ||||||
|           cd ${{ gitea.workspace }} |           cd ${{ gitea.workspace }} | ||||||
|           cmake -A x64 -DCMAKE_BUILD_TYPE=Release --preset=default . |           mkdir build | ||||||
|           cd build |           cd build | ||||||
|  |           cmake -A x64 -DCMAKE_BUILD_TYPE=Release -DCMAKE_TOOLCHAIN_FILE="$env:VCPKG_ROOT\scripts\buildsystems\vcpkg.cmake" .. | ||||||
|           cmake --build . --config Release |           cmake --build . --config Release | ||||||
|           cmake --install . |           cmake --install . | ||||||
|  |  | ||||||
| @@ -28,10 +32,12 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           cd ${{ gitea.workspace }} |           cd ${{ gitea.workspace }} | ||||||
|           mkdir bin |           mkdir bin | ||||||
|  |           mv build/Release/EHS_Dyn.dll bin | ||||||
|           mv build/Release/StrToHash.exe bin |           mv build/Release/StrToHash.exe bin | ||||||
|           mv build/Release/zlib1.dll bin |           mv build/Release/zlib1.dll bin | ||||||
|           mkdir lib |           mkdir lib | ||||||
|           mv build/Release/EHS.lib lib |           mv build/Release/EHS_Stc.lib lib | ||||||
|  |           mv build/Release/EHS_Dyn.lib lib | ||||||
|  |  | ||||||
|       - name: Zipping Binaries |       - name: Zipping Binaries | ||||||
|         run: | |         run: | | ||||||
| @@ -49,6 +55,7 @@ jobs: | |||||||
|           files: |- |           files: |- | ||||||
|             ehs-windows-amd64.zip |             ehs-windows-amd64.zip | ||||||
|           api_key: '${{secrets.RELEASE_TOKEN}}' |           api_key: '${{secrets.RELEASE_TOKEN}}' | ||||||
|  |           pre_release: false | ||||||
|  |  | ||||||
|   Linux-AMD64-Build: |   Linux-AMD64-Build: | ||||||
|     runs-on: linux-x86_64 |     runs-on: linux-x86_64 | ||||||
| @@ -58,7 +65,7 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Installing Dependencies |       - name: Installing Dependencies | ||||||
|         run: | |         run: | | ||||||
|           sudo pacman -S --noconfirm doxygen zip alsa-lib libxcb xcb-util-cursor |           sudo pacman -S --noconfirm doxygen zip alsa-lib libxcb xcb-util-cursor pipewire | ||||||
|  |  | ||||||
|       - name: Generating Documentation |       - name: Generating Documentation | ||||||
|         run: | |         run: | | ||||||
| @@ -73,10 +80,12 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Creating Appropriate Directories |       - name: Creating Appropriate Directories | ||||||
|         run: | |         run: | | ||||||
|  |           cd ${{ gitea.workspace }} | ||||||
|           mkdir bin |           mkdir bin | ||||||
|  |           mv libEHS_Dyn.so bin | ||||||
|           mv StrToHash bin |           mv StrToHash bin | ||||||
|           mkdir lib |           mkdir lib | ||||||
|           mv libEHS.a lib |           mv libEHS_Stc.a lib | ||||||
|  |  | ||||||
|       - name: Zipping Binaries |       - name: Zipping Binaries | ||||||
|         run: zip -r ehs-linux-amd64.zip include bin lib docs LICENSE RADME.md |         run: zip -r ehs-linux-amd64.zip include bin lib docs LICENSE RADME.md | ||||||
| @@ -92,6 +101,7 @@ jobs: | |||||||
|           files: |- |           files: |- | ||||||
|             ehs-linux-amd64.zip |             ehs-linux-amd64.zip | ||||||
|           api_key: '${{secrets.RELEASE_TOKEN}}' |           api_key: '${{secrets.RELEASE_TOKEN}}' | ||||||
|  |           pre_release: false | ||||||
|  |  | ||||||
|   Linux-AARCH64-Build: |   Linux-AARCH64-Build: | ||||||
|     runs-on: linux-aarch64 |     runs-on: linux-aarch64 | ||||||
| @@ -100,7 +110,7 @@ jobs: | |||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       - name: Installing Dependencies |       - name: Installing Dependencies | ||||||
|         run: sudo apt install -y doxygen zip libasound2-dev libxcb1-dev libxcb-xinput-dev libxcb-cursor-dev |         run: sudo apt install -y doxygen zip libasound2-dev libxcb1-dev libxcb-xinput-dev libxcb-cursor-dev libpipewire-0.3-dev | ||||||
|  |  | ||||||
|       - name: Generating Documentation |       - name: Generating Documentation | ||||||
|         run: | |         run: | | ||||||
| @@ -115,10 +125,12 @@ jobs: | |||||||
|  |  | ||||||
|       - name: Creating Appropriate Directories |       - name: Creating Appropriate Directories | ||||||
|         run: | |         run: | | ||||||
|  |           cd ${{ gitea.workspace }} | ||||||
|           mkdir bin |           mkdir bin | ||||||
|  |           mv libEHS_Dyn.so bin | ||||||
|           mv StrToHash bin |           mv StrToHash bin | ||||||
|           mkdir lib |           mkdir lib | ||||||
|           mv libEHS.a lib |           mv libEHS_Stc.a lib | ||||||
|  |  | ||||||
|       - name: Zipping Binaries |       - name: Zipping Binaries | ||||||
|         run: zip -r ehs-linux-aarch64.zip include bin lib docs LICENSE README.md |         run: zip -r ehs-linux-aarch64.zip include bin lib docs LICENSE README.md | ||||||
| @@ -134,3 +146,4 @@ jobs: | |||||||
|           files: |- |           files: |- | ||||||
|             ehs-linux-aarch64.zip |             ehs-linux-aarch64.zip | ||||||
|           api_key: '${{secrets.RELEASE_TOKEN}}' |           api_key: '${{secrets.RELEASE_TOKEN}}' | ||||||
|  |           pre_release: false | ||||||
							
								
								
									
										105
									
								
								CMakeLists.txt
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								CMakeLists.txt
									
									
									
									
									
								
							| @@ -13,7 +13,8 @@ project(EHS CXX C) | |||||||
|  |  | ||||||
| if (${CMAKE_HOST_SYSTEM_NAME} STREQUAL "Windows") | if (${CMAKE_HOST_SYSTEM_NAME} STREQUAL "Windows") | ||||||
|     set(IS_OS_WINDOWS TRUE) |     set(IS_OS_WINDOWS TRUE) | ||||||
|     set(USER_HOME_DIRECTORY $ENV{USERPROFILE}) |     set(USER_HOME_DIRECTORY "$ENV{USERPROFILE}") | ||||||
|  |     string(REPLACE "\\" "/" USER_HOME_DIRECTORY "${USER_HOME_DIRECTORY}") | ||||||
|     message("Building for the Windows operating system.") |     message("Building for the Windows operating system.") | ||||||
| elseif (${CMAKE_HOST_SYSTEM_NAME} STREQUAL "Linux") | elseif (${CMAKE_HOST_SYSTEM_NAME} STREQUAL "Linux") | ||||||
|     set(IS_OS_LINUX TRUE) |     set(IS_OS_LINUX TRUE) | ||||||
| @@ -42,7 +43,7 @@ set(EHS_SOURCES | |||||||
|     src/EHS.cpp include/ehs/EHS.h |     src/EHS.cpp include/ehs/EHS.h | ||||||
|     src/Type.cpp include/ehs/Type.h |     src/Type.cpp include/ehs/Type.h | ||||||
|     src/BaseObj.cpp include/ehs/BaseObj.h |     src/BaseObj.cpp include/ehs/BaseObj.h | ||||||
|         src/GarbageCollector.cpp include/ehs/GarbageCollector.h |     src/GC.cpp include/ehs/GC.h | ||||||
|     src/Log.cpp include/ehs/Log.h |     src/Log.cpp include/ehs/Log.h | ||||||
|     src/URI.cpp include/ehs/URI.h |     src/URI.cpp include/ehs/URI.h | ||||||
|     src/Math.cpp include/ehs/Math.h |     src/Math.cpp include/ehs/Math.h | ||||||
| @@ -82,7 +83,7 @@ set(EHS_SOURCES | |||||||
|     include/ehs/ShdPtr.h |     include/ehs/ShdPtr.h | ||||||
|     include/ehs/WkPtr.h |     include/ehs/WkPtr.h | ||||||
|  |  | ||||||
|         src/database/DVar.cpp include/ehs/database/DVar.h |     src/db/DbVarTmpl.cpp include/ehs/db/DbVarTmpl.h | ||||||
|  |  | ||||||
|     src/system/CPU.cpp include/ehs/system/CPU.h |     src/system/CPU.cpp include/ehs/system/CPU.h | ||||||
|     src/system/Thread.cpp include/ehs/system/Thread.h |     src/system/Thread.cpp include/ehs/system/Thread.h | ||||||
| @@ -120,19 +121,27 @@ set(EHS_SOURCES | |||||||
|     include/ehs/io/FileMonitor.h |     include/ehs/io/FileMonitor.h | ||||||
|     include/ehs/io/Window.h |     include/ehs/io/Window.h | ||||||
|  |  | ||||||
|  |     include/ehs/io/socket/Socket.h | ||||||
|     src/io/socket/Request.cpp include/ehs/io/socket/Request.h |     src/io/socket/Request.cpp include/ehs/io/socket/Request.h | ||||||
|     src/io/socket/Response.cpp include/ehs/io/socket/Response.h |     src/io/socket/Response.cpp include/ehs/io/socket/Response.h | ||||||
|         src/io/socket/DNS.cpp include/ehs/io/socket/DNS.h |     src/io/socket/BaseDNS.cpp include/ehs/io/socket/BaseDNS.h | ||||||
|  |     include/ehs/io/socket/DNS.h | ||||||
|     src/io/socket/BaseUDP.cpp include/ehs/io/socket/BaseUDP.h |     src/io/socket/BaseUDP.cpp include/ehs/io/socket/BaseUDP.h | ||||||
|  |     include/ehs/io/socket/UDP.h | ||||||
|     src/io/socket/BaseTCP.cpp include/ehs/io/socket/BaseTCP.h |     src/io/socket/BaseTCP.cpp include/ehs/io/socket/BaseTCP.h | ||||||
|  |     include/ehs/io/socket/TCP.h | ||||||
|     src/io/socket/SSL.cpp include/ehs/io/socket/SSL.h |     src/io/socket/SSL.cpp include/ehs/io/socket/SSL.h | ||||||
|  |  | ||||||
|  |     include/ehs/io/socket/ehc/NetUtils.h | ||||||
|  |     src/io/socket/EHC.cpp include/ehs/io/socket/EHC.h | ||||||
|  |     src/io/socket/ehc/NetFrag.cpp include/ehs/io/socket/ehc/NetFrag.h | ||||||
|  |     src/io/socket/ehc/NetEnd.cpp include/ehs/io/socket/ehc/NetEnd.h | ||||||
|  |     src/io/socket/ehc/NetSys.cpp include/ehs/io/socket/ehc/NetSys.h | ||||||
|  |     src/io/socket/ehc/NetOp.cpp include/ehs/io/socket/ehc/NetOp.h | ||||||
|  |  | ||||||
|     src/io/socket/rest/Twitch.cpp include/ehs/io/socket/rest/Twitch.h |     src/io/socket/rest/Twitch.cpp include/ehs/io/socket/rest/Twitch.h | ||||||
|     src/io/socket/rest/TwitchChat.cpp include/ehs/io/socket/rest/TwitchChat.h |     src/io/socket/rest/TwitchChat.cpp include/ehs/io/socket/rest/TwitchChat.h | ||||||
|     src/io/socket/rest/Spotify.cpp include/ehs/io/socket/rest/Spotify.h |     src/io/socket/rest/Spotify.cpp include/ehs/io/socket/rest/Spotify.h | ||||||
|         include/ehs/io/socket/Socket.h |  | ||||||
|         include/ehs/io/socket/TCP.h |  | ||||||
|         include/ehs/io/socket/UDP.h |  | ||||||
|  |  | ||||||
|     src/io/audio/Audio.cpp include/ehs/io/audio/Audio.h |     src/io/audio/Audio.cpp include/ehs/io/audio/Audio.h | ||||||
|     src/io/audio/BaseAudioDevice.cpp include/ehs/io/audio/BaseAudioDevice.h |     src/io/audio/BaseAudioDevice.cpp include/ehs/io/audio/BaseAudioDevice.h | ||||||
| @@ -162,12 +171,38 @@ set(EHS_SOURCES | |||||||
|     src/io/hid/Input.cpp include/ehs/io/hid/Input.h |     src/io/hid/Input.cpp include/ehs/io/hid/Input.h | ||||||
|     src/io/model/MdlCodec.cpp |     src/io/model/MdlCodec.cpp | ||||||
|     include/ehs/io/mdl/MdlCodec.h |     include/ehs/io/mdl/MdlCodec.h | ||||||
|  |     include/ehs/io/UsbBase.h | ||||||
|  |     src/io/UsbBase.cpp | ||||||
|  |     include/ehs/db/DbTable.h | ||||||
|  |     include/ehs/db/DbObject.h | ||||||
|  |     include/ehs/db/DbVar.h | ||||||
|  |     src/db/DbVar.cpp | ||||||
|  |     include/ehs/db/Database.h | ||||||
|  |     src/db/DbObject.cpp | ||||||
|  |     src/db/Database.cpp | ||||||
|  |     src/db/Database.cpp | ||||||
|  |     src/db/DbTable.cpp | ||||||
|  |     include/ehs/io/BaseDirectory.h | ||||||
|  |     src/io/BaseDirectory.cpp | ||||||
|  |     include/ehs/io/Directory.h | ||||||
|  |     include/ehs/io/socket/ehc/NetEnc.h | ||||||
|  |     src/io/socket/ehc/NetEnc.cpp | ||||||
|  |     include/ehs/io/socket/ehc/NetChannel.h | ||||||
|  |     src/io/socket/ehc/NetChannel.cpp | ||||||
|  |     include/ehs/io/socket/ehc/NetServerCh.h | ||||||
|  |     include/ehs/io/socket/ehc/NetClientCh.h | ||||||
|  |     src/io/socket/ehc/NetClientCh.cpp | ||||||
|  |     src/io/socket/ehc/NetServerCh.cpp | ||||||
|  |     src/io/socket/ehc/NetUtils.cpp | ||||||
|  |     include/ehs/io/socket/BaseICMP.h src/io/socket/BaseICMP.cpp | ||||||
|  |     include/ehs/io/socket/ICMP.h | ||||||
| ) | ) | ||||||
|  |  | ||||||
| if (IS_OS_WINDOWS) | if (IS_OS_WINDOWS) | ||||||
|     list(APPEND EHS_SOURCES |     list(APPEND EHS_SOURCES | ||||||
|         src/io/socket/UDP_W32.cpp include/ehs/io/socket/UDP_W32.h |         src/io/socket/UDP_W32.cpp include/ehs/io/socket/UDP_W32.h | ||||||
|         src/io/socket/TCP_W32.cpp include/ehs/io/socket/TCP_W32.h |         src/io/socket/TCP_W32.cpp include/ehs/io/socket/TCP_W32.h | ||||||
|  |         src/io/socket/DNS_W32.cpp include/ehs/io/socket/DNS_W32.h | ||||||
|         src/system/Semaphore_W32.cpp include/ehs/system/Semaphore_W32.h |         src/system/Semaphore_W32.cpp include/ehs/system/Semaphore_W32.h | ||||||
|         src/system/System_W32.cpp include/ehs/system/System_W32.h |         src/system/System_W32.cpp include/ehs/system/System_W32.h | ||||||
|         src/system/Mutex_W32.cpp include/ehs/system/Mutex_W32.h |         src/system/Mutex_W32.cpp include/ehs/system/Mutex_W32.h | ||||||
| @@ -178,27 +213,37 @@ if (IS_OS_WINDOWS) | |||||||
|         src/io/Window_W32.cpp include/ehs/io/Window_W32.h |         src/io/Window_W32.cpp include/ehs/io/Window_W32.h | ||||||
|         src/io/COM.cpp include/ehs/io/COM.h |         src/io/COM.cpp include/ehs/io/COM.h | ||||||
|         src/system/CPU_MSVC_AMD64.asm src/HRNG_MSVC.asm src/Math_MSVC_AMD64.asm |         src/system/CPU_MSVC_AMD64.asm src/HRNG_MSVC.asm src/Math_MSVC_AMD64.asm | ||||||
|  |         src/io/Directory_W32.cpp include/ehs/io/Directory_W32.h | ||||||
|  |         include/ehs/io/socket/ICMP_W32.h src/io/socket/ICMP_W32.cpp | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
| elseif (IS_OS_LINUX) | elseif (IS_OS_LINUX) | ||||||
|     list(APPEND EHS_SOURCES |     list(APPEND EHS_SOURCES | ||||||
|         src/io/socket/UDP_BSD.cpp include/ehs/io/socket/UDP_BSD.h |         src/io/socket/UDP_BSD.cpp include/ehs/io/socket/UDP_BSD.h | ||||||
|         src/io/socket/TCP_BSD.cpp include/ehs/io/socket/TCP_BSD.h |         src/io/socket/TCP_BSD.cpp include/ehs/io/socket/TCP_BSD.h | ||||||
|  |         src/io/socket/DNS_LNX.cpp include/ehs/io/socket/DNS_LNX.h | ||||||
|         src/system/Semaphore_P.cpp include/ehs/system/Semaphore_P.h |         src/system/Semaphore_P.cpp include/ehs/system/Semaphore_P.h | ||||||
|         src/system/System_LNX.cpp include/ehs/system/System_LNX.h |         src/system/System_LNX.cpp include/ehs/system/System_LNX.h | ||||||
|         src/system/Open_UNX.cpp include/ehs/system/Open_UNX.h |         src/system/Open_UNX.cpp include/ehs/system/Open_UNX.h | ||||||
|         src/io/File_UNX.cpp include/ehs/io/File_UNX.h |         src/io/File_UNX.cpp include/ehs/io/File_UNX.h | ||||||
|         src/io/FileMonitor_UNX.cpp include/ehs/io/FileMonitor_UNX.h |         src/io/FileMonitor_UNX.cpp include/ehs/io/FileMonitor_UNX.h | ||||||
|         src/system/Mutex_PT.cpp include/ehs/system/Mutex_PT.h |         src/system/Mutex_PT.cpp include/ehs/system/Mutex_PT.h | ||||||
|             src/io/audio/AudioDevice_ALSA.cpp include/ehs/io/audio/AudioDevice_ALSA.h |         src/io/audio/AudioDevice_PW.cpp include/ehs/io/audio/AudioDevice_PW.h | ||||||
|         src/system/FileSystem.cpp include/ehs/system/FileSystem.h |         src/system/FileSystem.cpp include/ehs/system/FileSystem.h | ||||||
|         src/system/User.cpp include/ehs/system/User.h |         src/system/User.cpp include/ehs/system/User.h | ||||||
|  |         src/io/Directory_LNX.cpp include/ehs/io/Directory_LNX.h | ||||||
|  |         src/io/Usb_LNX.cpp include/ehs/io/Usb_LNX.h | ||||||
|  |         include/ehs/io/socket/ICMP_LNX.h src/io/socket/ICMP_LNX.cpp | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|     set(LINUX_WINDOW_SYSTEM "Wayland" CACHE STRING "Linux Window System") |     #set(LINUX_WINDOW_SYSTEM "Wayland" CACHE STRING "Linux Window System") | ||||||
|  |  | ||||||
|     if (LINUX_WINDOW_SYSTEM STREQUAL "Wayland") |     if (LINUX_WINDOW_SYSTEM STREQUAL "Wayland") | ||||||
|         add_compile_definitions(EHS_WS_WAYLAND) |         add_compile_definitions(EHS_WS_WAYLAND) | ||||||
|         list(APPEND EHS_SOURCES src/io/xdg-shell-protocol.c include/ehs/io/xdg-shell-client-protocol.h src/io/Window_Way.cpp include/ehs/io/Window_Way.h) |         list(APPEND EHS_SOURCES | ||||||
|  |                 src/io/xdg-shell-protocol.c include/ehs/io/xdg-shell-client-protocol.h | ||||||
|  |                 src/io/xdg-decoration.c include/ehs/io/xdg-decoration.h | ||||||
|  |                 src/io/Window_Way.cpp include/ehs/io/Window_Way.h) | ||||||
|         message("Building for Wayland.") |         message("Building for Wayland.") | ||||||
|     elseif (LINUX_WINDOW_SYSTEM STREQUAL "XCB") |     elseif (LINUX_WINDOW_SYSTEM STREQUAL "XCB") | ||||||
|         add_compile_definitions(EHS_WS_XCB) |         add_compile_definitions(EHS_WS_XCB) | ||||||
| @@ -216,23 +261,37 @@ endif() | |||||||
| #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC") | #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC") | ||||||
| #message("${CMAKE_CXX_FLAGS}") | #message("${CMAKE_CXX_FLAGS}") | ||||||
|  |  | ||||||
| add_library(EHS ${EHS_SOURCES}) | add_library(EHS_Stc STATIC ${EHS_SOURCES}) | ||||||
|  | add_library(EHS_Dyn SHARED ${EHS_SOURCES}) | ||||||
| add_executable(StrToHash src/StrToHash.cpp) | add_executable(StrToHash src/StrToHash.cpp) | ||||||
|  |  | ||||||
| target_include_directories(EHS PUBLIC ${PROJECT_SOURCE_DIR}/include) | target_compile_definitions(EHS_Dyn PRIVATE EHS_LIB_EXPORT) | ||||||
|  |  | ||||||
|  | target_include_directories(EHS_Stc PUBLIC ${PROJECT_SOURCE_DIR}/include) | ||||||
|  | target_include_directories(EHS_Dyn PUBLIC ${PROJECT_SOURCE_DIR}/include) | ||||||
|  |  | ||||||
| if (IS_OS_LINUX) | if (IS_OS_LINUX) | ||||||
|     set(CMAKE_INSTALL_PREFIX "${USER_HOME_DIRECTORY}/.local") |     set(CMAKE_INSTALL_PREFIX "${USER_HOME_DIRECTORY}/.local") | ||||||
|  |     install(TARGETS EHS_Dyn LIBRARY DESTINATION "bin") | ||||||
|  |  | ||||||
|  |     find_package(PkgConfig REQUIRED) | ||||||
|  |     pkg_check_modules(PIPEWIRE REQUIRED libpipewire-0.3) | ||||||
|  |  | ||||||
|  |     target_include_directories(EHS_Stc PRIVATE ${PIPEWIRE_INCLUDE_DIRS}) | ||||||
|  |     target_include_directories(EHS_Dyn PRIVATE ${PIPEWIRE_INCLUDE_DIRS}) | ||||||
| elseif (IS_OS_WINDOWS) | elseif (IS_OS_WINDOWS) | ||||||
|     set(CMAKE_INSTALL_PREFIX "${USER_HOME_DIRECTORY}/EHS") |     set(CMAKE_INSTALL_PREFIX "${USER_HOME_DIRECTORY}/EHS") | ||||||
|  |     install(TARGETS EHS_Dyn LIBRARY DESTINATION "lib") | ||||||
|  |     install(TARGETS EHS_Dyn RUNTIME DESTINATION "bin") | ||||||
|  |  | ||||||
|  |     file(GLOB DLL_FILES "${CMAKE_CURRENT_BINARY_DIR}/*.dll") | ||||||
|  |     install(FILES ${DLL_FILES} DESTINATION "bin") | ||||||
| endif () | endif () | ||||||
|  |  | ||||||
| install(TARGETS EHS DESTINATION lib) | install(TARGETS EHS_Stc DESTINATION "lib") | ||||||
|  | install(TARGETS StrToHash DESTINATION "bin") | ||||||
|  |  | ||||||
| install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/include/ DESTINATION include) | install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/" DESTINATION "include") | ||||||
|  |  | ||||||
| install(TARGETS StrToHash DESTINATION bin) |  | ||||||
|  |  | ||||||
| find_package(ZLIB REQUIRED) | find_package(ZLIB REQUIRED) | ||||||
| if (ZLIB_FOUND) | if (ZLIB_FOUND) | ||||||
| @@ -248,16 +307,22 @@ else () | |||||||
|     message(STATUS "OpenSSL was not found.") |     message(STATUS "OpenSSL was not found.") | ||||||
| endif () | endif () | ||||||
|  |  | ||||||
| target_link_libraries(EHS OpenSSL::SSL OpenSSL::Crypto ZLIB::ZLIB) | target_link_libraries(EHS_Stc OpenSSL::SSL OpenSSL::Crypto ZLIB::ZLIB) | ||||||
|  | target_link_libraries(EHS_Dyn OpenSSL::SSL OpenSSL::Crypto ZLIB::ZLIB) | ||||||
|  | target_link_libraries(StrToHash OpenSSL::SSL OpenSSL::Crypto ZLIB::ZLIB) | ||||||
|  |  | ||||||
| if (IS_OS_WINDOWS) | if (IS_OS_WINDOWS) | ||||||
|     target_link_libraries(StrToHash ws2_32 avrt EHS) |     target_link_libraries(EHS_Dyn avrt ws2_32 IPHLPAPI) | ||||||
|  |     target_link_libraries(StrToHash ws2_32 avrt EHS_Stc) | ||||||
| elseif (IS_OS_LINUX) | elseif (IS_OS_LINUX) | ||||||
|     if (LINUX_WINDOW_SYSTEM STREQUAL "Wayland") |     if (LINUX_WINDOW_SYSTEM STREQUAL "Wayland") | ||||||
|  |         target_link_libraries(EHS_Dyn wayland-client) | ||||||
|         target_link_libraries(StrToHash wayland-client) |         target_link_libraries(StrToHash wayland-client) | ||||||
|     elseif (LINUX_WINDOW_SYSTEM STREQUAL "XCB") |     elseif (LINUX_WINDOW_SYSTEM STREQUAL "XCB") | ||||||
|  |         target_link_libraries(EHS_Dyn xcb xcb-cursor xcb-xfixes xcb-xinput) | ||||||
|         target_link_libraries(StrToHash xcb xcb-cursor xcb-xfixes xcb-xinput) |         target_link_libraries(StrToHash xcb xcb-cursor xcb-xfixes xcb-xinput) | ||||||
|     endif () |     endif () | ||||||
|  |  | ||||||
|     target_link_libraries(StrToHash z asound EHS) |     target_link_libraries(EHS_Dyn z asound pipewire-0.3) | ||||||
|  |     target_link_libraries(StrToHash z asound EHS_Stc) | ||||||
| endif () | endif () | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| { |  | ||||||
|   "version": 3, |  | ||||||
|   "configurePresets": [ |  | ||||||
|     { |  | ||||||
|       "name": "default", |  | ||||||
|       "binaryDir": "${sourceDir}/build", |  | ||||||
|       "cacheVariables": { |  | ||||||
|         "CMAKE_TOOLCHAIN_FILE": "$env{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake" |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   ] |  | ||||||
| } |  | ||||||
							
								
								
									
										21
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								README.md
									
									
									
									
									
								
							| @@ -8,6 +8,7 @@ This project does not fully follow the C++ standard. | |||||||
| ### Features | ### Features | ||||||
| - Audio IO/Processing/Manipulation | - Audio IO/Processing/Manipulation | ||||||
| - Image Processing/Manipulation | - Image Processing/Manipulation | ||||||
|  | - Databases | ||||||
| - 3D Model & Mesh Processing/Manipulation | - 3D Model & Mesh Processing/Manipulation | ||||||
| - File IO | - File IO | ||||||
| - Basic File Monitoring | - Basic File Monitoring | ||||||
| @@ -20,7 +21,8 @@ This project does not fully follow the C++ standard. | |||||||
| - Mutexes | - Mutexes | ||||||
| - Semaphores | - Semaphores | ||||||
| - CPU information and features at runtime | - CPU information and features at runtime | ||||||
| - HTTP(S) Sockets | - HTTP(S) Socket Layer | ||||||
|  | - ICMP & ICMPv6 Socket | ||||||
| - TCP Socket | - TCP Socket | ||||||
| - UDP Socket | - UDP Socket | ||||||
| - COM (Serial) IO | - COM (Serial) IO | ||||||
| @@ -29,12 +31,13 @@ This project does not fully follow the C++ standard. | |||||||
| - Twitch Integration | - Twitch Integration | ||||||
| - Json Parsing/Writing | - Json Parsing/Writing | ||||||
| - User Friendly HID Input | - User Friendly HID Input | ||||||
| - Basic Garbage Collector | - Heap Garbage Collector | ||||||
| - Linked List | - Linked List | ||||||
| - Array | - Array | ||||||
| - Vector | - Vector | ||||||
| - Asynchronous Task System | - Asynchronous Task System | ||||||
| - URI Parsing | - URI Parsing | ||||||
|  | - USB (WIP) | ||||||
|  |  | ||||||
| ### Supported Architectures | ### Supported Architectures | ||||||
| - AMD64 | - AMD64 | ||||||
| @@ -71,8 +74,10 @@ Wayland Window System. Wayland support is currently not fully supported yet, use | |||||||
| - [CMake](https://cmake.org/) | - [CMake](https://cmake.org/) | ||||||
| - [vcpkg](https://learn.microsoft.com/en-us/vcpkg/get_started/get-started?pivots=shell-cmd) | - [vcpkg](https://learn.microsoft.com/en-us/vcpkg/get_started/get-started?pivots=shell-cmd) | ||||||
|  |  | ||||||
|  | `vcpkg install` - Use this command in the directory where `vcpkg.json` is located to download/install dependencies. | ||||||
|  |  | ||||||
| ### Building | ### Building | ||||||
| `cmake -A x64 -DCMAKE_BUILD_TYPE=Release --preset=default /path/to/source` | `cmake -A x64 -DCMAKE_BUILD_TYPE=Release /path/to/source` | ||||||
|  |  | ||||||
| ### Compiling | ### Compiling | ||||||
| `cmake --build /path/to/build --config Release` | `cmake --build /path/to/build --config Release` | ||||||
| @@ -87,12 +92,10 @@ This will require the terminal to be running in administrator mode. | |||||||
| #include <ehs/EHS.h> | #include <ehs/EHS.h> | ||||||
| #include <ehs/io/Console.h> | #include <ehs/io/Console.h> | ||||||
|  |  | ||||||
| ehs::Int_32 Main(ehs::Str_8* appName, ehs::Str_8* appVerId, ehs::Version* appVer) | int main() | ||||||
| { | { | ||||||
| 	// Simple identifying meta-data for the logger. | 	// Simple identifying meta-data for the logger. | ||||||
| 	*appName = "Simple Example App"; // The application's name | 	ehs::Initialize("Simple Example App", "Release", {1, 0, 0}); | ||||||
| 	*appVerId = "Release"; // The app's version prefix; i.e. Alpha, Beta or Release as an example. |  | ||||||
| 	*appVer = {1, 0, 0}; // The app's version major, minor and patch number. |  | ||||||
| 	 | 	 | ||||||
| 	ehs::Console::Write_8("How old are you?"); // Write to the console in UTF_8 character encoding. | 	ehs::Console::Write_8("How old are you?"); // Write to the console in UTF_8 character encoding. | ||||||
| 	 | 	 | ||||||
| @@ -101,13 +104,15 @@ ehs::Int_32 Main(ehs::Str_8* appName, ehs::Str_8* appVerId, ehs::Version* appVer | |||||||
| 	if (!response.IsNum()) | 	if (!response.IsNum()) | ||||||
|     { |     { | ||||||
| 		ehs::Console::Clear(); // Clear the console's buffer. | 		ehs::Console::Clear(); // Clear the console's buffer. | ||||||
| 		return Main(appName, appVerId, appVer); // Repeat process if given response is not a number. | 		return main(); // Repeat process if given response is not a number. | ||||||
|     } |     } | ||||||
| 	 | 	 | ||||||
| 	ehs::UInt_8 age = response.ToDecimal<ehs::UInt_8>(); // Converts the string number into a number based primitive. | 	ehs::UInt_8 age = response.ToDecimal<ehs::UInt_8>(); // Converts the string number into a number based primitive. | ||||||
| 	 | 	 | ||||||
| 	ehs::Console::Write("Your age is " + ehs::Str_8::FromNum(age) + "."); // Write the console with the age converted back to string. | 	ehs::Console::Write("Your age is " + ehs::Str_8::FromNum(age) + "."); // Write the console with the age converted back to string. | ||||||
|  |  | ||||||
|  |     ehs::Uninitialize(); | ||||||
|  |  | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
| @@ -12,7 +12,7 @@ namespace ehs | |||||||
|     /// @tparam T Array data type to use. |     /// @tparam T Array data type to use. | ||||||
|     /// @tparam N Number data type to use. |     /// @tparam N Number data type to use. | ||||||
| 	template<typename T, typename N = UInt_64> | 	template<typename T, typename N = UInt_64> | ||||||
| 	class Array : public BaseObj | 	class Array | ||||||
|     { |     { | ||||||
|     protected: |     protected: | ||||||
|         T* data; |         T* data; | ||||||
| @@ -20,7 +20,7 @@ namespace ehs | |||||||
|  |  | ||||||
|     public: |     public: | ||||||
|         /// Frees any data created on the heap. |         /// Frees any data created on the heap. | ||||||
|         ~Array() override |         ~Array() | ||||||
|         { |         { | ||||||
|             delete[] data; |             delete[] data; | ||||||
|         } |         } | ||||||
| @@ -29,7 +29,6 @@ namespace ehs | |||||||
|         Array() |         Array() | ||||||
|             : data(nullptr), size(0) |             : data(nullptr), size(0) | ||||||
|         { |         { | ||||||
| 			AddType("Array"); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         /// Initializes an empty array with the given size. |         /// Initializes an empty array with the given size. | ||||||
| @@ -37,7 +36,6 @@ namespace ehs | |||||||
|         explicit Array(const N size) |         explicit Array(const N size) | ||||||
| 			: data(new T[size]), size(size) | 			: data(new T[size]), size(size) | ||||||
|         { |         { | ||||||
| 			AddType("Array"); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         /// Initializes this array with an initializer list object. |         /// Initializes this array with an initializer list object. | ||||||
| @@ -45,8 +43,6 @@ namespace ehs | |||||||
|         Array(std::initializer_list<T> list) |         Array(std::initializer_list<T> list) | ||||||
| 			: data(new T[list.size()]), size(list.size()) | 			: data(new T[list.size()]), size(list.size()) | ||||||
|         { |         { | ||||||
| 			AddType("Array"); |  | ||||||
|  |  | ||||||
|             N i = 0; |             N i = 0; | ||||||
|             for (auto v = list.begin(); v != list.end(); ++v) |             for (auto v = list.begin(); v != list.end(); ++v) | ||||||
|                 data[i++] = std::move(*v); |                 data[i++] = std::move(*v); | ||||||
| @@ -58,14 +54,12 @@ namespace ehs | |||||||
|         Array(const T* const data, const N size) |         Array(const T* const data, const N size) | ||||||
| 			: data(new T[size]), size(size) | 			: data(new T[size]), size(size) | ||||||
|         { |         { | ||||||
| 			AddType("Array"); |  | ||||||
|  |  | ||||||
|             for (N i = 0; i < size; ++i) |             for (N i = 0; i < size; ++i) | ||||||
|                 this->data[i] = data[i]; |                 this->data[i] = data[i]; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		Array(Array&& array) noexcept | 		Array(Array&& array) noexcept | ||||||
| 			: BaseObj(array), data(array.data), size(array.size) | 			: data(array.data), size(array.size) | ||||||
| 		{ | 		{ | ||||||
| 			array.data = nullptr; | 			array.data = nullptr; | ||||||
| 			array.size = 0; | 			array.size = 0; | ||||||
| @@ -74,7 +68,7 @@ namespace ehs | |||||||
|         /// Copies all members from the given array object. |         /// Copies all members from the given array object. | ||||||
|         /// @param [in] array The array object to copy from. |         /// @param [in] array The array object to copy from. | ||||||
|         Array(const Array& array) |         Array(const Array& array) | ||||||
| 			: BaseObj((BaseObj&&)array), data(new T[array.size]), size(array.size) | 			: data(new T[array.size]), size(array.size) | ||||||
|         { |         { | ||||||
|             for (N i = 0; i < size; ++i) |             for (N i = 0; i < size; ++i) | ||||||
|                 data[i] = array.data[i]; |                 data[i] = array.data[i]; | ||||||
| @@ -85,8 +79,6 @@ namespace ehs | |||||||
| 			if (this == &array) | 			if (this == &array) | ||||||
| 				return *this; | 				return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=((BaseObj&&)array); |  | ||||||
|  |  | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
| 			data = array.data; | 			data = array.data; | ||||||
| 			size = array.size; | 			size = array.size; | ||||||
| @@ -105,8 +97,6 @@ namespace ehs | |||||||
|             if (this == &array) |             if (this == &array) | ||||||
|                 return *this; |                 return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=(array); |  | ||||||
|  |  | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
|             data = new T[array.size]; |             data = new T[array.size]; | ||||||
|             for (N i = 0; i < array.size; ++i) |             for (N i = 0; i < array.size; ++i) | ||||||
|   | |||||||
| @@ -5,20 +5,20 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Base64 | 	class EHS_LIB_IO Base64 | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		static const char ascii[]; | 		static const char ascii[]; | ||||||
| 		 | 		 | ||||||
| 	public: | 	public: | ||||||
| 		static Str_8 Encode(const Str_8 input); | 		static Str_8 Encode(const Str_8 &input); | ||||||
| 		 | 		 | ||||||
| 		static Str_8 Decode(const Str_8 input); | 		static Str_8 Decode(const Str_8 &input); | ||||||
| 		 | 		 | ||||||
| 	private: | 	private: | ||||||
| 		static char Find(const char c); | 		static char Find(char c); | ||||||
| 	 | 	 | ||||||
| 		static bool IsBase64(const char c); | 		static bool IsBase64(char c); | ||||||
| 		 | 		 | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class BaseObj |     class EHS_LIB_IO BaseObj | ||||||
|     { |     { | ||||||
|     private: |     private: | ||||||
| 		Type* hierarchy; | 		Type* hierarchy; | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Color3 |     class EHS_LIB_IO Color3 | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|         float r; |         float r; | ||||||
| @@ -13,13 +13,13 @@ namespace ehs | |||||||
|  |  | ||||||
|         Color3(); |         Color3(); | ||||||
|  |  | ||||||
|         Color3(const float scalar); |         Color3(float scalar); | ||||||
|  |  | ||||||
|         Color3(const float r, const float g, const float b); |         Color3(float r, float g, float b); | ||||||
|  |  | ||||||
|         Color3(const Color3& color); |         Color3(const Color3& color); | ||||||
|  |  | ||||||
| 		Color3& operator=(const float scalar); | 		Color3& operator=(float scalar); | ||||||
|  |  | ||||||
|         Color3& operator=(const Color3& color); |         Color3& operator=(const Color3& color); | ||||||
|  |  | ||||||
| @@ -27,9 +27,9 @@ namespace ehs | |||||||
|  |  | ||||||
| 		bool operator!=(const Color3& color) const; | 		bool operator!=(const Color3& color) const; | ||||||
|  |  | ||||||
|         float operator[](const UInt_64 i) const; |         float operator[](UInt_64 i) const; | ||||||
|  |  | ||||||
|         float& operator[](const UInt_64 i); |         float& operator[](UInt_64 i); | ||||||
|  |  | ||||||
| 		Color3& operator*=(const Color3& color); | 		Color3& operator*=(const Color3& color); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Color4 |     class EHS_LIB_IO Color4 | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|         float r; |         float r; | ||||||
| @@ -15,15 +15,15 @@ namespace ehs | |||||||
|  |  | ||||||
|         Color4(); |         Color4(); | ||||||
|  |  | ||||||
| 		Color4(const float scalar); | 		Color4(float scalar); | ||||||
|  |  | ||||||
| 		explicit Color4(const Color3& color); | 		explicit Color4(const Color3& color); | ||||||
|  |  | ||||||
| 		Color4(const float r, const float g, const float b, const float a = 1.0f); | 		Color4(float r, float g, float b, float a = 1.0f); | ||||||
|  |  | ||||||
|         Color4(const Color4& color); |         Color4(const Color4& color); | ||||||
|  |  | ||||||
| 		Color4& operator=(const float scalar); | 		Color4& operator=(float scalar); | ||||||
|  |  | ||||||
| 		Color4& operator=(const Color3& color); | 		Color4& operator=(const Color3& color); | ||||||
|  |  | ||||||
| @@ -33,9 +33,9 @@ namespace ehs | |||||||
|  |  | ||||||
| 		bool operator!=(const Color4& color) const; | 		bool operator!=(const Color4& color) const; | ||||||
|  |  | ||||||
|         float operator[](const UInt_64 i) const; |         float operator[](UInt_64 i) const; | ||||||
|  |  | ||||||
|         float& operator[](const UInt_64 i); |         float& operator[](UInt_64 i); | ||||||
|  |  | ||||||
| 		Color4& operator*=(const Color4& color); | 		Color4& operator*=(const Color4& color); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Data |     class EHS_LIB_IO Data | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
|         template<typename T> |         template<typename T> | ||||||
|   | |||||||
| @@ -21,9 +21,9 @@ namespace ehs | |||||||
| 		UINT_8 | 		UINT_8 | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	DataType FromAudioBitDepth(UInt_16 bitDepth); | 	EHS_LIB_IO DataType FromAudioBitDepth(UInt_16 bitDepth); | ||||||
|  |  | ||||||
| 	UInt_8 ToByteDepth(DataType type); | 	EHS_LIB_IO UInt_8 ToByteDepth(DataType type); | ||||||
|  |  | ||||||
| 	UInt_8 ToBitDepth(DataType type); | 	EHS_LIB_IO UInt_8 ToBitDepth(DataType type); | ||||||
| } | } | ||||||
| @@ -19,45 +19,47 @@ namespace ehs | |||||||
|         SIZE |         SIZE | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  | 	EHS_LIB_IO void Initialize(Str_8 appName, Str_8 appVerId, const Version &appVer); | ||||||
|  |  | ||||||
|  | 	EHS_LIB_IO void Uninitialize(); | ||||||
|  |  | ||||||
| 	/// Retrieves the UTF32 C-style string as "Event Horizon Standard" | 	/// Retrieves the UTF32 C-style string as "Event Horizon Standard" | ||||||
| 	/// @returns The result. | 	/// @returns The result. | ||||||
|     const Char_32* GetName_32(); | 	EHS_LIB_IO const Char_32* GetName_32(); | ||||||
|  |  | ||||||
|     /// Retrieves the UTF16 C-style string as "Event Horizon Standard" |     /// Retrieves the UTF16 C-style string as "Event Horizon Standard" | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
|     const Char_16* GetName_16(); | 	EHS_LIB_IO const Char_16* GetName_16(); | ||||||
|  |  | ||||||
|     /// Retrieves the UTF8 C-style string as "Event Horizon Standard" |     /// Retrieves the UTF8 C-style string as "Event Horizon Standard" | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
|     const Char_8* GetName_8(); | 	EHS_LIB_IO const Char_8* GetName_8(); | ||||||
|  |  | ||||||
| 	Str_8 GetAppName_8(); | 	EHS_LIB_IO Str_8 GetAppName_8(); | ||||||
|  |  | ||||||
|     const Char_32* GetAcronym_32(); | 	EHS_LIB_IO const Char_32* GetAcronym_32(); | ||||||
|  |  | ||||||
|     const Char_16* GetAcronym_16(); | 	EHS_LIB_IO const Char_16* GetAcronym_16(); | ||||||
|  |  | ||||||
|     const Char_8* GetAcronym_8(); | 	EHS_LIB_IO const Char_8* GetAcronym_8(); | ||||||
|  |  | ||||||
|     /// Retrieves the version identifier in UTF32. |     /// Retrieves the version identifier in UTF32. | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
|     const Char_32* GetVersionId_32(); | 	EHS_LIB_IO const Char_32* GetVersionId_32(); | ||||||
|  |  | ||||||
|     /// Retrieves the version identifier in UTF16. |     /// Retrieves the version identifier in UTF16. | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
|     const Char_16* GetVersionId_16(); | 	EHS_LIB_IO const Char_16* GetVersionId_16(); | ||||||
|  |  | ||||||
|     /// Retrieves the version identifier in UTF8. |     /// Retrieves the version identifier in UTF8. | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
|     const Char_8* GetVersionId_8(); | 	EHS_LIB_IO const Char_8* GetVersionId_8(); | ||||||
|  |  | ||||||
| 	Str_8 GetAppVersionId_8(); | 	EHS_LIB_IO Str_8 GetAppVersionId_8(); | ||||||
|  |  | ||||||
|     /// Retrieves the current Event Horizon Standard version. |     /// Retrieves the current Event Horizon Standard version. | ||||||
|     /// @returns The result. |     /// @returns The result. | ||||||
| 	Version GetVersion(); | 	EHS_LIB_IO Version GetVersion(); | ||||||
|  |  | ||||||
| 	Version GetAppVersion(); | 	EHS_LIB_IO Version GetAppVersion(); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| extern ehs::SInt_32 Main(ehs::Str_8* appName, ehs::Str_8* appVerId, ehs::Version* appVer); |  | ||||||
| @@ -1,6 +1,5 @@ | |||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include "EHS.h" |  | ||||||
| #include "Vector.h" | #include "Vector.h" | ||||||
| #include "BaseObj.h" | #include "BaseObj.h" | ||||||
| #include "ehs/system/Mutex.h" | #include "ehs/system/Mutex.h" | ||||||
| @@ -10,10 +9,10 @@ namespace ehs | |||||||
| { | { | ||||||
| 	typedef bool (*GcLogic)(BaseObj*); | 	typedef bool (*GcLogic)(BaseObj*); | ||||||
| 
 | 
 | ||||||
| 	class GarbageCollector | 	class EHS_LIB_IO GC | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		static Vector<GcLogic>* logic; | 		static Array<GcLogic> logic; | ||||||
| 		static Vector<BaseObj*> garbage; | 		static Vector<BaseObj*> garbage; | ||||||
| 		static UInt_64 max; | 		static UInt_64 max; | ||||||
| 		static Thread thread; | 		static Thread thread; | ||||||
| @@ -27,13 +26,17 @@ namespace ehs | |||||||
| 
 | 
 | ||||||
| 		static void Stop(); | 		static void Stop(); | ||||||
| 
 | 
 | ||||||
|  | 		static bool HasLogic(GcLogic logicCb); | ||||||
|  | 
 | ||||||
|  | 		static bool AddLogic(GcLogic logicCb); | ||||||
|  | 
 | ||||||
| 		/// Adds an object to the garbage pile to be deleted.
 | 		/// Adds an object to the garbage pile to be deleted.
 | ||||||
| 		/// @param[in] obj The object to be deleted.
 | 		/// @param[in] obj The object to be deleted.
 | ||||||
| 		static void Add(BaseObj* obj); | 		static void Add(BaseObj* obj); | ||||||
| 
 | 
 | ||||||
| 		/// Sets the maximum amount of garbage to delete per poll.
 | 		/// Sets the maximum amount of garbage to delete per poll.
 | ||||||
| 		/// @param[in] newMax The new maximum.
 | 		/// @param[in] newMax The new maximum.
 | ||||||
| 		static void SetMax(const UInt_64 newMax); | 		static void SetMax(UInt_64 newMax); | ||||||
| 
 | 
 | ||||||
| 		/// Gets the maximum amount of garbage to delete per poll.
 | 		/// Gets the maximum amount of garbage to delete per poll.
 | ||||||
| 		/// @returns The maximum.
 | 		/// @returns The maximum.
 | ||||||
| @@ -41,7 +44,7 @@ namespace ehs | |||||||
| 
 | 
 | ||||||
| 		/// Sets a new amount for memory pre-allocation to save on memory operations.
 | 		/// Sets a new amount for memory pre-allocation to save on memory operations.
 | ||||||
| 		/// @param[in] newStride The stride to pre-allocate.
 | 		/// @param[in] newStride The stride to pre-allocate.
 | ||||||
| 		static void SetStride(const UInt_64 newStride); | 		static void SetStride(UInt_64 newStride); | ||||||
| 
 | 
 | ||||||
| 		/// The amount of data pre-allocated to save on memory operations.
 | 		/// The amount of data pre-allocated to save on memory operations.
 | ||||||
| 		/// @returns The stride.
 | 		/// @returns The stride.
 | ||||||
| @@ -59,5 +62,8 @@ namespace ehs | |||||||
| 		static void Dump(); | 		static void Dump(); | ||||||
| 
 | 
 | ||||||
| 		static bool IsRunning(); | 		static bool IsRunning(); | ||||||
|  | 
 | ||||||
|  | 	private: | ||||||
|  | 		static bool ShouldDelete(BaseObj *obj); | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class HRNG |     class EHS_LIB_IO HRNG | ||||||
|     { |     { | ||||||
|     public: |     public: | ||||||
| 		static UInt_64 GenerateSeed_u64(); | 		static UInt_64 GenerateSeed_u64(); | ||||||
|   | |||||||
| @@ -9,26 +9,53 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|  | 	class Log; | ||||||
|  |  | ||||||
|  | 	typedef void (*LogRaisedCb)(const Log &); | ||||||
|  | 	typedef void (*LogOutputCb)(const Array<Log> &); | ||||||
|  |  | ||||||
|  | 	enum class LogType : UInt_8 | ||||||
|  | 	{ | ||||||
|  | 		SUCCESS, | ||||||
|  | 		ERR, | ||||||
|  | 		WARN, | ||||||
|  | 		INFO | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	/// A helper class for holding error information and handling them. | 	/// A helper class for holding error information and handling them. | ||||||
| 	/// @tparam T The character data type to use. | 	/// @tparam T The character data type to use. | ||||||
| 	/// @tparam N The number data type to use. | 	/// @tparam N The number data type to use. | ||||||
| 	class Log | 	class EHS_LIB_IO Log | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
|         static void (*logCb)(const Log&); | 		static void DefaultRaisedCb(const Log &log); | ||||||
|  |  | ||||||
|  | 		static void DefaultOutputCb(const Array<Log> &logs); | ||||||
|  |  | ||||||
|  |         static LogRaisedCb raisedCb; | ||||||
|  | 		static LogOutputCb outputCb; | ||||||
|  | 		static Array<Log> logs; | ||||||
| 		static Log lastLog; | 		static Log lastLog; | ||||||
|  | 		static bool immediate; | ||||||
|  | 		LogType type; | ||||||
| 		Array<Str_8> tags; | 		Array<Str_8> tags; | ||||||
| 		UInt_64 code; | 		UInt_64 code; | ||||||
| 		Str_8 msg; | 		Str_8 msg; | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
|         static void SetCallback(void (*newLogCb)(const Log&)); |         static void SetRaisedCallback(LogRaisedCb newCb); | ||||||
|  |  | ||||||
|         static void Raise(const Log& log); | 		static void SetOutputCallback(LogOutputCb newCb); | ||||||
|  |  | ||||||
|  | 		static void OnExit(); | ||||||
|  |  | ||||||
|  |         static void Raise(Log log); | ||||||
|  |  | ||||||
| 		/// Retrieves the last log raised. | 		/// Retrieves the last log raised. | ||||||
| 		static Log GetLastLog(); | 		static Log GetLastLog(); | ||||||
|  |  | ||||||
|  | 		static void EnableImmediateMode(bool enable); | ||||||
|  |  | ||||||
|         /// Default members initialization. |         /// Default members initialization. | ||||||
| 		Log(); | 		Log(); | ||||||
|  |  | ||||||
| @@ -36,18 +63,22 @@ namespace ehs | |||||||
|         /// @param [in] tags The tags to associate this log with. |         /// @param [in] tags The tags to associate this log with. | ||||||
| 		/// @param [in] code The unique code to use. | 		/// @param [in] code The unique code to use. | ||||||
|         /// @param [in] msg Detailed information about what happened. |         /// @param [in] msg Detailed information about what happened. | ||||||
| 		Log(std::initializer_list<Str_8> tags, const UInt_64 code, const Str_8& msg); | 		Log(LogType type, const std::initializer_list<Str_8> &tags, UInt_64 code, Str_8 msg); | ||||||
|  |  | ||||||
|         /// Initializes members with the given information. |         /// Initializes members with the given information. | ||||||
|         /// @param [in] tags The tags to associate this log with. |         /// @param [in] tags The tags to associate this log with. | ||||||
| 		/// @param [in] code The unique code to use. | 		/// @param [in] code The unique code to use. | ||||||
|         /// @param [in] msg Detailed information about what happened. |         /// @param [in] msg Detailed information about what happened. | ||||||
|         Log(Array<Str_8>& tags, const UInt_64 code, const Str_8& msg); |         Log(LogType type, Array<Str_8> tags, UInt_64 code, Str_8 msg); | ||||||
|  |  | ||||||
|  | 		Log(Log &&log) noexcept; | ||||||
|  |  | ||||||
|         /// Copies all members from the given log. |         /// Copies all members from the given log. | ||||||
|         /// @param [in] log The log to copy from. |         /// @param [in] log The log to copy from. | ||||||
| 		Log(const Log &log); | 		Log(const Log &log); | ||||||
|  |  | ||||||
|  | 		Log &operator=(Log &&log) noexcept; | ||||||
|  |  | ||||||
|         /// Copies all members from the given log. |         /// Copies all members from the given log. | ||||||
|         /// @param [in] log The log to copy from. |         /// @param [in] log The log to copy from. | ||||||
|         /// @returns The log that has been assigned to. |         /// @returns The log that has been assigned to. | ||||||
| @@ -65,10 +96,12 @@ namespace ehs | |||||||
| 		bool operator!=(const Log log); | 		bool operator!=(const Log log); | ||||||
| 		*/ | 		*/ | ||||||
|  |  | ||||||
|  | 		LogType GetType() const; | ||||||
|  |  | ||||||
|         /// Checks whether or not this log has the given tags. |         /// Checks whether or not this log has the given tags. | ||||||
|         /// @param [in] tags The tags to look for. |         /// @param [in] tags The tags to look for. | ||||||
|         /// @returns True if all tags were found, otherwise false. |         /// @returns True if all tags were found, otherwise false. | ||||||
| 		bool HasTags(const std::initializer_list<Str_8> tags) const; | 		bool HasTags(const std::initializer_list<Str_8> &tags) const; | ||||||
|  |  | ||||||
|         /// Checks whether or not this log has the given tags. |         /// Checks whether or not this log has the given tags. | ||||||
|         /// @param [in] tags The tags to look for. |         /// @param [in] tags The tags to look for. | ||||||
| @@ -82,7 +115,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		/// Retrieves all the tags. | 		/// Retrieves all the tags. | ||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
|         Array<Str_8> GetTags() const; |         const Array<Str_8> &GetTags() const; | ||||||
|  |  | ||||||
| 		UInt_64 GetCode() const; | 		UInt_64 GetCode() const; | ||||||
|  |  | ||||||
| @@ -101,16 +134,20 @@ namespace ehs | |||||||
|  |  | ||||||
| #ifndef EHS_LOG_INT | #ifndef EHS_LOG_INT | ||||||
| 	#ifdef EHS_DEBUG | 	#ifdef EHS_DEBUG | ||||||
| 		#define EHS_LOG_INT(type, code, msg) Log::Raise({{type, GetAcronym_8(), EHS_FILE, EHS_FUNC, Str_8::FromNum((UInt_32)EHS_LINE)}, code, msg}) | 		#define EHS_LOG_INT(type, code, msg) ehs::Log::Raise({type, {ehs::GetAcronym_8(), EHS_FILE, EHS_FUNC, ehs::Str_8::FromNum((ehs::UInt_32)EHS_LINE)}, code, msg}) | ||||||
| 	#else | 	#else | ||||||
| 		#define EHS_LOG_INT(type, code, msg) Log::Raise({{type, GetAcronym_8(), EHS_FUNC}, code, msg}) | 		#define EHS_LOG_INT(type, code, msg) ehs::Log::Raise({type, {ehs::GetAcronym_8(), EHS_FUNC}, code, msg}) | ||||||
| 	#endif | 	#endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef EHS_LOG | #ifndef EHS_LOG | ||||||
| 	#ifdef EHS_DEBUG | 	#ifdef EHS_DEBUG | ||||||
| 		#define EHS_LOG(type, code, msg) ehs::Log::Raise({{type, ehs::GetAppName_8(), EHS_FILE, EHS_FUNC, ehs::Str_8::FromNum((ehs::UInt_32)EHS_LINE)}, code, msg}) | 		#define EHS_LOG(type, code, msg) ehs::Log::Raise({type, {ehs::GetAppName_8(), EHS_FILE, EHS_FUNC, ehs::Str_8::FromNum((ehs::UInt_32)EHS_LINE)}, code, msg}) | ||||||
| 	#else | 	#else | ||||||
| 		#define EHS_LOG(type, code, msg) ehs::Log::Raise({{type, ehs::GetAppName_8(), EHS_FUNC}, code, msg}) | 		#define EHS_LOG(type, code, msg) ehs::Log::Raise({type, {ehs::GetAppName_8(), EHS_FUNC}, code, msg}) | ||||||
| 	#endif | 	#endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifndef EHS_LOG_SUCCESS | ||||||
|  | #define EHS_LOG_SUCCESS() ehs::Log::Raise({}) | ||||||
|  | #endif | ||||||
| @@ -120,7 +120,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		Mat2<T> GetMinor() const | 		Mat2<T> GetMinor() const | ||||||
| 		{ | 		{ | ||||||
| 			Mat2<T> result(0); | 			Mat2<T> result; | ||||||
| 			result.data[0] = data[3]; | 			result.data[0] = data[3]; | ||||||
| 			result.data[1] = data[2]; | 			result.data[1] = data[2]; | ||||||
| 			result.data[2] = data[1]; | 			result.data[2] = data[1]; | ||||||
| @@ -187,7 +187,7 @@ namespace ehs | |||||||
| 		Mat2<T> GetInverse() const | 		Mat2<T> GetInverse() const | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return {}; | 				return {}; | ||||||
|  |  | ||||||
| 			return GetAdjugate() * (1 / det); | 			return GetAdjugate() * (1 / det); | ||||||
| @@ -196,7 +196,7 @@ namespace ehs | |||||||
| 		void Inverse() | 		void Inverse() | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return; | 				return; | ||||||
|  |  | ||||||
| 			Adjugate(); | 			Adjugate(); | ||||||
| @@ -212,6 +212,9 @@ namespace ehs | |||||||
| 		} | 		} | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	template class EHS_LIB_IO Mat2<float>; | ||||||
|  | 	template class EHS_LIB_IO Mat2<double>; | ||||||
|  |  | ||||||
| 	typedef Mat2<float> Mat2_f; | 	typedef Mat2<float> Mat2_f; | ||||||
| 	typedef Mat2<double> Mat2_d; | 	typedef Mat2<double> Mat2_d; | ||||||
| } | } | ||||||
| @@ -50,7 +50,7 @@ namespace ehs | |||||||
| 			Mat2<T> result; | 			Mat2<T> result; | ||||||
|  |  | ||||||
| 			for (UInt_8 i = 0; i < 4; ++i) | 			for (UInt_8 i = 0; i < 4; ++i) | ||||||
| 				result.data[i] = data[i / 2 * 4 + i % 2]; | 				result[i] = data[i / 2 * 4 + i % 2]; | ||||||
|  |  | ||||||
| 			return result; | 			return result; | ||||||
| 		} | 		} | ||||||
| @@ -234,7 +234,7 @@ namespace ehs | |||||||
| 		Mat3<T> GetInverse() const | 		Mat3<T> GetInverse() const | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return {}; | 				return {}; | ||||||
|  |  | ||||||
| 			return GetAdjugate() * (1 / det); | 			return GetAdjugate() * (1 / det); | ||||||
| @@ -243,7 +243,7 @@ namespace ehs | |||||||
| 		void Inverse() | 		void Inverse() | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return; | 				return; | ||||||
|  |  | ||||||
| 			Adjugate(); | 			Adjugate(); | ||||||
| @@ -317,6 +317,9 @@ namespace ehs | |||||||
| 		} | 		} | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	template class EHS_LIB_IO Mat3<float>; | ||||||
|  | 	template class EHS_LIB_IO Mat3<double>; | ||||||
|  |  | ||||||
| 	typedef Mat3<float> Mat3_f; | 	typedef Mat3<float> Mat3_f; | ||||||
| 	typedef Mat3<double> Mat3_d; | 	typedef Mat3<double> Mat3_d; | ||||||
| } | } | ||||||
| @@ -268,7 +268,7 @@ namespace ehs | |||||||
| 		Mat4<T> GetInverse() const | 		Mat4<T> GetInverse() const | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return {}; | 				return {}; | ||||||
|  |  | ||||||
| 			return GetAdjugate() * (1 / det); | 			return GetAdjugate() * (1 / det); | ||||||
| @@ -277,7 +277,7 @@ namespace ehs | |||||||
| 		void Inverse() | 		void Inverse() | ||||||
| 		{ | 		{ | ||||||
| 			T det = GetDeterminant(); | 			T det = GetDeterminant(); | ||||||
| 			if (Math::ComCmp(det, 0.0f)) | 			if (Math::ComCmp(det, 0)) | ||||||
| 				return; | 				return; | ||||||
|  |  | ||||||
| 			Adjugate(); | 			Adjugate(); | ||||||
| @@ -332,14 +332,14 @@ namespace ehs | |||||||
|  |  | ||||||
| 		static Mat4<T> YawRotate(const T angle) | 		static Mat4<T> YawRotate(const T angle) | ||||||
| 		{ | 		{ | ||||||
| 			T radians = Math::Rads(angle); | 			T radians = Math::Rads<T>(angle); | ||||||
|  |  | ||||||
| 			Mat4<T> result; | 			Mat4<T> result; | ||||||
| 			result.data[0] = Math::Cos(radians); | 			result.data[0] = Math::Cos<T>(radians); | ||||||
| 			result.data[2] = -Math::Sin(radians); | 			result.data[2] = -Math::Sin<T>(radians); | ||||||
| 			result.data[5] = 1; | 			result.data[5] = 1; | ||||||
| 			result.data[8] = Math::Sin(radians); | 			result.data[8] = Math::Sin<T>(radians); | ||||||
| 			result.data[10] = Math::Cos(radians); | 			result.data[10] = Math::Cos<T>(radians); | ||||||
| 			result.data[15] = 1; | 			result.data[15] = 1; | ||||||
|  |  | ||||||
| 			return result; | 			return result; | ||||||
| @@ -347,7 +347,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		static Mat4<T> RollRotate(const T angle) | 		static Mat4<T> RollRotate(const T angle) | ||||||
| 		{ | 		{ | ||||||
| 			T radians = Math::Rads(angle); | 			T radians = Math::Rads<T>(angle); | ||||||
|  |  | ||||||
| 			Mat4<T> result; | 			Mat4<T> result; | ||||||
| 			result.data[0] = Math::Cos(radians); | 			result.data[0] = Math::Cos(radians); | ||||||
| @@ -367,7 +367,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		static Mat4<T> RH_Perspective(const T fov, const T aspect, const T zNear, const T zFar) | 		static Mat4<T> RH_Perspective(const T fov, const T aspect, const T zNear, const T zFar) | ||||||
| 		{ | 		{ | ||||||
| 			const float tanHalfFovy = tan(Math::Rads(fov) / 2.0f); | 			const T tanHalfFovy = Math::Tan<T>(Math::Rads(fov) / 2.0f); | ||||||
|  |  | ||||||
| 			Mat4<T> result; | 			Mat4<T> result; | ||||||
| 			result[0] = 1.0f / (aspect * tanHalfFovy); | 			result[0] = 1.0f / (aspect * tanHalfFovy); | ||||||
| @@ -380,7 +380,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		static Mat4<T> LH_Perspective(const T fov, const T aspect, const T zNear, const T zFar) | 		static Mat4<T> LH_Perspective(const T fov, const T aspect, const T zNear, const T zFar) | ||||||
| 		{ | 		{ | ||||||
| 			const float tanHalfFovy = Math::Tan(Math::Rads(fov) / 2.0f); | 			const T tanHalfFovy = Math::Tan<T>(Math::Rads(fov) / 2.0f); | ||||||
|  |  | ||||||
| 			Mat4<T> result; | 			Mat4<T> result; | ||||||
| 			result[0] = 1.0f / (aspect * tanHalfFovy); | 			result[0] = 1.0f / (aspect * tanHalfFovy); | ||||||
| @@ -421,6 +421,9 @@ namespace ehs | |||||||
| 		} | 		} | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	template class EHS_LIB_IO Mat4<float>; | ||||||
|  | 	template class EHS_LIB_IO Mat4<double>; | ||||||
|  |  | ||||||
| 	typedef Mat4<float> Mat4_f; | 	typedef Mat4<float> Mat4_f; | ||||||
| 	typedef Mat4<double> Mat4_d; | 	typedef Mat4<double> Mat4_d; | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Math | 	class EHS_LIB_IO Math | ||||||
| 	{ | 	{ | ||||||
|     private: |     private: | ||||||
|         static float Sqrt_AVX(const float from); |         static float Sqrt_AVX(const float from); | ||||||
| @@ -26,22 +26,22 @@ namespace ehs | |||||||
| 		constexpr static double dblEpsilon = 1e-16; | 		constexpr static double dblEpsilon = 1e-16; | ||||||
|  |  | ||||||
| 		/// Absolute tolerance comparison for single precision floats. | 		/// Absolute tolerance comparison for single precision floats. | ||||||
| 		static bool AbsCmp(const float a, const float b); | 		static bool AbsCmp(float a, float b); | ||||||
|  |  | ||||||
| 		/// Absolute tolerance comparison for double precision floats. | 		/// Absolute tolerance comparison for double precision floats. | ||||||
| 		static bool AbsCmp(const double a, const double b); | 		static bool AbsCmp(double a, double b); | ||||||
|  |  | ||||||
| 		/// Relative tolerance comparison for single precision floats. | 		/// Relative tolerance comparison for single precision floats. | ||||||
| 		static bool RelCmp(const float a, const float b); | 		static bool RelCmp(float a, float b); | ||||||
|  |  | ||||||
| 		/// Relative tolerance comparison for double precision floats. | 		/// Relative tolerance comparison for double precision floats. | ||||||
| 		static bool RelCmp(const double a, const double b); | 		static bool RelCmp(double a, double b); | ||||||
|  |  | ||||||
| 		/// Combined absolute and relative tolerance comparison for single precision floats. | 		/// Combined absolute and relative tolerance comparison for single precision floats. | ||||||
| 		static bool ComCmp(const float a, const float b); | 		static bool ComCmp(float a, float b); | ||||||
|  |  | ||||||
| 		/// Combined absolute and relative tolerance comparison for double precision floats. | 		/// Combined absolute and relative tolerance comparison for double precision floats. | ||||||
| 		static bool ComCmp(const double a, const double b); | 		static bool ComCmp(double a, double b); | ||||||
|  |  | ||||||
| 		template<typename T = float> | 		template<typename T = float> | ||||||
| 		static T Max(const T a, const T b) | 		static T Max(const T a, const T b) | ||||||
| @@ -101,29 +101,113 @@ namespace ehs | |||||||
| 			return from * 57.295779513082320876798154814105; | 			return from * 57.295779513082320876798154814105; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		template <typename T = float> | ||||||
|  | 		static T Exp(const T x) | ||||||
|  | 		{ | ||||||
|  | 			T sum = 1; | ||||||
|  | 			T term = 1; | ||||||
|  |  | ||||||
|  | 			for (int n = 1; n <= 20; ++n) | ||||||
|  | 			{ | ||||||
|  | 				term *= x / n; | ||||||
|  | 				sum += term; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return sum; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template <typename T = float> | ||||||
|  | 		static T Ln_Taylor(T x) | ||||||
|  | 		{ | ||||||
|  | 			T result = 0; | ||||||
|  | 			T term = (x - 1) / (x + 1); | ||||||
|  | 			T term_squared = term * term; | ||||||
|  | 			T denominator = 1; | ||||||
|  | 			T current_term = term; | ||||||
|  |  | ||||||
|  | 			for (int n = 0; n < 100; ++n) | ||||||
|  | 			{ | ||||||
|  | 				result += current_term / denominator; | ||||||
|  | 				current_term *= term_squared; | ||||||
|  | 				denominator += 2; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return 2 * result; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template <typename T = float> | ||||||
|  | 		static T Ln(T x) | ||||||
|  | 		{ | ||||||
|  | 			if (x <= 0) | ||||||
|  | 				return -1; | ||||||
|  |  | ||||||
|  | 			if (x == 1) | ||||||
|  | 				return 0; | ||||||
|  |  | ||||||
|  | 			SSize exp = 0; | ||||||
|  | 			while (x > 2) | ||||||
|  | 			{ | ||||||
|  | 				x /= 2; | ||||||
|  | 				exp++; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			while (x < 0.5) | ||||||
|  | 			{ | ||||||
|  | 				x *= 2; | ||||||
|  | 				exp--; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			T result = Ln_Taylor<T>(x); | ||||||
|  | 			result += exp * Ln_Taylor<T>(2); | ||||||
|  |  | ||||||
|  | 			return result; | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		/// A method for use of exponents. | 		/// A method for use of exponents. | ||||||
| 		/// @tparam T The data type to return; | 		/// @tparam T The data type to return; | ||||||
| 		/// @tparam I The data type to use as the exponent. | 		/// @tparam I The data type to use as the exponent. | ||||||
| 		/// @param [in] from The value to use the exponent on. | 		/// @param [in] from The value to use the exponent on. | ||||||
| 		/// @param [in] of The exponent. | 		/// @param [in] of The exponent. | ||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
| 		template<typename T = float, typename I = UInt_64> | 		template<typename T = float, typename I = float> | ||||||
|         static T Pow(const T from, const I of) |         static T Pow(const T base, const I exponent) | ||||||
| 		{ | 		{ | ||||||
|             if (of < 0) | 			if (base == 0) | ||||||
|             { | 				return (exponent == 0) ? 1 : 0; | ||||||
|                 if (from == 0) |  | ||||||
|                     return -0; |  | ||||||
|  |  | ||||||
|                 return 1 / (from * Pow<T>(from, (-of) - 1)); | 			if (exponent == 0) | ||||||
|  | 				return 1; | ||||||
|  |  | ||||||
|  | 			SSize intExp = (SSize)exponent; | ||||||
|  | 			bool isInteger = exponent == intExp; | ||||||
|  | 			bool isNeg = base < 0; | ||||||
|  |  | ||||||
|  | 			if (isNeg && isInteger) | ||||||
|  | 			{ | ||||||
|  | 				T result = Exp<T>(exponent * Ln<T>(-base)); | ||||||
|  | 				if ((SSize)exponent % 2) | ||||||
|  | 					result = -result; | ||||||
|  |  | ||||||
|  | 				return result; | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|             if (of == 0) | 			if (isNeg && !isInteger) | ||||||
|                 return 1; | 			{ | ||||||
|             else if (of == 1) | 				T magnitude = Exp<T>(exponent * Ln<T>(-base)); | ||||||
|                 return from; | 				T angle = exponent * Pi<T>(); | ||||||
|  | 				T realPart = magnitude * Cos<T>(angle); | ||||||
|  | 				T imagPart = magnitude * Sin<T>(angle); | ||||||
|  |  | ||||||
| 			return from * Pow<T>(from, of - 1); | 				return realPart; | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return Exp<T>(exponent * Ln<T>(base)); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template <typename T = float> | ||||||
|  | 		static T Log10(const T x) | ||||||
|  | 		{ | ||||||
|  | 			return Ln<T>(x) / Ln<T>(10); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         static float Near(const float from); |         static float Near(const float from); | ||||||
|   | |||||||
| @@ -10,9 +10,9 @@ namespace ehs | |||||||
| 		void* data; | 		void* data; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	bool HasPtrData(void* data); | 	EHS_LIB_IO bool HasPtrData(void* data); | ||||||
|  |  | ||||||
| 	void AddPtrData(void* data); | 	EHS_LIB_IO void AddPtrData(void* data); | ||||||
|  |  | ||||||
| 	bool RemovePtrData(void* data); | 	EHS_LIB_IO bool RemovePtrData(void* data); | ||||||
| } | } | ||||||
| @@ -130,7 +130,7 @@ namespace ehs | |||||||
| 				case 3: | 				case 3: | ||||||
| 					return h; | 					return h; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Rectangle."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Rectangle."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -148,7 +148,7 @@ namespace ehs | |||||||
| 				case 3: | 				case 3: | ||||||
| 					return h; | 					return h; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Rectangle."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Rectangle."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -87,7 +87,7 @@ namespace ehs | |||||||
| 		{ | 		{ | ||||||
| 			if (index >= size) | 			if (index >= size) | ||||||
| 			{ | 			{ | ||||||
| 				EHS_LOG_INT("Warning", 0, "Cannot insert value at " + Str_8::FromNum(index) + " because it is outside of array range of " + size + "."); | 				EHS_LOG_INT(LogType::WARN, 0, "Cannot insert value at " + Str_8::FromNum(index) + " because it is outside of array range of " + size + "."); | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ | |||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	template<typename N = UInt_64> | 	template<typename N = UInt_64> | ||||||
| 	class Serializer : public BaseObj | 	class Serializer | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
|         Endianness endianness; |         Endianness endianness; | ||||||
| @@ -30,7 +30,7 @@ namespace ehs | |||||||
|         N offset; |         N offset; | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
|         ~Serializer() override |         ~Serializer() | ||||||
| 		{ | 		{ | ||||||
|             delete[] data; |             delete[] data; | ||||||
| 		} | 		} | ||||||
| @@ -38,32 +38,27 @@ namespace ehs | |||||||
| 		Serializer() | 		Serializer() | ||||||
| 			: endianness(Endianness::BE), data(nullptr), size(0), offset(0) | 			: endianness(Endianness::BE), data(nullptr), size(0), offset(0) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Serializer"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         Serializer(const Endianness endianness) |         Serializer(const Endianness endianness) | ||||||
|             : endianness(endianness), data(nullptr), size(0), offset(0) |             : endianness(endianness), data(nullptr), size(0), offset(0) | ||||||
|         { |         { | ||||||
| 			AddType("Serializer"); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Serializer(const Endianness endianness, const N size) |         Serializer(const Endianness endianness, const N size) | ||||||
|             : endianness(endianness), data(new Byte[size]), size(size), offset(0) |             : endianness(endianness), data(new Byte[size]), size(size), offset(0) | ||||||
|         { |         { | ||||||
| 			AddType("Serializer"); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		Serializer(const Endianness endianness, const Byte* const data, const N size, const N offset = 0) | 		Serializer(const Endianness endianness, const Byte* const data, const N size, const N offset = 0) | ||||||
| 			: endianness(endianness), data(new Byte[size]), size(size), offset(offset) | 			: endianness(endianness), data(new Byte[size]), size(size), offset(offset) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Serializer"); |  | ||||||
|  |  | ||||||
| 			for (N i = 0; i < size; ++i) | 			for (N i = 0; i < size; ++i) | ||||||
| 				this->data[i] = data[i]; | 				this->data[i] = data[i]; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		Serializer(Serializer&& serializer) noexcept | 		Serializer(Serializer&& serializer) noexcept | ||||||
| 			: BaseObj((BaseObj&&)serializer), endianness(serializer.endianness), data(serializer.data), | 			: endianness(serializer.endianness), data(serializer.data), | ||||||
| 			size(serializer.size), offset(serializer.offset) | 			size(serializer.size), offset(serializer.offset) | ||||||
| 		{ | 		{ | ||||||
| 			serializer.data = nullptr; | 			serializer.data = nullptr; | ||||||
| @@ -72,7 +67,7 @@ namespace ehs | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		Serializer(const Serializer& serializer) | 		Serializer(const Serializer& serializer) | ||||||
| 			: BaseObj(serializer), endianness(serializer.endianness), data(new Byte[serializer.size]), | 			: endianness(serializer.endianness), data(new Byte[serializer.size]), | ||||||
| 			size(serializer.size), offset(serializer.offset) | 			size(serializer.size), offset(serializer.offset) | ||||||
| 		{ | 		{ | ||||||
| 			for (N i = 0; i < serializer.size; ++i) | 			for (N i = 0; i < serializer.size; ++i) | ||||||
| @@ -84,8 +79,6 @@ namespace ehs | |||||||
| 			if (this == &serializer) | 			if (this == &serializer) | ||||||
| 				return *this; | 				return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=((Serializer&&)serializer); |  | ||||||
|  |  | ||||||
| 			endianness = serializer.endianness; | 			endianness = serializer.endianness; | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
| 			data = serializer.data; | 			data = serializer.data; | ||||||
| @@ -104,8 +97,6 @@ namespace ehs | |||||||
|             if (this == &serializer) |             if (this == &serializer) | ||||||
|                 return *this; |                 return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=(serializer); |  | ||||||
|  |  | ||||||
|             endianness = serializer.endianness; |             endianness = serializer.endianness; | ||||||
|  |  | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
| @@ -1044,7 +1035,10 @@ namespace ehs | |||||||
|         void ReadArray(T* const value, O* const size) |         void ReadArray(T* const value, O* const size) | ||||||
|         { |         { | ||||||
|             if (!*size) |             if (!*size) | ||||||
|  |             { | ||||||
| 	            *size = (O)Read<N>(); | 	            *size = (O)Read<N>(); | ||||||
|  |             	return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             for (N i = 0; i < *size; ++i) |             for (N i = 0; i < *size; ++i) | ||||||
|                 value[i] = Read<T>(); |                 value[i] = Read<T>(); | ||||||
| @@ -1072,14 +1066,14 @@ namespace ehs | |||||||
|             return result; |             return result; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         template<typename T, typename O> |         template<typename T = Char_8, typename O = UInt_64> | ||||||
|         Str<T, O> ReadStr(O size = 0) |         Str<T, O> ReadStr(O size = 0) | ||||||
|         { |         { | ||||||
| 			bool sizeKnown = size; | 			bool sizeKnown = size; | ||||||
|  |  | ||||||
| 			if (!sizeKnown) | 			if (!sizeKnown) | ||||||
| 				while (&data[offset + sizeof(T) * size]) | 				while (((T*)&data[offset])[size]) | ||||||
| 					size++; | 					++size; | ||||||
|  |  | ||||||
|             Str<T, O> result(size); |             Str<T, O> result(size); | ||||||
|  |  | ||||||
| @@ -1090,14 +1084,14 @@ namespace ehs | |||||||
| 				else | 				else | ||||||
| 					for (N i = 0; i < size; ++i) | 					for (N i = 0; i < size; ++i) | ||||||
| 						for (N b = 0; b < sizeof(T); ++b) | 						for (N b = 0; b < sizeof(T); ++b) | ||||||
| 							((Byte*)&result[i])[sizeof(T) - i - 1] = data[offset + sizeof(T) * i + b]; | 							((Byte*)&result[i])[b] = data[offset + sizeof(T) * i + b]; | ||||||
| 			} | 			} | ||||||
| 			else | 			else | ||||||
| 			{ | 			{ | ||||||
| 				if (endianness == Endianness::LE) | 				if (endianness == Endianness::LE) | ||||||
| 					for (N i = 0; i < size; ++i) | 					for (N i = 0; i < size; ++i) | ||||||
| 						for (N b = 0; b < sizeof(T); ++b) | 						for (N b = 0; b < sizeof(T); ++b) | ||||||
| 							((Byte*)&result[i])[sizeof(T) - i - 1] = data[offset + sizeof(T) * i + b]; | 							((Byte*)&result[i])[b] = data[offset + sizeof(T) * i + b]; | ||||||
| 				else | 				else | ||||||
| 					Util::Copy(&result[0], &data[offset], result.Size(true)); | 					Util::Copy(&result[0], &data[offset], result.Size(true)); | ||||||
| 			} | 			} | ||||||
| @@ -1225,7 +1219,7 @@ namespace ehs | |||||||
| 		void Resize(const N newSize) | 		void Resize(const N newSize) | ||||||
| 		{ | 		{ | ||||||
| 			Byte* result = new Byte[newSize]; | 			Byte* result = new Byte[newSize]; | ||||||
|             Util::Copy(result, data, size); |             Util::Copy(result, data, newSize >= size ? size : newSize); | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
| 			data = result; | 			data = result; | ||||||
| 			size = newSize; | 			size = newSize; | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ namespace ehs | |||||||
|     /// @tparam T The character's data type to use. |     /// @tparam T The character's data type to use. | ||||||
|     /// @tparam N The number data type to use. |     /// @tparam N The number data type to use. | ||||||
| 	template<typename T = Char_8, typename N = UInt_64> | 	template<typename T = Char_8, typename N = UInt_64> | ||||||
| 	class Str : public BaseObj | 	class Str | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		N size; | 		N size; | ||||||
| @@ -33,7 +33,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
| 	    /// Frees any data created on the heap. | 	    /// Frees any data created on the heap. | ||||||
|         ~Str() override |         ~Str() | ||||||
| 		{ | 		{ | ||||||
|             delete[] data; |             delete[] data; | ||||||
| 		} | 		} | ||||||
| @@ -42,7 +42,6 @@ namespace ehs | |||||||
| 		Str() | 		Str() | ||||||
| 			: size(0), data(nullptr) | 			: size(0), data(nullptr) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Str"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		/// Initializes members with given C-style string. | 		/// Initializes members with given C-style string. | ||||||
| @@ -56,8 +55,6 @@ namespace ehs | |||||||
|             Util::Copy(data, str, Size(true)); |             Util::Copy(data, str, Size(true)); | ||||||
|  |  | ||||||
| 			data[this->size] = 0; | 			data[this->size] = 0; | ||||||
|  |  | ||||||
| 			AddType("Str"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		/// Initializes members with given C-style string. | 		/// Initializes members with given C-style string. | ||||||
| @@ -70,8 +67,6 @@ namespace ehs | |||||||
|             Util::Copy(data, str, Size(true)); |             Util::Copy(data, str, Size(true)); | ||||||
|  |  | ||||||
| 			data[size] = 0; | 			data[size] = 0; | ||||||
|  |  | ||||||
| 			AddType("Str"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		/// Initializes string with the given size. | 		/// Initializes string with the given size. | ||||||
| @@ -80,13 +75,11 @@ namespace ehs | |||||||
| 			: size(size), data(new T[size + 1]) | 			: size(size), data(new T[size + 1]) | ||||||
| 		{ | 		{ | ||||||
| 			data[size] = 0; | 			data[size] = 0; | ||||||
|  |  | ||||||
| 			AddType("Str"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		/// A move constructor. | 		/// A move constructor. | ||||||
| 		Str(Str&& str) noexcept | 		Str(Str&& str) noexcept | ||||||
| 			: BaseObj((BaseObj&&)str), size(str.size), data(str.data) | 			: size(str.size), data(str.data) | ||||||
| 		{ | 		{ | ||||||
| 			str.size = 0; | 			str.size = 0; | ||||||
| 			str.data = nullptr; | 			str.data = nullptr; | ||||||
| @@ -95,7 +88,7 @@ namespace ehs | |||||||
| 		/// Copies all members from the given string object. | 		/// Copies all members from the given string object. | ||||||
| 		/// @param [in] str The string object to copy from. | 		/// @param [in] str The string object to copy from. | ||||||
| 		Str(const Str& str) | 		Str(const Str& str) | ||||||
| 			: BaseObj(str), size(str.size), data(new T[size + 1]) | 			: size(str.size), data(new T[size + 1]) | ||||||
| 		{ | 		{ | ||||||
|             Util::Copy(data, str.data, Size(true)); |             Util::Copy(data, str.data, Size(true)); | ||||||
|  |  | ||||||
| @@ -107,8 +100,6 @@ namespace ehs | |||||||
| 			if (this == &str) | 			if (this == &str) | ||||||
| 				return *this; | 				return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=((BaseObj&&)str); |  | ||||||
|  |  | ||||||
| 			size = str.size; | 			size = str.size; | ||||||
| 			delete[] data; | 			delete[] data; | ||||||
| 			data = str.data; | 			data = str.data; | ||||||
| @@ -127,8 +118,6 @@ namespace ehs | |||||||
| 	        if (&str == this) | 	        if (&str == this) | ||||||
| 	            return *this; | 	            return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=(str); |  | ||||||
|  |  | ||||||
| 			size = str.size; | 			size = str.size; | ||||||
|  |  | ||||||
|             delete[] data; |             delete[] data; | ||||||
| @@ -564,7 +553,7 @@ namespace ehs | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             Util::Copy(data[dstOffset], src, src.Size(true)); |             Util::Copy(&data[dstOffset], src, src.Size(true)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         /// Copies a C-style string to the referenced string object. |         /// Copies a C-style string to the referenced string object. | ||||||
| @@ -580,7 +569,7 @@ namespace ehs | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             Util::Copy(data[dstOffset], src, srcSize * sizeof(T)); |             Util::Copy(&data[dstOffset], src, srcSize * sizeof(T)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		/// Copies a C-style string to the referenced string object. | 		/// Copies a C-style string to the referenced string object. | ||||||
| @@ -595,7 +584,7 @@ namespace ehs | |||||||
| 	            return; | 	            return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             Util::Copy(data[dstOffset], src, srcSize * sizeof(T)); |             Util::Copy(&data[dstOffset], src, srcSize * sizeof(T)); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 		/// Inserts a string at a specified index. | 		/// Inserts a string at a specified index. | ||||||
| @@ -747,7 +736,7 @@ namespace ehs | |||||||
|  |  | ||||||
|             T* result = new T[size + inSize + 1]; |             T* result = new T[size + inSize + 1]; | ||||||
|             Util::Copy(result, data, Size(true)); |             Util::Copy(result, data, Size(true)); | ||||||
|             Util::Copy(result[size], value, inSize * sizeof(T)); |             Util::Copy(&result[size], value, inSize * sizeof(T)); | ||||||
|  |  | ||||||
|             result[size + inSize] = 0; |             result[size + inSize] = 0; | ||||||
|  |  | ||||||
| @@ -1271,8 +1260,11 @@ namespace ehs | |||||||
| 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | ||||||
|         float ToFloat() const |         float ToFloat() const | ||||||
|         { |         { | ||||||
|  | 			Str<T, N> ide; | ||||||
|  | 			ide.Push(46); | ||||||
|  |  | ||||||
|             N decPoint = size; |             N decPoint = size; | ||||||
|             Find(".", &decPoint); |             Find(ide, &decPoint); | ||||||
|  |  | ||||||
|             float result = 0.0f; |             float result = 0.0f; | ||||||
|             float fraction = 0.0f; |             float fraction = 0.0f; | ||||||
| @@ -1297,8 +1289,11 @@ namespace ehs | |||||||
| 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | ||||||
|         double ToDouble() const |         double ToDouble() const | ||||||
|         { |         { | ||||||
|  | 			Str<T, N> ide; | ||||||
|  | 			ide.Push(46); | ||||||
|  |  | ||||||
|             N decPoint = size; |             N decPoint = size; | ||||||
|             Find(".", &decPoint); |             Find(ide, &decPoint); | ||||||
|  |  | ||||||
|             double result = 0.0f; |             double result = 0.0f; | ||||||
|             double fraction = 0.0f; |             double fraction = 0.0f; | ||||||
| @@ -1323,8 +1318,11 @@ namespace ehs | |||||||
| 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | 		/// @note Use "IsNum" before this if the string object is not guaranteed to be a number. | ||||||
|         long double ToLDouble() const |         long double ToLDouble() const | ||||||
|         { |         { | ||||||
|  | 			Str<T, N> ide; | ||||||
|  | 			ide.Push(46); | ||||||
|  |  | ||||||
|             N decPoint = size; |             N decPoint = size; | ||||||
|             Find(".", &decPoint); |             Find(ide, &decPoint); | ||||||
|  |  | ||||||
|             long double result = 0.0f; |             long double result = 0.0f; | ||||||
|             long double fraction = 0.0f; |             long double fraction = 0.0f; | ||||||
| @@ -1679,7 +1677,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 			Str<T, N> result; | 			Str<T, N> result; | ||||||
| 			if (whole < 0) | 			if (whole < 0) | ||||||
| 				result += "-"; | 				result.Push(45); | ||||||
|  |  | ||||||
| 			result += Str<T, N>::FromNum(whole); | 			result += Str<T, N>::FromNum(whole); | ||||||
|  |  | ||||||
| @@ -1691,7 +1689,7 @@ namespace ehs | |||||||
| 			if (!fraction) | 			if (!fraction) | ||||||
| 				return result; | 				return result; | ||||||
|  |  | ||||||
| 			result += "."; | 			result.Push(46); | ||||||
|  |  | ||||||
| 			Str<T, N> fResult(maxDecimals); | 			Str<T, N> fResult(maxDecimals); | ||||||
| 			N i = 0; | 			N i = 0; | ||||||
| @@ -1721,7 +1719,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 			Str<T, N> result; | 			Str<T, N> result; | ||||||
| 			if (whole < 0) | 			if (whole < 0) | ||||||
| 				result += "-"; | 				result.Push(45); | ||||||
|  |  | ||||||
| 			result += Str<T, N>::FromNum(whole); | 			result += Str<T, N>::FromNum(whole); | ||||||
|  |  | ||||||
| @@ -1733,7 +1731,7 @@ namespace ehs | |||||||
| 			if (!fraction) | 			if (!fraction) | ||||||
| 				return result; | 				return result; | ||||||
|  |  | ||||||
| 			result += "."; | 			result.Push(46); | ||||||
|  |  | ||||||
| 			Str<T, N> fResult(maxDecimals); | 			Str<T, N> fResult(maxDecimals); | ||||||
| 			N i = 0; | 			N i = 0; | ||||||
| @@ -1763,7 +1761,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 			Str<T, N> result; | 			Str<T, N> result; | ||||||
| 			if (whole < 0) | 			if (whole < 0) | ||||||
| 				result += "-"; | 				result.Push(45); | ||||||
|  |  | ||||||
| 			result += Str<T, N>::FromNum(whole); | 			result += Str<T, N>::FromNum(whole); | ||||||
|  |  | ||||||
| @@ -1775,7 +1773,7 @@ namespace ehs | |||||||
| 			if (!fraction) | 			if (!fraction) | ||||||
| 				return result; | 				return result; | ||||||
|  |  | ||||||
| 			result += "."; | 			result.Push(46); | ||||||
|  |  | ||||||
| 			Str<T, N> fResult(maxDecimals); | 			Str<T, N> fResult(maxDecimals); | ||||||
| 			N i = 0; | 			N i = 0; | ||||||
| @@ -1870,6 +1868,9 @@ namespace ehs | |||||||
| 		/// @returns The character count. | 		/// @returns The character count. | ||||||
|         static N Len(const T* const str) |         static N Len(const T* const str) | ||||||
|         { |         { | ||||||
|  | 			if (!str) | ||||||
|  | 				return 0; | ||||||
|  |  | ||||||
|             N count = 0; |             N count = 0; | ||||||
|             while (str[count]) |             while (str[count]) | ||||||
|                 ++count; |                 ++count; | ||||||
| @@ -1888,14 +1889,14 @@ namespace ehs | |||||||
|             if (aSize != bSize) |             if (aSize != bSize) | ||||||
|                 return false; |                 return false; | ||||||
|  |  | ||||||
|             for (UInt_64 i = 0; i < aSize; ++i) |         	return Util::Compare(a, b, aSize); | ||||||
|                 if (a[i] != b[i]) |  | ||||||
|                     return false; |  | ||||||
|  |  | ||||||
|             return true; |  | ||||||
|         } |         } | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	template class EHS_LIB_IO Str<Char_32, UInt_64>; | ||||||
|  | 	template class EHS_LIB_IO Str<Char_16, UInt_64>; | ||||||
|  | 	template class EHS_LIB_IO Str<Char_8, UInt_64>; | ||||||
|  |  | ||||||
| 	typedef Str<Char_32, UInt_64> Str_32; | 	typedef Str<Char_32, UInt_64> Str_32; | ||||||
| 	typedef Str<Char_16, UInt_64> Str_16; | 	typedef Str<Char_16, UInt_64> Str_16; | ||||||
| 	typedef Str<Char_8, UInt_64> Str_8; | 	typedef Str<Char_8, UInt_64> Str_8; | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ namespace ehs | |||||||
| { | { | ||||||
| 	typedef void (*TaskCb)(Serializer<UInt_64>*); | 	typedef void (*TaskCb)(Serializer<UInt_64>*); | ||||||
|  |  | ||||||
| 	class Task | 	class EHS_LIB_IO Task | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		bool working; | 		bool working; | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Type |     class EHS_LIB_IO Type | ||||||
|     { |     { | ||||||
|     private: |     private: | ||||||
| 		friend class BaseObj; | 		friend class BaseObj; | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "ehs/system/OS.h" | #include "ehs/system/OS.h" | ||||||
|  | #include "ehs/system/Architecture.h" | ||||||
|  |  | ||||||
| #define EHS_MAX_PATH 0x104 | #define EHS_MAX_PATH 0x104 | ||||||
| #define EHS_UINT_8_MAX 0xFF | #define EHS_UINT_8_MAX 0xFF | ||||||
| @@ -25,6 +26,12 @@ | |||||||
| #define EHS_LDOUBLE_MAX 1.79769e+308 | #define EHS_LDOUBLE_MAX 1.79769e+308 | ||||||
| #define EHS_LDOUBLE_MIN 2.22507e-308 | #define EHS_LDOUBLE_MIN 2.22507e-308 | ||||||
|  |  | ||||||
|  | #if defined(EHS_64_BIT) | ||||||
|  | 	#define EHS_SIZE_MAX 0xFFFFFFFFFFFFFFFF | ||||||
|  | #elif defined(EHS_32_BIT) | ||||||
|  | 	#define EHS_SIZE_MAX 0xFFFFFFFF | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #define EHS_INFINITE EHS_UINT_32_MAX | #define EHS_INFINITE EHS_UINT_32_MAX | ||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| @@ -52,4 +59,12 @@ namespace ehs | |||||||
| 		typedef signed long SInt_64; | 		typedef signed long SInt_64; | ||||||
| 		typedef long Int_64; | 		typedef long Int_64; | ||||||
| 	#endif | 	#endif | ||||||
|  |  | ||||||
|  | 	#if defined(EHS_64_BIT) | ||||||
|  | 		typedef UInt_64 Size; | ||||||
|  | 		typedef SInt_64 SSize; | ||||||
|  | 	#elif defined(EHS_32_BIT) | ||||||
|  | 		typedef UInt_32 Size; | ||||||
|  | 		typedef SInt_32 SSize; | ||||||
|  | 	#endif | ||||||
| } | } | ||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class URI | 	class EHS_LIB_IO URI | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 		/// Encodes specialized characters in the URI. | 		/// Encodes specialized characters in the URI. | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ namespace ehs | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     /// A helper class for converting between UTF8, 16 and 32. |     /// A helper class for converting between UTF8, 16 and 32. | ||||||
| 	class UTF | 	class EHS_LIB_IO UTF | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 	    /// Converts the given UTF16 C-style string into UTF32. | 	    /// Converts the given UTF16 C-style string into UTF32. | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Util | 	class EHS_LIB_IO Util | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 		static bool Compare(const void* a, const void* b, UInt_64 size); | 		static bool Compare(const void* a, const void* b, UInt_64 size); | ||||||
|   | |||||||
| @@ -229,7 +229,7 @@ namespace ehs | |||||||
| 				case 1: | 				case 1: | ||||||
| 					return y; | 					return y; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -243,7 +243,7 @@ namespace ehs | |||||||
| 				case 1: | 				case 1: | ||||||
| 					return y; | 					return y; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -266,7 +266,7 @@ namespace ehs | |||||||
| 				case 2: | 				case 2: | ||||||
| 					return z; | 					return z; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -282,7 +282,7 @@ namespace ehs | |||||||
| 				case 2: | 				case 2: | ||||||
| 					return z; | 					return z; | ||||||
| 				default: | 				default: | ||||||
| 					EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | 					EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 3."); | ||||||
| 					return x; | 					return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -279,7 +279,7 @@ namespace ehs | |||||||
| 			case 3: | 			case 3: | ||||||
| 				return w; | 				return w; | ||||||
|             default: |             default: | ||||||
|                 EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 4."); |                 EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 4."); | ||||||
|                 return x; |                 return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @@ -297,7 +297,7 @@ namespace ehs | |||||||
| 			case 3: | 			case 3: | ||||||
| 				return w; | 				return w; | ||||||
|             default: |             default: | ||||||
|                 EHS_LOG_INT("Error", 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 4."); |                 EHS_LOG_INT(LogType::ERR, 0, "Index of, \"" + Str_8::FromNum(index) + "\" is out of range for a Vector 4."); | ||||||
|                 return x; |                 return x; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ namespace ehs | |||||||
|     /// @tparam N Number data type to use. |     /// @tparam N Number data type to use. | ||||||
|     /// @note If extra memory is set to five then each time that memory is filled it will add five extra. |     /// @note If extra memory is set to five then each time that memory is filled it will add five extra. | ||||||
| 	template<typename T, typename N = UInt_64> | 	template<typename T, typename N = UInt_64> | ||||||
| 	class Vector : public BaseObj | 	class Vector | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		N rawSize; | 		N rawSize; | ||||||
| @@ -24,7 +24,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
|         /// Frees any data created on the heap. |         /// Frees any data created on the heap. | ||||||
|         ~Vector() override |         ~Vector() | ||||||
| 		{ | 		{ | ||||||
|             delete[] data; |             delete[] data; | ||||||
| 		} | 		} | ||||||
| @@ -33,7 +33,6 @@ namespace ehs | |||||||
| 		Vector() | 		Vector() | ||||||
| 			: rawSize(0), size(0), stride(5), data(nullptr) | 			: rawSize(0), size(0), stride(5), data(nullptr) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Vector"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		/// Initializes members for pre-allocated memory to write to later. | 		/// Initializes members for pre-allocated memory to write to later. | ||||||
| @@ -42,7 +41,6 @@ namespace ehs | |||||||
| 		Vector(const N size, const N stride) | 		Vector(const N size, const N stride) | ||||||
| 			: rawSize(size + stride), size(size), stride(stride), data(new T[rawSize]) | 			: rawSize(size + stride), size(size), stride(stride), data(new T[rawSize]) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Vector"); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         /// Initializes this vector with an initializer list object. |         /// Initializes this vector with an initializer list object. | ||||||
| @@ -51,8 +49,6 @@ namespace ehs | |||||||
|         Vector(std::initializer_list<T> list, const N stride = 5) |         Vector(std::initializer_list<T> list, const N stride = 5) | ||||||
| 			: rawSize(0), size(list.size()), stride(stride), data(nullptr) | 			: rawSize(0), size(list.size()), stride(stride), data(nullptr) | ||||||
|         { |         { | ||||||
| 			AddType("Vector"); |  | ||||||
|  |  | ||||||
| 			if (stride) | 			if (stride) | ||||||
| 			{ | 			{ | ||||||
| 				rawSize = list.size() / stride * stride; | 				rawSize = list.size() / stride * stride; | ||||||
| @@ -78,8 +74,6 @@ namespace ehs | |||||||
| 		Vector(const T* data, const N size, const N stride) | 		Vector(const T* data, const N size, const N stride) | ||||||
| 			: rawSize(0), size(size), stride(stride), data(nullptr) | 			: rawSize(0), size(size), stride(stride), data(nullptr) | ||||||
| 		{ | 		{ | ||||||
| 			AddType("Vector"); |  | ||||||
|  |  | ||||||
| 			if (stride) | 			if (stride) | ||||||
| 			{ | 			{ | ||||||
| 				rawSize = size / stride * stride; | 				rawSize = size / stride * stride; | ||||||
| @@ -100,14 +94,14 @@ namespace ehs | |||||||
|         /// Copies all members from the given vector object. |         /// Copies all members from the given vector object. | ||||||
|         /// @param [in] vec The vector object to copy from. |         /// @param [in] vec The vector object to copy from. | ||||||
| 		Vector(const Vector& vec) | 		Vector(const Vector& vec) | ||||||
| 			: BaseObj(vec), rawSize(vec.rawSize), size(vec.size), stride(vec.stride), data(new T[rawSize]) | 			: rawSize(vec.rawSize), size(vec.size), stride(vec.stride), data(new T[rawSize]) | ||||||
| 		{ | 		{ | ||||||
| 			for (N i = 0; i < size; ++i) | 			for (N i = 0; i < size; ++i) | ||||||
| 				data[i] = vec.data[i]; | 				data[i] = vec.data[i]; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         Vector(Vector&& vec) noexcept |         Vector(Vector&& vec) noexcept | ||||||
|             : BaseObj((BaseObj&&)vec), rawSize(vec.rawSize), size(vec.size), stride(vec.stride), data(vec.data) |             : rawSize(vec.rawSize), size(vec.size), stride(vec.stride), data(vec.data) | ||||||
|         { |         { | ||||||
|             vec.rawSize = 0; |             vec.rawSize = 0; | ||||||
|             vec.size = 0; |             vec.size = 0; | ||||||
| @@ -123,8 +117,6 @@ namespace ehs | |||||||
|             if (this == &vec) |             if (this == &vec) | ||||||
|                 return *this; |                 return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=(vec); |  | ||||||
|  |  | ||||||
| 			rawSize = vec.rawSize; | 			rawSize = vec.rawSize; | ||||||
| 			size = vec.size; | 			size = vec.size; | ||||||
| 			stride = vec.stride; | 			stride = vec.stride; | ||||||
| @@ -143,8 +135,6 @@ namespace ehs | |||||||
|             if (this == &vec) |             if (this == &vec) | ||||||
|                 return *this; |                 return *this; | ||||||
|  |  | ||||||
| 			BaseObj::operator=((BaseObj&&)vec); |  | ||||||
|  |  | ||||||
|             rawSize = vec.rawSize; |             rawSize = vec.rawSize; | ||||||
|             size = vec.size; |             size = vec.size; | ||||||
|             stride = vec.stride; |             stride = vec.stride; | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     /// A helper class for storing version major, minor and patch. |     /// A helper class for storing version major, minor and patch. | ||||||
| 	class Version | 	class EHS_LIB_IO Version | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 		UInt_32 major; | 		UInt_32 major; | ||||||
|   | |||||||
| @@ -1,20 +0,0 @@ | |||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "ehs/EHS.h" |  | ||||||
| #include "ehs/BaseObj.h" |  | ||||||
| #include "ehs/Str.h" |  | ||||||
|  |  | ||||||
| namespace ehs |  | ||||||
| { |  | ||||||
| 	enum class DType : UInt_8 |  | ||||||
| 	{ |  | ||||||
| 	 |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	class DVar : public BaseObj |  | ||||||
| 	{ |  | ||||||
| 	private: |  | ||||||
| 		Str_8 id; |  | ||||||
| 		UInt_64 hashId; |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
							
								
								
									
										56
									
								
								include/ehs/db/Database.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								include/ehs/db/Database.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Array.h" | ||||||
|  | #include "DbTable.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO Database | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		UInt_64 hashId; | ||||||
|  | 		Str_8 id; | ||||||
|  | 		Version version; | ||||||
|  | 		Array<DbTable> tables; | ||||||
|  | 		Str_8 dir; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		Database(); | ||||||
|  |  | ||||||
|  | 		Database(Str_8 id, const Version& version); | ||||||
|  |  | ||||||
|  | 		Database(Str_8 filePath); | ||||||
|  |  | ||||||
|  | 		Database(Database&& db) noexcept; | ||||||
|  |  | ||||||
|  | 		Database(const Database& db); | ||||||
|  |  | ||||||
|  | 		Database& operator=(Database&& db) noexcept; | ||||||
|  |  | ||||||
|  | 		Database& operator=(const Database& db); | ||||||
|  |  | ||||||
|  | 		UInt_64 GetHashId() const; | ||||||
|  |  | ||||||
|  | 		void SetId(Str_8 newId); | ||||||
|  |  | ||||||
|  | 		Str_8 GetId() const; | ||||||
|  |  | ||||||
|  | 		void SetVersion(const Version& newVersion); | ||||||
|  |  | ||||||
|  | 		Version GetVersion() const; | ||||||
|  |  | ||||||
|  | 		bool HasTable(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		bool HasTable(const Str_8& id) const; | ||||||
|  |  | ||||||
|  | 		DbTable* CreateTable(Str_8 id); | ||||||
|  |  | ||||||
|  | 		DbTable* GetTable(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		DbTable* GetTable(const Str_8& id) const; | ||||||
|  |  | ||||||
|  | 		Str_8 GetDirectory() const; | ||||||
|  |  | ||||||
|  | 		void Save(Str_8 directory); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										52
									
								
								include/ehs/db/DbObject.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								include/ehs/db/DbObject.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Array.h" | ||||||
|  | #include "DbVar.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class DbTable; | ||||||
|  |  | ||||||
|  | 	class EHS_LIB_IO DbObject | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		friend class DbTable; | ||||||
|  | 		friend class DbVar; | ||||||
|  |  | ||||||
|  | 		UInt_64 id; | ||||||
|  | 		DbTable* parent; | ||||||
|  | 		Array<DbVar> vars; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		DbObject(); | ||||||
|  |  | ||||||
|  | 		DbObject(UInt_64 id); | ||||||
|  |  | ||||||
|  | 		DbObject(DbObject&& obj) noexcept; | ||||||
|  |  | ||||||
|  | 		DbObject(const DbObject& obj); | ||||||
|  |  | ||||||
|  | 		DbObject& operator=(DbObject&& obj) noexcept; | ||||||
|  |  | ||||||
|  | 		DbObject& operator=(const DbObject& obj); | ||||||
|  |  | ||||||
|  | 		UInt_64 GetId() const; | ||||||
|  |  | ||||||
|  | 		bool HasVariable(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		DbVar* GetVariable(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		DbVar* GetVariable(const Str_8& id) const; | ||||||
|  |  | ||||||
|  | 		void Save() const; | ||||||
|  |  | ||||||
|  | 		void Load(); | ||||||
|  |  | ||||||
|  | 		bool IsLoaded() const; | ||||||
|  |  | ||||||
|  | 		void Free(); | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		void CreateVariable(DbVarTmpl* master); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										66
									
								
								include/ehs/db/DbTable.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								include/ehs/db/DbTable.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Version.h" | ||||||
|  | #include "ehs/Array.h" | ||||||
|  | #include "DbVarTmpl.h" | ||||||
|  | #include "DbObject.h" | ||||||
|  | #include "ehs/Serializer.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class Database; | ||||||
|  |  | ||||||
|  | 	class EHS_LIB_IO DbTable | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		friend class Database; | ||||||
|  | 		friend class DbVar; | ||||||
|  | 		friend class DbObject; | ||||||
|  |  | ||||||
|  | 		Database *parent; | ||||||
|  | 		UInt_64 hashId; | ||||||
|  | 		Str_8 id; | ||||||
|  | 		Array<DbVarTmpl> varTmpls; | ||||||
|  | 		Array<DbObject> objects; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		DbTable(); | ||||||
|  |  | ||||||
|  | 		DbTable(Str_8 id); | ||||||
|  |  | ||||||
|  | 		DbTable(DbTable&& table) noexcept; | ||||||
|  |  | ||||||
|  | 		DbTable(const DbTable& table); | ||||||
|  |  | ||||||
|  | 		DbTable& operator=(DbTable&& table) noexcept; | ||||||
|  |  | ||||||
|  | 		DbTable& operator=(const DbTable& table); | ||||||
|  |  | ||||||
|  | 		UInt_64 GetHashId() const; | ||||||
|  |  | ||||||
|  | 		void SetId(Str_8 newId); | ||||||
|  |  | ||||||
|  | 		Str_8 GetId() const; | ||||||
|  |  | ||||||
|  | 		bool HasVariable(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		bool HasVariable(const Str_8& id) const; | ||||||
|  |  | ||||||
|  | 		bool CreateVariable(DbVarTmpl var); | ||||||
|  |  | ||||||
|  | 		DbObject *CreateObject(); | ||||||
|  |  | ||||||
|  | 		DbObject *GetObject(UInt_64 variableHashId, const Str_8 &value) const; | ||||||
|  |  | ||||||
|  | 		DbObject *GetObject(const Str_8 &variable, const Str_8 &value) const; | ||||||
|  |  | ||||||
|  | 		DbObject *GetObject(UInt_64 id) const; | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		DbVarTmpl *GetVariableTemplate(UInt_64 hashId) const; | ||||||
|  |  | ||||||
|  | 		void Serialize(const Str_8 &dir, Serializer<UInt_64>& data) const; | ||||||
|  |  | ||||||
|  | 		void Deserialize(const Str_8 &dir, Serializer<UInt_64>& data); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										105
									
								
								include/ehs/db/DbVar.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								include/ehs/db/DbVar.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,105 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Types.h" | ||||||
|  | #include "ehs/Serializer.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class DbVarTmpl; | ||||||
|  | 	class DbObject; | ||||||
|  |  | ||||||
|  | 	class EHS_LIB_IO DbVar | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		friend class DbObject; | ||||||
|  |  | ||||||
|  | 		UInt_64 hashId; | ||||||
|  | 		DbObject *parent; | ||||||
|  | 		Byte *value; | ||||||
|  | 		UInt_64 size; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		~DbVar(); | ||||||
|  |  | ||||||
|  | 		DbVar(); | ||||||
|  |  | ||||||
|  | 		DbVar(UInt_64 hashId, const DbVarTmpl *master); | ||||||
|  |  | ||||||
|  | 		DbVar(DbVar &&var) noexcept; | ||||||
|  |  | ||||||
|  | 		DbVar(const DbVar &var); | ||||||
|  |  | ||||||
|  | 		DbVar &operator=(DbVar &&var) noexcept; | ||||||
|  |  | ||||||
|  | 		DbVar &operator=(const DbVar &var); | ||||||
|  |  | ||||||
|  | 		explicit operator Byte *() const; | ||||||
|  |  | ||||||
|  | 		UInt_64 GetHashId() const; | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		void SetValueArray(const T* const newValue, const UInt_64 newSize) | ||||||
|  | 		{ | ||||||
|  | 			size = sizeof(T) * newSize; | ||||||
|  |  | ||||||
|  | 			value = new Byte[size]; | ||||||
|  |  | ||||||
|  | 			Util::Copy(value, newValue, size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T = Char_8> | ||||||
|  | 		void SetValueStr(const T * const newValue) | ||||||
|  | 		{ | ||||||
|  | 			size = sizeof(T) * Str<Char_8, UInt_64>::Len(newValue); | ||||||
|  |  | ||||||
|  | 			value = new Byte[size]; | ||||||
|  |  | ||||||
|  | 			Util::Copy(value, newValue, size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T = Char_8, typename I = UInt_64> | ||||||
|  | 		void SetValueStr(const Str<T, I>& newValue) | ||||||
|  | 		{ | ||||||
|  | 			size = newValue.Size(true); | ||||||
|  |  | ||||||
|  | 			value = new Byte[size]; | ||||||
|  |  | ||||||
|  | 			Util::Copy(value, &newValue[0], size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		void SetValue(const Byte* newValue) | ||||||
|  | 		{ | ||||||
|  | 			size = sizeof(T); | ||||||
|  |  | ||||||
|  | 			value = new Byte[size]; | ||||||
|  |  | ||||||
|  | 			Util::Copy(value, newValue, size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		T* GetValueArray() const | ||||||
|  | 		{ | ||||||
|  | 			return (T*)value; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T = Char_8, typename I = UInt_64> | ||||||
|  | 		Str<T, I> GetValueStr() const | ||||||
|  | 		{ | ||||||
|  | 			return {(T*)value, size / sizeof(T)}; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		T GetValue() const | ||||||
|  | 		{ | ||||||
|  | 			return *(T*)value; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		UInt_64 GetSize() const; | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		void Serialize(Serializer<UInt_64> &data) const; | ||||||
|  |  | ||||||
|  | 		void Deserialize(Serializer<UInt_64> &data); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										77
									
								
								include/ehs/db/DbVarTmpl.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								include/ehs/db/DbVarTmpl.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/EHS.h" | ||||||
|  | #include "ehs/Serializer.h" | ||||||
|  | #include "ehs/Str.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class DbVar; | ||||||
|  |  | ||||||
|  | 	class EHS_LIB_IO DbVarTmpl | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		friend class DbTable; | ||||||
|  |  | ||||||
|  | 		UInt_64 hashId; | ||||||
|  | 		Str_8 id; | ||||||
|  | 		Byte* def; | ||||||
|  | 		UInt_64 size; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		~DbVarTmpl(); | ||||||
|  |  | ||||||
|  | 		DbVarTmpl(); | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		DbVarTmpl(Str_8 id, const T* const def, UInt_64 size) | ||||||
|  | 			: hashId(id.Hash_64()), id((Str_8&&)id), def(new Byte[sizeof(T) * size]), size(sizeof(T) * size) | ||||||
|  | 		{ | ||||||
|  | 			Util::Copy(this->def, def, this->size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		DbVarTmpl(Str_8 id, const T* const def) | ||||||
|  | 			: hashId(id.Hash_64()), id((Str_8&&)id), def(new Byte[sizeof(T)]), size(sizeof(T)) | ||||||
|  | 		{ | ||||||
|  | 			Util::Copy(this->def, def, this->size); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		DbVarTmpl(Str_8 id); | ||||||
|  |  | ||||||
|  | 		DbVarTmpl(DbVarTmpl&& varTmpl) noexcept; | ||||||
|  |  | ||||||
|  | 		DbVarTmpl(const DbVarTmpl& varTmpl); | ||||||
|  |  | ||||||
|  | 		DbVarTmpl& operator=(DbVarTmpl&& varTmpl) noexcept; | ||||||
|  |  | ||||||
|  | 		DbVarTmpl& operator=(const DbVarTmpl& varTmpl); | ||||||
|  |  | ||||||
|  | 		operator Byte *() const; | ||||||
|  |  | ||||||
|  | 		UInt_64 GetHashId() const; | ||||||
|  |  | ||||||
|  | 		void SetId(Str_8 newId); | ||||||
|  |  | ||||||
|  | 		Str_8 GetId() const; | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		T* GetDefaultArray() const | ||||||
|  | 		{ | ||||||
|  | 			return (T*)def; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		template<typename T> | ||||||
|  | 		T GetDefault() const | ||||||
|  | 		{ | ||||||
|  | 			return *(T*)def; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		UInt_64 GetSize() const; | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		void Serialize(Serializer<UInt_64> &data) const; | ||||||
|  |  | ||||||
|  | 		void Deserialize(Serializer<UInt_64> &data); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										17
									
								
								include/ehs/io/BaseDirectory.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								include/ehs/io/BaseDirectory.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Array.h" | ||||||
|  | #include "ehs/Str.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO BaseDirectory | ||||||
|  | 	{ | ||||||
|  | 	public: | ||||||
|  | 		static Array<Str_8> GetAllFiles(const Str_8 &dir); | ||||||
|  |  | ||||||
|  | 		static void CreateRecursive(Str_8 dir); | ||||||
|  |  | ||||||
|  | 		static void Create(const Str_8 &dir); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
| @@ -25,7 +25,7 @@ namespace ehs | |||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	/// A cross-platform wrapper class that handles native file input/output. | 	/// A cross-platform wrapper class that handles native file input/output. | ||||||
| 	class BaseFile | 	class EHS_LIB_IO BaseFile | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		Str_8 path; | 		Str_8 path; | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class BaseFileMonitor | 	class EHS_LIB_IO BaseFileMonitor | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		Str_8 filePath; | 		Str_8 filePath; | ||||||
|   | |||||||
| @@ -1,9 +1,7 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "ehs/EHS.h" |  | ||||||
| #include "ehs/Str.h" | #include "ehs/Str.h" | ||||||
| #include "ehs/Vec2.h" | #include "ehs/Vec2.h" | ||||||
| #include "ehs/Rect.h" |  | ||||||
| #include "ehs/io/hid/Input.h" | #include "ehs/io/hid/Input.h" | ||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| @@ -20,7 +18,7 @@ namespace ehs | |||||||
| 		I_BEAM | 		I_BEAM | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|     class BaseWindow |     class EHS_LIB_IO BaseWindow | ||||||
|     { |     { | ||||||
| 	protected: | 	protected: | ||||||
| 		bool created; | 		bool created; | ||||||
| @@ -60,10 +58,6 @@ namespace ehs | |||||||
|  |  | ||||||
| 		bool HasFocus() const; | 		bool HasFocus() const; | ||||||
|  |  | ||||||
|     	void EnableResizing(bool enable); |  | ||||||
|  |  | ||||||
|     	bool IsResizable() const; |  | ||||||
|  |  | ||||||
| 		/// Gets the cursors position on the desktop in pixels. | 		/// Gets the cursors position on the desktop in pixels. | ||||||
| 		/// @param [in] relative Whether the position should be relative to the windows client. | 		/// @param [in] relative Whether the position should be relative to the windows client. | ||||||
| 		/// @returns The current value. | 		/// @returns The current value. | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ namespace ehs | |||||||
|         TWO |         TWO | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     class COM |     class EHS_LIB_IO COM | ||||||
|     { |     { | ||||||
|     private: |     private: | ||||||
|         UInt_8 port; |         UInt_8 port; | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ namespace ehs | |||||||
|         typedef int ConsoleHdl; |         typedef int ConsoleHdl; | ||||||
|     #endif |     #endif | ||||||
|  |  | ||||||
| 	class Console | 	class EHS_LIB_IO Console | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		static ConsoleHdl hdlOut; | 		static ConsoleHdl hdlOut; | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								include/ehs/io/Directory.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								include/ehs/io/Directory.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/system/OS.h" | ||||||
|  |  | ||||||
|  | #if defined(EHS_OS_WINDOWS) | ||||||
|  |     #include "Directory_W32.h" | ||||||
|  | #elif defined(EHS_OS_LINUX) | ||||||
|  |     #include "Directory_LNX.h" | ||||||
|  | #endif | ||||||
							
								
								
									
										16
									
								
								include/ehs/io/Directory_LNX.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								include/ehs/io/Directory_LNX.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "BaseDirectory.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO Directory : public BaseDirectory | ||||||
|  | 	{ | ||||||
|  | 	public: | ||||||
|  | 		static Array<Str_8> GetAllFiles(const Str_8 &dir); | ||||||
|  |  | ||||||
|  | 		static void CreateRecursive(Str_8 dir); | ||||||
|  |  | ||||||
|  | 		static void Create(const Str_8 &dir); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										16
									
								
								include/ehs/io/Directory_W32.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								include/ehs/io/Directory_W32.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "BaseDirectory.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  |     class EHS_LIB_IO Directory : public BaseDirectory | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |         static Array<Str_8> GetAllFiles(const Str_8 &dir); | ||||||
|  |  | ||||||
|  |         static void CreateRecursive(Str_8 dir); | ||||||
|  |  | ||||||
|  |         static void Create(const Str_8 &dir); | ||||||
|  |     }; | ||||||
|  | } | ||||||
| @@ -1,6 +1,6 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "ehs/EHS.h" | #include "ehs/system/OS.h" | ||||||
|  |  | ||||||
| #if defined(EHS_OS_WINDOWS) | #if defined(EHS_OS_WINDOWS) | ||||||
| #include "File_W32.h" | #include "File_W32.h" | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class FileMonitor : public BaseFileMonitor | 	class EHS_LIB_IO FileMonitor : public BaseFileMonitor | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		int hdl; | 		int hdl; | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class FileMonitor final : public BaseFileMonitor | 	class EHS_LIB_IO FileMonitor final : public BaseFileMonitor | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Handle hdl; | 		Handle hdl; | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class File : public BaseFile | 	class EHS_LIB_IO File : public BaseFile | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		int hdl; | 		int hdl; | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class File : public BaseFile | 	class EHS_LIB_IO File : public BaseFile | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		HANDLE hdl; | 		HANDLE hdl; | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class FontAtlas : public BaseObj | 	class EHS_LIB_IO FontAtlas : public BaseObj | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		UInt_64 hashId; | 		UInt_64 hashId; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Glyph | 	class EHS_LIB_IO Glyph | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Char_32 code; | 		Char_32 code; | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class RIFF | 	class EHS_LIB_IO RIFF | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 type; | 		Str_8 type; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class RIFF_Chunk | 	class EHS_LIB_IO RIFF_Chunk | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Resource : public BaseObj | 	class EHS_LIB_IO Resource : public BaseObj | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		ehs::UInt_64 hashId; | 		ehs::UInt_64 hashId; | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								include/ehs/io/UsbBase.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								include/ehs/io/UsbBase.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Types.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  |     class EHS_LIB_IO UsbBase | ||||||
|  |     { | ||||||
|  |     private: | ||||||
|  |         UInt_32 bus; | ||||||
|  |         UInt_32 address; | ||||||
|  |  | ||||||
|  |     public: | ||||||
|  |         virtual ~UsbBase() = default; | ||||||
|  |  | ||||||
|  |         UsbBase(); | ||||||
|  |  | ||||||
|  |         UsbBase(UInt_32 bus, UInt_32 address); | ||||||
|  |  | ||||||
|  |         UsbBase(UsbBase&& usb) noexcept; | ||||||
|  |  | ||||||
|  |         UsbBase(const UsbBase& usb); | ||||||
|  |  | ||||||
|  |         UsbBase& operator=(UsbBase&& usb) noexcept; | ||||||
|  |  | ||||||
|  |         UsbBase& operator=(const UsbBase& usb); | ||||||
|  |  | ||||||
|  |         virtual void Initialize() = 0; | ||||||
|  |  | ||||||
|  |         virtual void Release() = 0; | ||||||
|  |  | ||||||
|  |         virtual bool IsInitialized() const = 0; | ||||||
|  |  | ||||||
|  |         virtual Size Send(const Byte* data, Size size) = 0; | ||||||
|  |  | ||||||
|  |         void BulkSend(const Byte* data, Size size); | ||||||
|  |  | ||||||
|  |         virtual Size Receive(Byte* data, Size size) = 0; | ||||||
|  |  | ||||||
|  |         void BulkReceive(Byte** data, Size* size); | ||||||
|  |  | ||||||
|  |         UInt_32 GetBus() const; | ||||||
|  |  | ||||||
|  |         UInt_32 GetAddress() const; | ||||||
|  |  | ||||||
|  |         bool IsValid() const; | ||||||
|  |     }; | ||||||
|  | } | ||||||
							
								
								
									
										34
									
								
								include/ehs/io/Usb_LNX.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								include/ehs/io/Usb_LNX.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "UsbBase.h" | ||||||
|  | #include "File.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  |     class EHS_LIB_IO Usb final : public UsbBase | ||||||
|  |     { | ||||||
|  |     private: | ||||||
|  |         int hdl; | ||||||
|  |  | ||||||
|  |     public: | ||||||
|  |         ~Usb() override; | ||||||
|  |  | ||||||
|  |         Usb(); | ||||||
|  |  | ||||||
|  |         Usb(UInt_32 bus, UInt_32 address); | ||||||
|  |  | ||||||
|  |         Usb(Usb&& usb) noexcept; | ||||||
|  |  | ||||||
|  |         Usb(const Usb& usb); | ||||||
|  |  | ||||||
|  |         Usb& operator=(Usb&& usb) noexcept; | ||||||
|  |  | ||||||
|  |         Usb& operator=(const Usb& usb); | ||||||
|  |  | ||||||
|  |         void Initialize() override; | ||||||
|  |  | ||||||
|  |         void Release() override; | ||||||
|  |  | ||||||
|  |         bool IsInitialized() const override; | ||||||
|  |     }; | ||||||
|  | } | ||||||
| @@ -14,7 +14,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Window : public BaseWindow |     class EHS_LIB_IO Window : public BaseWindow | ||||||
|     { |     { | ||||||
|     private: |     private: | ||||||
|         UInt_32 owner; |         UInt_32 owner; | ||||||
| @@ -71,13 +71,6 @@ namespace ehs | |||||||
|  |  | ||||||
| 		void SetIcon(const Str_8& filePath); | 		void SetIcon(const Str_8& filePath); | ||||||
|  |  | ||||||
|         /// Sets the windows client scale. |  | ||||||
|         /// @param [in] w The width in pixels. |  | ||||||
|         /// @param [in] h The height in pixels. |  | ||||||
|         void SetClientSize(const Vec2<UInt_32>& size); |  | ||||||
|  |  | ||||||
|         Vec2<UInt_32> GetClientSize(); |  | ||||||
|  |  | ||||||
|         /// Gets the windows native handle for the operating system or other native tasks. |         /// Gets the windows native handle for the operating system or other native tasks. | ||||||
|         /// @returns The window's native handle. |         /// @returns The window's native handle. | ||||||
|         HWND GetHdl() const; |         HWND GetHdl() const; | ||||||
|   | |||||||
| @@ -4,21 +4,27 @@ | |||||||
|  |  | ||||||
| #include <wayland-client.h> | #include <wayland-client.h> | ||||||
| #include "xdg-shell-client-protocol.h" | #include "xdg-shell-client-protocol.h" | ||||||
|  | #include "xdg-decoration.h" | ||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Window : public BaseWindow | 	class EHS_LIB_IO Window : public BaseWindow | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	protected: | ||||||
| 		wl_display *display; | 		wl_display *display; | ||||||
| 		wl_registry *registry; | 		wl_registry *registry; | ||||||
| 		wl_compositor *compositor; | 		wl_compositor *compositor; | ||||||
| 		wl_surface* surface; | 		wl_surface *wlSurface; | ||||||
| 		xdg_wm_base *xdgShell; | 		xdg_wm_base *xdgShell; | ||||||
| 		xdg_surface *xdgSurface; | 		xdg_surface *xdgSurface; | ||||||
| 		xdg_toplevel *xdgToplevel; | 		xdg_toplevel *xdgToplevel; | ||||||
|  | 		zxdg_decoration_manager_v1 *decManager; | ||||||
|  | 		zxdg_toplevel_decoration_v1 *dec; | ||||||
|  | 		wl_seat *seat; | ||||||
|  | 		wl_pointer *pointer; | ||||||
|  | 		Vec2_u32 scale; | ||||||
|  |  | ||||||
| 		static void SurfaceConfigure(void *data, xdg_surface *xdg_surface, UInt_32 serial); | 		static void SurfaceConfigEvent(void *data, xdg_surface *xdg_surface, UInt_32 serial); | ||||||
|  |  | ||||||
| 		static void ShellPing(void *data, xdg_wm_base *shell, UInt_32 serial); | 		static void ShellPing(void *data, xdg_wm_base *shell, UInt_32 serial); | ||||||
|  |  | ||||||
| @@ -26,16 +32,32 @@ namespace ehs | |||||||
|  |  | ||||||
| 		static void RegistryRemoved(void *data, wl_registry *registry, UInt_32 id); | 		static void RegistryRemoved(void *data, wl_registry *registry, UInt_32 id); | ||||||
|  |  | ||||||
|  | 		static void ResizeEvent(void *data, xdg_toplevel *xdg_toplevel, Int_32 width, Int_32 height, wl_array *states); | ||||||
|  |  | ||||||
|  | 		static void CloseEvent(void *data, xdg_toplevel *xdg_toplevel); | ||||||
|  |  | ||||||
|  | 		static void SeatCapabilitiesEvent(void *data, wl_seat *seat, UInt_32 capabilities); | ||||||
|  |  | ||||||
|  | 		static void PointerMotionEvent(void *data, wl_pointer *pointer, UInt_32 time, wl_fixed_t sx, wl_fixed_t sy); | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
| 		~Window() override; | 		~Window() override; | ||||||
|  |  | ||||||
| 		Window(); | 		Window(); | ||||||
|  |  | ||||||
| 		void Create_32(const Str_32& title, const Vec2_s32& pos, const Vec2_u32 scale) override; | 		Window(Window &&win) noexcept; | ||||||
|  |  | ||||||
| 		void Create_16(const Str_16& title, const Vec2_s32& pos, const Vec2_u32 scale) override; | 		Window(const Window &win); | ||||||
|  |  | ||||||
| 		void Create_8(const Str_8& title, const Vec2_s32& pos, const Vec2_u32 scale) override; | 		Window &operator=(Window &&win) noexcept; | ||||||
|  |  | ||||||
|  | 		Window &operator=(const Window &win); | ||||||
|  |  | ||||||
|  | 		void Create_32(const Str_32& title, const Vec2_s32& pos, Vec2_u32 scale) override; | ||||||
|  |  | ||||||
|  | 		void Create_16(const Str_16& title, const Vec2_s32& pos, Vec2_u32 scale) override; | ||||||
|  |  | ||||||
|  | 		void Create_8(const Str_8& title, const Vec2_s32& pos, Vec2_u32 scale) override; | ||||||
|  |  | ||||||
| 		void OnCreated() override; | 		void OnCreated() override; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Window : public BaseWindow |     class EHS_LIB_IO Window : public BaseWindow | ||||||
|     { |     { | ||||||
|     protected: |     protected: | ||||||
| 		friend class Input; | 		friend class Input; | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Audio : public Resource |     class EHS_LIB_IO Audio : public Resource | ||||||
|     { |     { | ||||||
| 	private: | 	private: | ||||||
| 		static Array<AudioCodec> codecs; | 		static Array<AudioCodec> codecs; | ||||||
| @@ -81,10 +81,14 @@ namespace ehs | |||||||
|  |  | ||||||
| 		UInt_64 GetSampleCount() const; | 		UInt_64 GetSampleCount() const; | ||||||
|  |  | ||||||
|  | 		UInt_8 GetFrameSize() const; | ||||||
|  |  | ||||||
| 		UInt_64 GetSize() const; | 		UInt_64 GetSize() const; | ||||||
|  |  | ||||||
| 		float GetLength() const; | 		float GetLength() const; | ||||||
|  |  | ||||||
|  | 		Byte* GetFrame(UInt_64 frameIndex) const; | ||||||
|  |  | ||||||
| 		Array<Byte> FrameAsMono(UInt_64 frameIndex) const; | 		Array<Byte> FrameAsMono(UInt_64 frameIndex) const; | ||||||
|  |  | ||||||
| 		Array<Byte> FrameAsStereo(UInt_64 frameIndex) const; | 		Array<Byte> FrameAsStereo(UInt_64 frameIndex) const; | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ namespace ehs | |||||||
| { | { | ||||||
| 	class Audio; | 	class Audio; | ||||||
|  |  | ||||||
| 	class AudioCodec | 	class EHS_LIB_IO AudioCodec | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -5,5 +5,5 @@ | |||||||
| #if defined(EHS_OS_WINDOWS) | #if defined(EHS_OS_WINDOWS) | ||||||
| #include "AudioDevice_W32.h" | #include "AudioDevice_W32.h" | ||||||
| #elif defined(EHS_OS_LINUX) | #elif defined(EHS_OS_LINUX) | ||||||
| #include "AudioDevice_ALSA.h" | #include "AudioDevice_PW.h" | ||||||
| #endif | #endif | ||||||
| @@ -1,46 +0,0 @@ | |||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "ehs/EHS.h" |  | ||||||
| #include "BaseAudioDevice.h" |  | ||||||
|  |  | ||||||
| #include <alsa/asoundlib.h> |  | ||||||
|  |  | ||||||
| namespace ehs |  | ||||||
| { |  | ||||||
| 	class AudioDevice : public BaseAudioDevice |  | ||||||
| 	{ |  | ||||||
| 	private: |  | ||||||
| 		snd_pcm_t* hdl; |  | ||||||
|  |  | ||||||
| 	public: |  | ||||||
| 		~AudioDevice() override; |  | ||||||
|  |  | ||||||
| 		AudioDevice(); |  | ||||||
|  |  | ||||||
| 		AudioDevice(AudioDevice&& device) noexcept; |  | ||||||
|  |  | ||||||
| 		AudioDevice(const AudioDevice& device); |  | ||||||
|  |  | ||||||
| 		AudioDevice& operator=(AudioDevice&& device) noexcept; |  | ||||||
|  |  | ||||||
| 		AudioDevice& operator=(const AudioDevice& device); |  | ||||||
|  |  | ||||||
| 		void Release() override; |  | ||||||
|  |  | ||||||
| 		void OpenStream() override; |  | ||||||
|  |  | ||||||
| 		void CloseStream() override; |  | ||||||
|  |  | ||||||
| 		UInt_64 GetAvailFrames() const override; |  | ||||||
|  |  | ||||||
| 		Byte* Map(UInt_64* offset, UInt_64* frames) override; |  | ||||||
|  |  | ||||||
| 		void UnMap(const UInt_64 offset, const UInt_64 frames) override; |  | ||||||
|  |  | ||||||
| 		bool IsValid() const override; |  | ||||||
|  |  | ||||||
| 		static AudioDevice GetDefault(const AudioDeviceType type); |  | ||||||
|  |  | ||||||
| 		static Array<AudioDevice> Get(const AudioDeviceType type, const AudioDeviceState state); |  | ||||||
| 	}; |  | ||||||
| } |  | ||||||
							
								
								
									
										67
									
								
								include/ehs/io/audio/AudioDevice_PW.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								include/ehs/io/audio/AudioDevice_PW.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/EHS.h" | ||||||
|  | #include "BaseAudioDevice.h" | ||||||
|  |  | ||||||
|  | #include <pipewire/pipewire.h> | ||||||
|  | #include <pipewire/loop.h> | ||||||
|  | #include <pipewire/context.h> | ||||||
|  | #include <pipewire/stream.h> | ||||||
|  | #include <spa/param/audio/format-utils.h> | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO AudioDevice final : public BaseAudioDevice | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		static Array<AudioDevice> devices; | ||||||
|  | 		static AudioDevice defOut; | ||||||
|  | 		static AudioDevice defIn; | ||||||
|  |  | ||||||
|  | 		UInt_32 id; | ||||||
|  | 		Str_8 name; | ||||||
|  | 		pw_loop *loop; | ||||||
|  | 		pw_context *context; | ||||||
|  | 		pw_core *core; | ||||||
|  | 		pw_stream *input; | ||||||
|  | 		pw_stream *output; | ||||||
|  |  | ||||||
|  | 		static void RegistryEventGlobal(void *data, UInt_32 id, UInt_32 permissions, const char *type, UInt_32 version, const spa_dict *props); | ||||||
|  |  | ||||||
|  | 		static void RegistryEventGlobalRemove(void *data, UInt_32 id); | ||||||
|  |  | ||||||
|  | 		static void OnParamChanged(void *data, UInt_32 id, const spa_pod *param); | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		~AudioDevice() override; | ||||||
|  |  | ||||||
|  | 		AudioDevice(); | ||||||
|  |  | ||||||
|  | 		AudioDevice(AudioDevice&& device) noexcept; | ||||||
|  |  | ||||||
|  | 		AudioDevice(const AudioDevice& device); | ||||||
|  |  | ||||||
|  | 		AudioDevice& operator=(AudioDevice&& device) noexcept; | ||||||
|  |  | ||||||
|  | 		AudioDevice& operator=(const AudioDevice& device); | ||||||
|  |  | ||||||
|  | 		void OpenStream() override; | ||||||
|  |  | ||||||
|  | 		void CloseStream() override; | ||||||
|  |  | ||||||
|  | 		UInt_64 SendStream(const void *data, UInt_64 size) override; | ||||||
|  |  | ||||||
|  | 		UInt_64 ReceiveStream(void *data, UInt_64 size) override; | ||||||
|  |  | ||||||
|  | 		bool IsStreaming() const override; | ||||||
|  |  | ||||||
|  | 		bool IsValid() const override; | ||||||
|  |  | ||||||
|  | 		static AudioDevice GetDefault(AudioDeviceType type); | ||||||
|  |  | ||||||
|  | 		static Array<AudioDevice> Get(AudioDeviceType type, AudioDeviceState state); | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		Str_8 GetCategory() const; | ||||||
|  | 	}; | ||||||
|  | } | ||||||
| @@ -12,7 +12,7 @@ struct IMMDevice; | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class AudioDevice : public BaseAudioDevice | 	class EHS_LIB_IO AudioDevice final : public BaseAudioDevice | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		IMMDevice* hdl; | 		IMMDevice* hdl; | ||||||
| @@ -33,17 +33,13 @@ namespace ehs | |||||||
|  |  | ||||||
| 		AudioDevice& operator=(const AudioDevice& device); | 		AudioDevice& operator=(const AudioDevice& device); | ||||||
|  |  | ||||||
| 		void Release() override; |  | ||||||
|  |  | ||||||
| 		void OpenStream() override; | 		void OpenStream() override; | ||||||
|  |  | ||||||
| 		void CloseStream() override; | 		void CloseStream() override; | ||||||
|  |  | ||||||
| 		UInt_64 GetAvailFrames() const override; | 		UInt_64 SendStream(const void *data, UInt_64 outFrameSize) override; | ||||||
|  |  | ||||||
| 		Byte* Map(UInt_64* offset, UInt_64* frames) override; | 		UInt_64 ReceiveStream(void *data, UInt_64 inFrameSize) override; | ||||||
|  |  | ||||||
| 		void UnMap(const UInt_64 offset, const UInt_64 frames) override; |  | ||||||
|  |  | ||||||
| 		Str_32 GetInterfaceName_32() const; | 		Str_32 GetInterfaceName_32() const; | ||||||
|  |  | ||||||
| @@ -57,10 +53,12 @@ namespace ehs | |||||||
|  |  | ||||||
| 		Str_8 GetName_8() const; | 		Str_8 GetName_8() const; | ||||||
|  |  | ||||||
|  |         bool IsStreaming() const override; | ||||||
|  |  | ||||||
| 		bool IsValid() const override; | 		bool IsValid() const override; | ||||||
|  |  | ||||||
| 		static AudioDevice GetDefault(const AudioDeviceType type); | 		static AudioDevice GetDefault(AudioDeviceType type); | ||||||
|  |  | ||||||
| 		static Array<AudioDevice> Get(const AudioDeviceType type, const AudioDeviceState state); | 		static Array<AudioDevice> Get(AudioDeviceType type, AudioDeviceState state); | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,8 +10,8 @@ namespace ehs | |||||||
| { | { | ||||||
| 	enum class AudioDeviceType | 	enum class AudioDeviceType | ||||||
| 	{ | 	{ | ||||||
| 		OUTPUT = 0x0, |  | ||||||
| 		INPUT = 0x1, | 		INPUT = 0x1, | ||||||
|  | 		OUTPUT = 0x0, | ||||||
| 		ALL = 0x2 | 		ALL = 0x2 | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -23,18 +23,17 @@ namespace ehs | |||||||
| 		UNPLUGGED = 0x8 | 		UNPLUGGED = 0x8 | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|     class BaseAudioDevice |     class EHS_LIB_IO BaseAudioDevice | ||||||
|     { |     { | ||||||
| 	protected: | 	protected: | ||||||
|         AudioDeviceType type; |         AudioDeviceType type; | ||||||
| 		DataType dataType; | 		DataType dataType; | ||||||
| 		UInt_16 bitDepth; | 		UInt_16 byteDepth; | ||||||
| 		UInt_32 sampleRate; | 		UInt_32 sampleRate; | ||||||
| 		UInt_32 channels; | 		UInt_32 channels; | ||||||
| 		UInt_32 period; | 		UInt_32 period; | ||||||
| 		UInt_32 latency; | 		UInt_32 latency; | ||||||
| 		UInt_64 maxFrames; | 		UInt_64 maxFrames; | ||||||
| 		bool streaming; |  | ||||||
|  |  | ||||||
|     public: |     public: | ||||||
|         virtual ~BaseAudioDevice() = default; |         virtual ~BaseAudioDevice() = default; | ||||||
| @@ -45,21 +44,21 @@ namespace ehs | |||||||
|  |  | ||||||
|         BaseAudioDevice& operator=(const BaseAudioDevice& device); |         BaseAudioDevice& operator=(const BaseAudioDevice& device); | ||||||
|  |  | ||||||
| 		virtual void Release(); |  | ||||||
|  |  | ||||||
| 		virtual void OpenStream(); | 		virtual void OpenStream(); | ||||||
|  |  | ||||||
| 		virtual void CloseStream(); | 		virtual void CloseStream(); | ||||||
|  |  | ||||||
| 		virtual UInt_64 GetAvailFrames() const; |     	virtual UInt_64 SendStream(const void *data, UInt_64 size); | ||||||
|  |  | ||||||
| 		virtual Byte* Map(UInt_64* offset, UInt_64* frames); |     	virtual UInt_64 ReceiveStream(void *data, UInt_64 size); | ||||||
|  |  | ||||||
| 		virtual void UnMap(const UInt_64 offset, const UInt_64 frames); | 		void BridgeStreams(BaseAudioDevice *input, UInt_64 frameBufferSize); | ||||||
|  |  | ||||||
|  |     	void BridgeStreams(UInt_64 frameBufferSize); | ||||||
|  |  | ||||||
|         AudioDeviceType GetType() const; |         AudioDeviceType GetType() const; | ||||||
|  |  | ||||||
| 		void SetDataType(const DataType newDataType); | 		void SetDataType(DataType newDataType); | ||||||
|  |  | ||||||
| 		DataType GetDataType() const; | 		DataType GetDataType() const; | ||||||
|  |  | ||||||
| @@ -67,39 +66,39 @@ namespace ehs | |||||||
|  |  | ||||||
| 		UInt_16 GetBitDepth() const; | 		UInt_16 GetBitDepth() const; | ||||||
|  |  | ||||||
| 		void SetSampleRate(const UInt_32 newSampleRate); | 		void SetSampleRate(UInt_32 newSampleRate); | ||||||
|  |  | ||||||
| 		UInt_32 GetSampleRate() const; | 		UInt_32 GetSampleRate() const; | ||||||
|  |  | ||||||
| 		void SetChannels(const UInt_32 newChannels); | 		void SetChannels(UInt_32 newChannels); | ||||||
|  |  | ||||||
| 		UInt_16 GetChannels() const; | 		UInt_16 GetChannels() const; | ||||||
|  |  | ||||||
| 		UInt_32 GetFrameSize() const; | 		UInt_32 GetFrameSize() const; | ||||||
|  |  | ||||||
| 		void SetPeriod(const UInt_32 newPeriod); | 		void SetPeriod(UInt_32 newPeriod); | ||||||
|  |  | ||||||
| 		UInt_32 GetPeriod() const; | 		UInt_32 GetPeriod() const; | ||||||
|  |  | ||||||
| 		void SetLatency(const UInt_32 newLatency); | 		void SetLatency(UInt_32 newLatency); | ||||||
|  |  | ||||||
| 		UInt_32 GetLatency() const; | 		UInt_32 GetLatency() const; | ||||||
|  |  | ||||||
| 		UInt_64 GetMaxFrames() const; | 		UInt_64 GetMaxFrames() const; | ||||||
|  |  | ||||||
| 		bool IsStreaming() const; | 		virtual bool IsStreaming() const; | ||||||
|  |  | ||||||
| 		virtual bool IsValid() const; | 		virtual bool IsValid() const; | ||||||
|  |  | ||||||
| 		/// Retrieves the default audio input/output device. | 		/// Retrieves the default audio input/output device. | ||||||
| 		/// @param [in] type The audio device type to retrieve. | 		/// @param [in] type The audio device type to retrieve. | ||||||
| 		/// @param [out] device The default audio device. | 		/// @param [out] device The default audio device. | ||||||
| 		static BaseAudioDevice GetDefault(const AudioDeviceType type); | 		static BaseAudioDevice GetDefault(AudioDeviceType type); | ||||||
|  |  | ||||||
| 		/// Retrieves a list of audio input/output devices. | 		/// Retrieves a list of audio input/output devices. | ||||||
| 		/// @param [in] type The audio device type to retrieve. | 		/// @param [in] type The audio device type to retrieve. | ||||||
| 		/// @param [in] state The audio device state to retrieve. | 		/// @param [in] state The audio device state to retrieve. | ||||||
| 		/// @param [out] devices The list of audio devices. | 		/// @param [out] devices The list of audio devices. | ||||||
| 		static Array<BaseAudioDevice> Get(const AudioDeviceType type, const AudioDeviceState state); | 		static Array<BaseAudioDevice> Get(AudioDeviceType type, AudioDeviceState state); | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| @@ -5,27 +5,33 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Button | 	class EHS_LIB_IO Button | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 name; |  | ||||||
| 		UInt_32 hash; | 		UInt_32 hash; | ||||||
|  | 		Str_8 name; | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
| 		Button(); | 		Button(); | ||||||
|  |  | ||||||
| 		Button(const Str_8& name); | 		Button(Str_8 name); | ||||||
|  |  | ||||||
|  | 		Button(Button &&key) noexcept; | ||||||
|  |  | ||||||
| 		Button(const Button &key); | 		Button(const Button &key); | ||||||
|  |  | ||||||
|  | 		Button &operator=(Button &&key) noexcept; | ||||||
|  |  | ||||||
| 		Button &operator=(const Button &key); | 		Button &operator=(const Button &key); | ||||||
|  |  | ||||||
| 		bool operator==(const Button &key) const; | 		bool operator==(const Button &key) const; | ||||||
|  |  | ||||||
| 		bool operator!=(const Button &key) const; | 		bool operator!=(const Button &key) const; | ||||||
|  |  | ||||||
|  | 		UInt_32 GetHash() const; | ||||||
|  |  | ||||||
| 		Str_8 GetName() const; | 		Str_8 GetName() const; | ||||||
|  |  | ||||||
| 		UInt_32 GetHash() const; | 		bool IsValid() const; | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ namespace ehs | |||||||
| 		TOUCHED | 		TOUCHED | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class ButtonState | 	class EHS_LIB_IO ButtonState | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Button button; | 		Button button; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class HID | 	class EHS_LIB_IO HID | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		UInt_8 type; | 		UInt_8 type; | ||||||
| @@ -15,11 +15,15 @@ namespace ehs | |||||||
| 		Str_8 name; | 		Str_8 name; | ||||||
| 		UInt_64 id; | 		UInt_64 id; | ||||||
| 		Array<ButtonState> states; | 		Array<ButtonState> states; | ||||||
|  | 		Button lastState; | ||||||
|  | 		float heldTime; | ||||||
|  | 		float activateTime; | ||||||
|  | 		bool active; | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
| 		HID(); | 		HID(); | ||||||
|  |  | ||||||
| 		HID(const UInt_8 type, Str_8 name, const UInt_64 id); | 		HID(UInt_8 type, Str_8 name, UInt_64 id); | ||||||
|  |  | ||||||
| 		HID(HID&& hid) noexcept; | 		HID(HID&& hid) noexcept; | ||||||
|  |  | ||||||
| @@ -33,11 +37,11 @@ namespace ehs | |||||||
|  |  | ||||||
| 		bool operator!=(const HID& other) const; | 		bool operator!=(const HID& other) const; | ||||||
|  |  | ||||||
| 		bool operator==(const UInt_64 otherId) const; | 		bool operator==(UInt_64 otherId) const; | ||||||
|  |  | ||||||
| 		bool operator!=(const UInt_64 otherId) const; | 		bool operator!=(UInt_64 otherId) const; | ||||||
|  |  | ||||||
| 		virtual void Poll(); | 		virtual void Poll(float delta); | ||||||
|  |  | ||||||
| 		UInt_8 GetType() const; | 		UInt_8 GetType() const; | ||||||
|  |  | ||||||
| @@ -71,6 +75,10 @@ namespace ehs | |||||||
|  |  | ||||||
| 		const ButtonState* IsUp() const; | 		const ButtonState* IsUp() const; | ||||||
|  |  | ||||||
|  | 		const ButtonState *IsPressed(const Button &button); | ||||||
|  |  | ||||||
|  | 		const ButtonState *GetPressed(); | ||||||
|  |  | ||||||
| 		void ButtonDown(const Button& button); | 		void ButtonDown(const Button& button); | ||||||
|  |  | ||||||
| 		void ButtonUp(const Button& button); | 		void ButtonUp(const Button& button); | ||||||
| @@ -87,5 +95,11 @@ namespace ehs | |||||||
| 		bool AddState(const ButtonState& state); | 		bool AddState(const ButtonState& state); | ||||||
|  |  | ||||||
| 		ButtonState* GetState(const Button& button); | 		ButtonState* GetState(const Button& button); | ||||||
|  |  | ||||||
|  | 		bool TickHoldTime(float delta); | ||||||
|  |  | ||||||
|  | 		void ResetTime(); | ||||||
|  |  | ||||||
|  | 		void TickActivateTime(float delta); | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Input | 	class EHS_LIB_IO Input | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Array<InputHandler*> handlers; | 		Array<InputHandler*> handlers; | ||||||
|   | |||||||
| @@ -5,11 +5,13 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class InputHandler | 	class EHS_LIB_IO InputHandler | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		UInt_64 hashId; | 		UInt_64 hashId; | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|  | 		UInt_64 start; | ||||||
|  | 		UInt_64 delta; | ||||||
|  |  | ||||||
| 	protected: | 	protected: | ||||||
| 		Array<HID*> devices; | 		Array<HID*> devices; | ||||||
| @@ -29,9 +31,9 @@ namespace ehs | |||||||
|  |  | ||||||
| 		InputHandler& operator=(const InputHandler& ih); | 		InputHandler& operator=(const InputHandler& ih); | ||||||
|  |  | ||||||
| 		bool operator==(const UInt_64 otherHashId); | 		bool operator==(const UInt_64 otherHashId) const; | ||||||
|  |  | ||||||
| 		bool operator!=(const UInt_64 otherHashId); | 		bool operator!=(const UInt_64 otherHashId) const; | ||||||
|  |  | ||||||
| 		virtual bool Initialize(); | 		virtual bool Initialize(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Keyboard : public HID | 	class EHS_LIB_IO Keyboard : public HID | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 		Keyboard(); | 		Keyboard(); | ||||||
| @@ -23,7 +23,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		Keyboard& operator=(const Keyboard& hid); | 		Keyboard& operator=(const Keyboard& hid); | ||||||
|  |  | ||||||
| 		void Poll() override; | 		void Poll(float delta) override; | ||||||
|  |  | ||||||
| 		Keyboard* Clone() const override; | 		Keyboard* Clone() const override; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Mouse : public HID | 	class EHS_LIB_IO Mouse : public HID | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		friend class Input; | 		friend class Input; | ||||||
| @@ -19,7 +19,7 @@ namespace ehs | |||||||
| 	public: | 	public: | ||||||
| 		Mouse(); | 		Mouse(); | ||||||
|  |  | ||||||
| 		Mouse(Str_8 name, const UInt_64 id); | 		Mouse(Str_8 name, UInt_64 id); | ||||||
|  |  | ||||||
| 		Mouse(Mouse&& hid) noexcept = default; | 		Mouse(Mouse&& hid) noexcept = default; | ||||||
|  |  | ||||||
| @@ -29,7 +29,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		Mouse& operator=(const Mouse& hid); | 		Mouse& operator=(const Mouse& hid); | ||||||
|  |  | ||||||
| 		void Poll() override; | 		void Poll(float delta) override; | ||||||
|  |  | ||||||
| 		void SetDelta(const Vec2_s32& newDelta); | 		void SetDelta(const Vec2_s32& newDelta); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ namespace ehs | |||||||
| 		NEAREST_NEIGHBOR | 		NEAREST_NEIGHBOR | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class Img : public BaseObj | 	class EHS_LIB_IO Img : public BaseObj | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		static Array<ImgCodec> codecs; | 		static Array<ImgCodec> codecs; | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ namespace ehs | |||||||
| 	typedef bool (*EncodeImgCb)(const ImgCodec* const, Serializer<UInt_64>&, const Img*); | 	typedef bool (*EncodeImgCb)(const ImgCodec* const, Serializer<UInt_64>&, const Img*); | ||||||
| 	typedef bool (*DecodeImgCb)(const ImgCodec* const, Serializer<UInt_64>&, Img*); | 	typedef bool (*DecodeImgCb)(const ImgCodec* const, Serializer<UInt_64>&, Img*); | ||||||
|  |  | ||||||
| 	class ImgCodec | 	class EHS_LIB_IO ImgCodec | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class PNG | 	class EHS_LIB_IO PNG | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class PNG_Chunk | 	class EHS_LIB_IO PNG_Chunk | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class AnimBone | 	class EHS_LIB_IO AnimBone | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		UInt_8 boneId; | 		UInt_8 boneId; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Animation | 	class EHS_LIB_IO Animation | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		UInt_64 hashId; | 		UInt_64 hashId; | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class Bone | 	class EHS_LIB_IO Bone | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		UInt_64 hashName; | 		UInt_64 hashName; | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class KeyFrame | 	class EHS_LIB_IO KeyFrame | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		float num; | 		float num; | ||||||
|   | |||||||
| @@ -15,7 +15,7 @@ namespace ehs | |||||||
| 		EHM | 		EHM | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class Mdl : public BaseObj | 	class EHS_LIB_IO Mdl : public BaseObj | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		static Array<MdlCodec> codecs; | 		static Array<MdlCodec> codecs; | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ namespace ehs | |||||||
| 	typedef bool (*EnocdeMdlCb)(const MdlCodec*, Serializer<UInt_64>&, const Mdl*); | 	typedef bool (*EnocdeMdlCb)(const MdlCodec*, Serializer<UInt_64>&, const Mdl*); | ||||||
| 	typedef bool (*DecodeMdlCb)(const MdlCodec*, Serializer<UInt_64>&, Mdl*); | 	typedef bool (*DecodeMdlCb)(const MdlCodec*, Serializer<UInt_64>&, Mdl*); | ||||||
|  |  | ||||||
| 	class MdlCodec | 	class EHS_LIB_IO MdlCodec | ||||||
| 	{ | 	{ | ||||||
| 	private: | 	private: | ||||||
| 		Str_8 id; | 		Str_8 id; | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
|     class Mesh final : public BaseObj |     class EHS_LIB_IO Mesh final : public BaseObj | ||||||
|     { |     { | ||||||
|     protected: |     protected: | ||||||
| 		UInt_64 hashId; | 		UInt_64 hashId; | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ namespace ehs | |||||||
| 		INVALID | 		INVALID | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class PropertyChange | 	class EHS_LIB_IO PropertyChange | ||||||
| 	{ | 	{ | ||||||
| 	public: | 	public: | ||||||
| 		ChangeType type; | 		ChangeType type; | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								include/ehs/io/socket/BaseDNS.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								include/ehs/io/socket/BaseDNS.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "Socket.h" | ||||||
|  | #include "ehs/Str.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO BaseDNS | ||||||
|  | 	{ | ||||||
|  | 	public: | ||||||
|  | 		static Str_8 Resolve(IP type, const Str_8 &hostname); | ||||||
|  |  | ||||||
|  | 		/// Resolves a hostname to an ip address. | ||||||
|  | 		/// @param [in] hostname The given hostname to resolve. | ||||||
|  | 		/// @returns The resulting ip address. | ||||||
|  | 		static Str_8 Resolve(const Str_8 &hostname); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										68
									
								
								include/ehs/io/socket/BaseICMP.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								include/ehs/io/socket/BaseICMP.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/Serializer.h" | ||||||
|  | #include "ehs/Types.h" | ||||||
|  | #include "ehs/io/socket/Socket.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	struct ICMP_Header | ||||||
|  | 	{ | ||||||
|  | 		UInt_8 type; | ||||||
|  | 		UInt_8 code; | ||||||
|  | 		UInt_16 checksum; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	struct ICMP_EchoRequest | ||||||
|  | 	{ | ||||||
|  | 		UInt_16 id; | ||||||
|  | 		UInt_16 sequence; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	class BaseICMP | ||||||
|  | 	{ | ||||||
|  | 	private: | ||||||
|  | 		IP version; | ||||||
|  |  | ||||||
|  | 	public: | ||||||
|  | 		virtual ~BaseICMP() = default; | ||||||
|  |  | ||||||
|  | 		BaseICMP(); | ||||||
|  |  | ||||||
|  | 		BaseICMP(IP version); | ||||||
|  |  | ||||||
|  | 		BaseICMP(BaseICMP &&icmp) noexcept; | ||||||
|  |  | ||||||
|  | 		BaseICMP(const BaseICMP &icmp); | ||||||
|  |  | ||||||
|  | 		BaseICMP &operator=(BaseICMP &&icmp) noexcept; | ||||||
|  |  | ||||||
|  | 		BaseICMP &operator=(const BaseICMP &icmp); | ||||||
|  |  | ||||||
|  | 		virtual void Release(); | ||||||
|  |  | ||||||
|  | 		UInt_64 Send(const Str_8 &address, ICMP_Header header, const Byte *data, UInt_64 size); | ||||||
|  |  | ||||||
|  | 		UInt_64 Receive(Str_8 &address, ICMP_Header &header, Serializer<UInt_64> &data); | ||||||
|  |  | ||||||
|  | 		void SendEchoRequest(const Str_8 &address, ICMP_EchoRequest er, const Byte *data, UInt_64 size); | ||||||
|  |  | ||||||
|  | 		virtual void SetReceiveTimeout(UInt_64 timeout); | ||||||
|  |  | ||||||
|  | 		IP GetVersion() const; | ||||||
|  |  | ||||||
|  | 		virtual bool IsValid() const; | ||||||
|  |  | ||||||
|  | 	protected: | ||||||
|  | 		static UInt_16 ComputeChecksumV4(UInt_16 *buffer, Size length); | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		virtual UInt_64 SendV6(const Str_8 &address, ICMP_Header header, const Byte *data, UInt_64 size); | ||||||
|  |  | ||||||
|  | 		virtual UInt_64 SendV4(const Str_8 &address, ICMP_Header header, const Byte *data, UInt_64 size); | ||||||
|  |  | ||||||
|  | 		virtual UInt_64 ReceiveV6(Str_8 &address, ICMP_Header &header, Serializer<UInt_64> &data) const; | ||||||
|  |  | ||||||
|  | 		virtual UInt_64 ReceiveV4(Str_8 &address, ICMP_Header &header, Serializer<UInt_64> &data) const; | ||||||
|  | 	}; | ||||||
|  | } | ||||||
| @@ -9,10 +9,10 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class BaseTCP | 	class EHS_LIB_IO BaseTCP | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		AddrType addrType; | 		IP ip; | ||||||
| 		Str_8 localAddr; | 		Str_8 localAddr; | ||||||
| 		UInt_16 localPort; | 		UInt_16 localPort; | ||||||
| 		Str_8 remoteHostName; | 		Str_8 remoteHostName; | ||||||
| @@ -35,7 +35,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		/// Properly initializes the socket. | 		/// Properly initializes the socket. | ||||||
| 		/// @param [in] type The ip version to initialize the socket with. | 		/// @param [in] type The ip version to initialize the socket with. | ||||||
| 		BaseTCP(AddrType addrType); | 		BaseTCP(IP ip); | ||||||
|  |  | ||||||
| 		BaseTCP(BaseTCP&& tcp) noexcept; | 		BaseTCP(BaseTCP&& tcp) noexcept; | ||||||
|  |  | ||||||
| @@ -104,7 +104,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		/// Retrieves the sockets ip version. | 		/// Retrieves the sockets ip version. | ||||||
| 		/// @returns The ip version. | 		/// @returns The ip version. | ||||||
| 		AddrType GetAddressType() const; | 		IP GetAddressType() const; | ||||||
|  |  | ||||||
| 		/// Retrieves the bound ip address. | 		/// Retrieves the bound ip address. | ||||||
| 		/// @returns The ip address. | 		/// @returns The ip address. | ||||||
| @@ -146,6 +146,10 @@ namespace ehs | |||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
| 		virtual bool IsBlocking() const = 0; | 		virtual bool IsBlocking() const = 0; | ||||||
|  |  | ||||||
|  | 		virtual void SetIPv6Only(bool value) = 0; | ||||||
|  |  | ||||||
|  | 		virtual bool IsIPv6Only() const = 0; | ||||||
|  |  | ||||||
| 		/// Retrieves whether or not this socket was initialized. | 		/// Retrieves whether or not this socket was initialized. | ||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
| 		virtual bool IsValid() const = 0; | 		virtual bool IsValid() const = 0; | ||||||
|   | |||||||
| @@ -6,12 +6,10 @@ | |||||||
|  |  | ||||||
| namespace ehs | namespace ehs | ||||||
| { | { | ||||||
| 	class BaseUDP | 	class EHS_LIB_IO BaseUDP | ||||||
| 	{ | 	{ | ||||||
| 	protected: | 	protected: | ||||||
| 		AddrType type; | 		Endpoint localEndpoint; | ||||||
| 		Str_8 address; |  | ||||||
| 		UInt_16 port; |  | ||||||
| 		bool bound; | 		bool bound; | ||||||
|  |  | ||||||
| 	public: | 	public: | ||||||
| @@ -22,7 +20,7 @@ namespace ehs | |||||||
|  |  | ||||||
| 		/// Properly initializes the socket. | 		/// Properly initializes the socket. | ||||||
| 		/// @param [in] type The ip version to initialize the socket with. | 		/// @param [in] type The ip version to initialize the socket with. | ||||||
| 		BaseUDP(AddrType type); | 		BaseUDP(IP version); | ||||||
|  |  | ||||||
| 		BaseUDP(BaseUDP&& udp) noexcept; | 		BaseUDP(BaseUDP&& udp) noexcept; | ||||||
|  |  | ||||||
| @@ -40,13 +38,13 @@ namespace ehs | |||||||
| 		/// @param [in] address The ip address to bind to. | 		/// @param [in] address The ip address to bind to. | ||||||
| 		/// @param [in] port The port to bind to. | 		/// @param [in] port The port to bind to. | ||||||
| 		/// @note Used for servers. | 		/// @note Used for servers. | ||||||
| 		virtual void Bind(AddrType type, const Str_8& address, UInt_16 port) = 0; | 		virtual void Bind(const Endpoint &endpoint) = 0; | ||||||
|  |  | ||||||
| 		/// Sends data to the endpoint. | 		/// Sends data to the endpoint. | ||||||
| 		/// @param [in] type The ip version of the endpoint. | 		/// @param [in] type The ip version of the endpoint. | ||||||
| 		/// @param [in] address The ip address of the endpoint. | 		/// @param [in] address The ip address of the endpoint. | ||||||
| 		/// @param [in] port The port of the endpoint is bound to. | 		/// @param [in] port The port of the endpoint is bound to. | ||||||
| 		virtual UInt_64 Send(AddrType type, const Str_8& address, UInt_16 port, const Byte* data, UInt_64 size) = 0; | 		virtual UInt_64 Send(const Endpoint &endpoint, const Byte *data, UInt_64 size) = 0; | ||||||
|  |  | ||||||
| 		/// Receives data from the endpoint. | 		/// Receives data from the endpoint. | ||||||
| 		/// @param [out] type The ip version of the endpoint. | 		/// @param [out] type The ip version of the endpoint. | ||||||
| @@ -55,7 +53,7 @@ namespace ehs | |||||||
| 		/// @param [out] data The incoming data from the endpoint. | 		/// @param [out] data The incoming data from the endpoint. | ||||||
| 		/// @param [in] size The max size of the buffer in bytes to store the data. | 		/// @param [in] size The max size of the buffer in bytes to store the data. | ||||||
| 		/// @returns The size of the incoming data in bytes. | 		/// @returns The size of the incoming data in bytes. | ||||||
| 		virtual UInt_64 Receive(AddrType* type, Str_8* address, UInt_16* port, Byte* data, UInt_64 size) = 0; | 		virtual UInt_64 Receive(Endpoint *endpoint, Byte *data, UInt_64 size) = 0; | ||||||
|  |  | ||||||
| 		/// Retrieves whether or not this socket is bound to an ip address and port. | 		/// Retrieves whether or not this socket is bound to an ip address and port. | ||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
| @@ -69,17 +67,11 @@ namespace ehs | |||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
| 		virtual bool IsBlocking() const = 0; | 		virtual bool IsBlocking() const = 0; | ||||||
|  |  | ||||||
| 		/// Retrieves the bound ip version. | 		virtual void SetIPv6Only(bool value) = 0; | ||||||
| 		/// @returns The result. |  | ||||||
| 		AddrType GetLocalAddressType() const; |  | ||||||
|  |  | ||||||
| 		/// Retrieves the bound ip address. | 		virtual bool IsIPv6Only() const = 0; | ||||||
| 		/// @returns The bound ip address. |  | ||||||
| 		Str_8 GetLocalAddress() const; |  | ||||||
|  |  | ||||||
| 		/// Retrieves the bound port. | 		Endpoint GetLocalEndpoint() const; | ||||||
| 		/// @returns The bound port. |  | ||||||
| 		UInt_16 GetLocalPort() const; |  | ||||||
|  |  | ||||||
| 		/// Retrieves whether or not this socket was initialized. | 		/// Retrieves whether or not this socket was initialized. | ||||||
| 		/// @returns The result. | 		/// @returns The result. | ||||||
|   | |||||||
| @@ -1,17 +1,9 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "ehs/EHS.h" | #include "ehs/system/OS.h" | ||||||
| #include "ehs/Str.h" |  | ||||||
| #include "Socket.h" |  | ||||||
|  |  | ||||||
| namespace ehs | #if defined(EHS_OS_WINDOWS) | ||||||
| { | 	#include "DNS_W32.h" | ||||||
|     class DNS | #elif defined(EHS_OS_LINUX) | ||||||
|     { | 	#include "DNS_LNX.h" | ||||||
|     public: | #endif | ||||||
| 		/// Resolves a hostname to an ip address. |  | ||||||
| 		/// @param [in] hostname The given hostname to resolve. |  | ||||||
| 		/// @returns The resulting ip address. |  | ||||||
|         static Str_8 Resolve(const Str_8& hostname); |  | ||||||
|     }; |  | ||||||
| } |  | ||||||
							
								
								
									
										17
									
								
								include/ehs/io/socket/DNS_LNX.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								include/ehs/io/socket/DNS_LNX.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "BaseDNS.h" | ||||||
|  | #include "ehs/EHS.h" | ||||||
|  | #include "ehs/Str.h" | ||||||
|  | #include "Socket.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  |     class EHS_LIB_IO DNS final : public BaseDNS | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |     	static Str_8 Resolve(IP type, const Str_8 &hostname); | ||||||
|  |  | ||||||
|  |         static Str_8 Resolve(const Str_8 &hostname); | ||||||
|  |     }; | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								include/ehs/io/socket/DNS_W32.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								include/ehs/io/socket/DNS_W32.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "BaseDNS.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class EHS_LIB_IO DNS final : public BaseDNS | ||||||
|  | 	{ | ||||||
|  | 	public: | ||||||
|  | 		static Str_8 Resolve(IP type, const Str_8 &hostname); | ||||||
|  |  | ||||||
|  | 		static Str_8 Resolve(const Str_8 &hostname); | ||||||
|  | 	}; | ||||||
|  | } | ||||||
							
								
								
									
										95
									
								
								include/ehs/io/socket/EHC.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								include/ehs/io/socket/EHC.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,95 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/io/socket/ehc/NetEnc.h" | ||||||
|  | #include "ehs/Array.h" | ||||||
|  | #include "Socket.h" | ||||||
|  | #include "UDP.h" | ||||||
|  |  | ||||||
|  | namespace ehs | ||||||
|  | { | ||||||
|  | 	class NetServerCh; | ||||||
|  | 	class NetClientCh; | ||||||
|  | 	class NetEnd; | ||||||
|  | 	class EHC; | ||||||
|  |  | ||||||
|  | 	class EHC | ||||||
|  |     { | ||||||
|  |     private: | ||||||
|  | 		friend class NetEnc; | ||||||
|  | 		friend class NetChannel; | ||||||
|  | 		friend class NetServerCh; | ||||||
|  | 		friend class NetClientCh; | ||||||
|  | 		friend class NetEnd; | ||||||
|  |  | ||||||
|  | 		static const Version version; | ||||||
|  |  | ||||||
|  | 		UDP udp; | ||||||
|  | 		Byte* buffer; | ||||||
|  | 		UInt_32 bufferSize; | ||||||
|  | 		UInt_64 lastTSC; | ||||||
|  | 		float delta; | ||||||
|  | 		Array<NetEnc *> encryptions; | ||||||
|  | 		Array<NetServerCh *> servers; | ||||||
|  | 		Array<NetClientCh *> clients; | ||||||
|  |  | ||||||
|  |     public: | ||||||
|  |         ~EHC(); | ||||||
|  |  | ||||||
|  | 		EHC(IP version = IP::V6); | ||||||
|  |  | ||||||
|  | 		EHC(EHC &&sock) noexcept; | ||||||
|  |  | ||||||
|  | 		EHC(const EHC &sock); | ||||||
|  |  | ||||||
|  | 		EHC &operator=(EHC&& sock) noexcept; | ||||||
|  |  | ||||||
|  | 		EHC &operator=(const EHC &sock); | ||||||
|  |  | ||||||
|  |         void Initialize(); | ||||||
|  |  | ||||||
|  |         void Release(); | ||||||
|  |  | ||||||
|  |         void Bind(const Endpoint &endpoint); | ||||||
|  |  | ||||||
|  | 		void Poll(); | ||||||
|  |  | ||||||
|  |         bool IsInitialized() const; | ||||||
|  |  | ||||||
|  | 		Endpoint GetLocalEndpoint() const; | ||||||
|  |  | ||||||
|  |         bool IsBound() const; | ||||||
|  |  | ||||||
|  | 		static Version GetVersion(); | ||||||
|  |  | ||||||
|  | 		bool AddEncryption(NetEnc *enc); | ||||||
|  |  | ||||||
|  | 		bool HasServer(UInt_64 serverId) const; | ||||||
|  |  | ||||||
|  | 		bool HasServer(const Str_8& serverName) const; | ||||||
|  |  | ||||||
|  | 		bool AddServer(NetServerCh *server); | ||||||
|  |  | ||||||
|  | 		NetServerCh *GetServer(UInt_64 serverId) const; | ||||||
|  |  | ||||||
|  | 		NetServerCh *GetServer(const Str_8& serverName) const; | ||||||
|  |  | ||||||
|  | 		bool HasClient(UInt_64 clientId) const; | ||||||
|  |  | ||||||
|  | 		bool HasClient(const Str_8& clientName) const; | ||||||
|  |  | ||||||
|  | 		bool AddClient(NetClientCh *channel); | ||||||
|  |  | ||||||
|  | 		NetClientCh *GetClient(UInt_64 clientId) const; | ||||||
|  |  | ||||||
|  | 		NetClientCh *GetClient(const Str_8& clientName) const; | ||||||
|  |  | ||||||
|  | 	private: | ||||||
|  | 		bool HasEncryption(UInt_64 encId) const; | ||||||
|  |  | ||||||
|  | 		bool HasEncryption(const Str_8& encName) const; | ||||||
|  |  | ||||||
|  | 		NetEnc* GetEncryption(UInt_64 encId) const; | ||||||
|  |  | ||||||
|  | 		NetEnc* GetEncryption(const Str_8& encName) const; | ||||||
|  |     }; | ||||||
|  | } | ||||||
							
								
								
									
										9
									
								
								include/ehs/io/socket/ICMP.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								include/ehs/io/socket/ICMP.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "ehs/system/OS.h" | ||||||
|  |  | ||||||
|  | #ifdef EHS_OS_WINDOWS | ||||||
|  | 	#include "ICMP_W32.h" | ||||||
|  | #else | ||||||
|  | 	#include "ICMP_LNX.h" | ||||||
|  | #endif | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user