mirror of
				https://github.com/fedddddd/iw5-gsc-utils.git
				synced 2025-10-26 15:25:53 +00:00 
			
		
		
		
	Compare commits
	
		
			59 Commits
		
	
	
		
			v1.3.2
			...
			dependabot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 0a98694008 | ||
|  | 1061c08829 | ||
|  | c75cf561f7 | ||
|  | 3ea6050498 | ||
|  | 1551d7f1fd | ||
|  | bf1d649bc1 | ||
|  | 71727a5197 | ||
|  | 530cd10466 | ||
|  | 978e251df8 | ||
|  | cb96052638 | ||
|  | 9b217b20e3 | ||
|  | 136a723187 | ||
|  | ad27dcb098 | ||
|  | 96acf0718e | ||
|  | 72f936e82a | ||
|  | 9a11ac82b3 | ||
|  | 8f36c271fd | ||
|  | e952b8a0f7 | ||
|  | f6d78fd815 | ||
|  | cadcca22f9 | ||
|  | c04a0a0d8c | ||
|  | 61706336ce | ||
|  | eb08109392 | ||
|  | b23cb2014b | ||
|  | 4d979bf659 | ||
|  | 206d06dc7d | ||
|  | 4d8af4bd45 | ||
|  | 46ab288488 | ||
|  | dd8c1ff71e | ||
|  | ed1ac62153 | ||
|  | 7f7fd016cf | ||
|  | 6c093888b5 | ||
|  | 1440760aa5 | ||
|  | 105c11a8b2 | ||
|  | 795f8ac162 | ||
|  | 6dd4d2651a | ||
|  | b2f030f349 | ||
|  | 2690eeeece | ||
|  | 098bd21008 | ||
|  | 2f474e979f | ||
|  | 2ab4da0ad9 | ||
|  | 28c5594094 | ||
|  | 6525bbb8bf | ||
|  | 1a9e3dfb15 | ||
|  | c62f1995e7 | ||
|  | 883e38ae58 | ||
|  | 1b2d4dbc46 | ||
|  | 7dfb35233e | ||
|  | d842022056 | ||
|  | 0a8ebc3058 | ||
|  | 8ccae5ddec | ||
|  | cfb143f0fd | ||
|  | 0281b5bef6 | ||
|  | 70a91b271d | ||
|  | a7576ea765 | ||
|  | 3a492f51d9 | ||
|  | d4ba37cde5 | ||
|  | 2ded4c6a2a | ||
|  | 24b3a9369e | 
							
								
								
									
										7
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.github/dependabot.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | version: 2 | ||||||
|  | updates: | ||||||
|  | - package-ecosystem: gitsubmodule | ||||||
|  |   directory: "/" | ||||||
|  |   schedule: | ||||||
|  |     interval: daily | ||||||
|  |   open-pull-requests-limit: 10 | ||||||
							
								
								
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | |||||||
|  | name: Build | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |       - "*" | ||||||
|  |   pull_request: | ||||||
|  |     branches: | ||||||
|  |       - "*" | ||||||
|  |     types: [opened, synchronize, reopened] | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |     name: Build binaries | ||||||
|  |     runs-on: windows-2022 | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         configuration: | ||||||
|  |           - Debug | ||||||
|  |           - Release | ||||||
|  |     steps: | ||||||
|  |       - name: Check out files | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |         with: | ||||||
|  |           submodules: true | ||||||
|  |           fetch-depth: 0 | ||||||
|  |           lfs: false | ||||||
|  |  | ||||||
|  |       - name: Add msbuild to PATH | ||||||
|  |         uses: microsoft/setup-msbuild@v1.1.3 | ||||||
|  |  | ||||||
|  |       - name: Generate project files | ||||||
|  |         run: tools/premake5 vs2022 | ||||||
|  |  | ||||||
|  |       - name: Set up problem matching | ||||||
|  |         uses: ammaraskar/msvc-problem-matcher@master | ||||||
|  |  | ||||||
|  |       - name: Build ${{matrix.configuration}} binaries | ||||||
|  |         run: msbuild /m /v:minimal /p:Configuration=${{matrix.configuration}} /p:PlatformTarget=x86 build/iw5-gsc-utils.sln | ||||||
|  |  | ||||||
|  |       - name: Upload ${{matrix.configuration}} binaries | ||||||
|  |         uses: actions/upload-artifact@v3.1.0 | ||||||
|  |         with: | ||||||
|  |           name: ${{matrix.configuration}} binaries | ||||||
|  |           path: | | ||||||
|  |             build/bin/${{matrix.configuration}}/iw5-gsc-utils.dll | ||||||
							
								
								
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -8,3 +8,9 @@ | |||||||
| 	path = deps/json | 	path = deps/json | ||||||
| 	url = https://github.com/nlohmann/json.git | 	url = https://github.com/nlohmann/json.git | ||||||
| 	branch = develop | 	branch = develop | ||||||
|  | [submodule "deps/gsc-tool"] | ||||||
|  | 	path = deps/gsc-tool | ||||||
|  | 	url = https://github.com/xensik/gsc-tool.git | ||||||
|  | [submodule "deps/zlib"] | ||||||
|  | 	path = deps/zlib | ||||||
|  | 	url = https://github.com/madler/zlib.git | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								deps/GSL
									
									
									
									
										vendored
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								deps/GSL
									
									
									
									
										vendored
									
									
								
							 Submodule deps/GSL updated: c31a9ad5e8...b39e7e4b09
									
								
							
							
								
								
									
										1
									
								
								deps/gsc-tool
									
									
									
									
										vendored
									
									
										Submodule
									
								
							
							
								
								
								
								
								
							
						
						
									
										1
									
								
								deps/gsc-tool
									
									
									
									
										vendored
									
									
										Submodule
									
								
							 Submodule deps/gsc-tool added at 0e6238a6ab
									
								
							
							
								
								
									
										2
									
								
								deps/json
									
									
									
									
										vendored
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								deps/json
									
									
									
									
										vendored
									
									
								
							 Submodule deps/json updated: e4643d1f1b...0457de21cf
									
								
							
							
								
								
									
										2
									
								
								deps/minhook
									
									
									
									
										vendored
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								deps/minhook
									
									
									
									
										vendored
									
									
								
							 Submodule deps/minhook updated: 423d1e45af...f5485b8454
									
								
							
							
								
								
									
										62
									
								
								deps/premake/gsc-tool.lua
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								deps/premake/gsc-tool.lua
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | |||||||
|  | gsc_tool = { | ||||||
|  | 	source = path.join(dependencies.basePath, "gsc-tool"), | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function gsc_tool.import() | ||||||
|  | 	links { "xsk-gsc-iw5-pc", "xsk-gsc-utils" } | ||||||
|  | 	gsc_tool.includes() | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function gsc_tool.includes() | ||||||
|  | 	includedirs { | ||||||
|  | 		path.join(gsc_tool.source, "include"), | ||||||
|  | 	} | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function gsc_tool.project() | ||||||
|  | 	project "xsk-gsc-utils" | ||||||
|  | 		kind "StaticLib" | ||||||
|  | 		language "C++" | ||||||
|  |  | ||||||
|  | 		files { | ||||||
|  | 			path.join(gsc_tool.source, "include/xsk/utils/*.hpp"), | ||||||
|  | 			path.join(gsc_tool.source, "src/utils/*.cpp"), | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		includedirs { | ||||||
|  | 			path.join(gsc_tool.source, "include"), | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		zlib.includes() | ||||||
|  |  | ||||||
|  | 	project "xsk-gsc-iw5-pc" | ||||||
|  | 		kind "StaticLib" | ||||||
|  | 		language "C++" | ||||||
|  |  | ||||||
|  | 		filter "action:vs*" | ||||||
|  | 			buildoptions "/Zc:__cplusplus" | ||||||
|  | 		filter {} | ||||||
|  |  | ||||||
|  | 		files { | ||||||
|  | 			path.join(gsc_tool.source, "include/xsk/stdinc.hpp"), | ||||||
|  |  | ||||||
|  | 			path.join(gsc_tool.source, "include/xsk/gsc/engine/iw5_pc.hpp"), | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/engine/iw5_pc.cpp"), | ||||||
|  |  | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/engine/iw5_pc_code.cpp"), | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/engine/iw5_pc_func.cpp"), | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/engine/iw5_pc_meth.cpp"), | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/engine/iw5_pc_token.cpp"), | ||||||
|  |  | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/*.cpp"), | ||||||
|  |  | ||||||
|  | 			path.join(gsc_tool.source, "src/gsc/common/*.cpp"), | ||||||
|  | 			path.join(gsc_tool.source, "include/xsk/gsc/common/*.hpp"), | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		includedirs { | ||||||
|  | 			path.join(gsc_tool.source, "include"), | ||||||
|  | 		} | ||||||
|  | end | ||||||
|  |  | ||||||
|  | table.insert(dependencies, gsc_tool) | ||||||
							
								
								
									
										39
									
								
								deps/premake/zlib.lua
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								deps/premake/zlib.lua
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | zlib = { | ||||||
|  | 	source = path.join(dependencies.basePath, "zlib"), | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function zlib.import() | ||||||
|  | 	links { "zlib" } | ||||||
|  | 	zlib.includes() | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function zlib.includes() | ||||||
|  | 	includedirs { | ||||||
|  | 		zlib.source | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	defines { | ||||||
|  | 		"ZLIB_CONST", | ||||||
|  | 	} | ||||||
|  | end | ||||||
|  |  | ||||||
|  | function zlib.project() | ||||||
|  | 	project "zlib" | ||||||
|  | 		language "C" | ||||||
|  |  | ||||||
|  | 		zlib.includes() | ||||||
|  |  | ||||||
|  | 		files { | ||||||
|  | 			path.join(zlib.source, "*.h"), | ||||||
|  | 			path.join(zlib.source, "*.c"), | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		defines { | ||||||
|  | 			"_CRT_SECURE_NO_DEPRECATE", | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		warnings "Off" | ||||||
|  | 		kind "StaticLib" | ||||||
|  | end | ||||||
|  |  | ||||||
|  | table.insert(dependencies, zlib) | ||||||
							
								
								
									
										1
									
								
								deps/zlib
									
									
									
									
										vendored
									
									
										Submodule
									
								
							
							
								
								
								
								
								
							
						
						
									
										1
									
								
								deps/zlib
									
									
									
									
										vendored
									
									
										Submodule
									
								
							 Submodule deps/zlib added at 0f51fb4933
									
								
							| @@ -1,3 +1,3 @@ | |||||||
| @echo off | @echo off | ||||||
| call git submodule update --init --recursive | call git submodule update --init --recursive | ||||||
| tools\windows\premake5.exe vs2022 | tools\premake5.exe vs2022 | ||||||
|   | |||||||
| @@ -21,13 +21,13 @@ namespace gsc | |||||||
| 	{ | 	{ | ||||||
| 		std::string method_name(unsigned int id) | 		std::string method_name(unsigned int id) | ||||||
| 		{ | 		{ | ||||||
| 			const auto& map = *game::plutonium::method_map_rev; | 			const auto& map = (*game::plutonium::gsc_ctx)->meth_map(); | ||||||
|  |  | ||||||
| 			for (const auto& function : map) | 			for (const auto& function : map) | ||||||
| 			{ | 			{ | ||||||
| 				if (function.second == id) | 				if (function.second == id) | ||||||
| 				{ | 				{ | ||||||
| 					return function.first; | 					return function.first.data(); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -36,13 +36,13 @@ namespace gsc | |||||||
|  |  | ||||||
| 		std::string function_name(unsigned int id) | 		std::string function_name(unsigned int id) | ||||||
| 		{ | 		{ | ||||||
| 			const auto& map = *game::plutonium::function_map_rev; | 			const auto& map = (*game::plutonium::gsc_ctx)->func_map(); | ||||||
|  |  | ||||||
| 			for (const auto& function : map) | 			for (const auto& function : map) | ||||||
| 			{ | 			{ | ||||||
| 				if (function.second == id) | 				if (function.second == id) | ||||||
| 				{ | 				{ | ||||||
| 					return function.first; | 					return function.first.data(); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -248,10 +248,21 @@ namespace gsc | |||||||
| 	{ | 	{ | ||||||
| 		void add(const std::string& name, const script_function& func) | 		void add(const std::string& name, const script_function& func) | ||||||
| 		{ | 		{ | ||||||
| 			const auto index = function_map_start++; | 			auto index = 0u; | ||||||
|  | 			auto& ctx = (*game::plutonium::gsc_ctx); | ||||||
| 			 | 			 | ||||||
| 			functions[index] = func; | 			if (ctx->func_exists(name)) | ||||||
| 			(*game::plutonium::function_map_rev)[name] = index; | 			{ | ||||||
|  | 				printf("[iw5-gsc-utils] Warning: function '%s' already defined\n", name.data()); | ||||||
|  | 				index = ctx->func_id(name); | ||||||
|  | 			} | ||||||
|  | 			else | ||||||
|  | 			{ | ||||||
|  | 				index = function_map_start++; | ||||||
|  | 				ctx->func_add(name, index); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			functions.insert(std::make_pair(index, func)); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -259,10 +270,21 @@ namespace gsc | |||||||
| 	{ | 	{ | ||||||
| 		void add(const std::string& name, const script_method& func) | 		void add(const std::string& name, const script_method& func) | ||||||
| 		{ | 		{ | ||||||
| 			const auto index = method_map_start++; | 			auto index = 0u; | ||||||
|  | 			auto& ctx = (*game::plutonium::gsc_ctx); | ||||||
|  |  | ||||||
| 			methods[index] = func; | 			if (ctx->meth_exists(name)) | ||||||
| 			(*game::plutonium::method_map_rev)[name] = index; | 			{ | ||||||
|  | 				printf("[iw5-gsc-utils] Warning: method '%s' already defined\n", name.data()); | ||||||
|  | 				index = ctx->meth_id(name); | ||||||
|  | 			} | ||||||
|  | 			else | ||||||
|  | 			{ | ||||||
|  | 				index = method_map_start++; | ||||||
|  | 				ctx->meth_add(name, index); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			methods.insert(std::make_pair(index, func)); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -272,25 +294,13 @@ namespace gsc | |||||||
| 			const std::function<scripting::script_value(unsigned int entnum)>& getter, | 			const std::function<scripting::script_value(unsigned int entnum)>& getter, | ||||||
| 			const std::function<void(unsigned int entnum, const scripting::script_value&)>& setter) | 			const std::function<void(unsigned int entnum, const scripting::script_value&)>& setter) | ||||||
| 		{ | 		{ | ||||||
| 			uint16_t token_id{}; |  | ||||||
| 			auto& token_map = *game::plutonium::token_map_rev; |  | ||||||
| 			if (token_map.find(name) != token_map.end()) |  | ||||||
| 			{ |  | ||||||
| 				token_id = token_map.at(name); |  | ||||||
| 			} |  | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
| 				token_id = token_map_start++; |  | ||||||
| 				token_map.insert(std::make_pair(name, token_id)); |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			const auto offset = field_offset_start++; | 			const auto offset = field_offset_start++; | ||||||
| 			custom_fields[classnum][offset] = {name, getter, setter}; | 			custom_fields[classnum][offset] = {name, getter, setter}; | ||||||
|  |  | ||||||
| 			post_load_callbacks.push_back([classnum, name, token_id, offset]() | 			post_load_callbacks.push_back([=]() | ||||||
| 			{ | 			{ | ||||||
| 				const auto name_str = game::SL_GetString(name.data(), 0); | 				const auto name_str = game::SL_GetString(name.data(), 0); | ||||||
| 				game::Scr_AddClassField(classnum, name_str, token_id, offset); | 				game::Scr_AddClassField(classnum, name_str, game::SL_GetCanonicalString(name.data()), offset); | ||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -35,11 +35,18 @@ namespace signatures | |||||||
| 		const auto base = reinterpret_cast<size_t>(GetModuleHandle("plutonium-bootstrapper-win32.exe")); | 		const auto base = reinterpret_cast<size_t>(GetModuleHandle("plutonium-bootstrapper-win32.exe")); | ||||||
| 		utils::hook::signature signature(base, get_image_size() - base); | 		utils::hook::signature signature(base, get_image_size() - base); | ||||||
|  |  | ||||||
|  | 		auto found = false; | ||||||
| 		signature.add({ | 		signature.add({ | ||||||
| 			string, | 			string, | ||||||
| 			mask, | 			mask, | ||||||
| 			[&](char* address) | 			[&](char* address) | ||||||
| 			{ | 			{ | ||||||
|  | 				if (found) | ||||||
|  | 				{ | ||||||
|  | 					return; | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				found = true; | ||||||
| 				string_ptr = address; | 				string_ptr = address; | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
| @@ -52,23 +59,26 @@ namespace signatures | |||||||
| 	{ | 	{ | ||||||
| 		char bytes[4] = {0}; | 		char bytes[4] = {0}; | ||||||
| 		const auto string_ptr = find_string_ptr(string); | 		const auto string_ptr = find_string_ptr(string); | ||||||
| 		memcpy(bytes, &string_ptr, sizeof(bytes)); | 		if (!string_ptr) | ||||||
|  | 		{ | ||||||
|  | 			return 0; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		std::memcpy(bytes, &string_ptr, sizeof(bytes)); | ||||||
| 		return find_string_ptr({bytes, 4}); | 		return find_string_ptr({bytes, 4}); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool process_maps() | 	bool process_gsc_ctx() | ||||||
| 	{ | 	{ | ||||||
| 		const auto string_ref = find_string_ref("Couldn't resolve builtin function id for name '%s'!"); | 		const auto string_ref = find_string_ref("in call to builtin %s \"%s\""); | ||||||
| 		if (!string_ref) | 		if (!string_ref) | ||||||
| 		{ | 		{ | ||||||
| 			return false; | 			return false; | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
| 		const auto map_ptr = *reinterpret_cast<size_t*>(string_ref - 0x3A); | 		const auto gsc_ctx_ptr = *reinterpret_cast<size_t*>(string_ref - 0xAD); | ||||||
| 		game::plutonium::function_map_rev.set(map_ptr); | 		OutputDebugString(utils::string::va("gsc_ctx_ptr: %p\n", gsc_ctx_ptr)); | ||||||
| 		game::plutonium::method_map_rev.set(map_ptr + 0x20); | 		game::plutonium::gsc_ctx.set(gsc_ctx_ptr); | ||||||
| 		game::plutonium::file_map_rev.set(map_ptr + 0x40); |  | ||||||
| 		game::plutonium::token_map_rev.set(map_ptr + 0x60); |  | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -81,13 +91,16 @@ namespace signatures | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		const auto offset = *reinterpret_cast<size_t*>(string_ref + 5); | 		const auto offset = *reinterpret_cast<size_t*>(string_ref + 5); | ||||||
| 		game::plutonium::printf.set(string_ref + 4 + 5 + offset); | 		const auto printf_ptr = string_ref + 4 + 5 + offset; | ||||||
|  | 		OutputDebugString(utils::string::va("printf_ptr: %p\n", printf_ptr)); | ||||||
|  | 		game::plutonium::printf.set(printf_ptr); | ||||||
|  |  | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool process() | 	bool process() | ||||||
| 	{ | 	{ | ||||||
| 		load_function_tables(); | 		load_function_tables(); | ||||||
| 		return process_printf() && process_maps(); | 		return process_printf() && process_gsc_ctx(); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -7,51 +7,20 @@ namespace scripting | |||||||
| { | { | ||||||
| 	namespace | 	namespace | ||||||
| 	{ | 	{ | ||||||
| 		std::unordered_map<std::string, uint16_t> lowercase_map( | 		int find_function_index(const std::string& name, [[maybe_unused]] const bool prefer_global) | ||||||
| 			const std::unordered_map<std::string, uint16_t>& old_map) |  | ||||||
| 		{ |  | ||||||
| 			std::unordered_map<std::string, uint16_t> new_map{}; |  | ||||||
| 			for (auto& entry : old_map) |  | ||||||
| 			{ |  | ||||||
| 				new_map[utils::string::to_lower(entry.first)] = entry.second; |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			return new_map; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		const std::unordered_map<std::string, uint16_t>& get_methods() |  | ||||||
| 		{ |  | ||||||
| 			static auto methods = lowercase_map(*game::plutonium::method_map_rev); |  | ||||||
| 			return methods; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		const std::unordered_map<std::string, uint16_t>& get_functions() |  | ||||||
| 		{ |  | ||||||
| 			static auto function = lowercase_map(*game::plutonium::function_map_rev); |  | ||||||
| 			return function; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		int find_function_index(const std::string& name, const bool prefer_global) |  | ||||||
| 		{ | 		{ | ||||||
| 			const auto target = utils::string::to_lower(name); | 			const auto target = utils::string::to_lower(name); | ||||||
|  | 			auto const& first = (*game::plutonium::gsc_ctx)->func_map(); | ||||||
|  | 			auto const& second = (*game::plutonium::gsc_ctx)->meth_map(); | ||||||
|  |  | ||||||
| 			const auto& primary_map = prefer_global | 			if (const auto itr = first.find(name); itr != first.end()) | ||||||
| 				                          ? get_functions() |  | ||||||
| 				                          : get_methods(); |  | ||||||
| 			const auto& secondary_map = !prefer_global |  | ||||||
| 				                            ? get_functions() |  | ||||||
| 				                            : get_methods(); |  | ||||||
|  |  | ||||||
| 			auto function_entry = primary_map.find(target); |  | ||||||
| 			if (function_entry != primary_map.end()) |  | ||||||
| 			{ | 			{ | ||||||
| 				return function_entry->second; | 				return static_cast<int>(itr->second); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			function_entry = secondary_map.find(target); | 			if (const auto itr = second.find(name); itr != second.end()) | ||||||
| 			if (function_entry != secondary_map.end()) |  | ||||||
| 			{ | 			{ | ||||||
| 				return function_entry->second; | 				return static_cast<int>(itr->second); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			return -1; | 			return -1; | ||||||
| @@ -71,51 +40,28 @@ namespace scripting | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	std::string find_file(unsigned int id) |  | ||||||
| 	{ |  | ||||||
| 		const auto& file_map = *game::plutonium::file_map_rev; |  | ||||||
| 		for (const auto& file : file_map) |  | ||||||
| 		{ |  | ||||||
| 			if (file.second == id) |  | ||||||
| 			{ |  | ||||||
| 				return file.first; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return {}; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	std::string find_token(unsigned int id) | 	std::string find_token(unsigned int id) | ||||||
| 	{ | 	{ | ||||||
| 		const auto& token_map = *game::plutonium::token_map_rev; | 		return (*game::plutonium::gsc_ctx)->token_name(id); | ||||||
| 		for (const auto& token : token_map) |  | ||||||
| 		{ |  | ||||||
| 			if (token.second == id) |  | ||||||
| 			{ |  | ||||||
| 				return token.first; |  | ||||||
| 			} |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 		return {}; | 	std::string find_file(unsigned int id) | ||||||
|  | 	{ | ||||||
|  | 		return find_token(id); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	int find_token_id(const std::string& name) | 	int find_token_id(const std::string& name) | ||||||
| 	{ | 	{ | ||||||
| 		const auto& token_map = *game::plutonium::token_map_rev; | 		return (*game::plutonium::gsc_ctx)->token_id(name); | ||||||
| 		const auto result = token_map.find(name); |  | ||||||
|  |  | ||||||
| 		if (result != token_map.end()) |  | ||||||
| 		{ |  | ||||||
| 			return result->second; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		return -1; |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	script_function find_function(const std::string& name, const bool prefer_global) | 	script_function find_function(const std::string& name, const bool prefer_global) | ||||||
| 	{ | 	{ | ||||||
| 		const auto index = find_function_index(name, prefer_global); | 		const auto index = find_function_index(name, prefer_global); | ||||||
| 		if (index < 0) return nullptr; | 		if (index < 0) | ||||||
|  | 		{ | ||||||
|  | 			return nullptr; | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		return get_function_by_index(index); | 		return get_function_by_index(index); | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -86,10 +86,7 @@ namespace game | |||||||
|  |  | ||||||
| 	namespace plutonium | 	namespace plutonium | ||||||
| 	{ | 	{ | ||||||
| 		WEAK symbol<std::unordered_map<std::string, std::uint16_t>> function_map_rev{0}; | 		WEAK symbol<std::unique_ptr<xsk::gsc::iw5_pc::context>> gsc_ctx{0}; | ||||||
| 		WEAK symbol<std::unordered_map<std::string, std::uint16_t>> method_map_rev{0}; |  | ||||||
| 		WEAK symbol<std::unordered_map<std::string, std::uint16_t>> file_map_rev{0}; |  | ||||||
| 		WEAK symbol<std::unordered_map<std::string, std::uint16_t>> token_map_rev{0}; |  | ||||||
| 		WEAK symbol<int(const char* fmt, ...)> printf{0}; | 		WEAK symbol<int(const char* fmt, ...)> printf{0}; | ||||||
| 		WEAK symbol<void*> function_table{0}; | 		WEAK symbol<void*> function_table{0}; | ||||||
| 		WEAK symbol<void*> method_table{0}; | 		WEAK symbol<void*> method_table{0}; | ||||||
|   | |||||||
| @@ -8,6 +8,8 @@ | |||||||
| #pragma warning(disable: 4996) | #pragma warning(disable: 4996) | ||||||
| #pragma warning(disable: 26812) | #pragma warning(disable: 26812) | ||||||
|  |  | ||||||
|  | #include <xsk/gsc/engine/iw5_pc.hpp> | ||||||
|  |  | ||||||
| #define DLL_EXPORT extern "C" __declspec(dllexport) | #define DLL_EXPORT extern "C" __declspec(dllexport) | ||||||
| #define WIN32_LEAN_AND_MEAN | #define WIN32_LEAN_AND_MEAN | ||||||
| #include <windows.h> | #include <windows.h> | ||||||
| @@ -37,6 +39,7 @@ using namespace std::literals; | |||||||
| #include <gsl/gsl> | #include <gsl/gsl> | ||||||
| #include <MinHook.h> | #include <MinHook.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "utils/memory.hpp" | #include "utils/memory.hpp" | ||||||
| #include "utils/string.hpp" | #include "utils/string.hpp" | ||||||
| #include "utils/hook.hpp" | #include "utils/hook.hpp" | ||||||
|   | |||||||
| @@ -1,8 +1,14 @@ | |||||||
| #include <stdinc.hpp> | #include <stdinc.hpp> | ||||||
| #include <fstream> | #include <fstream> | ||||||
|  | #include "io.hpp" | ||||||
|  |  | ||||||
| namespace utils::io | namespace utils::io | ||||||
| { | { | ||||||
|  | 	bool remove_file(const std::string& file) | ||||||
|  | 	{ | ||||||
|  | 		return DeleteFileA(file.data()) == TRUE; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	bool file_exists(const std::string& file) | 	bool file_exists(const std::string& file) | ||||||
| 	{ | 	{ | ||||||
| 		return std::ifstream(file).good(); | 		return std::ifstream(file).good(); | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ | |||||||
|  |  | ||||||
| namespace utils::io | namespace utils::io | ||||||
| { | { | ||||||
|  | 	bool remove_file(const std::string& file); | ||||||
| 	bool file_exists(const std::string& file); | 	bool file_exists(const std::string& file); | ||||||
| 	bool write_file(const std::string& file, const std::string& data, bool append = false); | 	bool write_file(const std::string& file, const std::string& data, bool append = false); | ||||||
| 	bool read_file(const std::string& file, std::string* data); | 	bool read_file(const std::string& file, std::string* data); | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								tools/premake5.exe
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tools/premake5.exe
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user