Compare commits
	
		
			4 Commits
		
	
	
		
			NetChannel
			...
			fd452f6643
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| fd452f6643 | |||
| 389fa61fba | |||
| a67197766e | |||
| ae414c5c99 | 
| @@ -35,8 +35,6 @@ jobs: | ||||
|           mv build/Release/EHS_Dyn.dll bin | ||||
|           mv build/Release/StrToHash.exe bin | ||||
|           mv build/Release/zlib1.dll bin | ||||
|           mv build/Release/libcrypto-3-x64.dll bin | ||||
|           mv build/Release/libssl-3-x64.dll bin | ||||
|           mkdir lib | ||||
|           mv build/Release/EHS_Stc.lib lib | ||||
|           mv build/Release/EHS_Dyn.lib lib | ||||
| @@ -67,7 +65,7 @@ jobs: | ||||
|  | ||||
|       - name: Installing Dependencies | ||||
|         run: | | ||||
|           sudo pacman -S --noconfirm doxygen ninja zip libxcb xcb-util-cursor pipewire | ||||
|           sudo pacman -S --noconfirm doxygen zip alsa-lib libxcb xcb-util-cursor pipewire | ||||
|  | ||||
|       - name: Generating Documentation | ||||
|         run: | | ||||
| @@ -76,7 +74,7 @@ jobs: | ||||
|       - name: Building/Compiling/Installing Project | ||||
|         run: | | ||||
|           cd ${{ gitea.workspace }} | ||||
|           cmake -G Ninja -DCMAKE_BUILD_TYPE=Release -DLINUX_WINDOW_SYSTEM:STRING=XCB . | ||||
|           cmake -DCMAKE_BUILD_TYPE=Release -DLINUX_WINDOW_SYSTEM:STRING=XCB . | ||||
|           cmake --build . --config Release | ||||
|           cmake --install . | ||||
|  | ||||
| @@ -112,7 +110,7 @@ jobs: | ||||
|         uses: actions/checkout@v3 | ||||
|  | ||||
|       - name: Installing Dependencies | ||||
|         run: sudo apt install -y doxygen ninja-build zip libxcb1-dev libxcb-xinput-dev libxcb-cursor-dev libpipewire-0.3-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 | ||||
|         run: | | ||||
| @@ -121,7 +119,7 @@ jobs: | ||||
|       - name: Building/Compiling/Installing Project | ||||
|         run: | | ||||
|           cd ${{ gitea.workspace }} | ||||
|           cmake -G Ninja -DCMAKE_BUILD_TYPE=Release -DLINUX_WINDOW_SYSTEM:STRING=XCB . | ||||
|           cmake -DCMAKE_BUILD_TYPE=Release -DLINUX_WINDOW_SYSTEM:STRING=XCB . | ||||
|           cmake --build . --config Release | ||||
|           cmake --install . | ||||
|  | ||||
|   | ||||
							
								
								
									
										26
									
								
								Assembly.def
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								Assembly.def
									
									
									
									
									
								
							| @@ -1,26 +0,0 @@ | ||||
