mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2025-01-15 08:53:53 +08:00
.
This commit is contained in:
parent
e12089c21a
commit
0c3949811c
@ -67,7 +67,7 @@ struct passinfo
|
|||||||
};
|
};
|
||||||
bool Ryujinx::attach_function()
|
bool Ryujinx::attach_function()
|
||||||
{
|
{
|
||||||
WarningOutput("not support ryuujinx, please use yuzu/sudachi instead.");
|
HostInfo(HOSTINFO::Warning, "not support ryuujinx, please use yuzu/sudachi instead.");
|
||||||
return true;
|
return true;
|
||||||
/*
|
/*
|
||||||
UnsafeJitFunction
|
UnsafeJitFunction
|
||||||
|
@ -16,8 +16,6 @@ namespace
|
|||||||
}
|
}
|
||||||
uintptr_t getDoJitAddress() {
|
uintptr_t getDoJitAddress() {
|
||||||
auto DoJitPtr=getDoJitAddress_();
|
auto DoJitPtr=getDoJitAddress_();
|
||||||
|
|
||||||
ConsoleOutput("DoJitPtr %p",DoJitPtr);
|
|
||||||
if(!DoJitPtr)return 0;
|
if(!DoJitPtr)return 0;
|
||||||
//<--DoJitPtr
|
//<--DoJitPtr
|
||||||
//0f85 1b050000 // jbe 0x00 ; long jump
|
//0f85 1b050000 // jbe 0x00 ; long jump
|
||||||
@ -242,7 +240,7 @@ bool rpcs3::attach_function()
|
|||||||
if (DoJitPtr == 0)
|
if (DoJitPtr == 0)
|
||||||
return false;
|
return false;
|
||||||
unsafeinithooks();
|
unsafeinithooks();
|
||||||
spDefault.jittype = JITTYPE::RPCS3;
|
spDefault.isjithook = true;
|
||||||
spDefault.minAddress = 0;
|
spDefault.minAddress = 0;
|
||||||
spDefault.maxAddress = -1;
|
spDefault.maxAddress = -1;
|
||||||
HookParam hp;
|
HookParam hp;
|
||||||
|
@ -63,8 +63,7 @@ bool vita3k::attach_function()
|
|||||||
auto DoJitPtr = getDoJitAddress();
|
auto DoJitPtr = getDoJitAddress();
|
||||||
if (DoJitPtr == 0)
|
if (DoJitPtr == 0)
|
||||||
return false;
|
return false;
|
||||||
ConsoleOutput("DoJitPtr %p", DoJitPtr);
|
spDefault.isjithook = true;
|
||||||
spDefault.jittype = JITTYPE::VITA3K;
|
|
||||||
spDefault.minAddress = 0;
|
spDefault.minAddress = 0;
|
||||||
spDefault.maxAddress = -1;
|
spDefault.maxAddress = -1;
|
||||||
HookParam hp;
|
HookParam hp;
|
||||||
|
@ -122,13 +122,16 @@ bool Hook_Network_RoomMember_SendGameInfo()
|
|||||||
// Network::RoomMember *this,
|
// Network::RoomMember *this,
|
||||||
// const AnnounceMultiplayerRoom::GameInfo *game_info)
|
// const AnnounceMultiplayerRoom::GameInfo *game_info)
|
||||||
game_info = *(GameInfo *)stack->rdx;
|
game_info = *(GameInfo *)stack->rdx;
|
||||||
std::stringstream num;
|
if (game_info.id)
|
||||||
num << std::uppercase
|
{
|
||||||
<< std::hex
|
std::stringstream num;
|
||||||
<< std::setw(16)
|
num << std::uppercase
|
||||||
<< std::setfill('0')
|
<< std::hex
|
||||||
<< game_info.id;
|
<< std::setw(16)
|
||||||
ConsoleOutput("%s %s %s", game_info.name.c_str(), num.str().c_str(), game_info.version.c_str());
|
<< std::setfill('0')
|
||||||
|
<< game_info.id;
|
||||||
|
HostInfo(HOSTINFO::EmuGameName, "%s %s %s", game_info.name.c_str(), num.str().c_str(), game_info.version.c_str());
|
||||||
|
}
|
||||||
jitaddrclear();
|
jitaddrclear();
|
||||||
};
|
};
|
||||||
return NewHook(hp, "yuzuGameInfo");
|
return NewHook(hp, "yuzuGameInfo");
|
||||||
@ -137,15 +140,14 @@ bool Hook_Network_RoomMember_SendGameInfo()
|
|||||||
}
|
}
|
||||||
bool yuzu::attach_function()
|
bool yuzu::attach_function()
|
||||||
{
|
{
|
||||||
Hook_Network_RoomMember_SendGameInfo();
|
|
||||||
ConsoleOutput("[Compatibility] Yuzu 1616+");
|
ConsoleOutput("[Compatibility] Yuzu 1616+");
|
||||||
auto DoJitPtr = getDoJitAddress();
|
auto DoJitPtr = getDoJitAddress();
|
||||||
if (DoJitPtr == 0)
|
if (!DoJitPtr)
|
||||||
return false;
|
return false;
|
||||||
spDefault.jittype = JITTYPE::YUZU;
|
Hook_Network_RoomMember_SendGameInfo();
|
||||||
|
spDefault.isjithook = true;
|
||||||
spDefault.minAddress = 0;
|
spDefault.minAddress = 0;
|
||||||
spDefault.maxAddress = -1;
|
spDefault.maxAddress = -1;
|
||||||
ConsoleOutput("DoJitPtr %p", DoJitPtr);
|
|
||||||
HookParam hp;
|
HookParam hp;
|
||||||
hp.address = DoJitPtr;
|
hp.address = DoJitPtr;
|
||||||
hp.text_fun = [](hook_stack *stack, HookParam *hp, TextBuffer *buffer, uintptr_t *split)
|
hp.text_fun = [](hook_stack *stack, HookParam *hp, TextBuffer *buffer, uintptr_t *split)
|
||||||
@ -310,7 +312,7 @@ namespace
|
|||||||
s = std::regex_replace(s, std::regex(R"(#[^\]]*\])"), "");
|
s = std::regex_replace(s, std::regex(R"(#[^\]]*\])"), "");
|
||||||
s = std::regex_replace(s, std::regex(R"(#[^n]*n)"), "");
|
s = std::regex_replace(s, std::regex(R"(#[^n]*n)"), "");
|
||||||
s = std::regex_replace(s, std::regex(u8" "), "");
|
s = std::regex_replace(s, std::regex(u8" "), "");
|
||||||
s = std::regex_replace(s, std::regex(u8R"(Save(.|\s)*データ)"), "");
|
s = std::regex_replace(s, std::regex(u8R"(Save[\s\S]*データ)"), "");
|
||||||
buffer->from(s);
|
buffer->from(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -676,6 +678,16 @@ namespace
|
|||||||
strReplace(s, R"(\n)", "");
|
strReplace(s, R"(\n)", "");
|
||||||
buffer->from(s);
|
buffer->from(s);
|
||||||
}
|
}
|
||||||
|
template <int _1>
|
||||||
|
void F010053F0128DC000(TextBuffer *buffer, HookParam *hp)
|
||||||
|
{
|
||||||
|
CharFilter(buffer, '\n');
|
||||||
|
auto s = buffer->strA();
|
||||||
|
char __[] = "$1";
|
||||||
|
__[1] += _1 - 1;
|
||||||
|
s = std::regex_replace(s, std::regex(R"(<CLY2>(.*?)<CLNA>([\s\S]*))"), __);
|
||||||
|
buffer->from(s);
|
||||||
|
}
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
static std::string F0100FB50156E6000;
|
static std::string F0100FB50156E6000;
|
||||||
@ -1062,7 +1074,7 @@ namespace
|
|||||||
{
|
{
|
||||||
auto s = buffer->strA();
|
auto s = buffer->strA();
|
||||||
s = std::regex_replace(s, std::regex(R"(\[~\])"), "\n");
|
s = std::regex_replace(s, std::regex(R"(\[~\])"), "\n");
|
||||||
s = std::regex_replace(s, std::regex(R"(rom:(.|\s)*$)"), "");
|
s = std::regex_replace(s, std::regex(R"(rom:[\s\S]*$)"), "");
|
||||||
s = std::regex_replace(s, std::regex(R"(\[[\w\d]*\[[\w\d]*\].*?\[\/[\w\d]*\]\])"), "");
|
s = std::regex_replace(s, std::regex(R"(\[[\w\d]*\[[\w\d]*\].*?\[\/[\w\d]*\]\])"), "");
|
||||||
s = std::regex_replace(s, std::regex(R"(\[.*?\])"), "");
|
s = std::regex_replace(s, std::regex(R"(\[.*?\])"), "");
|
||||||
static std::string last;
|
static std::string last;
|
||||||
@ -1204,7 +1216,6 @@ namespace
|
|||||||
template <bool choice>
|
template <bool choice>
|
||||||
void F010027401A2A2000(TextBuffer *buffer, HookParam *hp)
|
void F010027401A2A2000(TextBuffer *buffer, HookParam *hp)
|
||||||
{
|
{
|
||||||
|
|
||||||
auto s = buffer->strW();
|
auto s = buffer->strW();
|
||||||
s = std::regex_replace(s, std::wregex(L"\\[dic.*?text="), L"");
|
s = std::regex_replace(s, std::wregex(L"\\[dic.*?text="), L"");
|
||||||
s = std::regex_replace(s, std::wregex(L"\\[|'.*?\\]"), L"");
|
s = std::regex_replace(s, std::wregex(L"\\[|'.*?\\]"), L"");
|
||||||
@ -1561,7 +1572,7 @@ namespace
|
|||||||
{
|
{
|
||||||
|
|
||||||
auto s = buffer->strW();
|
auto s = buffer->strW();
|
||||||
s = std::regex_replace(s, std::wregex(LR"((.|\s)*$)"), L"");
|
s = std::regex_replace(s, std::wregex(LR"([\s\S]*$)"), L"");
|
||||||
s = std::regex_replace(s, std::wregex(L"\n+"), L" ");
|
s = std::regex_replace(s, std::wregex(L"\n+"), L" ");
|
||||||
s = std::regex_replace(s, std::wregex(L"\\s"), L"");
|
s = std::regex_replace(s, std::wregex(L"\\s"), L"");
|
||||||
s = std::regex_replace(s, std::wregex(L"[븅]"), L"");
|
s = std::regex_replace(s, std::wregex(L"[븅]"), L"");
|
||||||
@ -3443,6 +3454,11 @@ namespace
|
|||||||
// 神凪ノ杜
|
// 神凪ノ杜
|
||||||
{0x8205e150, {CODEC_UTF16, 0, 0x14, 0, F0100B5801D7CE000, "0100B5801D7CE000", "1.0.0"}},
|
{0x8205e150, {CODEC_UTF16, 0, 0x14, 0, F0100B5801D7CE000, "0100B5801D7CE000", "1.0.0"}},
|
||||||
{0x820e2e6c, {CODEC_UTF16, 0, 0x14, 0, 0, "0100B5801D7CE000", "1.0.0"}},
|
{0x820e2e6c, {CODEC_UTF16, 0, 0x14, 0, 0, "0100B5801D7CE000", "1.0.0"}},
|
||||||
|
// シェルノサージュ ~失われた星へ捧ぐ詩~ DX
|
||||||
|
{0x801A1140, {CODEC_UTF8, 1, 0, 0, F010053F0128DC000<1>, "010053F0128DC000", "1.0.0"}},
|
||||||
|
{0x801A10A4, {CODEC_UTF8, 1, 0, 0, F010053F0128DC000<2>, "010053F0128DC000", "1.0.0"}},
|
||||||
|
{0x801A04F4, {CODEC_UTF8, 1, 0, 0, F010053F0128DC000<1>, "010053F0128DC000", "1.0.1"}},
|
||||||
|
{0x801A0590, {CODEC_UTF8, 1, 0, 0, F010053F0128DC000<2>, "010053F0128DC000", "1.0.1"}},
|
||||||
|
|
||||||
};
|
};
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -65,7 +65,7 @@ struct PPSSPPFunction
|
|||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
uintptr_t findleapushaddr(uintptr_t addr)
|
uintptr_t findleapushalignfuncaddr(uintptr_t addr)
|
||||||
{
|
{
|
||||||
#ifndef _WIN64
|
#ifndef _WIN64
|
||||||
addr = MemDbg::findPushAddress(addr, processStartAddress, processStopAddress);
|
addr = MemDbg::findPushAddress(addr, processStartAddress, processStopAddress);
|
||||||
@ -148,7 +148,7 @@ bool InsertPPSSPPHLEHooks()
|
|||||||
auto addr = MemDbg::findBytes(function.pattern, ::strlen(function.pattern), processStartAddress, processStopAddress);
|
auto addr = MemDbg::findBytes(function.pattern, ::strlen(function.pattern), processStartAddress, processStopAddress);
|
||||||
if (!addr)
|
if (!addr)
|
||||||
continue;
|
continue;
|
||||||
addr = findleapushaddr(addr);
|
addr = findleapushalignfuncaddr(addr);
|
||||||
|
|
||||||
if (!addr)
|
if (!addr)
|
||||||
continue;
|
continue;
|
||||||
@ -268,13 +268,23 @@ uintptr_t getDoJitAddress()
|
|||||||
|
|
||||||
namespace ppsspp
|
namespace ppsspp
|
||||||
{
|
{
|
||||||
|
struct GameInfo
|
||||||
|
{
|
||||||
|
std::string DISC_ID{""};
|
||||||
|
std::string TITLE{""};
|
||||||
|
} game_info;
|
||||||
bool checkiscurrentgame(const emfuncinfo &em)
|
bool checkiscurrentgame(const emfuncinfo &em)
|
||||||
{
|
{
|
||||||
auto wininfos = get_proc_windows();
|
auto wininfos = get_proc_windows();
|
||||||
for (auto &&info : wininfos)
|
for (auto &&info : wininfos)
|
||||||
{
|
{
|
||||||
if (std::regex_search(info.title, std::wregex(acastw(em._id))))
|
if (game_info.DISC_ID.size())
|
||||||
|
{
|
||||||
|
std::smatch match;
|
||||||
|
if (std::regex_match(game_info.DISC_ID, match, std::regex(em._id)))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (std::regex_search(info.title, std::wregex(acastw(em._id))))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -476,17 +486,61 @@ namespace ppsspp
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Load_PSP_ISO_StringFromFormat()
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
bool Load_PSP_ISO(FileLoader *fileLoader, std::string *error_string) {
|
||||||
|
// Mounting stuff relocated to InitMemoryForGameISO due to HD Remaster restructuring of code.
|
||||||
|
|
||||||
|
std::string sfoPath("disc0:/PSP_GAME/PARAM.SFO");
|
||||||
|
PSPFileInfo fileInfo = pspFileSystem.GetFileInfo(sfoPath.c_str());
|
||||||
|
if (fileInfo.exists) {
|
||||||
|
std::vector<u8> paramsfo;
|
||||||
|
pspFileSystem.ReadEntireFile(sfoPath, paramsfo);
|
||||||
|
if (g_paramSFO.ReadSFO(paramsfo)) {
|
||||||
|
std::string title = StringFromFormat("%s : %s", g_paramSFO.GetValueString("DISC_ID").c_str(), g_paramSFO.GetValueString("TITLE").c_str());
|
||||||
|
INFO_LOG(Log::Loader, "%s", title.c_str());
|
||||||
|
System_SetWindowTitle(title);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
------>StringFromFormat
|
||||||
|
*/
|
||||||
|
BYTE sig[] = {
|
||||||
|
#ifndef _WIN64
|
||||||
|
0x55, 0x8B, 0xEC, 0x6A, 0xFF, 0x68, XX4, 0x64, 0xA1, 0x00, 0x00, 0x00, 0x00, 0x50, 0x64, 0x89, 0x25, 0x00, 0x00, 0x00, 0x00, 0x83, 0xEC, 0x14, 0x56, 0x8B, 0x75, 0x08, 0x0F, 0x57, 0xC0, 0xC7, 0x45, 0xE8, 0x00, 0x00, 0x00, 0x00, 0x8D, 0x46, 0x10, 0x57, 0x89, 0x45, 0xF0, 0x0F, 0x11, 0x06, 0xC7, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC7, 0x46, 0x14, 0x00, 0x00, 0x00, 0x00, 0xC7, 0x00, 0x00, 0x00, 0x00, 0x00, 0xC7, 0x46, 0x14, 0x0F, 0x00, 0x00, 0x00, 0xC6, 0x06, 0x00, 0xC7, 0x45, 0xFC, 0x00, 0x00, 0x00, 0x00, 0xC7, 0x45, 0xE8, 0x01, 0x00, 0x00, 0x00, 0xE8, XX4, 0x8B, 0xC8, 0x8D, 0x45, 0x10, 0x50, 0x6A, 0x00, 0xFF, 0x75, 0x0C, 0x8B, 0x01, 0x6A, 0x00, 0x6A, 0x00, 0xFF, 0x71, 0x04, 0x83, 0xC8, 0x02, 0x89, 0x4D, 0xE0, 0x50, 0xE8, XX4
|
||||||
|
#else
|
||||||
|
0x48, 0x8B, 0xC4, 0x48, 0x89, 0x50, 0x10, 0x48, 0x89, 0x48, 0x08, 0x4C, 0x89, 0x40, 0x18, 0x4C, 0x89, 0x48, 0x20, 0x53, 0x55, 0x56, 0x57, 0x41, 0x56, 0x41, 0x57, 0x48, 0x83, 0xEC, 0x48, 0x48, 0x8B, 0xDA, 0x48, 0x8B, 0xF9, 0x33, 0xED, 0x89, 0x68, 0xB8, 0x0F, 0x57, 0xC0, 0x0F, 0x11, 0x01, 0x48, 0x89, 0x69, 0x10, 0x48, 0xC7, 0x41, 0x18, 0x0F, 0x00, 0x00, 0x00, 0x40, 0x88, 0x29, 0xC7, 0x40, 0xB8, 0x01, 0x00, 0x00, 0x00, 0x4C, 0x8D, 0x70, 0x18, 0xE8, XX4, 0x48, 0x8B, 0xF0, 0x48, 0x8B, 0x08, 0x48, 0x83, 0xC9, 0x02, 0x4C, 0x89, 0x74, 0x24, 0x28, 0x48, 0x89, 0x6C, 0x24, 0x20, 0x4C, 0x8B, 0xCB, 0x45, 0x33, 0xC0, 0x33, 0xD2, 0xE8, XX4
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
auto addr = MemDbg::findBytes(sig, sizeof(sig), processStartAddress, processStopAddress);
|
||||||
|
if (!addr)
|
||||||
|
return;
|
||||||
|
HookParam hp;
|
||||||
|
hp.address = addr;
|
||||||
|
hp.text_fun = [](hook_stack *stack, HookParam *hp, auto *buff, auto *split)
|
||||||
|
{
|
||||||
|
if (strcmp((char *)stack->ARG2, "%s : %s") != 0)
|
||||||
|
return;
|
||||||
|
game_info.DISC_ID = (char *)stack->ARG3;
|
||||||
|
game_info.TITLE = (char *)stack->ARG4;
|
||||||
|
HostInfo(HOSTINFO::EmuGameName, "%s %s", stack->ARG3, stack->ARG4);
|
||||||
|
jitaddrclear();
|
||||||
|
};
|
||||||
|
NewHook(hp, "PPSSPPGameInfo");
|
||||||
|
}
|
||||||
bool hookPPSSPPDoJit()
|
bool hookPPSSPPDoJit()
|
||||||
{
|
{
|
||||||
auto DoJitPtr = getDoJitAddress();
|
auto DoJitPtr = getDoJitAddress();
|
||||||
if (DoJitPtr == 0)
|
if (!DoJitPtr)
|
||||||
return false;
|
return false;
|
||||||
spDefault.jittype = JITTYPE::PPSSPP;
|
Load_PSP_ISO_StringFromFormat();
|
||||||
|
spDefault.isjithook = true;
|
||||||
spDefault.minAddress = 0;
|
spDefault.minAddress = 0;
|
||||||
spDefault.maxAddress = -1;
|
spDefault.maxAddress = -1;
|
||||||
HookParam hp;
|
HookParam hp;
|
||||||
hp.address = DoJitPtr; // Jit::DoJit
|
hp.address = DoJitPtr; // Jit::DoJit
|
||||||
ConsoleOutput("DoJitPtr %p", DoJitPtr);
|
|
||||||
hp.user_value = (uintptr_t) new uintptr_t;
|
hp.user_value = (uintptr_t) new uintptr_t;
|
||||||
hp.text_fun = [](hook_stack *stack, HookParam *hp, auto *, auto *)
|
hp.text_fun = [](hook_stack *stack, HookParam *hp, auto *, auto *)
|
||||||
{
|
{
|
||||||
@ -529,7 +583,7 @@ namespace
|
|||||||
auto addr = MemDbg::findBytes(GetPointer, sizeof(GetPointer), processStartAddress, processStopAddress);
|
auto addr = MemDbg::findBytes(GetPointer, sizeof(GetPointer), processStartAddress, processStopAddress);
|
||||||
if (!addr)
|
if (!addr)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
addr = findleapushaddr(addr);
|
addr = findleapushalignfuncaddr(addr);
|
||||||
return (void *)addr;
|
return (void *)addr;
|
||||||
}
|
}
|
||||||
bool Replace_memcpy()
|
bool Replace_memcpy()
|
||||||
|
@ -177,14 +177,6 @@ namespace ppsspp
|
|||||||
*split = haveNamve;
|
*split = haveNamve;
|
||||||
buffer->from(s);
|
buffer->from(s);
|
||||||
}
|
}
|
||||||
void ULJM05054(hook_stack *stack, HookParam *hp, TextBuffer *buffer, uintptr_t *split)
|
|
||||||
{
|
|
||||||
auto address = PPSSPP::emu_arg(stack)[1];
|
|
||||||
bool haveNamve;
|
|
||||||
auto s = Corda::readBinaryString(address, &haveNamve);
|
|
||||||
*split = haveNamve;
|
|
||||||
buffer->from(s);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ULJM05943F(TextBuffer *buffer, HookParam *hp)
|
void ULJM05943F(TextBuffer *buffer, HookParam *hp)
|
||||||
{
|
{
|
||||||
@ -426,10 +418,12 @@ namespace ppsspp
|
|||||||
{0x0891D72C, {CODEC_UTF8, 0, 0, 0, ULJM06119_filter, "ULJM06119"}},
|
{0x0891D72C, {CODEC_UTF8, 0, 0, 0, ULJM06119_filter, "ULJM06119"}},
|
||||||
// Princess Evangile
|
// Princess Evangile
|
||||||
{0x88506d0, {CODEC_UTF16, 2, 0, 0, ULJM06036_filter, "ULJM06036"}}, // [0x88506d0(2)...0x088507C0(?)] // name text text (line doubled)
|
{0x88506d0, {CODEC_UTF16, 2, 0, 0, ULJM06036_filter, "ULJM06036"}}, // [0x88506d0(2)...0x088507C0(?)] // name text text (line doubled)
|
||||||
|
// 金色のコルダ3
|
||||||
|
{0x896C3B8, {0, 0, 0, ULJM05428, 0, "ULJM05624"}},
|
||||||
// 金色のコルダ2 f
|
// 金色のコルダ2 f
|
||||||
{0x89b59dc, {0, 0, 0, ULJM05428, 0, "ULJM05428"}},
|
{0x89b59dc, {0, 0, 0, ULJM05428, 0, "ULJM05428"}},
|
||||||
// 金色のコルダ
|
// 金色のコルダ
|
||||||
{0x886162c, {0, 0, 0, ULJM05054, 0, "ULJM05054"}}, // dialogue: 0x886162c (x1), 0x889d5fc-0x889d520(a2) fullLine
|
{0x886162c, {0, 0, 0, ULJM05428, 0, "ULJM05054"}}, // dialogue: 0x886162c (x1), 0x889d5fc-0x889d520(a2) fullLine
|
||||||
{0x8899e90, {0, 0, 0x3c, 0, 0, "ULJM05054"}}, // name 0x88da57c, 0x8899ca4 (x0, oneTime), 0x8899e90
|
{0x8899e90, {0, 0, 0x3c, 0, 0, "ULJM05054"}}, // name 0x88da57c, 0x8899ca4 (x0, oneTime), 0x8899e90
|
||||||
// Sol Trigger
|
// Sol Trigger
|
||||||
{0x8952cfc, {CODEC_UTF8, 0, 0, 0, NPJH50619F, "NPJH50619"}}, // dialog
|
{0x8952cfc, {CODEC_UTF8, 0, 0, 0, NPJH50619F, "NPJH50619"}}, // dialog
|
||||||
|
@ -335,7 +335,7 @@ void SearchForHooks(SearchParam spUser)
|
|||||||
initrecords();
|
initrecords();
|
||||||
|
|
||||||
std::vector<uintptr_t> addresses;
|
std::vector<uintptr_t> addresses;
|
||||||
if( sp.jittype==JITTYPE::PC)
|
if( !sp.isjithook)
|
||||||
{
|
{
|
||||||
if (*sp.boundaryModule) {
|
if (*sp.boundaryModule) {
|
||||||
auto [minaddr,maxaddr]=Util::QueryModuleLimits(GetModuleHandleW(sp.boundaryModule));
|
auto [minaddr,maxaddr]=Util::QueryModuleLimits(GetModuleHandleW(sp.boundaryModule));
|
||||||
|
@ -105,21 +105,12 @@ void TextOutput(const ThreadParam &tp, const HookParam &hp, TextOutput_T *buffer
|
|||||||
memcpy(&buffer->hp, &hp, sizeof(hp));
|
memcpy(&buffer->hp, &hp, sizeof(hp));
|
||||||
WriteFile(hookPipe, buffer, sizeof(TextOutput_T) + len, DUMMY, nullptr);
|
WriteFile(hookPipe, buffer, sizeof(TextOutput_T) + len, DUMMY, nullptr);
|
||||||
}
|
}
|
||||||
|
void HostInfo(HOSTINFO type, LPCSTR text, ...)
|
||||||
void ConsoleOutput(LPCSTR text, ...)
|
|
||||||
{
|
{
|
||||||
ConsoleOutputNotif buffer;
|
HostInfoNotif buffer;
|
||||||
va_list args;
|
|
||||||
va_start(args, text);
|
|
||||||
vsnprintf(buffer.message, MESSAGE_SIZE, text, args);
|
|
||||||
WriteFile(hookPipe, &buffer, sizeof(buffer), DUMMY, nullptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
void WarningOutput(LPCSTR text, ...)
|
|
||||||
{
|
|
||||||
WarningNotif buffer;
|
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, text);
|
va_start(args, text);
|
||||||
|
buffer.type = type;
|
||||||
vsnprintf(buffer.message, MESSAGE_SIZE, text, args);
|
vsnprintf(buffer.message, MESSAGE_SIZE, text, args);
|
||||||
WriteFile(hookPipe, &buffer, sizeof(buffer), DUMMY, nullptr);
|
WriteFile(hookPipe, &buffer, sizeof(buffer), DUMMY, nullptr);
|
||||||
}
|
}
|
||||||
|
@ -5,8 +5,8 @@
|
|||||||
// Branch: ITH/IHF_DLL.h, rev 66
|
// Branch: ITH/IHF_DLL.h, rev 66
|
||||||
|
|
||||||
void TextOutput(const ThreadParam &tp, const HookParam &hp, TextOutput_T(*buffer), int len);
|
void TextOutput(const ThreadParam &tp, const HookParam &hp, TextOutput_T(*buffer), int len);
|
||||||
void ConsoleOutput(LPCSTR text, ...);
|
void HostInfo(HOSTINFO type, LPCSTR text, ...);
|
||||||
void WarningOutput(LPCSTR text, ...);
|
#define ConsoleOutput(text, ...) HostInfo(HOSTINFO::Console, text, ##__VA_ARGS__, -1)
|
||||||
void NotifyHookFound(HookParam hp, wchar_t *text);
|
void NotifyHookFound(HookParam hp, wchar_t *text);
|
||||||
void NotifyHookRemove(uint64_t addr, LPCSTR name);
|
void NotifyHookRemove(uint64_t addr, LPCSTR name);
|
||||||
bool NewHook(HookParam hp, LPCSTR name);
|
bool NewHook(HookParam hp, LPCSTR name);
|
||||||
@ -15,7 +15,6 @@ bool NewHookJit(HookParam hp, LPCSTR name);
|
|||||||
void RemoveHook(uint64_t addr, int maxOffset = 9);
|
void RemoveHook(uint64_t addr, int maxOffset = 9);
|
||||||
std::string LoadResData(LPCWSTR pszResID, LPCWSTR _type);
|
std::string LoadResData(LPCWSTR pszResID, LPCWSTR _type);
|
||||||
inline SearchParam spDefault;
|
inline SearchParam spDefault;
|
||||||
|
|
||||||
// EOF
|
// EOF
|
||||||
int HookStrLen(HookParam *, BYTE *data);
|
int HookStrLen(HookParam *, BYTE *data);
|
||||||
|
|
||||||
|
@ -113,6 +113,7 @@ inline uintptr_t regof(regs reg, hook_stack *stack)
|
|||||||
#define ARG1 stack[1]
|
#define ARG1 stack[1]
|
||||||
#define ARG2 stack[2]
|
#define ARG2 stack[2]
|
||||||
#define ARG3 stack[3]
|
#define ARG3 stack[3]
|
||||||
|
#define ARG4 stack[4]
|
||||||
#define LASTRETVAL eax
|
#define LASTRETVAL eax
|
||||||
#define THISCALL __thiscall
|
#define THISCALL __thiscall
|
||||||
#define THISCALLTHIS ecx
|
#define THISCALLTHIS ecx
|
||||||
@ -125,6 +126,7 @@ inline uintptr_t regof(regs reg, hook_stack *stack)
|
|||||||
#define ARG1 rcx
|
#define ARG1 rcx
|
||||||
#define ARG2 rdx
|
#define ARG2 rdx
|
||||||
#define ARG3 r8
|
#define ARG3 r8
|
||||||
|
#define ARG4 r9
|
||||||
#define LASTRETVAL rax
|
#define LASTRETVAL rax
|
||||||
#define THISCALLTHIS rcx
|
#define THISCALLTHIS rcx
|
||||||
#define THISCALLARG1 rdx
|
#define THISCALLARG1 rdx
|
||||||
|
@ -260,10 +260,11 @@ LunaHost::LunaHost()
|
|||||||
std::bind(&LunaHost::on_thread_create, this, std::placeholders::_1),
|
std::bind(&LunaHost::on_thread_create, this, std::placeholders::_1),
|
||||||
std::bind(&LunaHost::on_thread_delete, this, std::placeholders::_1),
|
std::bind(&LunaHost::on_thread_delete, this, std::placeholders::_1),
|
||||||
std::bind(&LunaHost::on_text_recv, this, std::placeholders::_1, std::placeholders::_2),
|
std::bind(&LunaHost::on_text_recv, this, std::placeholders::_1, std::placeholders::_2),
|
||||||
|
true,
|
||||||
|
[=](HOSTINFO type, const std::wstring &output)
|
||||||
|
{ on_info(type, output); },
|
||||||
{},
|
{},
|
||||||
{},
|
{});
|
||||||
{},
|
|
||||||
std::bind(&LunaHost::on_warning, this, std::placeholders::_1));
|
|
||||||
|
|
||||||
mainlayout = new gridlayout();
|
mainlayout = new gridlayout();
|
||||||
mainlayout->addcontrol(g_selectprocessbutton, 0, 0);
|
mainlayout->addcontrol(g_selectprocessbutton, 0, 0);
|
||||||
@ -411,9 +412,14 @@ bool LunaHost::on_text_recv(TextThread &thread, std::wstring &output)
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
void LunaHost::on_warning(const std::wstring &warning)
|
void LunaHost::on_info(HOSTINFO type, const std::wstring &warning)
|
||||||
{
|
{
|
||||||
MessageBoxW(winId, warning.c_str(), L"warning", 0);
|
switch (type)
|
||||||
|
{
|
||||||
|
case HOSTINFO::Warning:
|
||||||
|
MessageBoxW(winId, warning.c_str(), L"warning", 0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void LunaHost::on_thread_create(TextThread &thread)
|
void LunaHost::on_thread_create(TextThread &thread)
|
||||||
{
|
{
|
||||||
|
@ -116,7 +116,7 @@ class LunaHost : public mainwindow
|
|||||||
void on_thread_delete(TextThread &thread);
|
void on_thread_delete(TextThread &thread);
|
||||||
void on_proc_connect(DWORD pid);
|
void on_proc_connect(DWORD pid);
|
||||||
void on_proc_disconnect(DWORD pid);
|
void on_proc_disconnect(DWORD pid);
|
||||||
void on_warning(const std::wstring &);
|
void on_info(HOSTINFO type, const std::wstring &);
|
||||||
|
|
||||||
void showtext(const std::wstring &text, bool clear);
|
void showtext(const std::wstring &text, bool clear);
|
||||||
void updatelisttext(const std::wstring &text, LONG_PTR data);
|
void updatelisttext(const std::wstring &text, LONG_PTR data);
|
||||||
|
@ -19,7 +19,7 @@ typedef void (*ProcessEvent)(DWORD pid);
|
|||||||
typedef void (*ThreadEvent_maybe_embed)(const wchar_t *hookcode, const char *hookname, ThreadParam, bool isembedable);
|
typedef void (*ThreadEvent_maybe_embed)(const wchar_t *hookcode, const char *hookname, ThreadParam, bool isembedable);
|
||||||
typedef void (*ThreadEvent)(const wchar_t *hookcode, const char *hookname, ThreadParam);
|
typedef void (*ThreadEvent)(const wchar_t *hookcode, const char *hookname, ThreadParam);
|
||||||
typedef bool (*OutputCallback)(const wchar_t *hookcode, const char *hookname, ThreadParam, const wchar_t *text);
|
typedef bool (*OutputCallback)(const wchar_t *hookcode, const char *hookname, ThreadParam, const wchar_t *text);
|
||||||
typedef void (*ConsoleHandler)(const wchar_t *log);
|
typedef void (*HostInfoHandler)(HOSTINFO type, const wchar_t *log);
|
||||||
typedef void (*HookInsertHandler)(DWORD pid, uint64_t address, const wchar_t *hookcode);
|
typedef void (*HookInsertHandler)(DWORD pid, uint64_t address, const wchar_t *hookcode);
|
||||||
typedef void (*EmbedCallback)(const wchar_t *text, ThreadParam);
|
typedef void (*EmbedCallback)(const wchar_t *text, ThreadParam);
|
||||||
typedef void (*findhookcallback_t)(wchar_t *hookcode, const wchar_t *text);
|
typedef void (*findhookcallback_t)(wchar_t *hookcode, const wchar_t *text);
|
||||||
@ -30,7 +30,7 @@ std::optional<T> checkoption(bool check, T &&t)
|
|||||||
return std::move(t);
|
return std::move(t);
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
C_LUNA_API void Luna_Start(ProcessEvent Connect, ProcessEvent Disconnect, ThreadEvent_maybe_embed Create, ThreadEvent Destroy, OutputCallback Output, ConsoleHandler console, HookInsertHandler hookinsert, EmbedCallback embed, ConsoleHandler Warning)
|
C_LUNA_API void Luna_Start(ProcessEvent Connect, ProcessEvent Disconnect, ThreadEvent_maybe_embed Create, ThreadEvent Destroy, OutputCallback Output, HostInfoHandler hostinfo, HookInsertHandler hookinsert, EmbedCallback embed)
|
||||||
{
|
{
|
||||||
Host::StartEx(
|
Host::StartEx(
|
||||||
checkoption(Connect, std::function<void(DWORD)>(Connect)),
|
checkoption(Connect, std::function<void(DWORD)>(Connect)),
|
||||||
@ -41,14 +41,13 @@ C_LUNA_API void Luna_Start(ProcessEvent Connect, ProcessEvent Disconnect, Thread
|
|||||||
{ Destroy(thread.hp.hookcode, thread.hp.name, thread.tp); }),
|
{ Destroy(thread.hp.hookcode, thread.hp.name, thread.tp); }),
|
||||||
checkoption(Output, [=](const TextThread &thread, std::wstring &output)
|
checkoption(Output, [=](const TextThread &thread, std::wstring &output)
|
||||||
{ return Output(thread.hp.hookcode, thread.hp.name, thread.tp, output.c_str()); }),
|
{ return Output(thread.hp.hookcode, thread.hp.name, thread.tp, output.c_str()); }),
|
||||||
checkoption(console, [=](const std::wstring &output)
|
false,
|
||||||
{ console(output.c_str()); }),
|
checkoption(hostinfo, [=](HOSTINFO type, const std::wstring &output)
|
||||||
|
{ hostinfo(type, output.c_str()); }),
|
||||||
checkoption(hookinsert, [=](DWORD pid, uint64_t addr, const std::wstring &hookcode)
|
checkoption(hookinsert, [=](DWORD pid, uint64_t addr, const std::wstring &hookcode)
|
||||||
{ hookinsert(pid, addr, hookcode.c_str()); }),
|
{ hookinsert(pid, addr, hookcode.c_str()); }),
|
||||||
checkoption(embed, [=](const std::wstring &output, const ThreadParam &tp)
|
checkoption(embed, [=](const std::wstring &output, const ThreadParam &tp)
|
||||||
{ embed(output.c_str(), tp); }),
|
{ embed(output.c_str(), tp); }));
|
||||||
checkoption(Warning, [=](const std::wstring &output)
|
|
||||||
{ Warning(output.c_str()); }));
|
|
||||||
}
|
}
|
||||||
C_LUNA_API void Luna_Inject(DWORD pid, LPCWSTR basepath)
|
C_LUNA_API void Luna_Inject(DWORD pid, LPCWSTR basepath)
|
||||||
{
|
{
|
||||||
|
@ -49,8 +49,8 @@ namespace
|
|||||||
|
|
||||||
Host::ProcessEventHandler OnConnect, OnDisconnect;
|
Host::ProcessEventHandler OnConnect, OnDisconnect;
|
||||||
Host::ThreadEventHandler OnCreate, OnDestroy;
|
Host::ThreadEventHandler OnCreate, OnDestroy;
|
||||||
Host::ConsoleHandler OnConsole = 0;
|
Host::HostInfoHandler OnHostInfo = 0;
|
||||||
Host::ConsoleHandler OnWarning = 0;
|
bool has_consolethread = false;
|
||||||
Host::HookInsertHandler HookInsert = 0;
|
Host::HookInsertHandler HookInsert = 0;
|
||||||
Host::EmbedCallback embedcallback = 0;
|
Host::EmbedCallback embedcallback = 0;
|
||||||
void RemoveThreads(std::function<bool(ThreadParam)> removeIf)
|
void RemoveThreads(std::function<bool(ThreadParam)> removeIf)
|
||||||
@ -104,7 +104,7 @@ namespace
|
|||||||
WORD hookversion[4];
|
WORD hookversion[4];
|
||||||
if( ReadFile(hookPipe, hookversion, sizeof(hookversion), &bytesRead, nullptr)){
|
if( ReadFile(hookPipe, hookversion, sizeof(hookversion), &bytesRead, nullptr)){
|
||||||
if(memcmp(hookversion,LUNA_VERSION,sizeof(hookversion))!=0)
|
if(memcmp(hookversion,LUNA_VERSION,sizeof(hookversion))!=0)
|
||||||
Host::Warning(UNMATCHABLEVERSION);
|
Host::InfoOutput(HOSTINFO::Warning, UNMATCHABLEVERSION);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (ReadFile(hookPipe, buffer, PIPE_BUFFER_SIZE, &bytesRead, nullptr))
|
while (ReadFile(hookPipe, buffer, PIPE_BUFFER_SIZE, &bytesRead, nullptr))
|
||||||
@ -150,14 +150,8 @@ namespace
|
|||||||
break;
|
break;
|
||||||
case HOST_NOTIFICATION_TEXT:
|
case HOST_NOTIFICATION_TEXT:
|
||||||
{
|
{
|
||||||
auto info = *(ConsoleOutputNotif*)buffer;
|
auto info = *(HostInfoNotif*)buffer;
|
||||||
Host::AddConsoleOutput(StringToWideString(info.message));
|
Host::InfoOutput(info.type, StringToWideString(info.message));
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HOST_NOTIFICATION_WARNING:
|
|
||||||
{
|
|
||||||
auto info = *(WarningNotif*)buffer;
|
|
||||||
Host::Warning(StringToWideString(info.message));
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -225,20 +219,27 @@ namespace Host
|
|||||||
{
|
{
|
||||||
OnCreate(textThreadsByParams->try_emplace(console, console, HookParam{}, CONSOLE).first->second);
|
OnCreate(textThreadsByParams->try_emplace(console, console, HookParam{}, CONSOLE).first->second);
|
||||||
Host::AddConsoleOutput(ProjectHomePage);
|
Host::AddConsoleOutput(ProjectHomePage);
|
||||||
|
has_consolethread = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreatePipe();
|
// CreatePipe();
|
||||||
}
|
}
|
||||||
void StartEx(std::optional<ProcessEventHandler> Connect, std::optional<ProcessEventHandler> Disconnect, std::optional<ThreadEventHandler> Create, std::optional<ThreadEventHandler> Destroy, std::optional<TextThread::OutputCallback> Output, std::optional<ConsoleHandler> console, std::optional<HookInsertHandler> hookinsert, std::optional<EmbedCallback> embed, std::optional<ConsoleHandler> warning)
|
void StartEx(std::optional<ProcessEventHandler> Connect,
|
||||||
|
std::optional<ProcessEventHandler> Disconnect,
|
||||||
|
std::optional<ThreadEventHandler> Create,
|
||||||
|
std::optional<ThreadEventHandler> Destroy,
|
||||||
|
std::optional<TextThread::OutputCallback> Output,
|
||||||
|
bool consolethread,
|
||||||
|
std::optional<HostInfoHandler> hostinfo,
|
||||||
|
std::optional<HookInsertHandler> hookinsert,
|
||||||
|
std::optional<EmbedCallback> embed)
|
||||||
{
|
{
|
||||||
Start(Connect.value_or([](auto) {}), Disconnect.value_or([](auto) {}), Create.value_or([](auto &) {}), Destroy.value_or([](auto &) {}), Output.value_or([](auto &, auto &)
|
Start(Connect.value_or([](auto) {}), Disconnect.value_or([](auto) {}), Create.value_or([](auto &) {}), Destroy.value_or([](auto &) {}), Output.value_or([](auto &, auto &)
|
||||||
{ return false; }),
|
{ return false; }),
|
||||||
!console);
|
consolethread);
|
||||||
if (warning)
|
if (hostinfo)
|
||||||
OnWarning = warning.value();
|
OnHostInfo = [=](auto &&...args)
|
||||||
if (console)
|
{std::lock_guard _(outputmutex);hostinfo.value()(std::forward<decltype(args)>(args)...); };
|
||||||
OnConsole = [=](auto &&...args)
|
|
||||||
{std::lock_guard _(outputmutex);console.value()(std::forward<decltype(args)>(args)...); };
|
|
||||||
if (hookinsert)
|
if (hookinsert)
|
||||||
HookInsert = [=](auto &&...args)
|
HookInsert = [=](auto &&...args)
|
||||||
{std::lock_guard _(threadmutex);hookinsert.value()(std::forward<decltype(args)>(args)...); };
|
{std::lock_guard _(threadmutex);hookinsert.value()(std::forward<decltype(args)>(args)...); };
|
||||||
@ -403,16 +404,29 @@ namespace Host
|
|||||||
}
|
}
|
||||||
void AddConsoleOutput(std::wstring text)
|
void AddConsoleOutput(std::wstring text)
|
||||||
{
|
{
|
||||||
if (OnConsole)
|
InfoOutput(HOSTINFO::Console, text);
|
||||||
OnConsole(std::move(text));
|
|
||||||
else
|
|
||||||
GetThread(console).AddSentence(std::move(text));
|
|
||||||
}
|
}
|
||||||
void Warning(std::wstring text)
|
void InfoOutput(HOSTINFO type, std::wstring text)
|
||||||
{
|
{
|
||||||
if (OnWarning)
|
if (OnHostInfo)
|
||||||
OnWarning(text);
|
OnHostInfo(type, std::move(text));
|
||||||
AddConsoleOutput(L"[Warning] " + text);
|
|
||||||
|
if (has_consolethread || (type != HOSTINFO::Console))
|
||||||
|
{
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case HOSTINFO::Warning:
|
||||||
|
text = L"[Warning] " + text;
|
||||||
|
break;
|
||||||
|
case HOSTINFO::EmuGameName:
|
||||||
|
text = L"[Game] " + text;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (has_consolethread)
|
||||||
|
GetThread(console).AddSentence(std::move(text));
|
||||||
|
else if (type != HOSTINFO::Console)
|
||||||
|
OnHostInfo(HOSTINFO::Console, std::move(text));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
bool CheckIsUsingEmbed(ThreadParam tp)
|
bool CheckIsUsingEmbed(ThreadParam tp)
|
||||||
{
|
{
|
||||||
|
@ -3,14 +3,14 @@
|
|||||||
#include "textthread.h"
|
#include "textthread.h"
|
||||||
namespace Host
|
namespace Host
|
||||||
{
|
{
|
||||||
using ConsoleHandler = std::function<void(const std::wstring &)>;
|
using HostInfoHandler = std::function<void(HOSTINFO type, const std::wstring &)>;
|
||||||
using ProcessEventHandler = std::function<void(DWORD)>;
|
using ProcessEventHandler = std::function<void(DWORD)>;
|
||||||
using ThreadEventHandler = std::function<void(TextThread &)>;
|
using ThreadEventHandler = std::function<void(TextThread &)>;
|
||||||
using HookEventHandler = std::function<void(const HookParam &, const std::wstring &text)>;
|
using HookEventHandler = std::function<void(const HookParam &, const std::wstring &text)>;
|
||||||
using HookInsertHandler = std::function<void(DWORD, uint64_t, const std::wstring &)>;
|
using HookInsertHandler = std::function<void(DWORD, uint64_t, const std::wstring &)>;
|
||||||
using EmbedCallback = std::function<void(const std::wstring &, const ThreadParam &)>;
|
using EmbedCallback = std::function<void(const std::wstring &, const ThreadParam &)>;
|
||||||
void Start(ProcessEventHandler Connect, ProcessEventHandler Disconnect, ThreadEventHandler Create, ThreadEventHandler Destroy, TextThread::OutputCallback Output, bool createconsole = true);
|
void Start(ProcessEventHandler Connect, ProcessEventHandler Disconnect, ThreadEventHandler Create, ThreadEventHandler Destroy, TextThread::OutputCallback Output, bool createconsole = true);
|
||||||
void StartEx(std::optional<ProcessEventHandler> Connect, std::optional<ProcessEventHandler> Disconnect, std::optional<ThreadEventHandler> Create, std::optional<ThreadEventHandler> Destroy, std::optional<TextThread::OutputCallback> Output, std::optional<ConsoleHandler> console, std::optional<HookInsertHandler> hookinsert, std::optional<EmbedCallback> embed, std::optional<ConsoleHandler> warning);
|
void StartEx(std::optional<ProcessEventHandler> Connect, std::optional<ProcessEventHandler> Disconnect, std::optional<ThreadEventHandler> Create, std::optional<ThreadEventHandler> Destroy, std::optional<TextThread::OutputCallback> Output, bool consolethread, std::optional<HostInfoHandler> hostinfo, std::optional<HookInsertHandler> hookinsert, std::optional<EmbedCallback> embed);
|
||||||
void InjectProcess(DWORD processId, const std::wstring locationX = L"");
|
void InjectProcess(DWORD processId, const std::wstring locationX = L"");
|
||||||
bool CreatePipeAndCheck(DWORD processId);
|
bool CreatePipeAndCheck(DWORD processId);
|
||||||
|
|
||||||
@ -23,9 +23,8 @@ namespace Host
|
|||||||
CommonSharedMem *GetCommonSharedMem(DWORD pid);
|
CommonSharedMem *GetCommonSharedMem(DWORD pid);
|
||||||
TextThread *GetThread(int64_t handle);
|
TextThread *GetThread(int64_t handle);
|
||||||
TextThread &GetThread(ThreadParam tp);
|
TextThread &GetThread(ThreadParam tp);
|
||||||
|
void InfoOutput(HOSTINFO type, std::wstring text);
|
||||||
void AddConsoleOutput(std::wstring text);
|
void AddConsoleOutput(std::wstring text);
|
||||||
void Warning(std::wstring text);
|
|
||||||
|
|
||||||
inline int defaultCodepage = SHIFT_JIS;
|
inline int defaultCodepage = SHIFT_JIS;
|
||||||
|
|
||||||
|
@ -36,7 +36,12 @@ enum HostNotificationType
|
|||||||
HOST_NOTIFICATION_RMVHOOK,
|
HOST_NOTIFICATION_RMVHOOK,
|
||||||
HOST_NOTIFICATION_INSERTING_HOOK,
|
HOST_NOTIFICATION_INSERTING_HOOK,
|
||||||
HOST_SETTEXTTHREADTYPE,
|
HOST_SETTEXTTHREADTYPE,
|
||||||
HOST_NOTIFICATION_WARNING
|
};
|
||||||
|
enum class HOSTINFO
|
||||||
|
{
|
||||||
|
Console,
|
||||||
|
Warning,
|
||||||
|
EmuGameName
|
||||||
};
|
};
|
||||||
#define NEXT_MASK(x) \
|
#define NEXT_MASK(x) \
|
||||||
DUMMY1_##x, \
|
DUMMY1_##x, \
|
||||||
|
@ -155,7 +155,7 @@ struct SearchParam
|
|||||||
wchar_t boundaryModule[MAX_MODULE_SIZE] = {}; // hook all functions within this module (middle priority)
|
wchar_t boundaryModule[MAX_MODULE_SIZE] = {}; // hook all functions within this module (middle priority)
|
||||||
wchar_t exportModule[MAX_MODULE_SIZE] = {}; // hook the exports of this module (highest priority)
|
wchar_t exportModule[MAX_MODULE_SIZE] = {}; // hook the exports of this module (highest priority)
|
||||||
wchar_t text[PATTERN_SIZE] = {}; // text to search for
|
wchar_t text[PATTERN_SIZE] = {}; // text to search for
|
||||||
JITTYPE jittype;
|
bool isjithook;
|
||||||
};
|
};
|
||||||
struct InsertPCHooksCmd
|
struct InsertPCHooksCmd
|
||||||
{
|
{
|
||||||
@ -183,16 +183,11 @@ struct FindHookCmd // From host
|
|||||||
SearchParam sp;
|
SearchParam sp;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ConsoleOutputNotif // From dll
|
struct HostInfoNotif // From dll
|
||||||
{
|
{
|
||||||
ConsoleOutputNotif(std::string message = "") { strncpy_s(this->message, message.c_str(), MESSAGE_SIZE - 1); }
|
HostInfoNotif(std::string message = "") { strncpy_s(this->message, message.c_str(), MESSAGE_SIZE - 1); }
|
||||||
HostNotificationType command = HOST_NOTIFICATION_TEXT;
|
HostNotificationType command = HOST_NOTIFICATION_TEXT;
|
||||||
char message[MESSAGE_SIZE] = {};
|
HOSTINFO type;
|
||||||
};
|
|
||||||
struct WarningNotif // From dll
|
|
||||||
{
|
|
||||||
WarningNotif(std::string message = "") { strncpy_s(this->message, message.c_str(), MESSAGE_SIZE - 1); }
|
|
||||||
HostNotificationType command = HOST_NOTIFICATION_WARNING;
|
|
||||||
char message[MESSAGE_SIZE] = {};
|
char message[MESSAGE_SIZE] = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -83,13 +83,14 @@ struct ThreadParam
|
|||||||
uint64_t ctx; // The context of the hook: by default the first value on stack, usually the return address
|
uint64_t ctx; // The context of the hook: by default the first value on stack, usually the return address
|
||||||
uint64_t ctx2; // The subcontext of the hook: 0 by default, generated in a method specific to the hook
|
uint64_t ctx2; // The subcontext of the hook: 0 by default, generated in a method specific to the hook
|
||||||
};
|
};
|
||||||
typedef void (*ProcessEvent)(DWORD);
|
|
||||||
typedef void (*HookInsertHandler)(DWORD, uint64_t, const wchar_t *);
|
typedef void (*ProcessEvent)(DWORD pid);
|
||||||
typedef void (*EmbedCallback)(const wchar_t *, ThreadParam);
|
typedef void (*HookInsertHandler)(DWORD pid, uint64_t address, const wchar_t *hookcode);
|
||||||
|
typedef void (*EmbedCallback)(const wchar_t *text, ThreadParam);
|
||||||
nlohmann::json config;
|
nlohmann::json config;
|
||||||
std::map<std::string, std::string> translation;
|
std::map<std::string, std::string> translation;
|
||||||
std::unordered_set<DWORD> connectedpids;
|
std::unordered_set<DWORD> connectedpids;
|
||||||
void (*Luna_Start)(ProcessEvent Connect, ProcessEvent Disconnect, void *, void *, void *, void *, HookInsertHandler hookinsert, EmbedCallback embed, void *);
|
void (*Luna_Start)(ProcessEvent Connect, ProcessEvent Disconnect, void *, void *, void *, void *, HookInsertHandler hookinsert, EmbedCallback embed);
|
||||||
void (*Luna_Inject)(DWORD pid, LPCWSTR basepath);
|
void (*Luna_Inject)(DWORD pid, LPCWSTR basepath);
|
||||||
void (*Luna_EmbedSettings)(DWORD pid, UINT32 waittime, UINT8 fontCharSet, bool fontCharSetEnabled, wchar_t *fontFamily, UINT32 keeprawtext, bool fastskipignore);
|
void (*Luna_EmbedSettings)(DWORD pid, UINT32 waittime, UINT8 fontCharSet, bool fontCharSetEnabled, wchar_t *fontFamily, UINT32 keeprawtext, bool fastskipignore);
|
||||||
void (*Luna_useembed)(ThreadParam, bool use);
|
void (*Luna_useembed)(ThreadParam, bool use);
|
||||||
@ -150,8 +151,7 @@ public:
|
|||||||
std::wstring text = output;
|
std::wstring text = output;
|
||||||
auto trans = findtranslation(text);
|
auto trans = findtranslation(text);
|
||||||
Luna_embedcallback(tp, output, trans.c_str());
|
Luna_embedcallback(tp, output, trans.c_str());
|
||||||
},
|
});
|
||||||
0);
|
|
||||||
}
|
}
|
||||||
void run()
|
void run()
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
|
|
||||||
set(VERSION_MAJOR 6)
|
set(VERSION_MAJOR 6)
|
||||||
set(VERSION_MINOR 6)
|
set(VERSION_MINOR 7)
|
||||||
set(VERSION_PATCH 10)
|
set(VERSION_PATCH 0)
|
||||||
set(VERSION_REVISION 0)
|
set(VERSION_REVISION 0)
|
||||||
set(LUNA_VERSION "{${VERSION_MAJOR},${VERSION_MINOR},${VERSION_PATCH},${VERSION_REVISION}}")
|
set(LUNA_VERSION "{${VERSION_MAJOR},${VERSION_MINOR},${VERSION_PATCH},${VERSION_REVISION}}")
|
||||||
add_library(VERSION_DEF ${CMAKE_CURRENT_LIST_DIR}/version_def.cpp)
|
add_library(VERSION_DEF ${CMAKE_CURRENT_LIST_DIR}/version_def.cpp)
|
||||||
|
@ -29,6 +29,12 @@ from gui.dynalang import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class HOSTINFO:
|
||||||
|
Console = 0
|
||||||
|
Warning = 1
|
||||||
|
EmuGameName = 2
|
||||||
|
|
||||||
|
|
||||||
def getformlayoutw(w=None, cls=LFormLayout, hide=False):
|
def getformlayoutw(w=None, cls=LFormLayout, hide=False):
|
||||||
if w is None:
|
if w is None:
|
||||||
_w = QWidget()
|
_w = QWidget()
|
||||||
@ -155,7 +161,7 @@ class searchhookparam(LDialog):
|
|||||||
usestruct.boundaryModule = dumpvalues["module"][:120]
|
usestruct.boundaryModule = dumpvalues["module"][:120]
|
||||||
usestruct.address_method = self.search_addr_range.idx()
|
usestruct.address_method = self.search_addr_range.idx()
|
||||||
usestruct.search_method = self.search_method.idx()
|
usestruct.search_method = self.search_method.idx()
|
||||||
usestruct.jittype = dumpvalues["jittype"]
|
usestruct.isjithook = bool(dumpvalues["isjithook"])
|
||||||
if self.search_addr_range.idx() == 0:
|
if self.search_addr_range.idx() == 0:
|
||||||
usestruct.minAddress = self.safehex(
|
usestruct.minAddress = self.safehex(
|
||||||
dumpvalues["startaddr"], usestruct.minAddress
|
dumpvalues["startaddr"], usestruct.minAddress
|
||||||
@ -336,7 +342,7 @@ class searchhookparam(LDialog):
|
|||||||
|
|
||||||
self.layoutsettings.addRow("搜索方式", _typelayout)
|
self.layoutsettings.addRow("搜索方式", _typelayout)
|
||||||
_jitcombo = FocusCombo()
|
_jitcombo = FocusCombo()
|
||||||
_jitcombo.addItems(["PC", "YUZU", "PPSSPP", "VITA3K", "RPCS3"])
|
_jitcombo.addItems(["PC", "JIT"])
|
||||||
self.search_method = QButtonGroup_switch_widegt(self)
|
self.search_method = QButtonGroup_switch_widegt(self)
|
||||||
_jitcombo.currentIndexChanged.connect(
|
_jitcombo.currentIndexChanged.connect(
|
||||||
lambda idx: [
|
lambda idx: [
|
||||||
@ -344,7 +350,7 @@ class searchhookparam(LDialog):
|
|||||||
self.resize(self.width(), 1),
|
self.resize(self.width(), 1),
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
self.regists["jittype"] = lambda: _jitcombo.currentIndex()
|
self.regists["isjithook"] = lambda: bool(_jitcombo.currentIndex())
|
||||||
|
|
||||||
_typelayout.addRow("类型", _jitcombo)
|
_typelayout.addRow("类型", _jitcombo)
|
||||||
|
|
||||||
@ -384,11 +390,10 @@ class searchhookparam(LDialog):
|
|||||||
class hookselect(closeashidewindow):
|
class hookselect(closeashidewindow):
|
||||||
addnewhooksignal = pyqtSignal(tuple, bool, bool)
|
addnewhooksignal = pyqtSignal(tuple, bool, bool)
|
||||||
getnewsentencesignal = pyqtSignal(str)
|
getnewsentencesignal = pyqtSignal(str)
|
||||||
sysmessagesignal = pyqtSignal(str)
|
sysmessagesignal = pyqtSignal(int, str)
|
||||||
removehooksignal = pyqtSignal(tuple)
|
removehooksignal = pyqtSignal(tuple)
|
||||||
getfoundhooksignal = pyqtSignal(dict)
|
getfoundhooksignal = pyqtSignal(dict)
|
||||||
update_item_new_line = pyqtSignal(tuple, str)
|
update_item_new_line = pyqtSignal(tuple, str)
|
||||||
warning = pyqtSignal(str)
|
|
||||||
|
|
||||||
SaveTextThreadRole = Qt.ItemDataRole.UserRole + 1
|
SaveTextThreadRole = Qt.ItemDataRole.UserRole + 1
|
||||||
|
|
||||||
@ -402,17 +407,9 @@ class hookselect(closeashidewindow):
|
|||||||
self.sysmessagesignal.connect(self.sysmessage)
|
self.sysmessagesignal.connect(self.sysmessage)
|
||||||
self.update_item_new_line.connect(self.update_item_new_line_function)
|
self.update_item_new_line.connect(self.update_item_new_line_function)
|
||||||
self.getfoundhooksignal.connect(self.getfoundhook)
|
self.getfoundhooksignal.connect(self.getfoundhook)
|
||||||
self.warning.connect(self.warningf)
|
|
||||||
self.setWindowTitle("选择文本")
|
self.setWindowTitle("选择文本")
|
||||||
self.changeprocessclear()
|
self.changeprocessclear()
|
||||||
|
|
||||||
def warningf(self, text):
|
|
||||||
getQMessageBox(
|
|
||||||
self,
|
|
||||||
"警告",
|
|
||||||
text,
|
|
||||||
)
|
|
||||||
|
|
||||||
def querykeyofrow(self, row):
|
def querykeyofrow(self, row):
|
||||||
if isinstance(row, QModelIndex):
|
if isinstance(row, QModelIndex):
|
||||||
row = row.row()
|
row = row.row()
|
||||||
@ -557,7 +554,9 @@ class hookselect(closeashidewindow):
|
|||||||
self.widget = QWidget()
|
self.widget = QWidget()
|
||||||
|
|
||||||
self.setCentralWidget(self.widget)
|
self.setCentralWidget(self.widget)
|
||||||
self.setWindowIcon(qtawesome.icon(globalconfig["toolbutton"]["buttons"]["selecttext"]["icon"]))
|
self.setWindowIcon(
|
||||||
|
qtawesome.icon(globalconfig["toolbutton"]["buttons"]["selecttext"]["icon"])
|
||||||
|
)
|
||||||
self.hboxlayout = QHBoxLayout()
|
self.hboxlayout = QHBoxLayout()
|
||||||
self.widget.setLayout(self.hboxlayout)
|
self.widget.setLayout(self.hboxlayout)
|
||||||
self.vboxlayout = QVBoxLayout()
|
self.vboxlayout = QVBoxLayout()
|
||||||
@ -861,11 +860,19 @@ class hookselect(closeashidewindow):
|
|||||||
if atBottom:
|
if atBottom:
|
||||||
scrollbar.setValue(scrollbar.maximum())
|
scrollbar.setValue(scrollbar.maximum())
|
||||||
|
|
||||||
def sysmessage(self, sentence):
|
def sysmessage(self, info, sentence):
|
||||||
|
if info == HOSTINFO.Console:
|
||||||
self.textbrowappendandmovetoend(
|
self.textbrowappendandmovetoend(
|
||||||
self.sysOutput, get_time_stamp() + " " + sentence
|
self.sysOutput, get_time_stamp() + " " + sentence
|
||||||
)
|
)
|
||||||
|
elif info == HOSTINFO.Warning:
|
||||||
|
getQMessageBox(
|
||||||
|
self,
|
||||||
|
"警告",
|
||||||
|
sentence,
|
||||||
|
)
|
||||||
|
elif info == HOSTINFO.EmuGameName:
|
||||||
|
gobject.baseobject.displayinfomessage(sentence, "<msg_info_refresh>")
|
||||||
|
|
||||||
def getnewsentence(self, sentence):
|
def getnewsentence(self, sentence):
|
||||||
if self.at1 == 2:
|
if self.at1 == 2:
|
||||||
|
@ -85,7 +85,7 @@ class SearchParam(Structure):
|
|||||||
("boundaryModule", c_wchar * 120),
|
("boundaryModule", c_wchar * 120),
|
||||||
("exportModule", c_wchar * 120),
|
("exportModule", c_wchar * 120),
|
||||||
("text", c_wchar * 30),
|
("text", c_wchar * 30),
|
||||||
("jittype", c_int),
|
("isjithook", c_bool),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
@ -94,7 +94,7 @@ ProcessEvent = CFUNCTYPE(None, DWORD)
|
|||||||
ThreadEvent_maybe_embed = CFUNCTYPE(None, c_wchar_p, c_char_p, ThreadParam, c_bool)
|
ThreadEvent_maybe_embed = CFUNCTYPE(None, c_wchar_p, c_char_p, ThreadParam, c_bool)
|
||||||
ThreadEvent = CFUNCTYPE(None, c_wchar_p, c_char_p, ThreadParam)
|
ThreadEvent = CFUNCTYPE(None, c_wchar_p, c_char_p, ThreadParam)
|
||||||
OutputCallback = CFUNCTYPE(c_bool, c_wchar_p, c_char_p, ThreadParam, c_wchar_p)
|
OutputCallback = CFUNCTYPE(c_bool, c_wchar_p, c_char_p, ThreadParam, c_wchar_p)
|
||||||
ConsoleHandler = CFUNCTYPE(None, c_wchar_p)
|
HostInfoHandler = CFUNCTYPE(None, c_int, c_wchar_p)
|
||||||
HookInsertHandler = CFUNCTYPE(None, DWORD, c_uint64, c_wchar_p)
|
HookInsertHandler = CFUNCTYPE(None, DWORD, c_uint64, c_wchar_p)
|
||||||
EmbedCallback = CFUNCTYPE(None, c_wchar_p, ThreadParam)
|
EmbedCallback = CFUNCTYPE(None, c_wchar_p, ThreadParam)
|
||||||
QueryHistoryCallback = CFUNCTYPE(None, c_wchar_p)
|
QueryHistoryCallback = CFUNCTYPE(None, c_wchar_p)
|
||||||
@ -206,7 +206,6 @@ class texthook(basetext):
|
|||||||
c_void_p,
|
c_void_p,
|
||||||
c_void_p,
|
c_void_p,
|
||||||
c_void_p,
|
c_void_p,
|
||||||
c_void_p,
|
|
||||||
)
|
)
|
||||||
self.Luna_Inject = LunaHost.Luna_Inject
|
self.Luna_Inject = LunaHost.Luna_Inject
|
||||||
self.Luna_Inject.argtypes = DWORD, LPCWSTR
|
self.Luna_Inject.argtypes = DWORD, LPCWSTR
|
||||||
@ -252,10 +251,9 @@ class texthook(basetext):
|
|||||||
ThreadEvent_maybe_embed(self.onnewhook),
|
ThreadEvent_maybe_embed(self.onnewhook),
|
||||||
ThreadEvent(self.onremovehook),
|
ThreadEvent(self.onremovehook),
|
||||||
OutputCallback(self.handle_output),
|
OutputCallback(self.handle_output),
|
||||||
ConsoleHandler(gobject.baseobject.hookselectdialog.sysmessagesignal.emit),
|
HostInfoHandler(gobject.baseobject.hookselectdialog.sysmessagesignal.emit),
|
||||||
HookInsertHandler(self.newhookinsert),
|
HookInsertHandler(self.newhookinsert),
|
||||||
EmbedCallback(self.getembedtext),
|
EmbedCallback(self.getembedtext),
|
||||||
ConsoleHandler(gobject.baseobject.hookselectdialog.warning.emit),
|
|
||||||
]
|
]
|
||||||
self.keepref += procs
|
self.keepref += procs
|
||||||
ptrs = [cast(_, c_void_p).value for _ in procs]
|
ptrs = [cast(_, c_void_p).value for _ in procs]
|
||||||
@ -342,7 +340,9 @@ class texthook(basetext):
|
|||||||
self.gameuid = gameuid
|
self.gameuid = gameuid
|
||||||
self.detachall()
|
self.detachall()
|
||||||
_filename, _ = os.path.splitext(os.path.basename(gamepath))
|
_filename, _ = os.path.splitext(os.path.basename(gamepath))
|
||||||
sqlitef = gobject.gettranslationrecorddir("{}_{}.sqlite".format(_filename, gameuid))
|
sqlitef = gobject.gettranslationrecorddir(
|
||||||
|
"{}_{}.sqlite".format(_filename, gameuid)
|
||||||
|
)
|
||||||
if os.path.exists(sqlitef) == False:
|
if os.path.exists(sqlitef) == False:
|
||||||
md5 = getfilemd5(gamepath)
|
md5 = getfilemd5(gamepath)
|
||||||
f2 = gobject.gettranslationrecorddir("{}_{}.sqlite".format(_filename, md5))
|
f2 = gobject.gettranslationrecorddir("{}_{}.sqlite".format(_filename, md5))
|
||||||
@ -396,7 +396,9 @@ class texthook(basetext):
|
|||||||
injectpids.append(pid)
|
injectpids.append(pid)
|
||||||
if len(injectpids):
|
if len(injectpids):
|
||||||
arch = ["32", "64"][self.is64bit]
|
arch = ["32", "64"][self.is64bit]
|
||||||
dll = os.path.abspath("./files/plugins/LunaHook/LunaHook{}.dll".format(arch))
|
dll = os.path.abspath(
|
||||||
|
"./files/plugins/LunaHook/LunaHook{}.dll".format(arch)
|
||||||
|
)
|
||||||
injectdll(injectpids, arch, dll)
|
injectdll(injectpids, arch, dll)
|
||||||
|
|
||||||
@threader
|
@threader
|
||||||
@ -605,7 +607,7 @@ class texthook(basetext):
|
|||||||
usestruct.maxRecords = 100000
|
usestruct.maxRecords = 100000
|
||||||
usestruct.codepage = self.codepage()
|
usestruct.codepage = self.codepage()
|
||||||
usestruct.boundaryModule = os.path.basename(self.gamepath)
|
usestruct.boundaryModule = os.path.basename(self.gamepath)
|
||||||
usestruct.jittype = 0
|
usestruct.isjithook = False
|
||||||
return usestruct
|
return usestruct
|
||||||
|
|
||||||
@threader
|
@threader
|
||||||
|
Loading…
x
Reference in New Issue
Block a user