Skip to content

Hook the CreateDirectory*() functions #122

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 7 additions & 1 deletion src/plugins/gta3/std.asi/ModuleInfo.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -499,6 +499,7 @@ static bool ModulesWalk(uint32_t pid, F functor)
* http://msdn.microsoft.com/en-us/library/windows/desktop/aa363950(v=vs.85).aspx
*/
extern const char aKernel32[] = "kernel32.dll";
extern const char aCreateDirectoryA[] = "CreateDirectoryA";
extern const char aCreateFileA[] = "CreateFileA";
extern const char aLoadLibraryA[] = "LoadLibraryA";
extern const char aLoadLibraryExA[] = "LoadLibraryExA";
Expand All @@ -518,6 +519,7 @@ extern const char aWritePrivateProfileStructA[] = "WritePrivateProfileStructA";
extern const char aGetFileAttributesA[] = "GetFileAttributesA";
extern const char aGetFileAttributesExA[] = "GetFileAttributesExA";

extern const char aCreateDirectoryW[] = "CreateDirectoryW";
extern const char aCreateFileW[] = "CreateFileW";
extern const char aLoadLibraryW[] = "LoadLibraryW";
extern const char aLoadLibraryExW[] = "LoadLibraryExW";
Expand All @@ -538,10 +540,14 @@ extern const char aGetFileAttributesExW[] = "GetFileAttributesExW";


// Operations
static path_translator_stdcall<aCreateDirectoryA, aKernel32, BOOL(LPCSTR, LPSECURITY_ATTRIBUTES)>
psCreateDirectoryA(0, AR_PATH_INE, 0);
static path_translator_stdcall<aCreateFileA, aKernel32, HANDLE(LPCSTR, DWORD, DWORD, LPSECURITY_ATTRIBUTES, DWORD, DWORD, HANDLE)>
psCreateFileA(0, AR_PATH_INE, 0, 0, 0, 0, 0, 0);
static path_translator_stdcall<aSetCurrentDirectoryA, aKernel32, BOOL(LPCSTR)>
psSetCurrentDirectoryA(0, AR_PATH_INE); // Do not work properly!! Don't use!!!
static path_translator_stdcall<aCreateDirectoryW, aKernel32, BOOL(LPCWSTR, LPSECURITY_ATTRIBUTES)>
psCreateDirectoryW(0, AR_PATH_INE, 0);
static path_translator_stdcall<aCreateFileW, aKernel32, HANDLE(LPCWSTR, DWORD, DWORD, LPSECURITY_ATTRIBUTES, DWORD, DWORD, HANDLE)>
psCreateFileW(0, AR_PATH_INE, 0, 0, 0, 0, 0, 0);
static path_translator_stdcall<aSetCurrentDirectoryW, aKernel32, BOOL(LPCWSTR)>
Expand Down Expand Up @@ -754,4 +760,4 @@ static path_translator_stdcall<aBASS_MusicLoad, aBass, DWORD(BOOL, const char*,
static path_translator_stdcall<aBASS_SampleLoad, aBass, DWORD(BOOL, const char*, uint64_t, DWORD, DWORD, DWORD)>
psBASS_SampleLoad(0, 0, AR_PATH_INE, 0, 0, 0, 0);
static path_translator_stdcall<aBASS_StreamCreateFile, aBass, DWORD(BOOL, const char*, uint64_t, uint64_t, DWORD)>
psBASS_StreamCreateFile(0, 0, AR_PATH_INE, 0, 0, 0);
psBASS_StreamCreateFile(0, 0, AR_PATH_INE, 0, 0, 0);