| LIBRARY EHS_Dyn | ||||
| EXPORTS | ||||
|     ?GenerateSeed_u64@HRNG@ehs@@SA_KXZ | ||||
|     ?Generate_u64@HRNG@ehs@@SA_K_K0@Z | ||||
|     ?Generate_u64@HRNG@ehs@@SA_KXZ | ||||
|     ?GenerateSeed_s64@HRNG@ehs@@SA_JXZ | ||||
|     ?Generate_s64@HRNG@ehs@@SA_J_J0@Z | ||||
|     ?Generate_s64@HRNG@ehs@@SA_JXZ | ||||
|     ?GenerateSeed_u32@HRNG@ehs@@SAIXZ | ||||
|     ?Generate_u32@HRNG@ehs@@SAIII@Z | ||||
|     ?Generate_u32@HRNG@ehs@@SAIXZ | ||||
|     ?GenerateSeed_s32@HRNG@ehs@@SAHXZ | ||||
|     ?Generate_s32@HRNG@ehs@@SAHHH@Z | ||||
|     ?Generate_s32@HRNG@ehs@@SAHXZ | ||||
|     ?GenerateSeed_u16@HRNG@ehs@@SAIXZ | ||||
|     ?Generate_u16@HRNG@ehs@@SAGGG@Z | ||||
|     ?Generate_u16@HRNG@ehs@@SAGXZ | ||||
|     ?GenerateSeed_s16@HRNG@ehs@@SAFXZ | ||||
|     ?Generate_s16@HRNG@ehs@@SAFFF@Z | ||||
|     ?Generate_s16@HRNG@ehs@@SAFXZ | ||||
|     ?GenerateSeed_u8@HRNG@ehs@@SAEXZ | ||||
|     ?Generate_u8@HRNG@ehs@@SAEEE@Z | ||||
|     ?Generate_u8@HRNG@ehs@@SAEXZ | ||||
|     ?GenerateSeed_s8@HRNG@ehs@@SACXZ | ||||
|     ?Generate_s8@HRNG@ehs@@SACCC@Z | ||||
|     ?Generate_s8@HRNG@ehs@@SACXZ | ||||
| @@ -1,4 +1,4 @@ | ||||
| cmake_minimum_required(VERSION 3.30.4) | ||||
| cmake_minimum_required(VERSION 3.25.1) | ||||
|  | ||||
| set(IS_OS_WINDOWS FALSE) | ||||
| set(IS_OS_LINUX FALSE) | ||||
| @@ -11,8 +11,6 @@ set(IS_ARCH_ARM FALSE) | ||||
|  | ||||
| project(EHS CXX C) | ||||
|  | ||||
| set(CMAKE_VERBOSE_MAKEFILE ON) | ||||
|  | ||||
| if (${CMAKE_HOST_SYSTEM_NAME} STREQUAL "Windows") | ||||
|     set(IS_OS_WINDOWS TRUE) | ||||
|     set(USER_HOME_DIRECTORY "$ENV{USERPROFILE}") | ||||
| @@ -53,7 +51,6 @@ set(EHS_SOURCES | ||||
|     src/Color3.cpp include/ehs/Color3.h | ||||
|     src/Version.cpp include/ehs/Version.h | ||||
|     src/Base64.cpp include/ehs/Base64.h | ||||
|     src/SHA256.cpp include/ehs/SHA256.h | ||||
|     src/Data.cpp include/ehs/Data.h | ||||
|     src/Range.cpp include/ehs/Range.h | ||||
|     src/Util.cpp include/ehs/Util.h | ||||
| @@ -100,8 +97,6 @@ set(EHS_SOURCES | ||||
|     include/ehs/system/OS.h | ||||
|     include/ehs/system/Semaphore.h | ||||
|     include/ehs/system/System.h | ||||
|     include/ehs/system/AVX2.h | ||||
|     include/ehs/system/AVX512.h | ||||
|  | ||||
|     src/json/Json.cpp include/ehs/json/Json.h | ||||
|     src/json/JsonBase.cpp include/ehs/json/JsonBase.h | ||||
| @@ -201,8 +196,6 @@ set(EHS_SOURCES | ||||
|     src/io/socket/ehc/NetUtils.cpp | ||||
|     include/ehs/io/socket/BaseICMP.h src/io/socket/BaseICMP.cpp | ||||
|     include/ehs/io/socket/ICMP.h | ||||
|     src/io/socket/QueryVar.cpp include/ehs/io/socket/QueryVar.h | ||||
|     src/io/socket/HeaderVar.cpp include/ehs/io/socket/HeaderVar.h | ||||
| ) | ||||
|  | ||||
| if (IS_OS_WINDOWS) | ||||
| @@ -222,7 +215,6 @@ if (IS_OS_WINDOWS) | ||||
|         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 | ||||
|         src/system/AVX2_MSVC_AMD64.asm src/system/AVX512_MSVC_AMD64.asm | ||||
|     ) | ||||
|  | ||||
| elseif (IS_OS_LINUX) | ||||
| @@ -244,7 +236,7 @@ elseif (IS_OS_LINUX) | ||||
|         include/ehs/io/socket/ICMP_LNX.h src/io/socket/ICMP_LNX.cpp | ||||
|     ) | ||||
|  | ||||
|     set(LINUX_WINDOW_SYSTEM "XCB" CACHE STRING "Linux Window System") | ||||
|     #set(LINUX_WINDOW_SYSTEM "Wayland" CACHE STRING "Linux Window System") | ||||
|  | ||||
|     if (LINUX_WINDOW_SYSTEM STREQUAL "Wayland") | ||||
|         add_compile_definitions(EHS_WS_WAYLAND) | ||||
| @@ -260,14 +252,17 @@ elseif (IS_OS_LINUX) | ||||
|     endif () | ||||
|  | ||||
|     if (IS_ARCH_AMD64) | ||||
|         list(APPEND EHS_SOURCES src/system/CPU_GCC_AMD64.asm src/HRNG_GCC.asm src/Math_GCC_AMD64.asm src/system/AVX2_GCC_AMD64.asm src/system/AVX512_GCC_AMD64.asm) | ||||
|         list(APPEND EHS_SOURCES src/system/CPU_GCC_AMD64.asm src/HRNG_GCC.asm src/Math_GCC_AMD64.asm) | ||||
|     elseif (IS_ARCH_ARM64) | ||||
|         list(APPEND EHS_SOURCES src/system/CPU_ARM64.cpp src/system/CPU_GCC_AARCH64.s src/HRNG_ARM64.cpp src/Math_GCC_ARM64.s src/system/AVX2_AARCH64.cpp src/system/AVX512_AARCH64.cpp) | ||||
|         list(APPEND EHS_SOURCES src/system/CPU_ARM64.cpp src/HRNG_ARM64.cpp src/Math_GCC_ARM64.s) | ||||
|     endif () | ||||
| endif() | ||||
|  | ||||
| #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fPIC") | ||||
| #message("${CMAKE_CXX_FLAGS}") | ||||
|  | ||||
| add_library(EHS_Stc STATIC ${EHS_SOURCES}) | ||||
| add_library(EHS_Dyn SHARED ${EHS_SOURCES} Assembly.def) | ||||
| add_library(EHS_Dyn SHARED ${EHS_SOURCES}) | ||||
| add_executable(StrToHash src/StrToHash.cpp) | ||||
|  | ||||
| target_compile_definitions(EHS_Dyn PRIVATE EHS_LIB_EXPORT) | ||||
| @@ -328,6 +323,6 @@ elseif (IS_OS_LINUX) | ||||
|         target_link_libraries(StrToHash xcb xcb-cursor xcb-xfixes xcb-xinput) | ||||
|     endif () | ||||
|  | ||||
|     target_link_libraries(EHS_Dyn z pipewire-0.3) | ||||
|     target_link_libraries(StrToHash z EHS_Stc) | ||||
|     target_link_libraries(EHS_Dyn z asound pipewire-0.3) | ||||
|     target_link_libraries(StrToHash z asound EHS_Stc) | ||||
| endif () | ||||
| @@ -38,8 +38,6 @@ This project does not fully follow the C++ standard. | ||||
| - Asynchronous Task System | ||||
| - URI Parsing | ||||
| - USB (WIP) | ||||
| - Base64 | ||||
| - SHA256 | ||||
|  | ||||
| ### Supported Architectures | ||||
| - AMD64 | ||||
|   | ||||
| @@ -8,26 +8,17 @@ namespace ehs | ||||
| 	class EHS_LIB_IO Base64 | ||||
| 	{ | ||||
| 	private: | ||||
| 		static constexpr UInt_8 asciiUrl[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"; | ||||
| 		static constexpr UInt_8 ascii[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; | ||||
| 		static const char ascii[]; | ||||
| 		 | ||||
| 	public: | ||||
| 		static Str_8 EncodeURL(const Str_8 &input); | ||||
|  | ||||
| 		static Str_8 Encode(const Str_8 &input); | ||||
| 		 | ||||
| 		static Str_8 DecodeURL(const Str_8 &input); | ||||
|  | ||||
| 		static Str_8 Decode(const Str_8 &input); | ||||
| 		 | ||||
| 	private: | ||||
| 		static UInt_8 FindURL(const UInt_8 &c); | ||||
| 		static char Find(char c); | ||||
| 	 | ||||
| 		static UInt_8 Find(const UInt_8 &c); | ||||
|  | ||||
| 		static bool IsBase64URL(const UInt_8 &c); | ||||
|  | ||||
| 		static bool IsBase64(const UInt_8 &c); | ||||
| 		static bool IsBase64(char c); | ||||
| 		 | ||||
| 	}; | ||||
| } | ||||
| @@ -5,7 +5,7 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class HRNG | ||||
|     class EHS_LIB_IO HRNG | ||||
|     { | ||||
|     public: | ||||
| 		static UInt_64 GenerateSeed_u64(); | ||||
|   | ||||
| @@ -63,7 +63,7 @@ namespace ehs | ||||
|         /// @param [in] tags The tags to associate this log with. | ||||
| 		/// @param [in] code The unique code to use. | ||||
|         /// @param [in] msg Detailed information about what happened. | ||||
| 		Log(LogType type, const Str_8 &tags, UInt_64 code, 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. | ||||
|         /// @param [in] tags The tags to associate this log with. | ||||
| @@ -134,20 +134,20 @@ namespace ehs | ||||
|  | ||||
| #ifndef EHS_LOG_INT | ||||
| 	#ifdef EHS_DEBUG | ||||
| 		#define EHS_LOG_INT(type, code, msg) ehs::Log::Raise(ehs::Log(type, ehs::Str_8(ehs::GetAcronym_8()) + ", " + EHS_FILE + ", " + EHS_FUNC + ", " + ehs::Str_8::FromNum((ehs::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 | ||||
| 		#define EHS_LOG_INT(type, code, msg) ehs::Log::Raise(ehs::Log(type, ehs::Str_8(ehs::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 | ||||
|  | ||||
| #ifndef EHS_LOG | ||||
| 	#ifdef EHS_DEBUG | ||||
| 		#define EHS_LOG(type, code, msg) ehs::Log::Raise(ehs::Log(type, ehs::Str_8(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 | ||||
| 		#define EHS_LOG(type, code, msg) ehs::Log::Raise(ehs::Log(type, ehs::Str_8(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 | ||||
|  | ||||
| #ifndef EHS_LOG_SUCCESS | ||||
| 	#define EHS_LOG_SUCCESS() ehs::Log::Raise({}) | ||||
| #define EHS_LOG_SUCCESS() ehs::Log::Raise({}) | ||||
| #endif | ||||
| @@ -1,59 +0,0 @@ | ||||
| #pragma once | ||||
| #include "Types.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class EHS_LIB_IO SHA256 | ||||
|     { | ||||
|     private: | ||||
|         static UInt_32 ROTR(UInt_32 x, UInt_32 n); | ||||
|  | ||||
|         static UInt_32 CH(UInt_32 x, UInt_32 y, UInt_32 z); | ||||
|  | ||||
|         static UInt_32 MAJ(UInt_32 x, UInt_32 y, UInt_32 z); | ||||
|  | ||||
|         static UInt_32 EP0(UInt_32 x); | ||||
|  | ||||
|         static UInt_32 EP1(UInt_32 x); | ||||
|  | ||||
|         static UInt_32 SIG0(UInt_32 x); | ||||
|  | ||||
|         static UInt_32 SIG1(UInt_32 x); | ||||
|  | ||||
|         static constexpr UInt_32 k[64] = { | ||||
|             0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, | ||||
|             0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, | ||||
|             0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, | ||||
|             0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, | ||||
|             0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, | ||||
|             0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, | ||||
|             0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, | ||||
|             0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2 | ||||
|         }; | ||||
|  | ||||
|         UInt_32 state[8]; | ||||
|         UInt_64 bitLen; | ||||
|         Byte data[64]; | ||||
|         UInt_64 dataLen; | ||||
|  | ||||
|     public: | ||||
|         SHA256(); | ||||
|  | ||||
|         SHA256(SHA256 &&other) noexcept; | ||||
|  | ||||
|         SHA256(const SHA256 &other); | ||||
|  | ||||
|         SHA256 &operator=(SHA256 &&other) noexcept; | ||||
|  | ||||
|         SHA256 &operator=(const SHA256 &other); | ||||
|  | ||||
|         void Update(const Byte *data, UInt_64 len); | ||||
|  | ||||
|         void Final(Byte hash[32]); | ||||
|  | ||||
|         void Hash(const Byte *data, UInt_64 len, Byte hash[32]); | ||||
|  | ||||
|     private: | ||||
|         void Transform(const Byte data[64]); | ||||
|     }; | ||||
| } | ||||
| @@ -48,11 +48,8 @@ namespace ehs | ||||
| 		/// @param [in] str The C-style string. | ||||
| 		/// @param [in] size The size of the given C-style string. | ||||
| 		Str(const T* const str, const N size) | ||||
| 			: size(size), data(nullptr) | ||||
| 			: size((size) ? size : Len(str)), data(nullptr) | ||||
| 		{ | ||||
|         	if (!size) | ||||
|         		return; | ||||
|  | ||||
| 			data = new T[this->size + 1]; | ||||
|  | ||||
|             Util::Copy(data, str, Size(true)); | ||||
| @@ -917,10 +914,10 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		/// Splits a string into a Vector with the given separator. | ||||
| 		/// @param [in] delimeter The given string as the separator. | ||||
| 		/// @param [in] ide The given string as the separator. | ||||
| 		/// @param [in] max The max amount of times to split the string. | ||||
| 		/// @returns The resulting string object. | ||||
| 		Vector<Str<T, N>, N> Split(const Str<T, N>& delimeter, const N max = 0) const | ||||
| 		Vector<Str<T, N>, N> Split(const Str<T, N>& ide, const N max = 0) const | ||||
| 		{ | ||||
| 			Vector<Str<T, N>, N> result(0, 5); | ||||
|  | ||||
| @@ -928,9 +925,9 @@ namespace ehs | ||||
|  | ||||
| 			for (N i = 0, c = 0; i < size; ++i) | ||||
| 			{ | ||||
| 				if (data[i] == delimeter[c]) | ||||
| 				if (data[i] == ide[c]) | ||||
| 				{ | ||||
| 					if (++c == delimeter.Size()) | ||||
| 					if (++c == ide.Size()) | ||||
| 					{ | ||||
| 					    N r = i - (c - 1) - b; | ||||
| 					    if (!r) | ||||
| @@ -958,17 +955,17 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		/// Removes all instances of the ide. | ||||
| 		/// @param [in] delimeter The string to look for. | ||||
| 		/// @param [in] ide The string to look for. | ||||
| 		/// @returns The resulting string object. | ||||
| 		Str<T, N> RemoveAll(const Str<T, N>& delimeter) const | ||||
| 		Str<T, N> RemoveAll(const Str<T, N>& ide) const | ||||
| 		{ | ||||
| 			Str<T, N> result(size); | ||||
|  | ||||
| 			for (N i = 0, b = 0, c = 0; i < size; ++i) | ||||
| 			{ | ||||
| 				if (data[i] == delimeter[c]) | ||||
| 				if (data[i] == ide[c]) | ||||
| 				{ | ||||
| 					if (++c == delimeter.Size()) | ||||
| 					if (++c == ide.Size()) | ||||
| 						c = 0; | ||||
| 				} | ||||
| 				else | ||||
| @@ -987,18 +984,18 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		/// Replaces all instances of ide with the replacer. | ||||
| 		/// @param [in] delimeter The string to look for. | ||||
| 		/// @param [in] ide The string to look for. | ||||
| 		/// @param [in] replacer The string placed. | ||||
| 		/// @returns The resulting string object. | ||||
| 		Str ReplaceAll(const Str& delimeter, const Str& replacer) const | ||||
| 		Str ReplaceAll(const Str& ide, const Str& replacer) const | ||||
| 		{ | ||||
| 			Str<T, N> result; | ||||
|  | ||||
| 			for (N i = 0, b = 0; i < size; ++i) | ||||
| 			{ | ||||
| 				if (data[i] == delimeter[b]) | ||||
| 				if (data[i] == ide[b]) | ||||
| 				{ | ||||
| 					if (++b == delimeter.Size()) | ||||
| 					if (++b == ide.Size()) | ||||
| 					{ | ||||
| 						result.Push(replacer); | ||||
| 						b = 0; | ||||
| @@ -1014,20 +1011,20 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		/// Finds the first instance of the given string object. | ||||
| 		/// @param [in] delimeter The string to look for. | ||||
| 		/// @param [in] ide The string to look for. | ||||
| 		/// @param [out] index The index of the string found. Can be a nullptr. | ||||
| 		/// @param [in] pattern The search pattern for optimization. | ||||
| 		/// @param [in] result What index to return where the first instance is found. | ||||
| 		/// @returns The index where the instance was found with the result varying from the result parameter. | ||||
| 		bool Find(const Str<T, N> &delimeter, N* const index = nullptr, const SearchPattern pattern = SearchPattern::LEFT_RIGHT, const IndexResult result = IndexResult::BEGINNING) const | ||||
| 		bool Find(const Str<T, N> &ide, N* const index = nullptr, const SearchPattern pattern = SearchPattern::LEFT_RIGHT, const IndexResult result = IndexResult::BEGINNING) const | ||||
| 		{ | ||||
| 			if (pattern == SearchPattern::LEFT_RIGHT) | ||||
| 			{ | ||||
| 				for (N i = 0, c = 0; i < size; ++i) | ||||
| 				{ | ||||
| 					if (data[i] == delimeter[c]) | ||||
| 					if (data[i] == ide[c]) | ||||
| 					{ | ||||
| 						if (++c == delimeter.Size()) | ||||
| 						if (++c == ide.Size()) | ||||
| 						{ | ||||
| 							if (result == IndexResult::BEGINNING) | ||||
|                             { | ||||
| @@ -1049,16 +1046,16 @@ namespace ehs | ||||
| 			} | ||||
| 			else if (pattern == SearchPattern::RIGHT_LEFT) | ||||
| 			{ | ||||
| 				for (N i = size, c = delimeter.Size(); i > 0; --i) | ||||
| 				for (N i = size, c = ide.Size(); i > 0; --i) | ||||
| 				{ | ||||
| 					if (data[i - 1] == delimeter[c - 1]) | ||||
| 					if (data[i - 1] == ide[c - 1]) | ||||
| 					{ | ||||
| 						if (--c == 0) | ||||
| 						{ | ||||
| 							if (result == IndexResult::BEGINNING) | ||||
|                             { | ||||
|                                 if (index) | ||||
|                                     *index = i - (delimeter.Size() - 1); | ||||
|                                     *index = i - (ide.Size() - 1); | ||||
|  | ||||
|                                 return true; | ||||
|                             } | ||||
| @@ -1078,18 +1075,18 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		/// Checks if the current string contains the given ide. | ||||
| 		/// @param [in] delimeter The given ide to check for. | ||||
| 		/// @param [in] ide The given ide to check for. | ||||
| 		/// @param [in] pattern The search pattern to use. | ||||
| 		/// @returns True if the current string does contain the ide. | ||||
|         bool Contains(const Str<T, N>& delimeter, const SearchPattern pattern = SearchPattern::LEFT_RIGHT) const | ||||
|         bool Contains(const Str<T, N>& ide, const SearchPattern pattern = SearchPattern::LEFT_RIGHT) const | ||||
|         { | ||||
|             if (pattern == SearchPattern::LEFT_RIGHT) | ||||
|             { | ||||
|                 for (N i = 0, c = 0; i < size; ++i) | ||||
|                 { | ||||
|                     if (data[i] == delimeter[c]) | ||||
|                     if (data[i] == ide[c]) | ||||
|                     { | ||||
|                         if (++c == delimeter.Size()) | ||||
|                         if (++c == ide.Size()) | ||||
|                         { | ||||
|                             return true; | ||||
|                         } | ||||
| @@ -1098,9 +1095,9 @@ namespace ehs | ||||
|             } | ||||
|             else if (pattern == SearchPattern::RIGHT_LEFT) | ||||
|             { | ||||
|                 for (N i = size, c = delimeter.Size(); i > 0; --i) | ||||
|                 for (N i = size, c = ide.Size(); i > 0; --i) | ||||
|                 { | ||||
|                     if (data[i - 1] == delimeter[c - 1]) | ||||
|                     if (data[i - 1] == ide[c - 1]) | ||||
|                     { | ||||
|                         if (--c == 0) | ||||
|                         { | ||||
| @@ -1113,54 +1110,6 @@ namespace ehs | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
| 		Vector<Str> ParseArgs() const | ||||
|         { | ||||
| 	        Vector<Str> args; | ||||
|         	T *quoteStart = nullptr; | ||||
|         	T *spaceStart = nullptr; | ||||
|  | ||||
|         	for (T *i = data; i <= data + size; ++i) | ||||
|         	{ | ||||
|         		if (*i == '\"' && !spaceStart) | ||||
|         		{ | ||||
|         			if (quoteStart) | ||||
|         			{ | ||||
|         				args.Push(Str(quoteStart, i - quoteStart)); | ||||
|         				quoteStart = nullptr; | ||||
|         			} | ||||
|         			else | ||||
|         			{ | ||||
|         				if (i + 1 < &data[size - 1]) | ||||
|         					quoteStart = i + 1; | ||||
|         				else | ||||
|         					args.Push({}); | ||||
|         			} | ||||
|         		} | ||||
|         		else if (*i == ' ' && !quoteStart) | ||||
|         		{ | ||||
|         			if (spaceStart) | ||||
|         			{ | ||||
|         				args.Push(Str(spaceStart, i - spaceStart)); | ||||
|         				spaceStart = i + 1; | ||||
|         			} | ||||
|         			else | ||||
|         			{ | ||||
|         				if (i + 1 < &data[size - 1]) | ||||
|         					spaceStart = i + 1; | ||||
|         				else | ||||
|         					args.Push({}); | ||||
|         			} | ||||
|         		} | ||||
|         	} | ||||
|  | ||||
|         	if (quoteStart) | ||||
|         		args.Push(Str(quoteStart, &data[size - 1] - (quoteStart - 1))); | ||||
|         	else if (spaceStart) | ||||
|         		args.Push(Str(spaceStart, &data[size - 1] - (spaceStart - 1))); | ||||
|  | ||||
|         	return args; | ||||
|         } | ||||
|  | ||||
| 		/// Checks if the string represents a number. Must not have any alphabetical characters. | ||||
| 		/// @returns The result. | ||||
| 		bool IsNum() const | ||||
|   | ||||
| @@ -392,7 +392,7 @@ namespace ehs | ||||
| 			{ | ||||
| 				if (stride) | ||||
| 				{ | ||||
| 					rawSize = (this->size + size) / stride * stride; | ||||
| 					rawSize = (this->size + size()) / stride * stride; | ||||
| 					if ((this->size + size) % stride) | ||||
| 						rawSize += stride; | ||||
| 				} | ||||
| @@ -403,7 +403,7 @@ namespace ehs | ||||
|  | ||||
| 				T* result = new T[rawSize]; | ||||
|  | ||||
| 				for (N i = 0; i < this->size; ++i) | ||||
| 				for (N i = 0; i < size; ++i) | ||||
| 					result[i] = std::move(data[i]); | ||||
|  | ||||
| 				delete[] data; | ||||
|   | ||||
| @@ -25,7 +25,6 @@ namespace ehs | ||||
| 		pw_core *core; | ||||
| 		pw_stream *input; | ||||
| 		pw_stream *output; | ||||
| 		spa_hook paramsHook; | ||||
|  | ||||
| 		static void RegistryEventGlobal(void *data, UInt_32 id, UInt_32 permissions, const char *type, UInt_32 version, const spa_dict *props); | ||||
|  | ||||
|   | ||||
| @@ -21,8 +21,6 @@ namespace ehs | ||||
| 		bool active; | ||||
|  | ||||
| 	public: | ||||
| 		virtual ~HID() = default; | ||||
|  | ||||
| 		HID(); | ||||
|  | ||||
| 		HID(UInt_8 type, Str_8 name, UInt_64 id); | ||||
|   | ||||
| @@ -10,7 +10,7 @@ namespace ehs | ||||
| 	{ | ||||
| 	private: | ||||
| 		Array<InputHandler*> handlers; | ||||
| 		bool initialized; | ||||
| 		bool initalized; | ||||
|  | ||||
| 	public: | ||||
| 		~Input(); | ||||
| @@ -31,13 +31,13 @@ namespace ehs | ||||
|  | ||||
| 		void Poll(); | ||||
|  | ||||
| 		bool HasHandler(UInt_64 hashId) const; | ||||
| 		bool HasHandler(const UInt_64 hashId) const; | ||||
|  | ||||
| 		bool HasHandler(const Str_8& id) const; | ||||
|  | ||||
| 		bool AddHandler(InputHandler* handler); | ||||
|  | ||||
| 		const InputHandler* GetHandler(UInt_64 hashId) const; | ||||
| 		const InputHandler* GetHandler(const UInt_64 hashId) const; | ||||
|  | ||||
| 		const InputHandler* GetHandler(const Str_8& id) const; | ||||
|  | ||||
|   | ||||
| @@ -31,9 +31,9 @@ namespace ehs | ||||
|  | ||||
| 		InputHandler& operator=(const InputHandler& ih); | ||||
|  | ||||
| 		bool operator==(UInt_64 otherHashId) const; | ||||
| 		bool operator==(const UInt_64 otherHashId) const; | ||||
|  | ||||
| 		bool operator!=(UInt_64 otherHashId) const; | ||||
| 		bool operator!=(const UInt_64 otherHashId) const; | ||||
|  | ||||
| 		virtual bool Initialize(); | ||||
|  | ||||
| @@ -47,13 +47,13 @@ namespace ehs | ||||
|  | ||||
| 		void ResetAllStates(); | ||||
|  | ||||
| 		bool HasDevice(UInt_64 id) const; | ||||
| 		bool HasDevice(const UInt_64 id) const; | ||||
|  | ||||
| 		bool AddDevice(HID* device); | ||||
|  | ||||
| 		HID* GetDevice(UInt_64 id) const; | ||||
| 		HID* GetDevice(const UInt_64 id) const; | ||||
|  | ||||
| 		HID* GetDeviceByType(UInt_8 type) const; | ||||
| 		HID* GetDeviceByType(const UInt_8 type) const; | ||||
|  | ||||
| 		virtual bool IsInitialized() const; | ||||
| 	}; | ||||
|   | ||||
| @@ -27,92 +27,92 @@ namespace ehs | ||||
|  | ||||
| 		Keyboard* Clone() const override; | ||||
|  | ||||
| 		static inline const Button Unknown = Button("Unknown"); | ||||
| 		static inline const Button Escape = Button("Escape Button"); | ||||
| 		static inline const Button Backspace = Button("Backspace Button"); | ||||
| 		static inline const Button Enter = Button("Enter Button"); | ||||
| 		static inline const Button LShift = Button("Left Shift Button"); | ||||
| 		static inline const Button RShift = Button("Right Shift Button"); | ||||
| 		static inline const Button LAlt = Button("Left Alt Button"); | ||||
| 		static inline const Button RAlt = Button("Right Alt Button"); | ||||
| 		static inline const Button LCtrl = Button("Left Control Button"); | ||||
| 		static inline const Button RCtrl = Button("Right Button"); | ||||
| 		static inline const Button Space = Button("Space Button"); | ||||
| 		static inline const Button A = Button("A Button"); | ||||
| 		static inline const Button B = Button("B Button"); | ||||
| 		static inline const Button C = Button("C Button"); | ||||
| 		static inline const Button D = Button("D Button"); | ||||
| 		static inline const Button E = Button("E Button"); | ||||
| 		static inline const Button F = Button("F Button"); | ||||
| 		static inline const Button G = Button("G Button"); | ||||
| 		static inline const Button H = Button("H Button"); | ||||
| 		static inline const Button I = Button("I Button"); | ||||
| 		static inline const Button J = Button("J Button"); | ||||
| 		static inline const Button K = Button("K Button"); | ||||
| 		static inline const Button L = Button("L Button"); | ||||
| 		static inline const Button M = Button("M Button"); | ||||
| 		static inline const Button N = Button("N Button"); | ||||
| 		static inline const Button O = Button("O Button"); | ||||
| 		static inline const Button P = Button("P Button"); | ||||
| 		static inline const Button Q = Button("Q Button"); | ||||
| 		static inline const Button R = Button("R Button"); | ||||
| 		static inline const Button S = Button("S Button"); | ||||
| 		static inline const Button T = Button("T Button"); | ||||
| 		static inline const Button U = Button("U Button"); | ||||
| 		static inline const Button V = Button("V Button"); | ||||
| 		static inline const Button W = Button("W Button"); | ||||
| 		static inline const Button X = Button("X Button"); | ||||
| 		static inline const Button Y = Button("Y Button"); | ||||
| 		static inline const Button Z = Button("Z Button"); | ||||
| 		static inline const Button One = Button("One Button"); | ||||
| 		static inline const Button Two = Button("Two Button"); | ||||
| 		static inline const Button Three = Button("Three Button"); | ||||
| 		static inline const Button Four = Button("Four Button"); | ||||
| 		static inline const Button Five = Button("Five Button"); | ||||
| 		static inline const Button Six = Button("Six Button"); | ||||
| 		static inline const Button Seven = Button("Seven Button"); | ||||
| 		static inline const Button Eight = Button("Eight Button"); | ||||
| 		static inline const Button Nine = Button("Nine Button"); | ||||
| 		static inline const Button Zero = Button("Zero Button"); | ||||
| 		static inline const Button Minus = Button("Minus Button"); | ||||
| 		static inline const Button Equals = Button("Equals Button"); | ||||
| 		static inline const Button Tilde = Button("Tilde Button"); | ||||
| 		static inline const Button BackSlash = Button("Back Slash Button"); | ||||
| 		static inline const Button LeftSquareBracket = Button("Left Square Bracket Button"); | ||||
| 		static inline const Button RightSquareBracket = Button("Right Square Bracket Button"); | ||||
| 		static inline const Button SemiColon = Button("Semi Colon Button"); | ||||
| 		static inline const Button Apostrophe = Button("Apostrophe Button"); | ||||
| 		static inline const Button Comma = Button("Comma Button"); | ||||
| 		static inline const Button Period = Button("Period Button"); | ||||
| 		static inline const Button ForwardSlash = Button("Forward Slash Button"); | ||||
| 		static inline const Button F1 = Button("Function One Button"); | ||||
| 		static inline const Button F2 = Button("Function Two Button"); | ||||
| 		static inline const Button F3 = Button("Function Three Button"); | ||||
| 		static inline const Button F4 = Button("Function Four Button"); | ||||
| 		static inline const Button F5 = Button("Function Five Button"); | ||||
| 		static inline const Button F6 = Button("Function Six Button"); | ||||
| 		static inline const Button F7 = Button("Function Seven Button"); | ||||
| 		static inline const Button F8 = Button("Function Eight Button"); | ||||
| 		static inline const Button F9 = Button("Function Nine Button"); | ||||
| 		static inline const Button F10 = Button("Function Ten Button"); | ||||
| 		static inline const Button F11 = Button("Function Eleven Button"); | ||||
| 		static inline const Button F12 = Button("Function Twelve Button"); | ||||
| 		static inline const Button F13 = Button("Function Thirteen Button"); | ||||
| 		static inline const Button F14 = Button("Function Fourteen Button"); | ||||
| 		static inline const Button F15 = Button("Function Fifteen Button"); | ||||
| 		static inline const Button F16 = Button("Function Sixteen Button"); | ||||
| 		static inline const Button F17 = Button("Function Seventeen Button"); | ||||
| 		static inline const Button F18 = Button("Function Eighteen Button"); | ||||
| 		static inline const Button F19 = Button("Function Nineteen Button"); | ||||
| 		static inline const Button F20 = Button("Function Twenty Button"); | ||||
| 		static inline const Button F21 = Button("Function Twenty One Button"); | ||||
| 		static inline const Button F22 = Button("Function Twenty Two Button"); | ||||
| 		static inline const Button F23 = Button("Function Twenty Three Button"); | ||||
| 		static inline const Button F24 = Button("Function Twenty Four Button"); | ||||
| 		static inline const Button Left = Button("Left Button"); | ||||
| 		static inline const Button Right = Button("Right Button"); | ||||
| 		static inline const Button Up = Button("Up Button"); | ||||
| 		static inline const Button Down = Button("Down Button"); | ||||
| 		static const Button Unknown; | ||||
| 		static const Button Escape; | ||||
| 		static const Button Backspace; | ||||
| 		static const Button Enter; | ||||
| 		static const Button LShift; | ||||
| 		static const Button RShift; | ||||
| 		static const Button LAlt; | ||||
| 		static const Button RAlt; | ||||
| 		static const Button LCtrl; | ||||
| 		static const Button RCtrl; | ||||
| 		static const Button Space; | ||||
| 		static const Button A; | ||||
| 		static const Button B; | ||||
| 		static const Button C; | ||||
| 		static const Button D; | ||||
| 		static const Button E; | ||||
| 		static const Button F; | ||||
| 		static const Button G; | ||||
| 		static const Button H; | ||||
| 		static const Button I; | ||||
| 		static const Button J; | ||||
| 		static const Button K; | ||||
| 		static const Button L; | ||||
| 		static const Button M; | ||||
| 		static const Button N; | ||||
| 		static const Button O; | ||||
| 		static const Button P; | ||||
| 		static const Button Q; | ||||
| 		static const Button R; | ||||
| 		static const Button S; | ||||
| 		static const Button T; | ||||
| 		static const Button U; | ||||
| 		static const Button V; | ||||
| 		static const Button W; | ||||
| 		static const Button X; | ||||
| 		static const Button Y; | ||||
| 		static const Button Z; | ||||
| 		static const Button One; | ||||
| 		static const Button Two; | ||||
| 		static const Button Three; | ||||
| 		static const Button Four; | ||||
| 		static const Button Five; | ||||
| 		static const Button Six; | ||||
| 		static const Button Seven; | ||||
| 		static const Button Eight; | ||||
| 		static const Button Nine; | ||||
| 		static const Button Zero; | ||||
| 		static const Button Minus; | ||||
| 		static const Button Equals; | ||||
| 		static const Button Tilde; | ||||
| 		static const Button BackSlash; | ||||
| 		static const Button LeftSquareBracket; | ||||
| 		static const Button RightSquareBracket; | ||||
| 		static const Button SemiColon; | ||||
| 		static const Button Apostrophe; | ||||
| 		static const Button Comma; | ||||
| 		static const Button Period; | ||||
| 		static const Button ForwardSlash; | ||||
| 		static const Button F1; | ||||
| 		static const Button F2; | ||||
| 		static const Button F3; | ||||
| 		static const Button F4; | ||||
| 		static const Button F5; | ||||
| 		static const Button F6; | ||||
| 		static const Button F7; | ||||
| 		static const Button F8; | ||||
| 		static const Button F9; | ||||
| 		static const Button F10; | ||||
| 		static const Button F11; | ||||
| 		static const Button F12; | ||||
| 		static const Button F13; | ||||
| 		static const Button F14; | ||||
| 		static const Button F15; | ||||
| 		static const Button F16; | ||||
| 		static const Button F17; | ||||
| 		static const Button F18; | ||||
| 		static const Button F19; | ||||
| 		static const Button F20; | ||||
| 		static const Button F21; | ||||
| 		static const Button F22; | ||||
| 		static const Button F23; | ||||
| 		static const Button F24; | ||||
| 		static const Button Left; | ||||
| 		static const Button Right; | ||||
| 		static const Button Up; | ||||
| 		static const Button Down; | ||||
|  | ||||
| 		static Button TranslateScanCode(UInt_32 code); | ||||
|  | ||||
|   | ||||
| @@ -37,18 +37,18 @@ namespace ehs | ||||
|  | ||||
| 		Mouse* Clone() const override; | ||||
|  | ||||
| 		static inline const Button Unknown = Button("Unknown Button"); | ||||
| 		static inline const Button LMB = Button("Left Mouse Button"); | ||||
| 		static inline const Button MMB = Button("Middle Mouse Button"); | ||||
| 		static inline const Button RMB = Button("Right Mouse Button"); | ||||
| 		static inline const Button Four = Button("Four Button"); | ||||
| 		static inline const Button Five = Button("Five Button"); | ||||
|         static inline const Button ScrollUp = Button("Scroll Up Button"); | ||||
|         static inline const Button ScrollDown = Button("Scroll Down Button"); | ||||
| 		static inline const Button ScrollLeft = Button("Scroll Left Button"); | ||||
| 		static inline const Button ScrollRight = Button("Scroll Right Button"); | ||||
|         static inline const Button Back = Button("Back Button"); | ||||
|         static inline const Button Forward = Button("Forward Button"); | ||||
| 		static const Button Unknown; | ||||
| 		static const Button LMB; | ||||
| 		static const Button MMB; | ||||
| 		static const Button RMB; | ||||
| 		static const Button Four; | ||||
| 		static const Button Five; | ||||
|         static const Button ScrollUp; | ||||
|         static const Button ScrollDown; | ||||
| 		static const Button ScrollLeft; | ||||
| 		static const Button ScrollRight; | ||||
|         static const Button Back; | ||||
|         static const Button Forward; | ||||
|  | ||||
| 		static Button TranslateXCB(const UInt_32 code); | ||||
| 	}; | ||||
|   | ||||
| @@ -24,9 +24,9 @@ namespace ehs | ||||
| 		bool connected; | ||||
|  | ||||
| 	public: | ||||
| 		static constexpr UInt_16 HTTPS_Port = 443; | ||||
| 		static constexpr UInt_16 HTTP_Port = 80; | ||||
| 		static constexpr UInt_16 MaxHeaderSize = 8192; | ||||
| 		static const UInt_16 HTTPS_Port = 443; | ||||
| 		static const UInt_16 HTTP_Port = 80; | ||||
| 		static const UInt_16 MaxHeaderSize = 8192; | ||||
|  | ||||
| 		virtual ~BaseTCP() = default; | ||||
|  | ||||
| @@ -55,7 +55,7 @@ namespace ehs | ||||
| 		/// @param [in] address The ip address to bind to. | ||||
| 		/// @param [in] port The port to bind to. | ||||
| 		/// @note Used for servers. | ||||
| 		virtual void Bind(Str_8 address, const UInt_16 &port) = 0; | ||||
| 		virtual void Bind(const Str_8& address, UInt_16 port) = 0; | ||||
|  | ||||
| 		/// Listens for new incoming connections. | ||||
| 		/// @note Used for servers. | ||||
| @@ -63,13 +63,13 @@ namespace ehs | ||||
|  | ||||
| 		/// Accepts the new incoming connection. | ||||
| 		/// @note Used for servers. | ||||
| 		virtual BaseTCP *Accept() = 0; | ||||
| 		virtual BaseTCP* Accept() = 0; | ||||
|  | ||||
| 		/// Connects to a server at the specified address and port. | ||||
| 		/// @param [in] address The ip address to connect to. | ||||
| 		/// @param [in] port The port to connect to. | ||||
| 		/// @note Used for clients. | ||||
| 		virtual void Connect(Str_8 address, const UInt_16 &port) = 0; | ||||
| 		virtual void Connect(const Str_8& address, UInt_16 port) = 0; | ||||
|  | ||||
| 		/// Sends data to the connected endpoint. | ||||
| 		/// @param [in] buffer The data to send to the endpoint. | ||||
| @@ -150,8 +150,6 @@ namespace ehs | ||||
|  | ||||
| 		virtual bool IsIPv6Only() const = 0; | ||||
|  | ||||
| 		virtual void SetReuse(const bool &enabled) = 0; | ||||
|  | ||||
| 		/// Retrieves whether or not this socket was initialized. | ||||
| 		/// @returns The result. | ||||
| 		virtual bool IsValid() const = 0; | ||||
|   | ||||
| @@ -1,45 +0,0 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "ehs/Str.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class HeaderVar | ||||
|     { | ||||
|     private: | ||||
|         UInt_64 id; | ||||
|         Str_8 name; | ||||
|         Str_8 value; | ||||
|  | ||||
|     public: | ||||
|         HeaderVar(); | ||||
|  | ||||
|         HeaderVar(Str_8 name, Str_8 value); | ||||
|  | ||||
|         HeaderVar(HeaderVar &&other) noexcept; | ||||
|  | ||||
|         HeaderVar(const HeaderVar &other); | ||||
|  | ||||
|         HeaderVar &operator=(HeaderVar &&other) noexcept; | ||||
|  | ||||
|         HeaderVar &operator=(const HeaderVar &other); | ||||
|  | ||||
|         bool operator==(const HeaderVar &other) const; | ||||
|  | ||||
|         bool operator!=(const HeaderVar &other) const; | ||||
|  | ||||
|         bool operator==(const UInt_64 &otherId) const; | ||||
|  | ||||
|         bool operator!=(const UInt_64 &otherId) const; | ||||
|  | ||||
|         UInt_64 GetId() const; | ||||
|  | ||||
|         Str_8 GetName() const; | ||||
|  | ||||
|         Str_8 GetValue() const; | ||||
|  | ||||
|         void SetValue(Str_8 value); | ||||
|  | ||||
|         Str_8 ToStr() const; | ||||
|     }; | ||||
| } | ||||
| @@ -1,45 +0,0 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "ehs/Str.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class QueryVar | ||||
|     { | ||||
|     private: | ||||
|         UInt_64 id; | ||||
|         Str_8 name; | ||||
|         Str_8 value; | ||||
|  | ||||
|     public: | ||||
|         QueryVar(); | ||||
|  | ||||
|         QueryVar(Str_8 name, Str_8 value); | ||||
|  | ||||
|         QueryVar(QueryVar &&other) noexcept; | ||||
|  | ||||
|         QueryVar(const QueryVar &other); | ||||
|  | ||||
|         QueryVar &operator=(QueryVar &&other) noexcept; | ||||
|  | ||||
|         QueryVar &operator=(const QueryVar &other); | ||||
|  | ||||
|         bool operator==(const QueryVar &other) const; | ||||
|  | ||||
|         bool operator!=(const QueryVar &other) const; | ||||
|  | ||||
|         bool operator==(const UInt_64 &otherId) const; | ||||
|  | ||||
|         bool operator!=(const UInt_64 &otherId) const; | ||||
|  | ||||
|         UInt_64 GetId() const; | ||||
|  | ||||
|         Str_8 GetName() const; | ||||
|  | ||||
|         Str_8 GetValue() const; | ||||
|  | ||||
|         void SetValue(Str_8 value); | ||||
|  | ||||
|         Str_8 ToStr() const; | ||||
|     }; | ||||
| } | ||||
| @@ -5,8 +5,6 @@ | ||||
| #include "ehs/Str.h" | ||||
| #include "ehs/json/Json.h" | ||||
| #include "Socket.h" | ||||
| #include "QueryVar.h" | ||||
| #include "HeaderVar.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| @@ -23,8 +21,8 @@ namespace ehs | ||||
| 	private: | ||||
| 		Verb verb; | ||||
| 		Str_8 rsrc; | ||||
| 		Vector<QueryVar> queries; | ||||
| 		Vector<HeaderVar> header; | ||||
| 		Vector<Str_8> queries; | ||||
| 		Vector<Str_8> header; | ||||
| 		ContentType cType; | ||||
| 		Str_8 body; | ||||
| 	 | ||||
| @@ -35,34 +33,25 @@ namespace ehs | ||||
| 	    /// Initializes this request with a given verb and URI resource. | ||||
| 	    /// @param [in] verb The type of request to make. | ||||
| 	    /// @param [in] rsrc The URI endpoint to make the request at. | ||||
| 		Request(const Verb &verb, Str_8 rsrc); | ||||
| 		Request(const Verb verb, const Str_8& rsrc); | ||||
|  | ||||
| 		/// Initializes this request with the raw request data. | ||||
| 		/// @param [in] data The C-style string of the request. | ||||
| 		/// @param [in] size The size of the given C-style string. | ||||
| 		Request(const char *data, const UInt_64 &size); | ||||
| 		Request(const char* data, const UInt_64 size); | ||||
|  | ||||
|         /// Initializes this request with the raw request data. | ||||
|         /// @param [in] data The string of the request. | ||||
| 		Request(const Str_8 &data); | ||||
|  | ||||
| 		/// Moves members from another object of the same type. | ||||
| 		/// @param [in] other The object to move from. | ||||
| 		Request(Request &&other) noexcept; | ||||
| 		Request(const Str_8& data); | ||||
|  | ||||
| 		/// Copies members from another object of the same type. | ||||
| 		/// @param [in] other The object to copy from. | ||||
| 		Request(const Request &other); | ||||
|  | ||||
| 		/// Moves members from another object of the same type. | ||||
| 		/// @param [in] other The object to move from. | ||||
| 		/// @returns The request that has been assigned to. | ||||
| 		Request& operator=(Request &&other) noexcept; | ||||
| 		/// @param [in] req The object to copy from. | ||||
| 		Request(const Request& req) = default; | ||||
|  | ||||
|         /// Copies members from another object of the same type. | ||||
|         /// @param [in] other The object to copy from. | ||||
|         /// @param [in] req The object to copy from. | ||||
|         /// @returns The request that has been assigned to. | ||||
| 		Request& operator=(const Request &other); | ||||
| 		Request& operator=(const Request& req); | ||||
|  | ||||
| 		/// Retrieves the verb for the request. | ||||
| 		/// @returns The result. | ||||
| @@ -70,7 +59,7 @@ namespace ehs | ||||
|  | ||||
| 		/// Sets the content type for the body. | ||||
| 		/// @param [in] cType The content type to use. | ||||
| 		void SetContentType(const ContentType &cType); | ||||
| 		void SetContentType(const ContentType cType); | ||||
|  | ||||
| 		/// Retrieves the content type for the body. | ||||
| 		/// @returns The result. | ||||
| @@ -78,145 +67,75 @@ namespace ehs | ||||
|  | ||||
| 		/// Sets the URI resource. | ||||
| 		/// @param [in] rsrc The resource. | ||||
| 		void SetResource(Str_8 rsrc); | ||||
| 		void SetResource(const Str_8& rsrc); | ||||
|  | ||||
| 		/// Retrieves the URI resource. | ||||
| 		/// @returns The result. | ||||
| 		Str_8 GetResource() const; | ||||
|  | ||||
| 		/// Checks whether a header variable exists using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasQueryVar(const UInt_64 &id) const; | ||||
| 		/// Adds a query variable to the URI. | ||||
| 		/// @param [in] var The variable identifier. | ||||
| 		/// @param [in] value The value of the variable. | ||||
| 		void AddQuery(const Str_8& var, const Str_8& value); | ||||
|  | ||||
| 		/// Checks whether a header variable exists using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasQueryVar(const Str_8 &name) const; | ||||
|  | ||||
| 		/// Adds a header variable. | ||||
| 		/// @param [in] var The variable to add to the header. | ||||
| 		/// @returns False if the given variable name already exists. True otherwise. | ||||
| 		bool AddQueryVar(QueryVar var); | ||||
|  | ||||
| 		/// Removes a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveQueryVar(const UInt_64 &id); | ||||
|  | ||||
| 		/// Removes a header variable using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveQueryVar(const Str_8 &name); | ||||
|  | ||||
| 		/// Retrieves a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable object if found. Nullptr otherwise. | ||||
| 		QueryVar *GetQueryVar(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Retrieves a header variable using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns The variable object if found. Nullptr otherwise. | ||||
| 		QueryVar *GetQueryVar(const Str_8& name) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetQueryValue(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetQueryValue(const Str_8& name) const; | ||||
| 		/// Retrieves a query variable from the URI. | ||||
| 		/// @param [in] var The variable identifier to look for. | ||||
| 		/// @returns The value of the query variable. Empty if it was not found. | ||||
| 		Str_8 GetQuery(const Str_8& var); | ||||
|  | ||||
| 		/// Retrieves all the query variables from the URI in a vector object. | ||||
| 		/// @returns The result. | ||||
| 		Vector<QueryVar> GetQueries() const; | ||||
| 		Vector<Str_8> GetQueries() const; | ||||
|  | ||||
| 		/// A helper method to automatically add the required header variables for basic authentication. | ||||
| 		/// @param [in] id The username or id. | ||||
| 		/// @param [in] secret The secret given by an API. | ||||
| 		void BasicAuth(const Str_8 &id, const Str_8 &secret); | ||||
| 		void BasicAuth(const Str_8& id, const Str_8& secret); | ||||
|  | ||||
|         /// A helper method to automatically add the required header variables for bearer authentication. | ||||
|         /// @param [in] token The token given by an API. | ||||
| 		void BearerAuth(const Str_8 &token); | ||||
| 		void BearerAuth(const Str_8& token); | ||||
|  | ||||
|         /// A helper method to automatically add the required header variables for bearer authentication. | ||||
|         /// @param [in] token The token given by an API. | ||||
|         /// @param [in] clientId The client id given by an API. | ||||
|         void BearerAuth(const Str_8 &token, const Str_8 &clientId); | ||||
|         void BearerAuth(const Str_8& token, const Str_8& clientId); | ||||
|  | ||||
|         /// A helper method to automatically add the required header variables for bot authentication. | ||||
|         /// @param [in] token The token given by an API. | ||||
| 		void BotAuth(const Str_8 &token); | ||||
|  | ||||
|         /// Checks whether a header variable exists using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasHeaderVar(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Checks whether a header variable exists using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasHeaderVar(const Str_8 &name) const; | ||||
| 		void BotAuth(const Str_8& token); | ||||
|  | ||||
|         /// Adds a header variable. | ||||
|         /// @param [in] var The variable to add to the header. | ||||
|         /// @returns False if the given variable name already exists. True otherwise. | ||||
| 		bool AddHeaderVar(HeaderVar var); | ||||
|         /// @param [in] var The variable identifier. | ||||
|         /// @param [in] value The value of the variable. | ||||
| 		void AddToHeader(const Str_8& var, const Str_8& value); | ||||
|  | ||||
| 		/// Removes a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveHeaderVar(const UInt_64 &id); | ||||
|  | ||||
| 		/// Removes a header variable using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveHeaderVar(const Str_8 &name); | ||||
|  | ||||
| 		/// Retrieves a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable object if found. Nullptr otherwise. | ||||
| 		HeaderVar *GetHeaderVar(const UInt_64 &id) const; | ||||
|  | ||||
|         /// Retrieves a header variable using the name. | ||||
|         /// @param [in] name The variable name to look for. | ||||
|         /// @returns The variable object if found. Nullptr otherwise. | ||||
| 		HeaderVar *GetHeaderVar(const Str_8& name) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetHeaderValue(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetHeaderValue(const Str_8& name) const; | ||||
|         /// Retrieves a header variable. | ||||
|         /// @param [in] var The variable identifier to look for. | ||||
|         /// @returns The value of the header variable. Empty if it was not found. | ||||
| 		Str_8 GetHeader(const Str_8& var) const; | ||||
|  | ||||
|         /// Retrieves all the header variables in a vector object. | ||||
|         /// @returns The result. | ||||
| 		Vector<HeaderVar> GetHeader() const; | ||||
| 		Vector<Str_8> GetHeader() const; | ||||
|  | ||||
|         /// Adds a body variable. | ||||
|         /// @param [in] var The variable identifier. | ||||
|         /// @param [in] value The value of the variable. | ||||
| 		void AddToBody(const Str_8 &var, const Str_8 &value); | ||||
| 		void AddToBody(const Str_8& var, const Str_8& value); | ||||
|  | ||||
|         /// Adds a value to the body. | ||||
|         /// @param [in] data The value to add. | ||||
| 		void AddToBody(const Str_8 &data); | ||||
| 		void AddToBody(const Str_8& data); | ||||
|  | ||||
| 		/// Sets the entire body. | ||||
| 		/// @param [in] body The body to use. | ||||
| 		void SetBody(const Str_8 &body); | ||||
| 		void SetBody(const Str_8& body); | ||||
|  | ||||
|         /// Retrieves a body variable. | ||||
|         /// @param [in] var The variable identifier to look for. | ||||
|         /// @returns The value of the body variable. Empty if it was not found. | ||||
| 		Str_8 GetVar(const Str_8 &var) const; | ||||
| 		Str_8 GetVar(const Str_8& var) const; | ||||
|  | ||||
| 		/// Retrieves the entire body. | ||||
| 		/// @returns The result. | ||||
| @@ -233,13 +152,13 @@ namespace ehs | ||||
| 		bool IsValid() const; | ||||
| 		 | ||||
| 	private: | ||||
| 		static Str_8 VerbToStr(const Verb &verb); | ||||
| 		static Str_8 VerbToStr(const Verb verb); | ||||
| 		 | ||||
| 		static Str_8 ContentTypeToStr(const ContentType &cType); | ||||
| 		static Str_8 ContentTypeToStr(const ContentType cType); | ||||
|  | ||||
| 		static ContentType StrToContentType(const Str_8 &value); | ||||
| 		static ContentType StrToContentType(const Str_8& value); | ||||
|  | ||||
| 		void ReadData(const Str_8 &data); | ||||
| 		void ReadData(const Str_8& data); | ||||
| 		 | ||||
| 	}; | ||||
| } | ||||
| @@ -5,7 +5,6 @@ | ||||
| #include "ehs/Str.h" | ||||
| #include "ehs/json/Json.h" | ||||
| #include "Socket.h" | ||||
| #include "HeaderVar.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| @@ -15,7 +14,7 @@ namespace ehs | ||||
| 		UInt_32 code; | ||||
| 		Str_8 server; | ||||
| 		ContentType cType; | ||||
| 		Vector<HeaderVar> header; | ||||
| 		Vector<Str_8> header; | ||||
| 		Str_8 body; | ||||
|  | ||||
| 	public: | ||||
| @@ -25,38 +24,29 @@ namespace ehs | ||||
|         /// Initializes this response with a given code and server identifier. | ||||
|         /// @param [in] code The code to give. | ||||
|         /// @param [in] server The server identifier. | ||||
| 		Response(const UInt_32 &code, Str_8 server); | ||||
| 		Response(const UInt_32 code, const Str_8& server); | ||||
|  | ||||
|         /// Initializes this response with the raw response data. | ||||
|         /// @param [in] data The C-style string of the response. | ||||
|         /// @param [in] size The size of the given C-style string. | ||||
| 		Response(const char *data, const UInt_64 &size); | ||||
| 		Response(const char* data, const UInt_64 size); | ||||
|  | ||||
|         /// Initializes this response with the raw response data. | ||||
|         /// @param [in] data The string of the response. | ||||
| 		Response(const Str_8 &data); | ||||
|  | ||||
| 		/// Moves members from another object of the same type. | ||||
| 		/// @param [in] other The object to move from. | ||||
| 		Response(Response &&other) noexcept; | ||||
| 		Response(const Str_8& data); | ||||
|  | ||||
|         /// Copies members from another object of the same type. | ||||
|         /// @param [in] other The object to copy from. | ||||
| 		Response(const Response &other); | ||||
|  | ||||
| 		/// Moves members from another object of the same type. | ||||
| 		/// @param [in] other The object to move from. | ||||
| 		/// @returns The response that has been assigned to. | ||||
| 		Response &operator=(Response &&other) noexcept; | ||||
|         /// @param [in] res The object to copy from. | ||||
| 		Response(const Response& res) = default; | ||||
|  | ||||
|         /// Copies members from another object of the same type. | ||||
|         /// @param [in] res The object to copy from. | ||||
|         /// @returns The response that has been assigned to. | ||||
| 		Response& operator=(const Response &other); | ||||
| 		Response& operator=(const Response& res); | ||||
|  | ||||
| 		/// Sets the response code to send to the endpoint. | ||||
| 		/// @param [in] code The code for success, error or info. | ||||
| 		void SetCode(const UInt_32 &code); | ||||
| 		void SetCode(const UInt_32 code); | ||||
|  | ||||
| 		/// Retrieves the response code. | ||||
| 		/// @returns The result. | ||||
| @@ -64,7 +54,7 @@ namespace ehs | ||||
|  | ||||
| 		/// Sets the server identifier. | ||||
| 		/// @param [in] server The server identifier to use. | ||||
| 		void SetServer(Str_8 server); | ||||
| 		void SetServer(const Str_8& server); | ||||
|  | ||||
| 		/// Retrieves the server identifier. | ||||
| 		/// @returns The result. | ||||
| @@ -72,60 +62,25 @@ namespace ehs | ||||
|  | ||||
|         /// Sets the content type for the body. | ||||
|         /// @param [in] cType The content type to use. | ||||
| 		void SetContentType(const ContentType &cType); | ||||
| 		void SetContentType(const ContentType cType); | ||||
|  | ||||
|         /// Retrieves the content type for the body. | ||||
|         /// @returns The result. | ||||
| 		ContentType GetContentType() const; | ||||
|  | ||||
| 		/// Checks whether a header variable exists using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasHeaderVar(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Checks whether a header variable exists using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable exists. False otherwise. | ||||
| 		bool HasHeaderVar(const Str_8 &name) const; | ||||
|  | ||||
|         /// Adds a header variable. | ||||
|         /// @param [in] var The variable to add to the header. | ||||
|         /// @returns False if the given variable name already exists. True otherwise. | ||||
| 		bool AddHeaderVar(HeaderVar var); | ||||
|         /// @param [in] var The variable identifier. | ||||
|         /// @param [in] value The value of the variable. | ||||
| 		void AddToHeader(const Str_8& var, const Str_8& value); | ||||
|  | ||||
| 		/// Removes a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveHeaderVar(const UInt_64 &id); | ||||
|  | ||||
| 		/// Removes a header variable using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns True if the variable was found. False otherwise. | ||||
| 		bool RemoveHeaderVar(const Str_8 &name); | ||||
|  | ||||
| 		/// Retrieves a header variable using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable object if found. Nullptr otherwise. | ||||
| 		HeaderVar *GetHeaderVar(const UInt_64 &id) const; | ||||
|  | ||||
|         /// Retrieves a header variable using the name. | ||||
|         /// @param [in] name The variable name to look for. | ||||
|         /// @returns The variable object if found. Nullptr otherwise. | ||||
| 		HeaderVar *GetHeaderVar(const Str_8& name) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the id. | ||||
| 		/// @param [in] id The variable id to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetHeaderValue(const UInt_64 &id) const; | ||||
|  | ||||
| 		/// Retrieves a header variable value using the name. | ||||
| 		/// @param [in] name The variable name to look for. | ||||
| 		/// @returns The variable's value if found. Empty otherwise. | ||||
| 		Str_8 GetHeaderValue(const Str_8& name) const; | ||||
|         /// Retrieves a header variable. | ||||
|         /// @param [in] var The variable identifier to look for. | ||||
|         /// @returns The value of the header variable. Empty if it was not found. | ||||
| 		Str_8 GetHeader(const Str_8& var) const; | ||||
|  | ||||
|         /// Retrieves all the header variables in a vector object. | ||||
|         /// @returns The result. | ||||
| 		Vector<HeaderVar> GetHeader() const; | ||||
| 		Vector<Str_8> GetHeader() const; | ||||
|  | ||||
|         /// Adds a body variable. | ||||
|         /// @param [in] var The variable identifier. | ||||
| @@ -160,13 +115,13 @@ namespace ehs | ||||
| 		bool IsValid() const; | ||||
|  | ||||
| 	private: | ||||
| 		static Str_8 CodeToStr(const UInt_32 &code); | ||||
| 		static Str_8 CodeToStr(const UInt_32 code); | ||||
|  | ||||
| 		static Str_8 ContentTypeToStr(const ContentType &cType); | ||||
| 		static Str_8 ContentTypeToStr(const ContentType cType); | ||||
|  | ||||
| 		static ContentType StrToContentType(const Str_8 &value); | ||||
| 		static ContentType StrToContentType(const Str_8& value); | ||||
|  | ||||
| 		void ReadData(const Str_8 &data); | ||||
| 		void ReadData(const Str_8& data); | ||||
|  | ||||
| 	}; | ||||
| } | ||||
| @@ -1,7 +1,5 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <openssl/types.h> | ||||
|  | ||||
| #include "ehs/EHS.h" | ||||
| #include "ehs/Str.h" | ||||
| #include "TCP.h" | ||||
| @@ -17,18 +15,15 @@ namespace ehs | ||||
| 	class EHS_LIB_IO SSL : public TCP | ||||
|     { | ||||
|     private: | ||||
| 		bool server; | ||||
|         SSL_CTX* ctx; | ||||
|         ::SSL* sslHdl; | ||||
| 		X509 *cert; | ||||
| 		EVP_PKEY* pkey; | ||||
|  | ||||
|     public: | ||||
|         ~SSL() override; | ||||
|  | ||||
|         SSL(); | ||||
|  | ||||
| 		SSL(const IP &type, const bool &server); | ||||
| 		SSL(const IP type); | ||||
|  | ||||
| 		SSL(TCP&& tcp) noexcept; | ||||
|  | ||||
| @@ -42,19 +37,19 @@ namespace ehs | ||||
|  | ||||
|         void Release() override; | ||||
|  | ||||
| 		void Listen() override; | ||||
| 		void Bind(const Str_8& address, unsigned short port) override; | ||||
|  | ||||
|         SSL* Accept() override; | ||||
|  | ||||
|         void Connect(Str_8 address, const UInt_16 &port) override; | ||||
|         void Connect(const Str_8& address, const UInt_16 port) override; | ||||
|  | ||||
| 		UInt_64 Send(const Byte* buffer, const UInt_32 size) override; | ||||
| 		UInt_64 Send(const Byte* const buffer, const UInt_32 size) override; | ||||
|  | ||||
| 		UInt_64 Receive(Byte* buffer, const UInt_32 size) override; | ||||
| 		UInt_64 Receive(Byte* const buffer, const UInt_32 size) override; | ||||
|  | ||||
| 		void UseCertificate(const Char_8* data, const UInt_32 &size); | ||||
| 		void UseCertificate(const Byte* data, const UInt_64 size); | ||||
|  | ||||
| 		void UsePrivateKey(const Char_8* data, const UInt_32 &size); | ||||
| 		void UsePrivateKey(const Byte* data, const UInt_64 size); | ||||
|  | ||||
| 		bool IsValid(); | ||||
|     }; | ||||
|   | ||||
| @@ -40,9 +40,7 @@ namespace ehs | ||||
|         APP_XML, | ||||
|         TEXT_PLAIN, | ||||
|         TEXT_HTML, | ||||
|     	TEXT_CSS, | ||||
|         TEXT_XML, | ||||
|     	IMG_X_ICON, | ||||
|         NONE | ||||
|     }; | ||||
|  | ||||
|   | ||||
| @@ -46,7 +46,7 @@ namespace ehs | ||||
| 		/// @param [in] address The local IPv4 or IPv6 address to bind to. Resolves domain names. The given address can be empty, "127.0.0.1", or "localhost" to automatically find the appropriate device. | ||||
| 		/// @param [in] port The port to bind to. | ||||
| 		/// @note Requires the port given to be forwarded if this is called. | ||||
| 		void Bind(Str_8 address, const UInt_16 &port) override; | ||||
| 		void Bind(const Str_8& address, UInt_16 port) override; | ||||
|  | ||||
| 		/// Listens for incoming connections. Used for servers or PtP. | ||||
| 		void Listen() override; | ||||
| @@ -58,7 +58,7 @@ namespace ehs | ||||
| 		/// Connects to a TCP Socket that listens for incoming connections. Used for clients or PtP. | ||||
| 		/// @param address The address of the listening TCP socket. Resolves domain names. The given address can be empty, "127.0.0.1", or "localhost" to automatically find the appropriate device. | ||||
| 		/// @param port The port of the listening TCP socket. | ||||
| 		void Connect(Str_8 address, const UInt_16 &port) override; | ||||
| 		void Connect(const Str_8& address, UInt_16 port) override; | ||||
|  | ||||
| 		/// Sends data in a C-style array with raw functionality. Meaning no internal help outside of native functions besides error checking. | ||||
| 		/// @param [in] buffer The C-style array to send. | ||||
| @@ -84,17 +84,15 @@ namespace ehs | ||||
|  | ||||
| 		bool IsIPv6Only() const override; | ||||
|  | ||||
| 		void SetReuse(const bool &value) override; | ||||
|  | ||||
| 		bool IsValid() const override; | ||||
|  | ||||
| 	private: | ||||
| 		void Bind_v6(const Str_8 &address, const UInt_16 &port) const; | ||||
| 		void Bind_v6(const Str_8& address, UInt_16 port); | ||||
|  | ||||
| 		void Bind_v4(const Str_8 &address, const UInt_16 &port) const; | ||||
| 		void Bind_v4(const Str_8& address, UInt_16 port); | ||||
|  | ||||
| 		void Connect_v6(const Str_8 &address, const UInt_16 &port); | ||||
| 		void Connect_v6(const Str_8& address, UInt_16 port); | ||||
|  | ||||
| 		void Connect_v4(const Str_8 &address, const UInt_16 &port); | ||||
| 		void Connect_v4(const Str_8& address, UInt_16 port); | ||||
| 	}; | ||||
| } | ||||
| @@ -46,7 +46,7 @@ namespace ehs | ||||
| 		/// @param [in] address The local IPv4 or IPv6 address to bind to. Resolves domain names. The given address can be empty, "127.0.0.1", or "localhost" to automatically find the appropriate device. | ||||
| 		/// @param [in] port The port to bind to. | ||||
| 		/// @note Requires the port given to be forwarded if this is called. | ||||
| 		void Bind(Str_8 address, const UInt_16 &port) override; | ||||
| 		void Bind(const Str_8& address, UInt_16 port) override; | ||||
|  | ||||
| 		/// Listens for incoming connections. Used for servers or PtP. | ||||
| 		void Listen() override; | ||||
| @@ -58,7 +58,7 @@ namespace ehs | ||||
| 		/// Connects to a TCP Socket that listens for incoming connections. Used for clients or PtP. | ||||
| 		/// @param address The address of the listening TCP socket. Resolves domain names. The given address can be empty, "127.0.0.1", or "localhost" to automatically find the appropriate device. | ||||
| 		/// @param port The port of the listening TCP socket. | ||||
| 		void Connect(Str_8 address, const UInt_16 &port) override; | ||||
| 		void Connect(const Str_8& address, UInt_16 port) override; | ||||
|  | ||||
| 		/// Sends data in a C-style array with raw functionality. Meaning no internal help outside of native functions besides error checking. | ||||
| 		/// @param [in] buffer The C-style array to send. | ||||
| @@ -84,14 +84,12 @@ namespace ehs | ||||
|  | ||||
| 		bool IsIPv6Only() const override; | ||||
|  | ||||
| 		void SetReuse(const bool &value) override; | ||||
|  | ||||
| 		bool IsValid() const override; | ||||
|  | ||||
| 	private: | ||||
| 		void Bind_v6(const Str_8& address, const UInt_16 &port); | ||||
| 		void Bind_v6(const Str_8& address, UInt_16 port); | ||||
|  | ||||
| 		void Bind_v4(const Str_8& address, const UInt_16 &port); | ||||
| 		void Bind_v4(const Str_8& address, UInt_16 port); | ||||
|  | ||||
| 		void Connect_v6(const Str_8& address, UInt_16 port); | ||||
|  | ||||
|   | ||||
| @@ -1,36 +0,0 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "ehs/Types.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class EHS_LIB_IO AVX2 | ||||
|     { | ||||
|     public: | ||||
|         /// Compares two unaligned 4 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 4 elements are equal. False otherwise. | ||||
|         static bool CompareUnaligned(const UInt_64 *a, const UInt_64 *b); | ||||
|  | ||||
|         /// Compares two unaligned 4 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 4 elements are equal. False otherwise. | ||||
|         static bool CompareUnaligned(const SInt_64 *a, const SInt_64 *b); | ||||
|  | ||||
|         /// Compares two aligned 4 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 4 elements are equal. False otherwise. | ||||
|         /// @note The parameters "a", and "b" must have alignas(32). | ||||
|         static bool CompareAligned(const UInt_64 *a, const UInt_64 *b); | ||||
|  | ||||
|         /// Compares two aligned 4 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 4 elements are equal. False otherwise. | ||||
|         /// @note The parameters "a", and "b" must have alignas(32). | ||||
|         static bool CompareAligned(const SInt_64 *a, const SInt_64 *b); | ||||
|     }; | ||||
| } | ||||
| @@ -1,36 +0,0 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "ehs/Types.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     class EHS_LIB_IO AVX512 | ||||
|     { | ||||
|     public: | ||||
|         /// Compares two unaligned 8 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 8 elements are equal. False otherwise. | ||||
|         static bool CompareUnaligned(const UInt_64 *a, const UInt_64 *b); | ||||
|  | ||||
|         /// Compares two unaligned 8 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 8 elements are equal. False otherwise. | ||||
|         static bool CompareUnaligned(const SInt_64 *a, const SInt_64 *b); | ||||
|  | ||||
|         /// Compares two aligned 8 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 8 elements are equal. False otherwise. | ||||
|         /// @note The parameters "a", and "b" must have alignas(32). | ||||
|         static bool CompareAligned(const UInt_64 *a, const UInt_64 *b); | ||||
|  | ||||
|         /// Compares two aligned 8 element vectors using 64-bit integers. | ||||
|         /// @param [in] a First vector. | ||||
|         /// @param [in] b Second vector. | ||||
|         /// @returns True if all 8 elements are equal. False otherwise. | ||||
|         /// @note The parameters "a", and "b" must have alignas(32). | ||||
|         static bool CompareAligned(const SInt_64 *a, const SInt_64 *b); | ||||
|     }; | ||||
| } | ||||
| @@ -6,7 +6,7 @@ | ||||
|     #define EHS_64_BIT | ||||
| #elif defined(_M_ARM64) || defined(__aarch64__) | ||||
|     #define EHS_LITTLE_ENDIAN | ||||
|     #define EHS_ARCH_AARCH64 | ||||
|     #define EHS_ARCH_ARM64 | ||||
|     #define EHS_64_BIT | ||||
| #else | ||||
|     #error Unsupported architecture. | ||||
|   | ||||
| @@ -8,7 +8,7 @@ namespace ehs | ||||
| 	class EHS_LIB_IO BaseSystem | ||||
| 	{ | ||||
| 	public: | ||||
| 		static void OpenURI(Str_8 uri); | ||||
| 		static void OpenURI(const Str_8& uri); | ||||
|  | ||||
| 		static Str_8 OpenFileDialog(const Str_8 &dir, const Str_8 &filters); | ||||
|  | ||||
|   | ||||
| @@ -38,70 +38,6 @@ namespace ehs | ||||
|         #endif | ||||
|  | ||||
| 	public: | ||||
| 		static const bool hasFPU; | ||||
| 		static const bool hasVME; | ||||
| 		static const bool hasDE; | ||||
| 		static const bool hasPSE; | ||||
| 		static const bool hasTSC; | ||||
| 		static const bool hasMSR; | ||||
| 		static const bool hasPAE; | ||||
| 		static const bool hasMCE; | ||||
| 		static const bool hasCX8; | ||||
| 		static const bool hasAPIC; | ||||
| 		static const bool hasSEP; | ||||
| 		static const bool hasMTRR; | ||||
| 		static const bool hasPGE; | ||||
| 		static const bool hasMCA; | ||||
| 		static const bool hasCMOV; | ||||
| 		static const bool hasPSE_36; | ||||
| 		static const bool hasPSN; | ||||
| 		static const bool hasCLFSH; | ||||
| 		static const bool hasDS; | ||||
| 		static const bool hasACPI; | ||||
| 		static const bool hasMMX; | ||||
| 		static const bool hasFXSR; | ||||
| 		static const bool hasSSE; | ||||
| 		static const bool hasSSE2; | ||||
| 		static const bool hasSS; | ||||
| 		static const bool hasHTT; | ||||
| 		static const bool hasTM; | ||||
| 		static const bool hasIA64; | ||||
| 		static const bool hasPBE; | ||||
| 		static const bool hasSSE3; | ||||
| 		static const bool hasPCLMULQDQ; | ||||
| 		static const bool hasDTES64; | ||||
| 		static const bool hasMONITOR; | ||||
| 		static const bool hasVMX; | ||||
| 		static const bool hasSMX; | ||||
| 		static const bool hasEST; | ||||
| 		static const bool hasTM2; | ||||
| 		static const bool hasSSSE3; | ||||
| 		static const bool hasCNXT_ID; | ||||
| 		static const bool hasSDBG; | ||||
| 		static const bool hasFMA; | ||||
| 		static const bool hasCX16; | ||||
| 		static const bool hasXTPR; | ||||
| 		static const bool hasPDCM; | ||||
| 		static const bool hasPCID; | ||||
| 		static const bool hasDCA; | ||||
| 		static const bool hasSSE4_1; | ||||
| 		static const bool hasSSE4_2; | ||||
| 		static const bool hasX2APIC; | ||||
| 		static const bool hasMOVBE; | ||||
| 		static const bool hasPOPCNT; | ||||
| 		static const bool hasTSC_DEADLINE; | ||||
| 		static const bool hasAES; | ||||
| 		static const bool hasXSAVE; | ||||
| 		static const bool hasOSXSAVE; | ||||
| 		static const bool hasAVX; | ||||
| 		static const bool hasF16C; | ||||
| 		static const bool hasRDRND; | ||||
| 		static const bool hasHYPERVISOR; | ||||
| 		static const bool hasAVX2; | ||||
| 		static const bool hasAVX512F; | ||||
| 		static const bool hasRDSEED; | ||||
| 		static const bool hasADX; | ||||
|  | ||||
| 		static Architecture GetArchitecture(); | ||||
|  | ||||
| 		static UInt_8 PointerSize(); | ||||
| @@ -132,157 +68,153 @@ namespace ehs | ||||
|  | ||||
| 		static UInt_8 GetExtFamilyId(); | ||||
|  | ||||
| 		static UInt_32 GetFeatureBits_1(); | ||||
|  | ||||
| 		static bool HasFPU(); | ||||
|  | ||||
| 		static bool HasVME(); | ||||
|  | ||||
| 		static bool HasDE(); | ||||
|  | ||||
| 		static bool HasPSE(); | ||||
|  | ||||
| 		static bool HasTSC(); | ||||
|  | ||||
| 		static bool HasMSR(); | ||||
|  | ||||
| 		static bool HasPAE(); | ||||
|  | ||||
| 		static bool HasMCE(); | ||||
|  | ||||
| 		static bool HasCX8(); | ||||
|  | ||||
| 		static bool HasAPIC(); | ||||
|  | ||||
| 		static bool HasSEP(); | ||||
|  | ||||
| 		static bool HasMTRR(); | ||||
|  | ||||
| 		static bool HasPGE(); | ||||
|  | ||||
| 		static bool HasMCA(); | ||||
|  | ||||
| 		static bool HasCMOV(); | ||||
|  | ||||
| 		static bool HasPAT(); | ||||
|  | ||||
| 		static bool HasPSE_36(); | ||||
|  | ||||
| 		static bool HasPSN(); | ||||
|  | ||||
| 		static bool HasCLFSH(); | ||||
|  | ||||
| 		static bool HasDS(); | ||||
|  | ||||
| 		static bool HasACPI(); | ||||
|  | ||||
| 		static bool HasMMX(); | ||||
|  | ||||
| 		static bool HasFXSR(); | ||||
|  | ||||
| 		static bool HasSSE(); | ||||
|  | ||||
| 		static bool HasSSE2(); | ||||
|  | ||||
| 		static bool HasSS(); | ||||
|  | ||||
| 		static bool HasHTT(); | ||||
|  | ||||
| 		static bool HasTM(); | ||||
|  | ||||
| 		static bool HasIA64(); | ||||
|  | ||||
| 		static bool HasPBE(); | ||||
|  | ||||
|         static UInt_32 GetFeatureBits_2(); | ||||
|  | ||||
|         static bool HasSSE3(); | ||||
|  | ||||
|         static bool HasPCLMULQDQ(); | ||||
|  | ||||
|         static bool HasDTES64(); | ||||
|  | ||||
|         static bool HasMONITOR(); | ||||
|  | ||||
|         static bool HasDS_CPL(); | ||||
|  | ||||
|         static bool HasVMX(); | ||||
|  | ||||
|         static bool HasSMX(); | ||||
|  | ||||
|         static bool HasEST(); | ||||
|  | ||||
|         static bool HasTM2(); | ||||
|  | ||||
|         static bool HasSSSE3(); | ||||
|  | ||||
|         static bool HasCNXT_ID(); | ||||
|  | ||||
|         static bool HasSDBG(); | ||||
|  | ||||
|         static bool HasFMA(); | ||||
|  | ||||
|         static bool HasCX16(); | ||||
|  | ||||
|         static bool HasXTPR(); | ||||
|  | ||||
|         static bool HasPDCM(); | ||||
|  | ||||
|         static bool HasPCID(); | ||||
|  | ||||
|         static bool HasDCA(); | ||||
|  | ||||
|         static bool HasSSE4_1(); | ||||
|  | ||||
|         static bool HasSSE4_2(); | ||||
|  | ||||
|         static bool HasX2APIC(); | ||||
|  | ||||
|         static bool HasMOVBE(); | ||||
|  | ||||
|         static bool HasPOPCNT(); | ||||
|  | ||||
|         static bool HasTSC_DEADLINE(); | ||||
|  | ||||
|         static bool HasAES(); | ||||
|  | ||||
|         static bool HasXSAVE(); | ||||
|  | ||||
|         static bool HasOSXSAVE(); | ||||
|  | ||||
|         static bool HasAVX(); | ||||
|  | ||||
|         static bool HasF16C(); | ||||
|  | ||||
|         static bool HasRDRND(); | ||||
|  | ||||
|         static bool HasHYPERVISOR(); | ||||
|  | ||||
|         static UInt_32 GetExtFeatureBits_1(); | ||||
|  | ||||
|         static bool HasAVX2(); | ||||
|  | ||||
|         static bool HasRDSEED(); | ||||
|  | ||||
|         static bool HasADX(); | ||||
|  | ||||
|         static UInt_32 GetExtFeatureBits_2(); | ||||
|  | ||||
|         static UInt_32 GetExtFeatureBits_3(); | ||||
|  | ||||
|         /// Retrieves the CPU brand as a null-terminated ASCII string. | ||||
|         /// @param[out] input A 48 byte character array representing the brand. | ||||
| 		static void GetBrand(Char_8* input); | ||||
|  | ||||
| 		static UInt_8 GetCacheLineSize(); | ||||
|  | ||||
| 		static UInt_32 GetFeatureBits_1(); | ||||
|  | ||||
| 		static UInt_32 GetFeatureBits_2(); | ||||
|  | ||||
| 		static UInt_32 GetExtFeatureBits_1(); | ||||
|  | ||||
| 		static UInt_32 GetExtFeatureBits_2(); | ||||
|  | ||||
| 		static UInt_32 GetExtFeatureBits_3(); | ||||
|  | ||||
| 	private: | ||||
| 		static bool RetrieveFPU(); | ||||
|  | ||||
| 		static bool RetrieveVME(); | ||||
|  | ||||
| 		static bool RetrieveDE(); | ||||
|  | ||||
| 		static bool RetrievePSE(); | ||||
|  | ||||
| 		static bool RetrieveTSC(); | ||||
|  | ||||
| 		static bool RetrieveMSR(); | ||||
|  | ||||
| 		static bool RetrievePAE(); | ||||
|  | ||||
| 		static bool RetrieveMCE(); | ||||
|  | ||||
| 		static bool RetrieveCX8(); | ||||
|  | ||||
| 		static bool RetrieveAPIC(); | ||||
|  | ||||
| 		static bool RetrieveSEP(); | ||||
|  | ||||
| 		static bool RetrieveMTRR(); | ||||
|  | ||||
| 		static bool RetrievePGE(); | ||||
|  | ||||
| 		static bool RetrieveMCA(); | ||||
|  | ||||
| 		static bool RetrieveCMOV(); | ||||
|  | ||||
| 		static bool RetrievePAT(); | ||||
|  | ||||
| 		static bool RetrievePSE_36(); | ||||
|  | ||||
| 		static bool RetrievePSN(); | ||||
|  | ||||
| 		static bool RetrieveCLFSH(); | ||||
|  | ||||
| 		static bool RetrieveDS(); | ||||
|  | ||||
| 		static bool RetrieveACPI(); | ||||
|  | ||||
| 		static bool RetrieveMMX(); | ||||
|  | ||||
| 		static bool RetrieveFXSR(); | ||||
|  | ||||
| 		static bool RetrieveSSE(); | ||||
|  | ||||
| 		static bool RetrieveSSE2(); | ||||
|  | ||||
| 		static bool RetrieveSS(); | ||||
|  | ||||
| 		static bool RetrieveHTT(); | ||||
|  | ||||
| 		static bool RetrieveTM(); | ||||
|  | ||||
| 		static bool RetrieveIA64(); | ||||
|  | ||||
| 		static bool RetrievePBE(); | ||||
|  | ||||
|         static bool RetrieveSSE3(); | ||||
|  | ||||
|         static bool RetrievePCLMULQDQ(); | ||||
|  | ||||
|         static bool RetrieveDTES64(); | ||||
|  | ||||
|         static bool RetrieveMONITOR(); | ||||
|  | ||||
|         static bool RetrieveDS_CPL(); | ||||
|  | ||||
|         static bool RetrieveVMX(); | ||||
|  | ||||
|         static bool RetrieveSMX(); | ||||
|  | ||||
|         static bool RetrieveEST(); | ||||
|  | ||||
|         static bool RetrieveTM2(); | ||||
|  | ||||
|         static bool RetrieveSSSE3(); | ||||
|  | ||||
|         static bool RetrieveCNXT_ID(); | ||||
|  | ||||
|         static bool RetrieveSDBG(); | ||||
|  | ||||
|         static bool RetrieveFMA(); | ||||
|  | ||||
|         static bool RetrieveCX16(); | ||||
|  | ||||
|         static bool RetrieveXTPR(); | ||||
|  | ||||
|         static bool RetrievePDCM(); | ||||
|  | ||||
|         static bool RetrievePCID(); | ||||
|  | ||||
|         static bool RetrieveDCA(); | ||||
|  | ||||
|         static bool RetrieveSSE4_1(); | ||||
|  | ||||
|         static bool RetrieveSSE4_2(); | ||||
|  | ||||
|         static bool RetrieveX2APIC(); | ||||
|  | ||||
|         static bool RetrieveMOVBE(); | ||||
|  | ||||
|         static bool RetrievePOPCNT(); | ||||
|  | ||||
|         static bool RetrieveTSC_DEADLINE(); | ||||
|  | ||||
|         static bool RetrieveAES(); | ||||
|  | ||||
|         static bool RetrieveXSAVE(); | ||||
|  | ||||
|         static bool RetrieveOSXSAVE(); | ||||
|  | ||||
|         static bool RetrieveAVX(); | ||||
|  | ||||
|         static bool RetrieveF16C(); | ||||
|  | ||||
|         static bool RetrieveRDRND(); | ||||
|  | ||||
|         static bool RetrieveHYPERVISOR(); | ||||
|  | ||||
|         static bool RetrieveAVX2(); | ||||
|  | ||||
| 		static bool RetrieveAVX512F(); | ||||
|  | ||||
|         static bool RetrieveRDSEED(); | ||||
|  | ||||
|         static bool RetrieveADX(); | ||||
|  | ||||
| 		//static Str_8 ToStr(); | ||||
|  | ||||
| 		static UInt_64 RetrieveFreq_AARCH64(); | ||||
|  | ||||
|     private: | ||||
|         static UInt_64 RetrieveTSC_Freq(); | ||||
|  | ||||
|         static UInt_64 CalculateTSC_Freq(); | ||||
|   | ||||
| @@ -8,7 +8,7 @@ namespace ehs | ||||
| 	class EHS_LIB_IO System : public BaseSystem | ||||
| 	{ | ||||
| 	public: | ||||
| 		static void OpenURI(Str_8 uri); | ||||
| 		static void OpenURI(const Str_8& uri); | ||||
|  | ||||
| 		static Str_8 OpenFileDialog(const Str_8 &dir, const Str_8 &filters); | ||||
|  | ||||
|   | ||||
| @@ -7,6 +7,6 @@ namespace ehs | ||||
| 	class EHS_LIB_IO System : public BaseSystem | ||||
| 	{ | ||||
| 	public: | ||||
| 		static void OpenURI(Str_8 uri); | ||||
| 		static void OpenURI(const Str_8& uri); | ||||
| 	}; | ||||
| } | ||||
							
								
								
									
										194
									
								
								src/Base64.cpp
									
									
									
									
									
								
							
							
						
						
									
										194
									
								
								src/Base64.cpp
									
									
									
									
									
								
							| @@ -2,35 +2,7 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	Str_8 Base64::EncodeURL(const Str_8 &input) | ||||
| 	{ | ||||
| 		UInt_64 input_length = input.Size(); | ||||
|  | ||||
| 		// Calculate the output length | ||||
| 		UInt_64 output_length = (input_length * 4 + 2) / 3; | ||||
|  | ||||
| 		// Allocate memory for the output | ||||
| 		Str_8 result(output_length); | ||||
|  | ||||
| 		// Loop through the input and fill the output | ||||
| 		for (int i = 0, j = 0; i < input_length;) { | ||||
|  | ||||
| 			// Take first byte and shift right by 2 bits | ||||
| 			UInt_32 octet_a = (UInt_8)input[i++]; | ||||
| 			UInt_32 octet_b = i < input_length ? (UInt_8)input[i++] : 0; | ||||
| 			UInt_32 octet_c = i < input_length ? (UInt_8)input[i++] : 0; | ||||
|  | ||||
| 			UInt_32 triple = (octet_a << 16) + (octet_b << 8) + octet_c; | ||||
|  | ||||
| 			// Encode the 24-bits into four 6-bits integers | ||||
| 			result[j++] = asciiUrl[(triple >> 3 * 6) & 0x3F]; | ||||
| 			result[j++] = asciiUrl[(triple >> 2 * 6) & 0x3F]; | ||||
| 			result[j++] = asciiUrl[(triple >> 1 * 6) & 0x3F]; | ||||
| 			result[j++] = asciiUrl[(triple >> 0 * 6) & 0x3F]; | ||||
| 		} | ||||
|  | ||||
| 		return result; | ||||
| 	} | ||||
| 	const char Base64::ascii[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; | ||||
| 	 | ||||
| 	Str_8 Base64::Encode(const Str_8 &input) | ||||
| 	{ | ||||
| @@ -46,9 +18,9 @@ namespace ehs | ||||
| 		for (int i = 0, j = 0; i < input_length;) { | ||||
|  | ||||
| 			// Take first byte and shift right by 2 bits | ||||
| 			UInt_32 octet_a = i < input_length ? (UInt_8)input[i++] : 0; | ||||
| 			UInt_32 octet_b = i < input_length ? (UInt_8)input[i++] : 0; | ||||
| 			UInt_32 octet_c = i < input_length ? (UInt_8)input[i++] : 0; | ||||
| 			UInt_32 octet_a = i < input_length ? input[i++] : 0; | ||||
| 			UInt_32 octet_b = i < input_length ? input[i++] : 0; | ||||
| 			UInt_32 octet_c = i < input_length ? input[i++] : 0; | ||||
|  | ||||
| 			UInt_32 triple = (octet_a << 0x10) + (octet_b << 0x08) + octet_c; | ||||
|  | ||||
| @@ -70,151 +42,63 @@ namespace ehs | ||||
| 		return result; | ||||
| 	} | ||||
| 	 | ||||
| 	Str_8 Base64::DecodeURL(const Str_8 &input) | ||||
| 	{ | ||||
| 		Str_8 result(input.Size() * 3 / 4); | ||||
|  | ||||
| 		UInt_64 remaining = input.Size(); | ||||
| 		UInt_64 offsetIn = 0; | ||||
| 		UInt_64 offsetOut = 0; | ||||
| 		UInt_8 quartet[4]; | ||||
|  | ||||
| 		while (remaining) | ||||
| 		{ | ||||
| 			if (remaining >= 4) | ||||
| 			{ | ||||
| 				for (UInt_8 i = 0; i < 4; ++i) | ||||
| 				{ | ||||
| 					if (!IsBase64URL(input[offsetIn + i])) | ||||
| 						return {}; | ||||
|  | ||||
| 					quartet[i] = FindURL(input[offsetIn + i]); | ||||
| 					if (quartet[i] == EHS_UINT_8_MAX) | ||||
| 						return {}; | ||||
| 				} | ||||
|  | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[0] << 2) | (((UInt_8*)&quartet)[1] >> 4)); | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[1] << 4) | (((UInt_8*)&quartet)[2] >> 2)); | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[2] << 6) |  ((UInt_8*)&quartet)[3]); | ||||
|  | ||||
| 				offsetIn += 4; | ||||
| 				remaining -= 4; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				for (UInt_8 i = 0; i < 4; ++i) | ||||
| 				{ | ||||
| 					if (i < remaining) | ||||
| 					{ | ||||
| 						if (!IsBase64URL(input[offsetIn + i])) | ||||
| 							return {}; | ||||
|  | ||||
| 						quartet[i] = FindURL(input[offsetIn + i]); | ||||
| 						if (quartet[i] == EHS_UINT_8_MAX) | ||||
| 							return {}; | ||||
| 					} | ||||
| 					else | ||||
| 						quartet[i] = 0; | ||||
| 				} | ||||
|  | ||||
| 				result[offsetOut++] = (Char_8)((quartet[0] << 2) | (quartet[1] >> 4)); | ||||
|  | ||||
| 				if (remaining == 3) | ||||
| 					result[offsetOut++] = (Char_8)((quartet[1] << 4) | (quartet[2] >> 2)); | ||||
|  | ||||
| 				offsetIn += remaining; | ||||
| 				remaining = 0; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Base64::Decode(const Str_8 &input) | ||||
| 	{ | ||||
| 		Str_8 result(input.Size() * 3 / 4); | ||||
| 		UInt_64 in_len = input.Size(); | ||||
| 		int i = 0; | ||||
| 		int j = 0; | ||||
| 		int in_ = 0; | ||||
| 		char char_array_4[4], char_array_3[3]; | ||||
| 		Str_8 ret; | ||||
|  | ||||
| 		UInt_64 remaining = input.Size(); | ||||
| 		UInt_64 offsetIn = 0; | ||||
| 		UInt_64 offsetOut = 0; | ||||
| 		UInt_8 quartet[4]; | ||||
|  | ||||
| 		while (remaining) | ||||
| 		while (in_len-- && ( input[in_] != '=') && IsBase64(input[in_])) | ||||
| 		{ | ||||
| 			if (remaining >= 4) | ||||
| 			char_array_4[i++] = input[in_]; in_++; | ||||
| 			 | ||||
| 			if (i ==4) | ||||
| 			{ | ||||
| 				for (UInt_8 i = 0; i < 4; ++i) | ||||
| 				{ | ||||
| 					if (!IsBase64(input[offsetIn + i])) | ||||
| 						return {}; | ||||
| 				for (i = 0; i <4; i++) | ||||
| 					char_array_4[i] = Find(char_array_4[i]); | ||||
|  | ||||
| 					quartet[i] = Find(input[offsetIn + i]); | ||||
| 					if (quartet[i] == EHS_UINT_8_MAX) | ||||
| 						return {}; | ||||
| 				} | ||||
| 				char_array_3[0] = ( char_array_4[0] << 2       ) + ((char_array_4[1] & 0x30) >> 4); | ||||
| 				char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2); | ||||
| 				char_array_3[2] = ((char_array_4[2] & 0x3) << 6) +   char_array_4[3]; | ||||
|  | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[0] << 2) | (((UInt_8*)&quartet)[1] >> 4)); | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[1] << 4) | (((UInt_8*)&quartet)[2] >> 2)); | ||||
| 				result[offsetOut++] = (Char_8)((((UInt_8*)&quartet)[2] << 6) |  ((UInt_8*)&quartet)[3]); | ||||
| 				for (i = 0; (i < 3); i++) | ||||
| 					ret += char_array_3[i]; | ||||
|  | ||||
| 				offsetIn += 4; | ||||
| 				remaining -= 4; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				for (UInt_8 i = 0; i < 4; ++i) | ||||
| 				{ | ||||
| 					if (i < remaining) | ||||
| 					{ | ||||
| 						if (!IsBase64(input[offsetIn + i])) | ||||
| 							return {}; | ||||
|  | ||||
| 						quartet[i] = Find(input[offsetIn + i]); | ||||
| 						if (quartet[i] == EHS_UINT_8_MAX) | ||||
| 							return {}; | ||||
| 					} | ||||
| 					else | ||||
| 						quartet[i] = 0; | ||||
| 				} | ||||
|  | ||||
| 				result[offsetOut++] = (Char_8)((quartet[0] << 2) | (quartet[1] >> 4)); | ||||
|  | ||||
| 				if (remaining == 3) | ||||
| 					result[offsetOut++] = (Char_8)((quartet[1] << 4) | (quartet[2] >> 2)); | ||||
|  | ||||
| 				offsetIn += remaining; | ||||
| 				remaining = 0; | ||||
| 				i = 0; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return result; | ||||
| 		if (i) | ||||
| 		{ | ||||
| 			for (j = 0; j < i; j++) | ||||
| 				char_array_4[j] = Find(char_array_4[j]); | ||||
|  | ||||
| 			char_array_3[0] = (char_array_4[0] << 2) + ((char_array_4[1] & 0x30) >> 4); | ||||
| 			char_array_3[1] = ((char_array_4[1] & 0xf) << 4) + ((char_array_4[2] & 0x3c) >> 2); | ||||
|  | ||||
| 			for (j = 0; (j < i - 1); j++) | ||||
| 				ret += char_array_3[j]; | ||||
| 		} | ||||
|  | ||||
| 	UInt_8 Base64::FindURL(const UInt_8 &c) | ||||
| 	{ | ||||
| 		for (UInt_8 i = 0; i < (UInt_8)sizeof(asciiUrl) - 1; ++i) | ||||
| 			if (asciiUrl[i] == c) | ||||
| 				return i; | ||||
|  | ||||
| 		return EHS_UINT_8_MAX;; | ||||
| 		return ret; | ||||
| 	} | ||||
| 	 | ||||
| 	UInt_8 Base64::Find(const UInt_8 &c) | ||||
| 	char Base64::Find(const char c) | ||||
| 	{ | ||||
| 		for (char i = 0; i < (char)sizeof(ascii); ++i) | ||||
| 		{ | ||||
| 		for (UInt_8 i = 0; i < (UInt_8)sizeof(ascii) - 1; ++i) | ||||
| 			if (ascii[i] == c) | ||||
| 				return i; | ||||
| 		} | ||||
| 		 | ||||
| 		return EHS_SINT_8_MAX; | ||||
| 	} | ||||
| 	 | ||||
| 	bool Base64::IsBase64URL(const UInt_8 &c) | ||||
| 	bool Base64::IsBase64(const char c) | ||||
| 	{ | ||||
| 		return (c > 47 && c < 58) || (c > 64 && c < 91) || (c > 96 && c < 123) || c == '-' || c == '_'; | ||||
| 	} | ||||
|  | ||||
| 	bool Base64::IsBase64(const UInt_8 &c) | ||||
| 	{ | ||||
| 		return (c > 47 && c < 58) || (c > 64 && c < 91) || (c > 96 && c < 123) || c == '+' || c == '/'; | ||||
| 		return (c > 47 && c < 58) || (c > 64 && c < 91) || (c > 96 && c < 123) || (c == '+') || (c == '/'); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										10
									
								
								src/Log.cpp
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/Log.cpp
									
									
									
									
									
								
							| @@ -75,12 +75,12 @@ namespace ehs | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     Log::Log(LogType type, const Str_8 &tags, const UInt_64 code, Str_8 msg) | ||||
|     : type(type), code(code), msg((Str_8&&)msg) | ||||
|     Log::Log(LogType type, const std::initializer_list<Str_8> &tags, const UInt_64 code, Str_8 msg) | ||||
|     : type(type), tags(tags.size()), code(code), msg((Str_8&&)msg) | ||||
|     { | ||||
|         const Vector<Str_8> tmpTags = tags.Split(", "); | ||||
|  | ||||
|         this->tags = Array<Str_8>(&tmpTags[0], tmpTags.Size()); | ||||
| 		UInt_64 i = 0; | ||||
|         for (auto v = tags.begin(); v != tags.end(); ++v) | ||||
|             this->tags[i++] = *v; | ||||
|     } | ||||
|  | ||||
|     Log::Log(LogType type, Array<Str_8> tags, const UInt_64 code, Str_8 msg) | ||||
|   | ||||
							
								
								
									
										12
									
								
								src/Math.cpp
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								src/Math.cpp
									
									
									
									
									
								
							| @@ -36,9 +36,9 @@ namespace ehs | ||||
|     double Math::Sqrt(const double from) | ||||
|     { | ||||
| 		#if defined(EHS_ARCH_X64) | ||||
| 			if (CPU::hasAVX) | ||||
| 			if (CPU::HasAVX()) | ||||
| 				return Sqrt_AVX(from); | ||||
| 			else if (CPU::hasSSE) | ||||
| 			else if (CPU::HasSSE()) | ||||
| 				return Sqrt_SSE2(from); | ||||
|  | ||||
| 			double temp = 0.0; | ||||
| @@ -51,7 +51,7 @@ namespace ehs | ||||
| 			} | ||||
|  | ||||
| 			return result; | ||||
| 		#elif defined(EHS_ARCH_AARCH64) | ||||
| 		#elif defined(EHS_ARCH_ARM64) | ||||
| 			return Sqrt_VFP4(from); | ||||
| 		#endif | ||||
|     } | ||||
| @@ -59,9 +59,9 @@ namespace ehs | ||||
|     float Math::Sqrt(const float from) | ||||
|     { | ||||
| 		#if defined(EHS_ARCH_X64) | ||||
| 			if (CPU::hasAVX) | ||||
| 			if (CPU::HasAVX()) | ||||
| 				return Sqrt_AVX(from); | ||||
| 			else if (CPU::hasSSE) | ||||
| 			else if (CPU::HasSSE()) | ||||
| 				return Sqrt_SSE(from); | ||||
|  | ||||
| 			float temp = 0.0f; | ||||
| @@ -74,7 +74,7 @@ namespace ehs | ||||
| 			} | ||||
|  | ||||
| 			return result; | ||||
| 		#elif defined(EHS_ARCH_AARCH64) | ||||
| 		#elif defined(EHS_ARCH_ARM64) | ||||
| 			return Sqrt_VFP4(from); | ||||
| 		#endif | ||||
|     } | ||||
|   | ||||
							
								
								
									
										209
									
								
								src/SHA256.cpp
									
									
									
									
									
								
							
							
						
						
									
										209
									
								
								src/SHA256.cpp
									
									
									
									
									
								
							| @@ -1,209 +0,0 @@ | ||||
| #include "ehs/SHA256.h" | ||||
|  | ||||
| #include "ehs/Util.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     UInt_32 SHA256::ROTR(const UInt_32 x, const UInt_32 n) | ||||
|     { | ||||
|         return (x >> n) | (x << (32 - n)); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::CH(const UInt_32 x, const UInt_32 y, const UInt_32 z) | ||||
|     { | ||||
|         return (x & y) ^ (~x & z); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::MAJ(const UInt_32 x, const UInt_32 y, const UInt_32 z) | ||||
|     { | ||||
|         return (x & y) ^ (x & z) ^ (y & z); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::EP0(const UInt_32 x) | ||||
|     { | ||||
|         return ROTR(x, 2) ^ ROTR(x, 13) ^ ROTR(x, 22); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::EP1(const UInt_32 x) | ||||
|     { | ||||
|         return ROTR(x, 6) ^ ROTR(x, 11) ^ ROTR(x, 25); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::SIG0(const UInt_32 x) | ||||
|     { | ||||
|         return ROTR(x, 7) ^ ROTR(x, 18) ^ (x >> 3); | ||||
|     } | ||||
|  | ||||
|     UInt_32 SHA256::SIG1(const UInt_32 x) | ||||
|     { | ||||
|         return ROTR(x,17) ^ ROTR(x, 19) ^ (x >> 10); | ||||
|     } | ||||
|  | ||||
|     SHA256::SHA256() | ||||
|         : state{0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19}, | ||||
|         bitLen(0), data{}, dataLen(0) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     SHA256::SHA256(SHA256&& other) noexcept | ||||
|         : state{}, bitLen(0), data{}, dataLen(0) | ||||
|     { | ||||
|         Util::Copy(state, other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         bitLen = other.bitLen; | ||||
|         Util::Copy(data, other.data, sizeof(data)); | ||||
|         dataLen = other.dataLen; | ||||
|  | ||||
|         Util::Zero(other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         other.bitLen = 0; | ||||
|         Util::Zero(other.data, sizeof(data)); | ||||
|         other.dataLen = 0; | ||||
|     } | ||||
|  | ||||
|     SHA256::SHA256(const SHA256& other) | ||||
|         : state{}, bitLen(0), data{}, dataLen(0) | ||||
|     { | ||||
|         Util::Copy(state, other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         bitLen = other.bitLen; | ||||
|         Util::Copy(data, other.data, sizeof(data)); | ||||
|         dataLen = other.dataLen; | ||||
|     } | ||||
|  | ||||
|     SHA256& SHA256::operator=(SHA256&& other) noexcept | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         Util::Copy(state, other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         bitLen = other.bitLen; | ||||
|         Util::Copy(data, other.data, sizeof(data)); | ||||
|         dataLen = other.dataLen; | ||||
|  | ||||
|         Util::Zero(other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         other.bitLen = 0; | ||||
|         Util::Zero(other.data, sizeof(data)); | ||||
|         other.dataLen = 0; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     SHA256& SHA256::operator=(const SHA256& other) | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         Util::Copy(state, other.state, sizeof(state) / sizeof(UInt_32)); | ||||
|         bitLen = other.bitLen; | ||||
|         Util::Copy(data, other.data, sizeof(data)); | ||||
|         dataLen = other.dataLen; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     void SHA256::Update(const Byte* data, const UInt_64 len) | ||||
|     { | ||||
|         for(UInt_64 i = 0; i < len; ++i) | ||||
|         { | ||||
|             this->data[dataLen++] = data[i]; | ||||
|  | ||||
|             if(dataLen == 64) | ||||
|             { | ||||
|                 Transform(this->data); | ||||
|                 bitLen += 512; | ||||
|                 dataLen = 0; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     void SHA256::Final(Byte hash[32]) | ||||
|     { | ||||
|         UInt_32 i = dataLen; | ||||
|  | ||||
|         /* Pad */ | ||||
|         data[i++] = 0x80; | ||||
|         if(i > 56) | ||||
|         { | ||||
|             while(i < 64) | ||||
|                 data[i++] = 0x00; | ||||
|  | ||||
|             Transform(data); | ||||
|  | ||||
|             i = 0; | ||||
|         } | ||||
|  | ||||
|         while(i < 56) | ||||
|             data[i++] = 0x00; | ||||
|  | ||||
|         /* Length in bits */ | ||||
|         bitLen += dataLen * 8ULL; | ||||
|         data[63] = bitLen; | ||||
|         data[62] = bitLen >> 8; | ||||
|         data[61] = bitLen >> 16; | ||||
|         data[60] = bitLen >> 24; | ||||
|         data[59] = bitLen >> 32; | ||||
|         data[58] = bitLen >> 40; | ||||
|         data[57] = bitLen >> 48; | ||||
|         data[56] = bitLen >> 56; | ||||
|         Transform(data); | ||||
|  | ||||
|         /* big‑endian output */ | ||||
|         for(i = 0; i < 4; ++i) { | ||||
|             hash[i]      = (state[0] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 4]  = (state[1] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 8]  = (state[2] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 12] = (state[3] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 16] = (state[4] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 20] = (state[5] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 24] = (state[6] >> (24 - i * 8)) & 0xff; | ||||
|             hash[i + 28] = (state[7] >> (24 - i * 8)) & 0xff; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     void SHA256::Hash(const Byte* data, const UInt_64 len, Byte hash[32]) | ||||
|     { | ||||
|         Update(data, len); | ||||
|         Final(hash); | ||||
|     } | ||||
|  | ||||
|     void SHA256::Transform(const Byte data[64]) | ||||
|     { | ||||
|         UInt_32 m[64]; | ||||
|         UInt_32 a = state[0]; | ||||
|         UInt_32 b = state[1]; | ||||
|         UInt_32 c = state[2]; | ||||
|         UInt_32 d = state[3]; | ||||
|         UInt_32 e = state[4]; | ||||
|         UInt_32 f = state[5]; | ||||
|         UInt_32 g = state[6]; | ||||
|         UInt_32 h = state[7]; | ||||
|         UInt_32 i, t1, t2; | ||||
|  | ||||
|         for (i = 0; i < 16; ++i) | ||||
|             m[i] = (UInt_32)data[i * 4] << 24 | (UInt_32)data[i * 4 + 1] << 16 | (UInt_32)data[i * 4 + 2] << 8 | (UInt_32)data[i * 4 + 3]; | ||||
|  | ||||
|         for (; i < 64; ++i) | ||||
|             m[i] = SIG1(m[i - 2]) + m[i - 7] + SIG0(m[i - 15]) + m[i - 16]; | ||||
|  | ||||
|         for(i = 0; i < 64; ++i) | ||||
|         { | ||||
|             t1 = h + EP1(e) + CH(e,f,g) + k[i] + m[i]; | ||||
|             t2 = EP0(a) + MAJ(a,b,c); | ||||
|             h = g; | ||||
|             g = f; | ||||
|             f = e; | ||||
|             e = d + t1; | ||||
|             d = c; | ||||
|             c = b; | ||||
|             b = a; | ||||
|             a = t1 + t2; | ||||
|         } | ||||
|  | ||||
|         state[0] += a; | ||||
|         state[1] += b; | ||||
|         state[2] += c; | ||||
|         state[3] += d; | ||||
|         state[4] += e; | ||||
|         state[5] += f; | ||||
|         state[6] += g; | ||||
|         state[7] += h; | ||||
|     } | ||||
| } | ||||
| @@ -1,9 +1,5 @@ | ||||
| #include "ehs/Util.h" | ||||
|  | ||||
| #include "ehs/system/CPU.h" | ||||
| #include "ehs/system/AVX2.h" | ||||
| #include "ehs/system/AVX512.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	bool Util::Compare(const void* const a, const void* const b, const UInt_64 size) | ||||
|   | ||||
| @@ -693,7 +693,7 @@ namespace ehs | ||||
| 	Vector<Str_32> Console::GetArgs_32(const UInt_64 bufferSize) | ||||
|     { | ||||
|         #if defined(EHS_OS_WINDOWS) | ||||
|             return UTF::To_32(GetCommandLineW()).ParseArgs(); | ||||
|             return UTF::To_32(GetCommandLineW()).Split(U" "); | ||||
|         #elif defined(EHS_OS_LINUX) | ||||
| 			File cmdFile("/proc/self/cmdline", Mode::READ, Disposition::OPEN); | ||||
| 			Array<Byte> data = cmdFile.ReadArray(bufferSize); | ||||
| @@ -725,7 +725,7 @@ namespace ehs | ||||
| 	Vector<Str_16> Console::GetArgs_16(const UInt_64 bufferSize) | ||||
|     { | ||||
|         #if defined(EHS_OS_WINDOWS) | ||||
|             return Str_16(GetCommandLineW()).ParseArgs(); | ||||
|             return Str_16(GetCommandLineW()).Split(L" "); | ||||
|         #elif defined(EHS_OS_LINUX) | ||||
| 			File cmdFile("/proc/self/cmdline", Mode::READ, Disposition::OPEN); | ||||
| 			Array<Byte> data = cmdFile.ReadArray(bufferSize); | ||||
| @@ -755,7 +755,7 @@ namespace ehs | ||||
|     Vector<Str_8> Console::GetArgs_8(const UInt_64 bufferSize) | ||||
|     { | ||||
|         #if defined(EHS_OS_WINDOWS) | ||||
|             return UTF::To_8(GetCommandLineW()).ParseArgs(); | ||||
|             return UTF::To_8(GetCommandLineW()).Split(" "); | ||||
|         #elif defined(EHS_OS_LINUX) | ||||
| 			File cmdFile("/proc/self/cmdline", Mode::READ, Disposition::OPEN); | ||||
| 			Array<Byte> data = cmdFile.ReadArray(bufferSize); | ||||
|   | ||||
| @@ -93,13 +93,13 @@ namespace ehs | ||||
| 	} | ||||
|  | ||||
| 	AudioDevice::AudioDevice() | ||||
| 		: id(0), loop(nullptr), context(nullptr), core(nullptr), input(nullptr), output(nullptr), paramsHook{} | ||||
| 		: id(0), loop(nullptr), context(nullptr), core(nullptr), input(nullptr), output(nullptr) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	AudioDevice::AudioDevice(AudioDevice&& device) noexcept | ||||
| 		: BaseAudioDevice(device), id(device.id), name((Str_8 &&)device.name), loop(device.loop), | ||||
| 		context(device.context), core(device.core), input(device.input), output(device.output), paramsHook(device.paramsHook) | ||||
| 		context(device.context), core(device.core), input(device.input), output(device.output) | ||||
| 	{ | ||||
| 		device.id = 0; | ||||
| 		device.loop = nullptr; | ||||
| @@ -107,12 +107,11 @@ namespace ehs | ||||
| 		device.core = nullptr; | ||||
| 		device.input = nullptr; | ||||
| 		device.output = nullptr; | ||||
| 		device.paramsHook = {}; | ||||
| 	} | ||||
|  | ||||
| 	AudioDevice::AudioDevice(const AudioDevice& device) | ||||
| 		: BaseAudioDevice(device), id(device.id), name(device.name), loop(nullptr), context(nullptr), core(nullptr), | ||||
| 		input(nullptr), output(nullptr), paramsHook{} | ||||
| 		input(nullptr), output(nullptr) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| @@ -130,7 +129,6 @@ namespace ehs | ||||
| 		core = device.core; | ||||
| 		input = device.input; | ||||
| 		output = device.output; | ||||
| 		paramsHook = device.paramsHook; | ||||
|  | ||||
| 		device.id = 0; | ||||
| 		device.loop = nullptr; | ||||
| @@ -138,7 +136,6 @@ namespace ehs | ||||
| 		device.core = nullptr; | ||||
| 		device.input = nullptr; | ||||
| 		device.output = nullptr; | ||||
| 		device.paramsHook = {}; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
| @@ -157,7 +154,6 @@ namespace ehs | ||||
| 		core = nullptr; | ||||
| 		input = nullptr; | ||||
| 		output = nullptr; | ||||
| 		paramsHook = {}; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
| @@ -210,18 +206,14 @@ namespace ehs | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			SInt_32 err = pw_stream_connect( | ||||
| 				input, | ||||
| 			pw_stream_connect( | ||||
| 				output, | ||||
| 				PW_DIRECTION_INPUT, | ||||
| 				id, | ||||
| 				(pw_stream_flags)(PW_STREAM_FLAG_AUTOCONNECT | PW_STREAM_FLAG_MAP_BUFFERS), | ||||
| 				pod, | ||||
| 				1 | ||||
| 			); | ||||
| 			if (err) | ||||
| 			{ | ||||
| 				EHS_LOG_INT(LogType::ERR, 2, "Failed to connect input stream for audio device."); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (GetType() == AudioDeviceType::OUTPUT || GetType() == AudioDeviceType::ALL) | ||||
| @@ -233,7 +225,7 @@ namespace ehs | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			SInt_32 err = pw_stream_connect( | ||||
| 			pw_stream_connect( | ||||
| 				output, | ||||
| 				PW_DIRECTION_OUTPUT, | ||||
| 				id, | ||||
| @@ -241,10 +233,6 @@ namespace ehs | ||||
| 				pod, | ||||
| 				1 | ||||
| 			); | ||||
| 			if (err) | ||||
| 			{ | ||||
| 				EHS_LOG_INT(LogType::ERR, 2, "Failed to connect output stream for audio device."); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		static constexpr pw_stream_events streamEvents = { | ||||
| @@ -252,17 +240,8 @@ namespace ehs | ||||
| 			.param_changed = OnParamChanged | ||||
| 		}; | ||||
|  | ||||
| 		pw_stream_add_listener(output, ¶msHook, &streamEvents, this); | ||||
|  | ||||
| 		while (pw_stream_get_state(output, nullptr) == PW_STREAM_STATE_CONNECTING) | ||||
| 		{ | ||||
| 			SInt_32 err = pw_loop_iterate(loop, 0); | ||||
| 			if (err < 0) | ||||
| 			{ | ||||
| 				EHS_LOG_INT(LogType::ERR, 3, "Failed to update audio with error #" + Str_8::FromNum(err) + "."); | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
| 		spa_hook streamListener = {}; | ||||
| 		pw_stream_add_listener(output, &streamListener, &streamEvents, this); | ||||
|  | ||||
| 		EHS_LOG_SUCCESS(); | ||||
| 	} | ||||
| @@ -304,15 +283,7 @@ namespace ehs | ||||
| 			return 0; | ||||
| 		} | ||||
|  | ||||
| 		if (!data || !size) | ||||
| 			return 0; | ||||
|  | ||||
| 		SInt_32 err = pw_loop_iterate(loop, 0); | ||||
| 		if (err < 0) | ||||
| 		{ | ||||
| 			EHS_LOG_INT(LogType::ERR, 1, "Failed to update audio with error #" + Str_8::FromNum(err) + "."); | ||||
| 			return 0; | ||||
| 		} | ||||
| 		pw_loop_iterate(loop, 0); | ||||
|  | ||||
| 		if (pw_stream_get_state(output, nullptr) != PW_STREAM_STATE_STREAMING) | ||||
| 			return 0; | ||||
|   | ||||
| @@ -9,18 +9,18 @@ namespace ehs | ||||
| 	} | ||||
|  | ||||
| 	Input::Input() | ||||
| 		: initialized(false) | ||||
| 		: initalized(false) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Input::Input(Input&& input) noexcept | ||||
| 		: handlers((Array<InputHandler*>&&)input.handlers), initialized(input.initialized) | ||||
| 		: handlers((Array<InputHandler*>&&)input.handlers), initalized(input.initalized) | ||||
| 	{ | ||||
| 		input.initialized = false; | ||||
| 		input.initalized = false; | ||||
| 	} | ||||
|  | ||||
| 	Input::Input(const Input& input) | ||||
| 		: initialized(false) | ||||
| 		: initalized(false) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| @@ -30,9 +30,9 @@ namespace ehs | ||||
| 			return *this; | ||||
|  | ||||
| 		handlers = (Array<InputHandler*>&&)input.handlers; | ||||
| 		initialized = input.initialized; | ||||
| 		initalized = input.initalized; | ||||
|  | ||||
| 		input.initialized = false; | ||||
| 		input.initalized = false; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
| @@ -46,14 +46,14 @@ namespace ehs | ||||
| 			delete handlers; | ||||
|  | ||||
| 		handlers = Array<InputHandler*>(); | ||||
| 		initialized = false; | ||||
| 		initalized = false; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
|  | ||||
| 	void Input::Initialize() | ||||
| 	{ | ||||
| 		if (initialized) | ||||
| 		if (initalized) | ||||
| 			return; | ||||
|  | ||||
| 		UInt_64 i = 0; | ||||
| @@ -72,12 +72,12 @@ namespace ehs | ||||
| 			i++; | ||||
| 		} | ||||
|  | ||||
| 		initialized = true; | ||||
| 		initalized = true; | ||||
| 	} | ||||
|  | ||||
| 	void Input::Release() | ||||
| 	{ | ||||
| 		if (!initialized) | ||||
| 		if (!initalized) | ||||
| 			return; | ||||
|  | ||||
| 		UInt_64 i = 0; | ||||
| @@ -96,7 +96,7 @@ namespace ehs | ||||
| 			i++; | ||||
| 		} | ||||
|  | ||||
| 		initialized = false; | ||||
| 		initalized = false; | ||||
| 	} | ||||
|  | ||||
| 	void Input::Poll() | ||||
| @@ -124,7 +124,7 @@ namespace ehs | ||||
| 		if (HasHandler(handler->GetHashId())) | ||||
| 			return false; | ||||
|  | ||||
| 		if (initialized) | ||||
| 		if (initalized) | ||||
| 		{ | ||||
| 			bool hInitialized = handler->Initialize(); | ||||
| 			if (!hInitialized) | ||||
| @@ -155,6 +155,6 @@ namespace ehs | ||||
|  | ||||
| 	bool Input::IsInitialized() const | ||||
| 	{ | ||||
| 		return initialized; | ||||
| 		return initalized; | ||||
| 	} | ||||
| } | ||||
| @@ -36,6 +36,93 @@ namespace ehs | ||||
| 		return new Keyboard(*this); | ||||
| 	} | ||||
|  | ||||
| 	const Button Keyboard::Unknown("Unknown"); | ||||
| 	const Button Keyboard::Escape("Escape Button"); | ||||
| 	const Button Keyboard::Backspace("Backspace Button"); | ||||
| 	const Button Keyboard::Enter("Enter Button"); | ||||
| 	const Button Keyboard::LShift("Left Shift Button"); | ||||
| 	const Button Keyboard::RShift("Right Shift Button"); | ||||
| 	const Button Keyboard::LAlt("Left Alt Button"); | ||||
| 	const Button Keyboard::RAlt("Right Alt Button"); | ||||
| 	const Button Keyboard::LCtrl("Left Control Button"); | ||||
| 	const Button Keyboard::RCtrl("Right Control Button"); | ||||
| 	const Button Keyboard::Space("Space Button"); | ||||
| 	const Button Keyboard::A("A Button"); | ||||
| 	const Button Keyboard::B("B Button"); | ||||
| 	const Button Keyboard::C("C Button"); | ||||
| 	const Button Keyboard::D("D Button"); | ||||
| 	const Button Keyboard::E("E Button"); | ||||
| 	const Button Keyboard::F("F Button"); | ||||
| 	const Button Keyboard::G("G Button"); | ||||
| 	const Button Keyboard::H("H Button"); | ||||
| 	const Button Keyboard::I("I Button"); | ||||
| 	const Button Keyboard::J("J Button"); | ||||
| 	const Button Keyboard::K("K Button"); | ||||
| 	const Button Keyboard::L("L Button"); | ||||
| 	const Button Keyboard::M("M Button"); | ||||
| 	const Button Keyboard::N("N Button"); | ||||
| 	const Button Keyboard::O("O Button"); | ||||
| 	const Button Keyboard::P("P Button"); | ||||
| 	const Button Keyboard::Q("Q Button"); | ||||
| 	const Button Keyboard::R("R Button"); | ||||
| 	const Button Keyboard::S("S Button"); | ||||
| 	const Button Keyboard::T("T Button"); | ||||
| 	const Button Keyboard::U("U Button"); | ||||
| 	const Button Keyboard::V("V Button"); | ||||
| 	const Button Keyboard::W("W Button"); | ||||
| 	const Button Keyboard::X("X Button"); | ||||
| 	const Button Keyboard::Y("Y Button"); | ||||
| 	const Button Keyboard::Z("Z Button"); | ||||
| 	const Button Keyboard::One("One Button"); | ||||
| 	const Button Keyboard::Two("Two Button"); | ||||
| 	const Button Keyboard::Three("Three Button"); | ||||
| 	const Button Keyboard::Four("Four Button"); | ||||
| 	const Button Keyboard::Five("Five Button"); | ||||
| 	const Button Keyboard::Six("Six Button"); | ||||
| 	const Button Keyboard::Seven("Seven Button"); | ||||
| 	const Button Keyboard::Eight("Eight Button"); | ||||
| 	const Button Keyboard::Nine("Nine Button"); | ||||
| 	const Button Keyboard::Zero("Zero Button"); | ||||
| 	const Button Keyboard::Equals("Equals Button"); | ||||
| 	const Button Keyboard::Minus("Minus Button"); | ||||
| 	const Button Keyboard::Tilde("Tilde Button"); | ||||
| 	const Button Keyboard::BackSlash("Back Slash Button"); | ||||
| 	const Button Keyboard::LeftSquareBracket("Left Square Bracket Button"); | ||||
| 	const Button Keyboard::RightSquareBracket("Right Square Bracket Button"); | ||||
| 	const Button Keyboard::SemiColon("Semi-Colon Button"); | ||||
| 	const Button Keyboard::Apostrophe("Apostrophe Button"); | ||||
| 	const Button Keyboard::Comma("Comma Button"); | ||||
| 	const Button Keyboard::Period("Period Button"); | ||||
| 	const Button Keyboard::ForwardSlash("Forward Slash Button"); | ||||
| 	const Button Keyboard::F1("Function 1 Button"); | ||||
| 	const Button Keyboard::F2("Function 2 Button"); | ||||
| 	const Button Keyboard::F3("Function 3 Button"); | ||||
| 	const Button Keyboard::F4("Function 4 Button"); | ||||
| 	const Button Keyboard::F5("Function 5 Button"); | ||||
| 	const Button Keyboard::F6("Function 6 Button"); | ||||
| 	const Button Keyboard::F7("Function 7 Button"); | ||||
| 	const Button Keyboard::F8("Function 8 Button"); | ||||
| 	const Button Keyboard::F9("Function 9 Button"); | ||||
| 	const Button Keyboard::F10("Function 10 Button"); | ||||
| 	const Button Keyboard::F11("Function 11 Button"); | ||||
| 	const Button Keyboard::F12("Function 12 Button"); | ||||
| 	const Button Keyboard::F13("Function 13 Button"); | ||||
| 	const Button Keyboard::F14("Function 14 Button"); | ||||
| 	const Button Keyboard::F15("Function 15 Button"); | ||||
| 	const Button Keyboard::F16("Function 16 Button"); | ||||
| 	const Button Keyboard::F17("Function 17 Button"); | ||||
| 	const Button Keyboard::F18("Function 18 Button"); | ||||
| 	const Button Keyboard::F19("Function 19 Button"); | ||||
| 	const Button Keyboard::F20("Function 20 Button"); | ||||
| 	const Button Keyboard::F21("Function 21 Button"); | ||||
| 	const Button Keyboard::F22("Function 22 Button"); | ||||
| 	const Button Keyboard::F23("Function 23 Button"); | ||||
| 	const Button Keyboard::F24("Function 24 Button"); | ||||
| 	const Button Keyboard::Left("Left Arrow Button"); | ||||
| 	const Button Keyboard::Right("Right Arrow Button"); | ||||
| 	const Button Keyboard::Up("Up Arrow Button"); | ||||
| 	const Button Keyboard::Down("Down Arrow Button"); | ||||
|  | ||||
| 	Button Keyboard::TranslateScanCode(const UInt_32 code) | ||||
| 	{ | ||||
| 		switch (code) | ||||
|   | ||||
| @@ -50,6 +50,19 @@ namespace ehs | ||||
| 		return new Mouse(*this); | ||||
| 	} | ||||
|  | ||||
| 	const Button Mouse::Unknown("Unknown"); | ||||
| 	const Button Mouse::LMB("Left Mouse Button"); | ||||
| 	const Button Mouse::MMB("Middle Mouse Button"); | ||||
| 	const Button Mouse::RMB("Right Mouse Button"); | ||||
| 	const Button Mouse::Four("Mouse Button Four"); | ||||
| 	const Button Mouse::Five("Mouse Button Five"); | ||||
| 	const Button Mouse::ScrollUp("Scroll Up"); | ||||
| 	const Button Mouse::ScrollDown("Scroll Down"); | ||||
| 	const Button Mouse::ScrollLeft("Scroll Left"); | ||||
| 	const Button Mouse::ScrollRight("Scroll Right"); | ||||
| 	const Button Mouse::Back("Back Mouse Button"); | ||||
| 	const Button Mouse::Forward("Forward Mouse Button"); | ||||
|  | ||||
| 	Button Mouse::TranslateXCB(const UInt_32 code) | ||||
| 	{ | ||||
| 		switch (code) | ||||
|   | ||||
| @@ -108,7 +108,7 @@ namespace ehs | ||||
| 		if (!IsValid()) | ||||
| 			return; | ||||
|  | ||||
| 		req.AddHeaderVar({"Host", remoteHostName}); | ||||
| 		req.AddToHeader("Host", remoteHostName); | ||||
|  | ||||
| 		SendStr(req.FormResult()); | ||||
| 	} | ||||
| @@ -124,10 +124,10 @@ namespace ehs | ||||
|  | ||||
| 		Response response(header); | ||||
|  | ||||
| 		Str_8 encoding = response.GetHeaderValue("Transfer-Encoding"); | ||||
| 		Str_8 encoding = response.GetHeader("Transfer-Encoding"); | ||||
| 		if (!encoding.Size()) | ||||
| 		{ | ||||
| 			int bodySize = response.GetHeaderValue("content-length").ToDecimal<int>(); | ||||
| 			int bodySize = response.GetHeader("content-length").ToDecimal<int>(); | ||||
| 			if (!bodySize) | ||||
| 				return response; | ||||
|  | ||||
| @@ -163,10 +163,10 @@ namespace ehs | ||||
| 		if (request.GetVerb() == Verb::GET) | ||||
| 			return request; | ||||
|  | ||||
| 		Str_8 encoding = request.GetHeaderValue("Transfer-Encoding"); | ||||
| 		Str_8 encoding = request.GetHeader("Transfer-Encoding"); | ||||
| 		if (!encoding.Size()) | ||||
| 		{ | ||||
| 			int bodySize = request.GetHeaderValue("Content-Length").ToDecimal<int>(); | ||||
| 			int bodySize = request.GetHeader("Content-Length").ToDecimal<int>(); | ||||
| 			if (!bodySize) | ||||
| 				return request; | ||||
|  | ||||
|   | ||||
| @@ -1,96 +0,0 @@ | ||||
| #include "ehs/io/socket/HeaderVar.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     HeaderVar::HeaderVar() | ||||
|         : id(0) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     HeaderVar::HeaderVar(Str_8 name, Str_8 value) | ||||
|         : id(name.Hash_64()), name((Str_8 &&)name), value((Str_8 &&)value) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     HeaderVar::HeaderVar(HeaderVar&& other) noexcept | ||||
|         : id(other.id), name((Str_8 &&)other.name), value((Str_8 &&)other.value) | ||||
|     { | ||||
|         other.id = 0; | ||||
|     } | ||||
|  | ||||
|     HeaderVar::HeaderVar(const HeaderVar& other) | ||||
|         : id(other.id), name(other.name), value(other.value) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     HeaderVar& HeaderVar::operator=(HeaderVar&& other) noexcept | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         id = other.id; | ||||
|         name = (Str_8 &&)other.name; | ||||
|         value = (Str_8 &&)other.value; | ||||
|  | ||||
|         other.id = 0; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     HeaderVar& HeaderVar::operator=(const HeaderVar& other) | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         id = other.id; | ||||
|         name = other.name; | ||||
|         value = other.value; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     bool HeaderVar::operator==(const HeaderVar& other) const | ||||
|     { | ||||
|         return id == other.id; | ||||
|     } | ||||
|  | ||||
|     bool HeaderVar::operator!=(const HeaderVar& other) const | ||||
|     { | ||||
|         return id != other.id; | ||||
|     } | ||||
|  | ||||
|     bool HeaderVar::operator==(const UInt_64& otherId) const | ||||
|     { | ||||
|         return id == otherId; | ||||
|     } | ||||
|  | ||||
|     bool HeaderVar::operator!=(const UInt_64& otherId) const | ||||
|     { | ||||
|         return id != otherId; | ||||
|     } | ||||
|  | ||||
|     UInt_64 HeaderVar::GetId() const | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|  | ||||
|     Str_8 HeaderVar::GetName() const | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     Str_8 HeaderVar::GetValue() const | ||||
|     { | ||||
|         return value; | ||||
|     } | ||||
|  | ||||
|     void HeaderVar::SetValue(Str_8 value) | ||||
|     { | ||||
|         this->value = (Str_8 &&)value; | ||||
|     } | ||||
|  | ||||
|     Str_8 HeaderVar::ToStr() const | ||||
|     { | ||||
|         return name + ": " + value; | ||||
|     } | ||||
| } | ||||
| @@ -1,96 +0,0 @@ | ||||
| #include "ehs/io/socket/QueryVar.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     QueryVar::QueryVar() | ||||
|         : id(0) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     QueryVar::QueryVar(Str_8 name, Str_8 value) | ||||
|         : id(name.Hash_64()), name((Str_8 &&)name), value((Str_8 &&)value) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     QueryVar::QueryVar(QueryVar&& other) noexcept | ||||
|         : id(other.id), name((Str_8 &&)other.name), value((Str_8 &&)other.value) | ||||
|     { | ||||
|         other.id = 0; | ||||
|     } | ||||
|  | ||||
|     QueryVar::QueryVar(const QueryVar& other) | ||||
|         : id(other.id), name(other.name), value(other.value) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     QueryVar& QueryVar::operator=(QueryVar&& other) noexcept | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         id = other.id; | ||||
|         name = (Str_8 &&)other.name; | ||||
|         value = (Str_8 &&)other.value; | ||||
|  | ||||
|         other.id = 0; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     QueryVar& QueryVar::operator=(const QueryVar& other) | ||||
|     { | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
|         id = other.id; | ||||
|         name = other.name; | ||||
|         value = other.value; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
|  | ||||
|     bool QueryVar::operator==(const QueryVar& other) const | ||||
|     { | ||||
|         return id == other.id; | ||||
|     } | ||||
|  | ||||
|     bool QueryVar::operator!=(const QueryVar& other) const | ||||
|     { | ||||
|         return id != other.id; | ||||
|     } | ||||
|  | ||||
|     bool QueryVar::operator==(const UInt_64& otherId) const | ||||
|     { | ||||
|         return id == otherId; | ||||
|     } | ||||
|  | ||||
|     bool QueryVar::operator!=(const UInt_64& otherId) const | ||||
|     { | ||||
|         return id != otherId; | ||||
|     } | ||||
|  | ||||
|     UInt_64 QueryVar::GetId() const | ||||
|     { | ||||
|         return id; | ||||
|     } | ||||
|  | ||||
|     Str_8 QueryVar::GetName() const | ||||
|     { | ||||
|         return name; | ||||
|     } | ||||
|  | ||||
|     Str_8 QueryVar::GetValue() const | ||||
|     { | ||||
|         return value; | ||||
|     } | ||||
|  | ||||
|     void QueryVar::SetValue(Str_8 value) | ||||
|     { | ||||
|         this->value = (Str_8 &&)value; | ||||
|     } | ||||
|  | ||||
|     Str_8 QueryVar::ToStr() const | ||||
|     { | ||||
|         return name + "=" + value; | ||||
|     } | ||||
| } | ||||
| @@ -4,70 +4,38 @@ | ||||
| namespace ehs | ||||
| { | ||||
| 	Request::Request() | ||||
| 		: verb(Verb::POST), cType(ContentType::NONE) | ||||
| 		: verb(Verb::GET), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Request::Request(const Verb &verb, Str_8 rsrc) | ||||
| 		: verb(verb), rsrc((Str_8 &&)rsrc), cType(ContentType::NONE) | ||||
| 	Request::Request(const Verb verb, const Str_8& rsrc) | ||||
| 		: verb(verb), rsrc(rsrc), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 	} | ||||
| 	 | ||||
| 	Request::Request(const char *data, const UInt_64 &size) | ||||
| 	Request::Request(const char* data, const UInt_64 size) | ||||
| 		: verb(Verb::POST), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 		ReadData(Str_8(data, size)); | ||||
| 	} | ||||
|  | ||||
| 	Request::Request(const Str_8 &data) | ||||
| 	Request::Request(const Str_8& data) | ||||
| 		: verb(Verb::POST), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 		ReadData(data); | ||||
| 	} | ||||
| 	 | ||||
| 	Request::Request(Request&& other) noexcept | ||||
| 		: verb(other.verb), rsrc((Str_8 &&)other.rsrc), queries((Vector<QueryVar> &&)other.queries), | ||||
| 		header((Vector<HeaderVar> &&)other.header), cType(other.cType), body((Str_8 &&)other.body) | ||||
| 	Request& Request::operator=(const Request &req) | ||||
| 	{ | ||||
| 		other.verb = Verb::POST; | ||||
| 		other.cType = ContentType::NONE; | ||||
| 	} | ||||
|  | ||||
| 	Request::Request(const Request& other) | ||||
| 		: verb(other.verb), rsrc(other.rsrc), queries(other.queries), header(other.header), cType(other.cType), | ||||
| 		body(other.body) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Request& Request::operator=(Request&& other) noexcept | ||||
| 	{ | ||||
| 		if (this == &other) | ||||
|         if (this == &req) | ||||
|             return *this; | ||||
|  | ||||
| 		verb = other.verb; | ||||
| 		rsrc = (Str_8 &&)other.rsrc; | ||||
| 		queries = (Vector<QueryVar> &&)other.queries; | ||||
| 		header = (Vector<HeaderVar> &&)other.header; | ||||
| 		cType = other.cType; | ||||
| 		body = (Str_8 &&)other.body; | ||||
|  | ||||
| 		other.verb = Verb::POST; | ||||
| 		other.cType = ContentType::NONE; | ||||
|  | ||||
| 		return* this; | ||||
| 	} | ||||
|  | ||||
| 	Request& Request::operator=(const Request &other) | ||||
| 	{ | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
| 		verb = other.verb; | ||||
| 		rsrc = other.rsrc; | ||||
| 		queries = other.queries; | ||||
| 		header = other.header; | ||||
|         cType = other.cType; | ||||
| 		body = other.body; | ||||
| 		verb = req.verb; | ||||
| 		rsrc = req.rsrc; | ||||
| 		queries = req.queries; | ||||
| 		header = req.header; | ||||
|         cType = req.cType; | ||||
| 		body = req.body; | ||||
|  | ||||
| 		return* this; | ||||
| 	} | ||||
| @@ -77,7 +45,7 @@ namespace ehs | ||||
| 		return verb; | ||||
| 	} | ||||
| 	 | ||||
| 	void Request::SetContentType(const ContentType &cType) | ||||
| 	void Request::SetContentType(const ContentType cType) | ||||
| 	{ | ||||
| 		if (body.Size()) | ||||
| 			body.Resize(0); | ||||
| @@ -90,9 +58,9 @@ namespace ehs | ||||
| 		return cType; | ||||
| 	} | ||||
|  | ||||
| 	void Request::SetResource(Str_8 rsrc) | ||||
| 	void Request::SetResource(const Str_8& rsrc) | ||||
| 	{ | ||||
| 		this->rsrc = (Str_8 &&)rsrc; | ||||
| 		this->rsrc = rsrc; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Request::GetResource() const | ||||
| @@ -100,179 +68,69 @@ namespace ehs | ||||
| 		return rsrc; | ||||
| 	} | ||||
|  | ||||
| 	bool Request::HasQueryVar(const UInt_64& id) const | ||||
| 	void Request::AddQuery(const Str_8& var, const Str_8& value) | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < queries.Size(); ++i) | ||||
| 			if (queries[i] == id) | ||||
| 				return true; | ||||
|  | ||||
| 		return false; | ||||
| 		queries.Push(var + "=" + value); | ||||
| 	} | ||||
|  | ||||
| 	bool Request::HasQueryVar(const Str_8& name) const | ||||
| 	{ | ||||
| 		return HasQueryVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	bool Request::AddQueryVar(QueryVar var) | ||||
| 	{ | ||||
| 		if (HasQueryVar(var.GetId())) | ||||
| 			return false; | ||||
|  | ||||
| 		queries.Push((QueryVar &&)var); | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	bool Request::RemoveQueryVar(const UInt_64& id) | ||||
| 	Str_8 Request::GetQuery(const Str_8& var) | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < queries.Size(); ++i) | ||||
| 		{ | ||||
| 			if (queries[i] != id) | ||||
| 				continue; | ||||
| 			Vector<Str_8> data = queries[i].Split("="); | ||||
|  | ||||
| 			queries.Swap(i, queries.End()); | ||||
| 			queries.Pop(); | ||||
|  | ||||
| 			return true; | ||||
| 			if (data[0] == var) | ||||
| 				return data[1]; | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 		return ""; | ||||
| 	} | ||||
|  | ||||
| 	bool Request::RemoveQueryVar(const Str_8& name) | ||||
| 	{ | ||||
| 		return RemoveQueryVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	QueryVar *Request::GetQueryVar(const UInt_64& id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < queries.Size(); ++i) | ||||
| 			if (queries[i] == id) | ||||
| 				return &queries[i]; | ||||
|  | ||||
| 		return nullptr; | ||||
| 	} | ||||
|  | ||||
| 	QueryVar *Request::GetQueryVar(const Str_8& name) const | ||||
| 	{ | ||||
| 		return GetQueryVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Request::GetQueryValue(const UInt_64& id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < queries.Size(); ++i) | ||||
| 			if (queries[i] == id) | ||||
| 				return queries[i].GetValue(); | ||||
|  | ||||
| 		return {}; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Request::GetQueryValue(const Str_8& name) const | ||||
| 	{ | ||||
| 		return GetQueryValue(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Vector<QueryVar> Request::GetQueries() const | ||||
| 	Vector<Str_8> Request::GetQueries() const | ||||
| 	{ | ||||
| 		return queries; | ||||
| 	} | ||||
| 	 | ||||
| 	void Request::BasicAuth(const Str_8& id, const Str_8& secret) | ||||
| 	{ | ||||
| 		AddHeaderVar({"Authorization", Str_8("Basic ") + Base64::Encode(id + ":" + secret)}); | ||||
| 		AddToHeader("Authorization", Str_8("Basic ") + Base64::Encode(id + ":" + secret)); | ||||
| 	} | ||||
| 	 | ||||
| 	void Request::BearerAuth(const Str_8& token) | ||||
| 	{ | ||||
| 		AddHeaderVar({"Authorization", "Bearer " + token}); | ||||
| 		AddToHeader("Authorization", "Bearer " + token); | ||||
| 	} | ||||
|  | ||||
|     void Request::BearerAuth(const Str_8& token, const Str_8& clientId) | ||||
|     { | ||||
|         AddHeaderVar({"Authorization", "Bearer " + token}); | ||||
|         AddHeaderVar({"Client-Id", clientId}); | ||||
|         AddToHeader("Authorization", "Bearer " + token); | ||||
|         AddToHeader("Client-Id", clientId); | ||||
|     } | ||||
| 	 | ||||
| 	void Request::BotAuth(const Str_8& token) | ||||
| 	{ | ||||
| 		AddHeaderVar({"Authorization", "Bot " + token}); | ||||
| 		AddToHeader("Authorization", "Bot " + token); | ||||
| 	} | ||||
| 	 | ||||
| 	bool Request::HasHeaderVar(const UInt_64& id) const | ||||
| 	void Request::AddToHeader(const Str_8& var, const Str_8& value) | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return true; | ||||
|  | ||||
| 		return false; | ||||
| 		header.Push(var + ": " + value); | ||||
| 	} | ||||
|  | ||||
| 	bool Request::HasHeaderVar(const Str_8& name) const | ||||
| 	{ | ||||
| 		return HasHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	bool Request::AddHeaderVar(HeaderVar var) | ||||
| 	{ | ||||
| 		if (HasHeaderVar(var.GetId())) | ||||
| 			return false; | ||||
|  | ||||
| 		header.Push((HeaderVar &&)var); | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	bool Request::RemoveHeaderVar(const UInt_64 &id) | ||||
| 	Str_8 Request::GetHeader(const Str_8& var) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 		{ | ||||
| 			if (header[i] != id) | ||||
| 				continue; | ||||
| 			Vector<Str_8> data = header[i].Split(": "); | ||||
|  | ||||
| 			header.Swap(i, header.End()); | ||||
| 			header.Pop(); | ||||
|  | ||||
| 			return true; | ||||
| 			if (data[0] == var) | ||||
| 				return data[1]; | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 		return ""; | ||||
| 	} | ||||
| 	 | ||||
| 	bool Request::RemoveHeaderVar(const Str_8 &name) | ||||
| 	{ | ||||
| 		return RemoveHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	HeaderVar *Request::GetHeaderVar(const UInt_64 &id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return &header[i]; | ||||
|  | ||||
| 		return nullptr; | ||||
| 	} | ||||
|  | ||||
| 	HeaderVar *Request::GetHeaderVar(const Str_8 &name) const | ||||
| 	{ | ||||
| 		return GetHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Request::GetHeaderValue(const UInt_64 &id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return header[i].GetValue(); | ||||
|  | ||||
| 		return {}; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Request::GetHeaderValue(const Str_8 &name) const | ||||
| 	{ | ||||
| 		return GetHeaderValue(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Vector<HeaderVar> Request::GetHeader() const | ||||
| 	Vector<Str_8> Request::GetHeader() const | ||||
| 	{ | ||||
| 		return header; | ||||
| 	} | ||||
| @@ -342,20 +200,16 @@ namespace ehs | ||||
| 		Str_8 result = VerbToStr(verb) + " " + rsrc; | ||||
|  | ||||
| 		if (queries.Size()) | ||||
| 		    result += "?" + queries[0].ToStr(); | ||||
| 		    result += "?" + queries[0]; | ||||
|  | ||||
| 		for (UInt_64 i = 1; i < queries.Size(); ++i) | ||||
| 			result += "&" + queries[i].ToStr(); | ||||
| 			result += "&" + queries[i]; | ||||
|  | ||||
| 		result += " HTTP/1.1\r\n"; | ||||
|  | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 		{ | ||||
| 			if (header[i] == 11245195881701120957ull || header[i] == 6556302699635904946ull || | ||||
| 				header[i] == 13347276190653935221ull) // Content-Length, Server, and Content-Type in order from left to right. | ||||
| 				continue; | ||||
|  | ||||
| 			result += header[i].ToStr() + "\r\n"; | ||||
| 			result += header[i] + "\r\n"; | ||||
| 		} | ||||
|  | ||||
| 		result += "Content-Type: " + ContentTypeToStr(cType) + "\r\n"; | ||||
| @@ -373,7 +227,7 @@ namespace ehs | ||||
| 		return rsrc.Size() || queries.Size() || header.Size() || body.Size(); | ||||
| 	} | ||||
| 	 | ||||
| 	Str_8 Request::VerbToStr(const Verb &verb) | ||||
| 	Str_8 Request::VerbToStr(const Verb verb) | ||||
| 	{ | ||||
| 		switch (verb) | ||||
| 		{ | ||||
| @@ -390,7 +244,7 @@ namespace ehs | ||||
| 		} | ||||
| 	} | ||||
| 	 | ||||
| 	Str_8 Request::ContentTypeToStr(const ContentType &cType) | ||||
| 	Str_8 Request::ContentTypeToStr(const ContentType cType) | ||||
| 	{ | ||||
| 		switch (cType) | ||||
| 		{ | ||||
| @@ -408,18 +262,14 @@ namespace ehs | ||||
| 			return "text/plain"; | ||||
| 		case ContentType::TEXT_HTML: | ||||
| 			return "text/html"; | ||||
| 		case ContentType::TEXT_CSS: | ||||
| 			return "text/css"; | ||||
| 		case ContentType::TEXT_XML: | ||||
| 			return "text/xml"; | ||||
| 		case ContentType::IMG_X_ICON: | ||||
| 			return "image/x-icon"; | ||||
| 		default: | ||||
| 			return ""; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	ContentType Request::StrToContentType(const Str_8 &value) | ||||
| 	ContentType Request::StrToContentType(const Str_8& value) | ||||
| 	{ | ||||
| 		if (value == "multipart/form-data") | ||||
| 			return ContentType::APP_MULTIPART_FORMDATA; | ||||
| @@ -435,17 +285,13 @@ namespace ehs | ||||
| 			return ContentType::TEXT_PLAIN; | ||||
| 		else if (value == "text/html") | ||||
| 			return ContentType::TEXT_HTML; | ||||
| 		else if (value == "text/css") | ||||
| 			return ContentType::TEXT_CSS; | ||||
| 		else if (value == "text/xml") | ||||
| 			return ContentType::TEXT_XML; | ||||
| 		else if (value == "image/x-icon") | ||||
| 			return ContentType::IMG_X_ICON; | ||||
| 		else | ||||
| 			return ContentType::NONE; | ||||
| 	} | ||||
|  | ||||
| 	void Request::ReadData(const Str_8 &data) | ||||
| 	void Request::ReadData(const Str_8& data) | ||||
| 	{ | ||||
| 		Vector<Str_8> lines = data.Split("\r\n"); | ||||
| 		Vector<Str_8> meta = lines[0].Split(" "); | ||||
| @@ -462,14 +308,7 @@ namespace ehs | ||||
| 		{ | ||||
| 			rsrc = meta[1].Sub(0, queryIndex); | ||||
| 			cType = ContentType::APP_FORMURLENCODED; | ||||
|  | ||||
| 			Vector<Str_8> strQueries = meta[1].Sub(queryIndex + 1).Split("&"); | ||||
| 			for (UInt_64 i = 0; i < strQueries.Size(); ++i) | ||||
| 			{ | ||||
| 				const Vector<Str_8> queryVar = strQueries[i].Split("="); | ||||
|  | ||||
| 				queries.Push({queryVar[0], queryVar[1]}); | ||||
| 			} | ||||
| 			queries = meta[1].Sub(queryIndex + 1).Split("&"); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| @@ -492,9 +331,7 @@ namespace ehs | ||||
| 			if (var[0] == "Content-Length") | ||||
| 				continue; | ||||
|  | ||||
| 			Vector<Str_8> headerVar = lines[i].Split(": "); | ||||
|  | ||||
| 			header.Push({headerVar[0], headerVar[1]}); | ||||
| 			header.Push(lines[i]); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -2,73 +2,43 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	Response::Response() | ||||
| 		: code(0), cType(ContentType::NONE) | ||||
| 	Response::Response(const UInt_32 code, const Str_8& server) | ||||
| 		: code(code), server(server), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Response::Response(const UInt_32 &code, Str_8 server) | ||||
| 		: code(code), server((Str_8 &&)server), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Response::Response(const char *data, const UInt_64 &size) | ||||
| 	Response::Response(const char* data, const UInt_64 size) | ||||
| 		: code(0), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 		ReadData(Str_8(data, size)); | ||||
| 	} | ||||
|  | ||||
| 	Response::Response(const Str_8 &data) | ||||
| 	Response::Response(const Str_8& data) | ||||
| 		: code(0), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 		ReadData(data); | ||||
| 	} | ||||
|  | ||||
| 	Response::Response(Response&& other) noexcept | ||||
| 		: code(other.code), server((Str_8 &&)other.server), cType(other.cType), header((Vector<HeaderVar> &&)other.header), | ||||
| 		body((Str_8 &&)other.body) | ||||
| 	{ | ||||
| 		other.code = 0; | ||||
| 		other.cType = ContentType::NONE; | ||||
| 	} | ||||
|  | ||||
| 	Response::Response(const Response &other) | ||||
| 		: code(other.code), server(other.server), cType(other.cType), header(other.header), body(other.body) | ||||
| 	Response::Response() | ||||
| 		: code(0), cType(ContentType::NONE) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	Response& Response::operator=(Response&& other) noexcept | ||||
| 	Response& Response::operator=(const Response& res) | ||||
| 	{ | ||||
| 		if (this == &other) | ||||
|         if (this == &res) | ||||
|             return *this; | ||||
|  | ||||
| 		code = other.code; | ||||
| 		server = (Str_8 &&)other.server; | ||||
| 		cType = other.cType; | ||||
| 		header = (Vector<HeaderVar> &&)other.header; | ||||
| 		body = (Str_8 &&)other.body; | ||||
|  | ||||
| 		other.code = 0; | ||||
| 		other.cType = ContentType::NONE; | ||||
| 		code = res.code; | ||||
| 		server = res.server; | ||||
| 		cType = res.cType; | ||||
| 		header = res.header; | ||||
| 		body = res.body; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
|  | ||||
| 	Response& Response::operator=(const Response& other) | ||||
| 	{ | ||||
|         if (this == &other) | ||||
|             return *this; | ||||
|  | ||||
| 		code = other.code; | ||||
| 		server = other.server; | ||||
| 		cType = other.cType; | ||||
| 		header = other.header; | ||||
| 		body = other.body; | ||||
|  | ||||
| 		return *this; | ||||
| 	} | ||||
|  | ||||
| 	void Response::SetCode(const UInt_32 &code) | ||||
| 	void Response::SetCode(const UInt_32 code) | ||||
| 	{ | ||||
| 		this->code = code; | ||||
| 	} | ||||
| @@ -78,9 +48,9 @@ namespace ehs | ||||
| 		return code; | ||||
| 	} | ||||
|  | ||||
| 	void Response::SetServer(Str_8 server) | ||||
| 	void Response::SetServer(const Str_8& server) | ||||
| 	{ | ||||
| 		this->server = (Str_8 &&)server; | ||||
| 		this->server = server; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Response::GetServer() const | ||||
| @@ -88,7 +58,7 @@ namespace ehs | ||||
| 		return server; | ||||
| 	} | ||||
|  | ||||
| 	void Response::SetContentType(const ContentType &cType) | ||||
| 	void Response::SetContentType(const ContentType cType) | ||||
| 	{ | ||||
| 		this->cType = cType; | ||||
| 	} | ||||
| @@ -98,80 +68,27 @@ namespace ehs | ||||
| 		return cType; | ||||
| 	} | ||||
|  | ||||
| 	bool Response::HasHeaderVar(const UInt_64& id) const | ||||
| 	void Response::AddToHeader(const Str_8& var, const Str_8& value) | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return true; | ||||
|  | ||||
| 		return false; | ||||
| 		header.Push(var + ": " + value); | ||||
| 	} | ||||
|  | ||||
| 	bool Response::HasHeaderVar(const Str_8& name) const | ||||
| 	Str_8 Response::GetHeader(const Str_8& var) const | ||||
| 	{ | ||||
| 		return HasHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
| 		Str_8 lIdentity = var.GetLower(); | ||||
|  | ||||
| 	bool Response::AddHeaderVar(HeaderVar var) | ||||
| 	{ | ||||
| 		if (HasHeaderVar(var.GetId())) | ||||
| 			return false; | ||||
|  | ||||
| 		header.Push((HeaderVar &&)var); | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	bool Response::RemoveHeaderVar(const UInt_64& id) | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 		{ | ||||
| 			if (header[i] != id) | ||||
| 				continue; | ||||
| 			Vector<Str_8> data = header[i].Split(": "); | ||||
|  | ||||
| 			header.Swap(i, header.End()); | ||||
| 			header.Pop(); | ||||
|  | ||||
| 			return true; | ||||
| 			if (data[0].GetLower() == lIdentity) | ||||
| 				return data[1]; | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 		return ""; | ||||
| 	} | ||||
|  | ||||
| 	bool Response::RemoveHeaderVar(const Str_8& name) | ||||
| 	{ | ||||
| 		return RemoveHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	HeaderVar* Response::GetHeaderVar(const UInt_64 &id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return &header[i]; | ||||
|  | ||||
| 		return nullptr; | ||||
| 	} | ||||
|  | ||||
| 	HeaderVar *Response::GetHeaderVar(const Str_8 &name) const | ||||
| 	{ | ||||
| 		return GetHeaderVar(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Response::GetHeaderValue(const UInt_64& id) const | ||||
| 	{ | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 			if (header[i] == id) | ||||
| 				return header[i].GetValue(); | ||||
|  | ||||
| 		return {}; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Response::GetHeaderValue(const Str_8& name) const | ||||
| 	{ | ||||
| 		return GetHeaderValue(name.Hash_64()); | ||||
| 	} | ||||
|  | ||||
| 	Vector<HeaderVar> Response::GetHeader() const | ||||
| 	Vector<Str_8> Response::GetHeader() const | ||||
| 	{ | ||||
| 		return header; | ||||
| 	} | ||||
| @@ -242,11 +159,14 @@ namespace ehs | ||||
|  | ||||
| 		for (UInt_64 i = 0; i < header.Size(); ++i) | ||||
| 		{ | ||||
|             if (header[i] == 11245195881701120957ull || header[i] == 6556302699635904946ull || | ||||
|             	header[i] == 13347276190653935221ull) // Content-Length, Server, and Content-Type in order from left to right. | ||||
|             if (header[i].Find("Content-Length", nullptr, SearchPattern::LEFT_RIGHT, IndexResult::ENDING)) | ||||
|                 continue; | ||||
|             else if (header[i].Find("Server", nullptr, SearchPattern::LEFT_RIGHT, IndexResult::ENDING)) | ||||
|                 continue; | ||||
|             else if (header[i].Find("Content-Type", nullptr, SearchPattern::LEFT_RIGHT, IndexResult::ENDING)) | ||||
|                 continue; | ||||
|  | ||||
| 			result += header[i].ToStr() + "\r\n"; | ||||
| 			result += header[i] + "\r\n"; | ||||
| 		} | ||||
|  | ||||
| 		result += "Content-Type: " + ContentTypeToStr(cType) + "\r\nContent-Length: " + Str_8::FromNum(body.Size()) + "\r\n\r\n" + body; | ||||
| @@ -259,7 +179,7 @@ namespace ehs | ||||
| 		return server.Size() || header.Size() || body.Size(); | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Response::CodeToStr(const UInt_32 &code) | ||||
| 	Str_8 Response::CodeToStr(const UInt_32 code) | ||||
| 	{ | ||||
| 		if (code == 100) | ||||
| 			return "Continue"; | ||||
| @@ -403,7 +323,7 @@ namespace ehs | ||||
| 			return "Unused Status Code"; | ||||
| 	} | ||||
|  | ||||
| 	Str_8 Response::ContentTypeToStr(const ContentType &cType) | ||||
| 	Str_8 Response::ContentTypeToStr(const ContentType cType) | ||||
| 	{ | ||||
| 		switch (cType) | ||||
| 		{ | ||||
| @@ -421,18 +341,14 @@ namespace ehs | ||||
| 			return "text/plain"; | ||||
| 		case ContentType::TEXT_HTML: | ||||
| 			return "text/html"; | ||||
| 		case ContentType::TEXT_CSS: | ||||
| 			return "text/css"; | ||||
| 		case ContentType::TEXT_XML: | ||||
| 			return "text/xml"; | ||||
| 		case ContentType::IMG_X_ICON: | ||||
| 			return "image/x-icon"; | ||||
| 		default: | ||||
| 			return ""; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	ContentType Response::StrToContentType(const Str_8 &value) | ||||
| 	ContentType Response::StrToContentType(const Str_8& value) | ||||
| 	{ | ||||
| 		if (value == "multipart/form-data") | ||||
| 			return ContentType::APP_MULTIPART_FORMDATA; | ||||
| @@ -448,17 +364,13 @@ namespace ehs | ||||
| 			return ContentType::TEXT_PLAIN; | ||||
| 		else if (value == "text/html") | ||||
| 			return ContentType::TEXT_HTML; | ||||
| 		else if (value == "text/css") | ||||
| 			return ContentType::TEXT_CSS; | ||||
| 		else if (value == "text/xml") | ||||
| 			return ContentType::TEXT_XML; | ||||
| 		else if (value == "image/x-icon") | ||||
| 			return ContentType::IMG_X_ICON; | ||||
| 		else | ||||
| 			return ContentType::NONE; | ||||
| 	} | ||||
|  | ||||
| 	void Response::ReadData(const Str_8 &data) | ||||
| 	void Response::ReadData(const Str_8& data) | ||||
| 	{ | ||||
| 		Vector<Str_8> lines = data.Split("\r\n"); | ||||
| 		Vector<Str_8> meta = lines[0].Split(" "); | ||||
| @@ -472,12 +384,12 @@ namespace ehs | ||||
|  | ||||
| 			Vector<Str_8> var = lines[i].Split(": "); | ||||
|  | ||||
| 			if (var[0] == "Server") | ||||
| 			if (var[0].GetLower() == "server") | ||||
| 			{ | ||||
| 				server = var[1]; | ||||
| 				continue; | ||||
| 			} | ||||
| 			else if (var[0] == "Content-Type") | ||||
| 			else if (var[0].GetLower() == "content-type") | ||||
| 			{ | ||||
| 				Vector<Str_8> ctData = var[1].Split(";"); | ||||
|  | ||||
| @@ -485,9 +397,7 @@ namespace ehs | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			Vector<Str_8> headerVar = lines[i].Split(": "); | ||||
|  | ||||
| 			header.Push({headerVar[0], headerVar[1]}); | ||||
| 			header.Push(lines[i]); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -4,8 +4,6 @@ | ||||
| #include <openssl/bio.h> | ||||
| #include <openssl/err.h> | ||||
| #include <openssl/pem.h> | ||||
| #include <openssl/opensslv.h> | ||||
| #include <openssl/provider.h> | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| @@ -14,11 +12,6 @@ namespace ehs | ||||
| 		if (!IsValid()) | ||||
| 			return; | ||||
|  | ||||
|     	EVP_PKEY_free(pkey); | ||||
|  | ||||
|     	X509_free(cert); | ||||
|  | ||||
|  | ||||
| 		if (sslHdl) | ||||
| 		{ | ||||
| 			if (connection) | ||||
| @@ -32,28 +25,28 @@ namespace ehs | ||||
|     } | ||||
|  | ||||
|     SSL::SSL() | ||||
| 		: server(false), ctx(nullptr), sslHdl(nullptr), cert(nullptr), pkey(nullptr) | ||||
| 		: ctx(nullptr), sslHdl(nullptr) | ||||
|     { | ||||
|     } | ||||
|  | ||||
| 	SSL::SSL(const IP &type, const bool &server) | ||||
| 		: TCP(type), server(server), ctx(nullptr), sslHdl(nullptr), cert(nullptr), pkey(nullptr) | ||||
| 	SSL::SSL(const IP type) | ||||
| 		: TCP(type), ctx(nullptr), sslHdl(nullptr) | ||||
| 	{ | ||||
| 		SSL::Initialize(); | ||||
| 	} | ||||
|  | ||||
| 	SSL::SSL(TCP&& tcp) noexcept | ||||
| 		: TCP(std::move(tcp)), server(false), ctx(nullptr), sslHdl(nullptr), cert(nullptr), pkey(nullptr) | ||||
| 		: TCP(std::move(tcp)), ctx(nullptr), sslHdl(nullptr) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	SSL::SSL(const TCP& tcp) | ||||
| 		: TCP(tcp), server(false), ctx(nullptr), sslHdl(nullptr), cert(nullptr), pkey(nullptr) | ||||
| 		: TCP(tcp), ctx(nullptr), sslHdl(nullptr) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
|     SSL::SSL(const SSL& ssl) | ||||
|         : TCP(ssl), server(ssl.server), ctx(nullptr), sslHdl(nullptr), cert(nullptr), pkey(nullptr) | ||||
|         : TCP(ssl), ctx(nullptr), sslHdl(nullptr) | ||||
|     { | ||||
|     } | ||||
|  | ||||
| @@ -64,11 +57,8 @@ namespace ehs | ||||
|  | ||||
| 		TCP::operator=(ssl); | ||||
|  | ||||
|     	server = ssl.server; | ||||
| 		ctx = nullptr; | ||||
| 		sslHdl = nullptr; | ||||
|     	cert = nullptr; | ||||
|     	pkey = nullptr; | ||||
|  | ||||
|         return *this; | ||||
|     } | ||||
| @@ -81,40 +71,6 @@ namespace ehs | ||||
| 			return; | ||||
|  | ||||
|         SSL_library_init(); | ||||
|     	OpenSSL_add_ssl_algorithms(); | ||||
|     	SSL_load_error_strings(); | ||||
|     	OPENSSL_init_ssl(OPENSSL_INIT_LOAD_CONFIG, nullptr); | ||||
|     	OSSL_PROVIDER_load(nullptr, "default"); | ||||
|  | ||||
|     	SSL_CTX_set_min_proto_version(ctx, TLS1_2_VERSION); | ||||
|  | ||||
|     	if (server) | ||||
|     	{ | ||||
|     		ctx = SSL_CTX_new(TLS_server_method()); | ||||
|     		if (!ctx) | ||||
|     		{ | ||||
|     			UInt_32 code = ERR_get_error(); | ||||
|     			EHS_LOG_INT(LogType::ERR, 0, ERR_error_string(code, nullptr)); | ||||
|     		} | ||||
|  | ||||
|     		SSL_CTX_set_cipher_list(ctx, "HIGH:!aNULL:!MD5"); | ||||
|     		SSL_CTX_set_ciphersuites(ctx, | ||||
| 				"TLS_AES_256_GCM_SHA384:TLS_AES_128_GCM_SHA256:" | ||||
| 				"TLS_CHACHA20_POLY1305_SHA256:ECDHE-RSA-AES128-GCM-SHA256" | ||||
| 			); | ||||
|     	} | ||||
|     	else | ||||
|     	{ | ||||
|     		ctx = SSL_CTX_new(TLS_client_method()); | ||||
|     		if (!ctx) | ||||
|     		{ | ||||
|     			UInt_32 code = ERR_get_error(); | ||||
|     			EHS_LOG_INT(LogType::ERR, 0, ERR_error_string(code, nullptr)); | ||||
|     		} | ||||
|  | ||||
|     		SSL_CTX_set_default_verify_paths(ctx); | ||||
|     		SSL_CTX_set_verify(ctx, SSL_VERIFY_PEER, nullptr); | ||||
|     	} | ||||
|     } | ||||
|  | ||||
|     void SSL::Release() | ||||
| @@ -124,12 +80,6 @@ namespace ehs | ||||
|         if (!IsValid()) | ||||
|             return; | ||||
|  | ||||
|     	EVP_PKEY_free(pkey); | ||||
|     	pkey = nullptr; | ||||
|  | ||||
|     	X509_free(cert); | ||||
|     	cert = nullptr; | ||||
|  | ||||
|         if (sslHdl) | ||||
|         { | ||||
| 			if (connection) | ||||
| @@ -147,14 +97,19 @@ namespace ehs | ||||
|         } | ||||
|     } | ||||
|  | ||||
| 	void SSL::Listen() | ||||
| 	void SSL::Bind(const Str_8& address, unsigned short port) | ||||
| 	{ | ||||
| 		if (bound) | ||||
| 			return; | ||||
|  | ||||
| 		OpenSSL_add_all_algorithms(); | ||||
| 		SSL_load_error_strings(); | ||||
| 		ctx = SSL_CTX_new(SSLv23_server_method()); | ||||
|  | ||||
| 		sslHdl = SSL_new(ctx); | ||||
| 		SSL_set_fd(sslHdl, hdl); | ||||
|  | ||||
| 		TCP::Listen(); | ||||
|  | ||||
|     	EHS_LOG_SUCCESS(); | ||||
| 		TCP::Bind(address, port); | ||||
| 	} | ||||
|  | ||||
|     SSL* SSL::Accept() | ||||
| @@ -163,21 +118,13 @@ namespace ehs | ||||
| 			return nullptr; | ||||
|  | ||||
| 		TCP* tcp = TCP::Accept(); | ||||
|     	if (!tcp) | ||||
|     		return nullptr; | ||||
|  | ||||
|         SSL* client = new SSL(std::move(*tcp)); | ||||
|  | ||||
| 		delete tcp; | ||||
|  | ||||
| 		client->sslHdl = SSL_new(this->ctx); | ||||
|     	if (!client->sslHdl) | ||||
|     	{ | ||||
|     		UInt_32 code = ERR_get_error(); | ||||
|     		EHS_LOG_INT(LogType::ERR, 0, ERR_error_string(code, nullptr)); | ||||
|     		return nullptr; | ||||
|     	} | ||||
|  | ||||
| 		client->ctx = nullptr; | ||||
| 		client->sslHdl = SSL_new(ctx); | ||||
| 		SSL_set_fd(client->sslHdl, client->hdl); | ||||
|  | ||||
| 		int err = SSL_accept(client->sslHdl); | ||||
| @@ -187,29 +134,21 @@ namespace ehs | ||||
| 			return {}; | ||||
| 		} | ||||
|  | ||||
|     	EHS_LOG_SUCCESS(); | ||||
|  | ||||
|         return client; | ||||
|     } | ||||
|  | ||||
|     void SSL::Connect(Str_8 address, const UInt_16 &port) | ||||
|     void SSL::Connect(const Str_8& address, const UInt_16 port) | ||||
|     { | ||||
| 		TCP::Connect(address, port); | ||||
| 		if (bound) | ||||
| 			return; | ||||
|  | ||||
| 		TCP::Connect(address, port); | ||||
| 		OpenSSL_add_all_algorithms(); | ||||
| 		SSL_load_error_strings(); | ||||
| 		ctx = SSL_CTX_new(SSLv23_client_method()); | ||||
| 		sslHdl = SSL_new(ctx); | ||||
| 		SSL_set_fd(sslHdl, hdl); | ||||
|  | ||||
|     	SSL_set_tlsext_host_name(sslHdl, &address[0]); | ||||
|  | ||||
| 		SInt_32 rc = SSL_connect(sslHdl); | ||||
|     	if (rc != 1) | ||||
|     	{ | ||||
|     		EHS_LOG_INT(LogType::ERR, 1, "Failed to connect with error #" + Str_8::FromNum(SSL_get_error(sslHdl, rc)) + "."); | ||||
|  | ||||
|     		return; | ||||
|     	} | ||||
|  | ||||
|     	EHS_LOG_SUCCESS(); | ||||
| 		SSL_connect(sslHdl); | ||||
|     } | ||||
|  | ||||
| 	UInt_64 SSL::Send(const Byte* const buffer, const UInt_32 size) | ||||
| @@ -218,12 +157,8 @@ namespace ehs | ||||
| 		if (written <= 0) | ||||
| 		{ | ||||
| 			int code = SSL_get_error(sslHdl, written); | ||||
| 			if (code != SSL_ERROR_WANT_WRITE) | ||||
| 			{ | ||||
| 			ERR_print_errors_fp(stderr); | ||||
| 			EHS_LOG_INT(LogType::ERR, 0, "Failed to send data with error #" + Str_8::FromNum(code) + "."); | ||||
| 			} | ||||
|  | ||||
| 			return 0; | ||||
| 		} | ||||
|  | ||||
| @@ -236,46 +171,48 @@ namespace ehs | ||||
| 		if (received <= 0) | ||||
| 		{ | ||||
| 			int code = SSL_get_error(sslHdl, received); | ||||
| 			if (code != SSL_ERROR_WANT_READ) | ||||
| 			{ | ||||
| 			ERR_print_errors_fp(stderr); | ||||
| 			EHS_LOG_INT(LogType::ERR, 0, "Failed to receive data with error #" + Str_8::FromNum(code) + "."); | ||||
| 			} | ||||
|  | ||||
| 			return 0; | ||||
| 		} | ||||
|  | ||||
| 		return received; | ||||
| 	} | ||||
|  | ||||
| 	void SSL::UseCertificate(const Char_8* data, const UInt_32 &size) | ||||
| 	void SSL::UseCertificate(const Byte* data, const UInt_64 size) | ||||
| 	{ | ||||
|     	BIO* certBio = BIO_new_mem_buf(data, (int)size); | ||||
| 		X509 *cert = PEM_read_bio_X509(certBio, nullptr, nullptr, nullptr); | ||||
|  | ||||
|     	if (!SSL_CTX_use_certificate(ctx, cert)) | ||||
| 		X509 *cert = d2i_X509(nullptr, &data, (long)size); | ||||
| 		if (!cert) | ||||
| 		{ | ||||
|     		UInt_32 code = ERR_get_error(); | ||||
|     		EHS_LOG_INT(LogType::ERR, 0, ERR_error_string(code, nullptr)); | ||||
| 			EHS_LOG_INT(LogType::ERR, 0, "Invalid certificate."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
|     	BIO_free(certBio); | ||||
| 	} | ||||
|  | ||||
| 	void SSL::UsePrivateKey(const Char_8* data, const UInt_32 &size) | ||||
| 		if (SSL_CTX_use_certificate(ctx, cert) != 1) | ||||
| 		{ | ||||
|     	BIO* keyBio = BIO_new_mem_buf(data, (int)size); | ||||
|     	EVP_PKEY* pkey = PEM_read_bio_PrivateKey(keyBio, nullptr, nullptr, nullptr); | ||||
|  | ||||
|     	if (!SSL_CTX_use_PrivateKey(ctx, pkey)) | ||||
|     	{ | ||||
|     		UInt_32 code = ERR_get_error(); | ||||
|     		EHS_LOG_INT(LogType::ERR, 0, ERR_error_string(code, nullptr)); | ||||
| 			EHS_LOG_INT(LogType::ERR, 1, "Failed to use certificate."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
|     	BIO_free(keyBio); | ||||
| 		X509_free(cert); | ||||
| 	} | ||||
|  | ||||
| 	void SSL::UsePrivateKey(const Byte* data, const UInt_64 size) | ||||
| 	{ | ||||
| 		EVP_PKEY *key = d2i_PrivateKey(EVP_PKEY_RSA, nullptr, &data, (long)size); | ||||
| 		if (!key) | ||||
| 		{ | ||||
| 			EHS_LOG_INT(LogType::ERR, 0, "Invalid private key."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		if (SSL_CTX_use_PrivateKey(ctx, key) != 1) | ||||
| 		{ | ||||
| 			EHS_LOG_INT(LogType::ERR, 1, "Failed to use private key."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		EVP_PKEY_free(key); | ||||
| 	} | ||||
|  | ||||
| 	bool SSL::IsValid() | ||||
|   | ||||
| @@ -114,7 +114,7 @@ namespace ehs | ||||
| 		hdl = EHS_INVALID_SOCKET; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Bind(Str_8 address, const UInt_16 &port) | ||||
| 	void TCP::Bind(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		if (!IsValid() || bound || connection) | ||||
| 			return; | ||||
| @@ -124,7 +124,7 @@ namespace ehs | ||||
| 		else if (ip == IP::V4) | ||||
| 			Bind_v4(address, port); | ||||
|  | ||||
| 		this->localAddr = (Str_8 &&)address; | ||||
| 		this->localAddr = address; | ||||
| 		this->localPort = port; | ||||
|  | ||||
| 		bound = true; | ||||
| @@ -207,26 +207,26 @@ namespace ehs | ||||
| 		return client; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Connect(Str_8 address, const UInt_16 &port) | ||||
| 	void TCP::Connect(const Str_8& address, const UInt_16 port) | ||||
| 	{ | ||||
| 		if (connection || !IsValid() || listening) | ||||
| 			return; | ||||
|  | ||||
| 		remoteHostName = (Str_8 &&)address; | ||||
| 		remoteHostName = address; | ||||
| 		remotePort = port; | ||||
|  | ||||
| 		if (ip == IP::V6) | ||||
| 		{ | ||||
| 			if (IsIPv6Only()) | ||||
| 				remoteAddr = DNS::Resolve(IP::V6, remoteHostName); | ||||
| 				remoteAddr = DNS::Resolve(IP::V6, address); | ||||
| 			else | ||||
| 				remoteAddr = DNS::Resolve(remoteHostName); | ||||
| 				remoteAddr = DNS::Resolve(address); | ||||
|  | ||||
| 			Connect_v6(remoteAddr, port); | ||||
| 		} | ||||
| 		else if (ip == IP::V4) | ||||
| 		{ | ||||
| 			remoteAddr = DNS::Resolve(IP::V4, remoteHostName); | ||||
| 			remoteAddr = DNS::Resolve(IP::V4, address); | ||||
|  | ||||
| 			Connect_v4(remoteAddr, port); | ||||
| 		} | ||||
| @@ -385,30 +385,12 @@ namespace ehs | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::SetReuse(const bool &value) | ||||
| 	{ | ||||
| 		if (!IsValid()) | ||||
| 		{ | ||||
| 			EHS_LOG_INT(LogType::WARN, 1, "Attempted to set address and port reuse while socket is not initialized."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		const int result = (int)value; | ||||
| 		if (setsockopt(hdl, SOL_SOCKET, SO_REUSEPORT, &result, sizeof(int)) == -1) | ||||
| 		{ | ||||
| 			EHS_LOG_INT(LogType::ERR, 2, "Failed to set address and port reuse with error #" + Str_8::FromNum(errno) + "."); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		EHS_LOG_SUCCESS(); | ||||
| 	} | ||||
|  | ||||
| 	bool TCP::IsValid() const | ||||
| 	{ | ||||
| 		return hdl != EHS_INVALID_SOCKET; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Bind_v6(const Str_8& address, const UInt_16 &port) const | ||||
| 	void TCP::Bind_v6(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		sockaddr_in6 result = {}; | ||||
| 		result.sin6_family = AF_INET6; | ||||
| @@ -444,7 +426,7 @@ namespace ehs | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Bind_v4(const Str_8& address, const UInt_16 &port) const | ||||
| 	void TCP::Bind_v4(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		sockaddr_in result = {}; | ||||
| 		result.sin_family = AF_INET; | ||||
| @@ -479,7 +461,7 @@ namespace ehs | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Connect_v6(const Str_8 &address, const UInt_16 &port) | ||||
| 	void TCP::Connect_v6(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		sockaddr_in6 result = {}; | ||||
| 		result.sin6_family = AF_INET6; | ||||
| @@ -516,7 +498,7 @@ namespace ehs | ||||
|             } | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Connect_v4(const Str_8 &address, const UInt_16 &port) | ||||
| 	void TCP::Connect_v4(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		sockaddr_in result = {}; | ||||
| 		result.sin_family = AF_INET; | ||||
|   | ||||
| @@ -137,7 +137,7 @@ namespace ehs | ||||
| 		connected = false; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Bind(Str_8 address, const UInt_16 &port) | ||||
| 	void TCP::Bind(const Str_8& address, UInt_16 port) | ||||
| 	{ | ||||
| 		if (!IsValid() || bound || connection) | ||||
| 			return; | ||||
| @@ -147,7 +147,7 @@ namespace ehs | ||||
| 		else if (ip == IP::V4) | ||||
| 			Bind_v4(address, port); | ||||
|  | ||||
| 		this->localAddr = (Str_8 &&)address; | ||||
| 		this->localAddr = address; | ||||
| 		this->localPort = port; | ||||
|  | ||||
| 		bound = true; | ||||
| @@ -236,26 +236,26 @@ namespace ehs | ||||
| 		return client; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::Connect(Str_8 address, const UInt_16 &port) | ||||
| 	void TCP::Connect(const Str_8& address, const UInt_16 port) | ||||
| 	{ | ||||
| 		if (connection || !IsValid() || listening) | ||||
| 			return; | ||||
|  | ||||
| 		remoteHostName = (Str_8 &&)address; | ||||
| 		remoteHostName = address; | ||||
| 		remotePort = port; | ||||
|  | ||||
| 		if (ip == IP::V6) | ||||
| 		{ | ||||
| 			if (IsIPv6Only()) | ||||
| 				remoteAddr = DNS::Resolve(IP::V6, remoteHostName); | ||||
| 				remoteAddr = DNS::Resolve(IP::V6, address); | ||||
| 			else | ||||
| 				remoteAddr = DNS::Resolve(remoteHostName); | ||||
| 				remoteAddr = DNS::Resolve(address); | ||||
|  | ||||
| 			Connect_v6(remoteAddr, port); | ||||
| 		} | ||||
| 		else if (ip == IP::V4) | ||||
| 		{ | ||||
| 			remoteAddr = DNS::Resolve(IP::V4, remoteHostName); | ||||
| 			remoteAddr = DNS::Resolve(IP::V4, address); | ||||
|  | ||||
| 			Connect_v4(remoteAddr, port); | ||||
| 		} | ||||
| @@ -406,10 +406,6 @@ namespace ehs | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
| 	void TCP::SetReuse(const bool &value) | ||||
|     { | ||||
|     } | ||||
|  | ||||
| 	bool TCP::IsValid() const | ||||
| 	{ | ||||
| 		return hdl != EHS_INVALID_SOCKET; | ||||
|   | ||||
| @@ -81,7 +81,7 @@ namespace ehs | ||||
| 		authReq.SetContentType(ContentType::APP_FORMURLENCODED); | ||||
| 		authReq.BasicAuth(clientId, secret); | ||||
| 		authReq.AddToBody("grant_type", "authorization_code"); | ||||
| 		authReq.AddToBody("code", cbReq.GetQueryValue("code")); | ||||
| 		authReq.AddToBody("code", cbReq.GetQuery("code")); | ||||
| 		authReq.AddToBody("redirect_uri", rURI); | ||||
|  | ||||
| 		accounts.SendReq(authReq); | ||||
| @@ -134,7 +134,7 @@ namespace ehs | ||||
| 		StartConnection(); | ||||
|  | ||||
| 		Request req(Verb::PUT, "/v1/me/player/volume"); | ||||
| 		req.AddQueryVar({"volume_percent", Str_8::FromNum(level)}); | ||||
| 		req.AddQuery("volume_percent", Str_8::FromNum(level)); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -206,7 +206,7 @@ namespace ehs | ||||
| 		} | ||||
|  | ||||
| 		Request req(Verb::PUT, "/v1/me/player/repeat"); | ||||
| 		req.AddQueryVar({"state", result}); | ||||
| 		req.AddQuery("state", result); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -226,7 +226,7 @@ namespace ehs | ||||
| 		StartConnection(); | ||||
|  | ||||
| 		Request req(Verb::PUT, "/v1/me/player/repeat"); | ||||
| 		req.AddQueryVar({"state", state ? "true" : "false"}); | ||||
| 		req.AddQuery("state", state ? "true" : "false"); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -258,10 +258,10 @@ namespace ehs | ||||
|  | ||||
| 		q += "+track%3A" + name.ReplaceAll(" ", "+"); | ||||
|  | ||||
| 		req.AddQueryVar({"q", q}); | ||||
| 		req.AddQueryVar({"type", "track"}); | ||||
| 		req.AddQueryVar({"limit", "1"}); | ||||
| 		req.AddQueryVar({"offset", "0"}); | ||||
| 		req.AddQuery("q", q); | ||||
| 		req.AddQuery("type", "track"); | ||||
| 		req.AddQuery("limit", "1"); | ||||
| 		req.AddQuery("offset", "0"); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -454,7 +454,7 @@ namespace ehs | ||||
| 		StartConnection(); | ||||
|  | ||||
| 		Request req(Verb::POST, "/v1/me/player/queue"); | ||||
| 		req.AddQueryVar({"uri", "spotify:track:" + id}); | ||||
| 		req.AddQuery("uri", "spotify:track:" + id); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -505,8 +505,8 @@ namespace ehs | ||||
| 		StartConnection(); | ||||
|  | ||||
| 		Request req(Verb::POST, "/v1/playlists/" + playlistId + "/tracks"); | ||||
| 		req.AddQueryVar({"position", Str_8::FromNum(pos)}); | ||||
| 		req.AddQueryVar({"uris", "spotify:track:" + trackId}); | ||||
| 		req.AddQuery("position", Str_8::FromNum(pos)); | ||||
| 		req.AddQuery("uris", "spotify:track:" + trackId); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
| @@ -564,7 +564,7 @@ namespace ehs | ||||
| 		StartConnection(); | ||||
|  | ||||
| 		Request req(Verb::PUT, "/v1/me/player/seek"); | ||||
| 		req.AddQueryVar({"position_ms", Str_8::FromNum(pos)}); | ||||
| 		req.AddQuery("position_ms", Str_8::FromNum(pos)); | ||||
| 		req.BearerAuth(token); | ||||
|  | ||||
| 		client.SendReq(req); | ||||
|   | ||||
| @@ -78,7 +78,7 @@ namespace ehs | ||||
| 		authReq.SetContentType(ContentType::APP_FORMURLENCODED); | ||||
| 		authReq.AddToBody("client_id", clientId); | ||||
| 		authReq.AddToBody("client_secret", secret); | ||||
| 		authReq.AddToBody("code", cbReq.GetQueryValue("code")); | ||||
| 		authReq.AddToBody("code", cbReq.GetQuery("code")); | ||||
| 		authReq.AddToBody("grant_type", "authorization_code"); | ||||
| 		authReq.AddToBody("redirect_uri", redURI); | ||||
|  | ||||
|   | ||||
| @@ -1,24 +0,0 @@ | ||||
| #include "ehs/system/AVX2.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     bool AVX2::CompareUnaligned(const UInt_64* a, const UInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX2::CompareUnaligned(const SInt_64* a, const SInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX2::CompareAligned(const UInt_64* a, const UInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX2::CompareAligned(const SInt_64* a, const SInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
| @@ -1,49 +0,0 @@ | ||||
| global _ZN3ehs4AVX216CompareUnalignedEPKmS2_ | ||||
| global _ZN3ehs4AVX216CompareUnalignedEPKlS2_ | ||||
| global _ZN3ehs4AVX214CompareAlignedEPKmS2_ | ||||
| global _ZN3ehs4AVX214CompareAlignedEPKlS2_ | ||||
|  | ||||
| section .text | ||||
|     _ZN3ehs4AVX216CompareUnalignedEPKmS2_: | ||||
|         VMOVDQU YMM0, [RDI] | ||||
|         VMOVDQU YMM1, [RSI] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs4AVX216CompareUnalignedEPKlS2_: | ||||
|         VMOVDQU YMM0, [RDI] | ||||
|         VMOVDQU YMM1, [RSI] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs4AVX214CompareAlignedEPKmS2_: | ||||
|         VMOVDQA YMM0, [RDI] | ||||
|         VMOVDQA YMM1, [RSI] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs4AVX214CompareAlignedEPKlS2_: | ||||
|         VMOVDQA YMM0, [RDI] | ||||
|         VMOVDQA YMM1, [RSI] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
| @@ -1,49 +0,0 @@ | ||||
| global ?CompareUnaligned@AVX2@ehs@@SA_NPEBK0@Z | ||||
| global ?CompareUnaligned@AVX2@ehs@@SA_NPEBJ0@Z | ||||
| global ?CompareAligned@AVX2@ehs@@SA_NPEBK0@Z | ||||
| global ?CompareAligned@AVX2@ehs@@SA_NPEBJ0@Z | ||||
|  | ||||
| section .text | ||||
|     ?CompareUnaligned@AVX2@ehs@@SA_NPEBK0@Z: | ||||
|         VMOVDQU YMM0, [RCX] | ||||
|         VMOVDQU YMM1, [RDX] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     ?CompareUnaligned@AVX2@ehs@@SA_NPEBJ0@Z: | ||||
|         VMOVDQU YMM0, [RCX] | ||||
|         VMOVDQU YMM1, [RDX] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     ?CompareAligned@AVX2@ehs@@SA_NPEBK0@Z: | ||||
|         VMOVDQA YMM0, [RCX] | ||||
|         VMOVDQA YMM1, [RDX] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     ?CompareAligned@AVX2@ehs@@SA_NPEBJ0@Z: | ||||
|         VMOVDQA YMM0, [RCX] | ||||
|         VMOVDQA YMM1, [RDX] | ||||
|         VPCMPEQQ YMM2, YMM0, YMM1 | ||||
|  | ||||
|         VPMOVMSKB EAX, YMM2 | ||||
|         CMP EAX, 0xFFFFFFFF | ||||
|         SETE AL | ||||
|  | ||||
|         RET | ||||
| @@ -1,24 +0,0 @@ | ||||
| #include "ehs/system/AVX512.h" | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
|     bool AVX512::CompareUnaligned(const UInt_64* a, const UInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX512::CompareUnaligned(const SInt_64* a, const SInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX512::CompareAligned(const UInt_64* a, const UInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     bool AVX512::CompareAligned(const SInt_64* a, const SInt_64* b) | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
| @@ -1,49 +0,0 @@ | ||||
| global _ZN3ehs6AVX51216CompareUnalignedEPKmS2_ | ||||
| global _ZN3ehs6AVX51216CompareUnalignedEPKlS2_ | ||||
| global _ZN3ehs6AVX51214CompareAlignedEPKmS2_ | ||||
| global _ZN3ehs6AVX51214CompareAlignedEPKlS2_ | ||||
|  | ||||
| section .text | ||||
|     _ZN3ehs6AVX51216CompareUnalignedEPKmS2_: | ||||
|         VMOVDQU64 ZMM0, [RDI] | ||||
|         VMOVDQU64 ZMM1, [RSI] | ||||
|  | ||||
|         VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
|         KORTESTQ K1, K1 | ||||
|         SETC AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs6AVX51216CompareUnalignedEPKlS2_: | ||||
|         VMOVDQU64 ZMM0, [RDI] | ||||
|         VMOVDQU64 ZMM1, [RSI] | ||||
|  | ||||
|         VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
|         KORTESTQ K1, K1 | ||||
|         SETC AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs6AVX51214CompareAlignedEPKmS2_: | ||||
|         VMOVDQA64 ZMM0, [RDI] | ||||
|         VMOVDQA64 ZMM1, [RSI] | ||||
|  | ||||
|         VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
|         KORTESTQ K1, K1 | ||||
|         SETC AL | ||||
|  | ||||
|         RET | ||||
|  | ||||
|     _ZN3ehs6AVX51214CompareAlignedEPKlS2_: | ||||
|         VMOVDQA64 ZMM0, [RDI] | ||||
|         VMOVDQA64 ZMM1, [RSI] | ||||
|  | ||||
|         VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
|         KORTESTQ K1, K1 | ||||
|         SETC AL | ||||
|  | ||||
|         RET | ||||
| @@ -1,49 +0,0 @@ | ||||
| global ?CompareUnaligned@AVX512@ehs@@SA_NPEBK0@Z | ||||
| global ?CompareUnaligned@AVX512@ehs@@SA_NPEBJ0@Z | ||||
| global ?CompareAligned@AVX512@ehs@@SA_NPEBK0@Z | ||||
| global ?CompareAligned@AVX512@ehs@@SA_NPEBJ0@Z | ||||
|  | ||||
| section .text | ||||
| 	?CompareUnaligned@AVX512@ehs@@SA_NPEBK0@Z: | ||||
| 		VMOVDQU64 ZMM0, [RCX] | ||||
| 		VMOVDQU64 ZMM1, [RDX] | ||||
|  | ||||
| 		VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
| 		KORTESTQ K1, K1 | ||||
| 		SETC AL | ||||
|  | ||||
| 		RET | ||||
|  | ||||
| 	?CompareUnaligned@AVX512@ehs@@SA_NPEBJ0@Z: | ||||
| 		VMOVDQU64 ZMM0, [RCX] | ||||
| 		VMOVDQU64 ZMM1, [RDX] | ||||
|  | ||||
| 		VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
| 		KORTESTQ K1, K1 | ||||
| 		SETC AL | ||||
|  | ||||
| 		RET | ||||
|  | ||||
| 	?CompareAligned@AVX512@ehs@@SA_NPEBK0@Z: | ||||
| 		VMOVDQA64 ZMM0, [RCX] | ||||
| 		VMOVDQA64 ZMM1, [RDX] | ||||
|  | ||||
| 		VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
| 		KORTESTQ K1, K1 | ||||
| 		SETC AL | ||||
|  | ||||
| 		RET | ||||
|  | ||||
| 	?CompareAligned@AVX512@ehs@@SA_NPEBJ0@Z: | ||||
| 		VMOVDQA64 ZMM0, [RCX] | ||||
| 		VMOVDQA64 ZMM1, [RDX] | ||||
|  | ||||
| 		VPCMPEQQ K1, ZMM0, ZMM1 | ||||
|  | ||||
| 		KORTESTQ K1, K1 | ||||
| 		SETC AL | ||||
|  | ||||
| 		RET | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	void BaseSystem::OpenURI(Str_8 uri) | ||||
| 	void BaseSystem::OpenURI(const Str_8& uri) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -10,75 +10,11 @@ namespace ehs | ||||
| 		UInt_64 CPU::TSC_Freq = 0; | ||||
|     #endif | ||||
|  | ||||
|     const bool CPU::hasFPU = RetrieveFPU(); | ||||
|     const bool CPU::hasVME = RetrieveVME(); | ||||
|     const bool CPU::hasDE = RetrieveDE(); | ||||
|     const bool CPU::hasPSE = RetrievePSE(); | ||||
|     const bool CPU::hasTSC = RetrieveTSC(); | ||||
|     const bool CPU::hasMSR = RetrieveMSR(); | ||||
|     const bool CPU::hasPAE = RetrievePAE(); | ||||
|     const bool CPU::hasMCE = RetrieveMCE(); | ||||
|     const bool CPU::hasCX8 = RetrieveCX8(); | ||||
|     const bool CPU::hasAPIC = RetrieveAPIC(); | ||||
|     const bool CPU::hasSEP = RetrieveSEP(); | ||||
|     const bool CPU::hasMTRR = RetrieveMTRR(); | ||||
|     const bool CPU::hasPGE = RetrievePGE(); | ||||
|     const bool CPU::hasMCA = RetrieveMCA(); | ||||
|     const bool CPU::hasCMOV = RetrieveCMOV(); | ||||
|     const bool CPU::hasPSE_36 = RetrievePSE_36(); | ||||
|     const bool CPU::hasPSN = RetrievePSN(); | ||||
|     const bool CPU::hasCLFSH = RetrieveCLFSH(); | ||||
|     const bool CPU::hasDS = RetrieveDS(); | ||||
|     const bool CPU::hasACPI = RetrieveACPI(); | ||||
|     const bool CPU::hasMMX = RetrieveMMX(); | ||||
|     const bool CPU::hasFXSR = RetrieveFXSR(); | ||||
|     const bool CPU::hasSSE = RetrieveSSE(); | ||||
|     const bool CPU::hasSSE2 = RetrieveSSE2(); | ||||
|     const bool CPU::hasSS = RetrieveSS(); | ||||
|     const bool CPU::hasHTT = RetrieveHTT(); | ||||
|     const bool CPU::hasTM = RetrieveTM(); | ||||
|     const bool CPU::hasIA64 = RetrieveIA64(); | ||||
|     const bool CPU::hasPBE = RetrievePBE(); | ||||
|     const bool CPU::hasSSE3 = RetrieveSSE3(); | ||||
|     const bool CPU::hasPCLMULQDQ = RetrievePCLMULQDQ(); | ||||
|     const bool CPU::hasDTES64 = RetrieveDTES64(); | ||||
|     const bool CPU::hasMONITOR = RetrieveMONITOR(); | ||||
|     const bool CPU::hasVMX = RetrieveVMX(); | ||||
|     const bool CPU::hasSMX = RetrieveSMX(); | ||||
|     const bool CPU::hasEST = RetrieveEST(); | ||||
|     const bool CPU::hasTM2 = RetrieveTM2(); | ||||
|     const bool CPU::hasSSSE3 = RetrieveSSSE3(); | ||||
|     const bool CPU::hasCNXT_ID = RetrieveCNXT_ID(); | ||||
|     const bool CPU::hasSDBG = RetrieveSDBG(); | ||||
|     const bool CPU::hasFMA = RetrieveFMA(); | ||||
|     const bool CPU::hasCX16 = RetrieveCX16(); | ||||
|     const bool CPU::hasXTPR = RetrieveXTPR(); | ||||
|     const bool CPU::hasPDCM = RetrievePDCM(); | ||||
|     const bool CPU::hasPCID = RetrievePCID(); | ||||
|     const bool CPU::hasDCA = RetrieveDCA(); | ||||
|     const bool CPU::hasSSE4_1 = RetrieveSSE4_1(); | ||||
|     const bool CPU::hasSSE4_2 = RetrieveSSE4_2(); | ||||
|     const bool CPU::hasX2APIC = RetrieveX2APIC(); | ||||
|     const bool CPU::hasMOVBE = RetrieveMOVBE(); | ||||
|     const bool CPU::hasPOPCNT = RetrievePOPCNT(); | ||||
|     const bool CPU::hasTSC_DEADLINE = RetrieveTSC_DEADLINE(); | ||||
|     const bool CPU::hasAES = RetrieveAES(); | ||||
|     const bool CPU::hasXSAVE = RetrieveXSAVE(); | ||||
|     const bool CPU::hasOSXSAVE = RetrieveOSXSAVE(); | ||||
|     const bool CPU::hasAVX = RetrieveAVX(); | ||||
|     const bool CPU::hasF16C = RetrieveF16C(); | ||||
|     const bool CPU::hasRDRND = RetrieveRDRND(); | ||||
|     const bool CPU::hasHYPERVISOR = RetrieveHYPERVISOR(); | ||||
|     const bool CPU::hasAVX2 = RetrieveAVX2(); | ||||
|     const bool CPU::hasAVX512F = RetrieveAVX512F(); | ||||
|     const bool CPU::hasRDSEED = RetrieveRDSEED(); | ||||
|     const bool CPU::hasADX = RetrieveADX(); | ||||
|  | ||||
| 	Architecture CPU::GetArchitecture() | ||||
| 	{ | ||||
| 		#if defined(EHS_ARCH_X64) | ||||
| 			return Architecture::X64; | ||||
| 		#elif defined(EHS_ARCH_AARCH64) | ||||
| 		#elif defined(EHS_ARCH_ARM64) | ||||
| 			return Architecture::ARM64; | ||||
| 		#else | ||||
| 			return Architecture::UNKNOWN; | ||||
| @@ -113,19 +49,13 @@ namespace ehs | ||||
|  | ||||
| 			return frequency.QuadPart; | ||||
|         #elif defined(EHS_OS_LINUX) | ||||
|             #if defined(EHS_ARCH_X64) | ||||
|             if (!TSC_Freq) | ||||
|                 TSC_Freq = RetrieveTSC_Freq(); | ||||
|  | ||||
|             return TSC_Freq; | ||||
|             #elif defined(EHS_ARCH_AARCH64) | ||||
| 	            return RetrieveFreq_AARCH64(); | ||||
|             #else | ||||
| 	            return 0; | ||||
| 		#endif | ||||
|         #else | ||||
|  | ||||
| 		return 0; | ||||
| 		#endif | ||||
| 	} | ||||
|  | ||||
| 	UInt_64 CPU::GetTSC() | ||||
| @@ -139,7 +69,7 @@ namespace ehs | ||||
|             TSC tsc; | ||||
|             RDTSCP(&tsc); | ||||
|  | ||||
|             #if defined(EHS_ARCH_X64) || defined(EHS_ARCH_AARCH64) | ||||
|             #if defined(EHS_ARCH_X64) | ||||
| 				UInt_64 result = 0; | ||||
|  | ||||
|                 #if defined(EHS_LITTLE_ENDIAN) | ||||
| @@ -189,589 +119,324 @@ namespace ehs | ||||
|         return (UInt_8)(GetInfoBits() >> 20); | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveFPU() | ||||
|     bool CPU::HasFPU() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000000001; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveVME() | ||||
|     bool CPU::HasVME() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000000010; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveDE() | ||||
|     bool CPU::HasDE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000000100; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePSE() | ||||
|     bool CPU::HasPSE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000001000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveTSC() | ||||
|     bool CPU::HasTSC() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000010000; | ||||
|         #else | ||||
| 	            return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMSR() | ||||
|     bool CPU::HasMSR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000000100000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePAE() | ||||
|     bool CPU::HasPAE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000001000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMCE() | ||||
|     bool CPU::HasMCE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000010000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveCX8() | ||||
|     bool CPU::HasCX8() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000000100000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveAPIC() | ||||
|     bool CPU::HasAPIC() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000001000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSEP() | ||||
|     bool CPU::HasSEP() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000000100000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMTRR() | ||||
|     bool CPU::HasMTRR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000001000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePGE() | ||||
|     bool CPU::HasPGE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000010000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMCA() | ||||
|     bool CPU::HasMCA() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000000100000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveCMOV() | ||||
|     bool CPU::HasCMOV() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000001000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePAT() | ||||
|     bool CPU::HasPAT() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000010000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePSE_36() | ||||
|     bool CPU::HasPSE_36() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000000100000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePSN() | ||||
|     bool CPU::HasPSN() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000001000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveCLFSH() | ||||
|     bool CPU::HasCLFSH() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000000010000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveDS() | ||||
|     bool CPU::HasDS() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000001000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveACPI() | ||||
|     bool CPU::HasACPI() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000010000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMMX() | ||||
|     bool CPU::HasMMX() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000000100000000000000000000000; | ||||
|         #else | ||||
| 	            return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveFXSR() | ||||
|     bool CPU::HasFXSR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000001000000000000000000000000; | ||||
|         #else | ||||
| 	            return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSE() | ||||
|     bool CPU::HasSSE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000010000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSE2() | ||||
|     bool CPU::HasSSE2() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00000100000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSS() | ||||
|     bool CPU::HasSS() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00001000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveHTT() | ||||
|     bool CPU::HasHTT() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00010000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveTM() | ||||
|     bool CPU::HasTM() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b00100000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveIA64() | ||||
|     bool CPU::HasIA64() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b01000000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePBE() | ||||
|     bool CPU::HasPBE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_1() & 0b10000000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSE3() | ||||
|     bool CPU::HasSSE3() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000000001; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePCLMULQDQ() | ||||
|     bool CPU::HasPCLMULQDQ() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000000010; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveDTES64() | ||||
|     bool CPU::HasDTES64() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000000100; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMONITOR() | ||||
|     bool CPU::HasMONITOR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000001000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveDS_CPL() | ||||
|     bool CPU::HasDS_CPL() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000010000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveVMX() | ||||
|     bool CPU::HasVMX() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000000100000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSMX() | ||||
|     bool CPU::HasSMX() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000001000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveEST() | ||||
|     bool CPU::HasEST() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000010000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveTM2() | ||||
|     bool CPU::HasTM2() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000000100000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSSE3() | ||||
|     bool CPU::HasSSSE3() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000001000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveCNXT_ID() | ||||
|     bool CPU::HasCNXT_ID() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000010000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSDBG() | ||||
|     bool CPU::HasSDBG() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000000100000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveFMA() | ||||
|     bool CPU::HasFMA() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000001000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveCX16() | ||||
|     bool CPU::HasCX16() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000010000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveXTPR() | ||||
|     bool CPU::HasXTPR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000000100000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePDCM() | ||||
|     bool CPU::HasPDCM() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000001000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePCID() | ||||
|     bool CPU::HasPCID() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000000100000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveDCA() | ||||
|     bool CPU::HasDCA() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000001000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSE4_1() | ||||
|     bool CPU::HasSSE4_1() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000010000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveSSE4_2() | ||||
|     bool CPU::HasSSE4_2() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000000100000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveX2APIC() | ||||
|     bool CPU::HasX2APIC() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000001000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveMOVBE() | ||||
|     bool CPU::HasMOVBE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000010000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrievePOPCNT() | ||||
|     bool CPU::HasPOPCNT() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000000100000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveTSC_DEADLINE() | ||||
|     bool CPU::HasTSC_DEADLINE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000001000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveAES() | ||||
|     bool CPU::HasAES() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000010000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveXSAVE() | ||||
|     bool CPU::HasXSAVE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00000100000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveOSXSAVE() | ||||
|     bool CPU::HasOSXSAVE() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00001000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveAVX() | ||||
|     bool CPU::HasAVX() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00010000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveF16C() | ||||
|     bool CPU::HasF16C() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b00100000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveRDRND() | ||||
|     bool CPU::HasRDRND() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b01000000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveHYPERVISOR() | ||||
|     bool CPU::HasHYPERVISOR() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetFeatureBits_2() & 0b10000000000000000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveAVX2() | ||||
|     bool CPU::HasAVX2() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetExtFeatureBits_1() & 0b00000000000000000000000000100000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveAVX512F() | ||||
|     bool CPU::HasRDSEED() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
| 	            return GetExtFeatureBits_1() & 0b00000000000000010000000000000000; | ||||
|         #else | ||||
| 	            return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveRDSEED() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetExtFeatureBits_1() & 0b00000000000001000000000000000000; | ||||
|         #else | ||||
| 	        return false; | ||||
|         #endif | ||||
|     } | ||||
|  | ||||
|     bool CPU::RetrieveADX() | ||||
|     bool CPU::HasADX() | ||||
|     { | ||||
|         #ifdef EHS_ARCH_X64 | ||||
|         return GetExtFeatureBits_1() & 0b00000000000010000000000000000000; | ||||
| 	    #else | ||||
| 	        return false; | ||||
| 	    #endif | ||||
|     } | ||||
|  | ||||
| 	/* | ||||
|   | ||||
| @@ -2,6 +2,10 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	void CPU::RDTSCP(TSC* tsc) | ||||
| 	{ | ||||
| 	} | ||||
|  | ||||
| 	void CPU::GetManufacturer(Char_8* input) | ||||
| 	{ | ||||
| 	} | ||||
|   | ||||
| @@ -1,14 +0,0 @@ | ||||
| .global _ZN3ehs3CPU6RDTSCPEPNS_3TSCE | ||||
| .global _ZN3ehs3CPU20RetrieveFreq_AARCH64Ev | ||||
|  | ||||
| .section .text | ||||
| 	_ZN3ehs3CPU6RDTSCPEPNS_3TSCE: | ||||
| 		MRS X2, CNTVCT_EL0 | ||||
| 		EOR W1, W1, W1 | ||||
| 		STR W1, [X0] | ||||
| 		STR X2, [X0, #4] | ||||
| 		RET | ||||
|  | ||||
| 	_ZN3ehs3CPU20RetrieveFreq_AARCH64Ev: | ||||
| 		MRS X0, CNTFRQ_EL0 | ||||
| 		RET | ||||
| @@ -13,17 +13,13 @@ namespace ehs | ||||
|  | ||||
| 		system("xdg-open \"" + *uri + "\""); | ||||
|  | ||||
| 		delete uri; | ||||
|  | ||||
| 		return 0; | ||||
| 	} | ||||
|  | ||||
| 	void System::OpenURI(Str_8 uri) | ||||
| 	void System::OpenURI(const Str_8& uri) | ||||
| 	{ | ||||
| 		Str_8 *arg = new Str_8((Str_8&&)uri); | ||||
|  | ||||
| 		Thread xdg; | ||||
| 		xdg.Start(XDG_Thread, arg); | ||||
| 		xdg.Start(XDG_Thread, (void*)&uri); | ||||
| 		xdg.Detach(); | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  | ||||
| namespace ehs | ||||
| { | ||||
| 	void System::OpenURI(Str_8 uri) | ||||
| 	void System::OpenURI(const Str_8& uri) | ||||
| 	{ | ||||
| 		ShellExecuteA(nullptr, "open", uri, nullptr, nullptr, SW_SHOW); | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user