remove useless

Update hookcode.cpp
This commit is contained in:
恍兮惚兮 2024-03-27 19:33:28 +08:00
parent a74f773826
commit d0e2bb27c2
3 changed files with 34 additions and 41 deletions

View File

@ -57,8 +57,7 @@ void TextThread::Push(BYTE* data, int length)
}
}
if (hp.type & HEX_DUMP) for (int i = 0; i < length; i += sizeof(short)) buffer.append(FormatString(L"%04hX ", *(short*)(data + i)));
else if (auto converted = commonparsestring(data,length,&hp,Host::defaultCodepage)) buffer.append(converted.value());
if (auto converted = commonparsestring(data,length,&hp,Host::defaultCodepage)) buffer.append(converted.value());
else Host::AddConsoleOutput(INVALID_CODEPAGE);
if (hp.type & FULL_STRING) buffer.push_back(L'\n');
lastPushTime = GetTickCount64();

View File

@ -49,7 +49,6 @@ enum HookParamType : uint64_t
FIXING_SPLIT = 0x800,
DIRECT_READ = 0x1000, // /R read code instead of classic /H hook code
FULL_STRING = 0x2000,
HEX_DUMP = 0x4000,
KNOWN_UNSTABLE = 0x20000,
EMBED_ABLE=0x40000,
EMBED_DYNA_SJIS=0x80000,

View File

@ -22,9 +22,6 @@ namespace
case L'V':
hp.type |= CODEC_UTF8;
break;
case L'M':
hp.type |= CODEC_UTF16 | HEX_DUMP;
break;
default:
return {};
}
@ -63,9 +60,6 @@ namespace
case L'I':
hp.type |= CODEC_UTF32;
break;
case L'H':
hp.type |= CODEC_UTF16 | HEX_DUMP;
break;
case L'S':
hp.type |= USING_STRING;
break;
@ -78,9 +72,6 @@ namespace
case L'V':
hp.type |= USING_STRING | CODEC_UTF8;
break;
case L'M':
hp.type |= USING_STRING | CODEC_UTF16 | HEX_DUMP;
break;
default:
return {};
}
@ -222,12 +213,12 @@ namespace
{
std::wstring RCode = L"R";
if (hp.type & CODEC_UTF16||hp.type & CODEC_UTF32)
{
if (hp.type & HEX_DUMP) RCode += L'M';
else if (hp.type&CODEC_UTF16)RCode += L'Q';
else if (hp.type&CODEC_UTF32)RCode += L'U';
}
if(hp.type&CODEC_UTF16)
RCode += L'Q';
else if (hp.type&CODEC_UTF32)
RCode += L'U';
else if (hp.type&CODEC_UTF8)
RCode += L'V';
else
{
RCode += L'S';
@ -254,6 +245,7 @@ namespace
HCode+=L"D";
if(hp.type&EMBED_BEFORE_SIMPLE)
HCode+=L"S";
if(hp.type&EMBED_AFTER_NEW)
HCode+=L"N";
else if(hp.type&EMBED_AFTER_OVERWRITE)
@ -266,39 +258,40 @@ namespace
else
HCode += L"H";
if (hp.type & CODEC_UTF16||hp.type & CODEC_UTF32)
if (hp.text_fun || hp.filter_fun)
HCode += L'X';
else
{
if (hp.type & HEX_DUMP)
if(hp.type & USING_STRING)
{
if (hp.type & USING_STRING) HCode += L'M';
else HCode += L'H';
if(hp.type&CODEC_UTF16)
HCode += L'Q';
else if(hp.type&CODEC_UTF8)
HCode += L'V';
else if(hp.type&CODEC_UTF32)
HCode += L'U';
else
HCode += L'S';
}
else
{
if(hp.type&CODEC_UTF16){
if(hp.type&CODEC_UTF16)
HCode += L'W';
else if(hp.type&CODEC_UTF32)
HCode += L'I';
else if (hp.type & CODEC_ANSI_BE)
HCode += L'A';
else
HCode += L'B';
}
if (hp.type & USING_STRING) HCode += L'Q';
else HCode += L'W';
}
else if(hp.type&CODEC_UTF32){
if (hp.type & USING_STRING) HCode += L'U';
else HCode += L'I';
}
}
}
else
{
if (hp.type & USING_STRING) HCode += L'S';
else if (hp.type & CODEC_ANSI_BE) HCode += L'A';
else HCode += L'B';
}
if (hp.type & FULL_STRING) HCode += L'F';
if (hp.type & NO_CONTEXT) HCode += L'N';
if (hp.text_fun || hp.filter_fun) HCode += L'X'; // no AGTH equivalent
if (hp.codepage != 0 && !(hp.type & CODEC_UTF16||hp.type & CODEC_UTF32)) HCode += std::to_wstring(hp.codepage) + L'#';
if (hp.codepage != 0 && !(hp.type & CODEC_UTF8) ) HCode += std::to_wstring(hp.codepage) + L'#';
if (hp.padding) HCode += HexString(hp.padding) + L'+';
@ -310,6 +303,8 @@ namespace
if (hp.type & USING_SPLIT) HCode += L':' + HexString(hp.split);
if (hp.type & SPLIT_INDIRECT) HCode += L'*' + HexString(hp.split_index);
// Attempt to make the address relative
if (processId && !(hp.type & MODULE_OFFSET))
if (AutoHandle<> process = OpenProcess(PROCESS_VM_READ | PROCESS_QUERY_INFORMATION, FALSE, processId))