Skip to content

Commit

Permalink
Console: Limit buffer size in ConsoleLogFromVM::Write
Browse files Browse the repository at this point in the history
  • Loading branch information
chaoticgd committed Nov 25, 2024
1 parent b049664 commit 0a03c36
Showing 1 changed file with 12 additions and 17 deletions.
29 changes: 12 additions & 17 deletions pcsx2/DebugTools/Debug.h
Original file line number Diff line number Diff line change
Expand Up @@ -87,8 +87,7 @@ struct ConsoleLog : public LogBase
// ConsoleLogFromVM
// --------------------------------------------------------------------------------------
// Special console logger for Virtual Machine log sources, such as the EE and IOP console
// writes (actual game developer messages and such). These logs do *not* automatically
// append newlines, since the VM generates them manually; and they do *not* support printf
// writes (actual game developer messages and such). These logs do *not* support printf
// formatting, since anything coming over the EE/IOP consoles should be considered raw
// string data. (otherwise %'s would get mis-interpreted).
//
Expand All @@ -102,22 +101,18 @@ class ConsoleLogFromVM : public LogBase
{
for (const char ch : msg)
{
if (ch == '\n')
{
if (!m_buffer.empty())
{
Console.WriteLn(conColor, m_buffer);
m_buffer.clear();
}
}
else if (ch < 0x20)
{
// Ignore control characters.
// Otherwise you get fun bells going off.
}
else
{
// Ignore control characters.
// Otherwise you get fun bells going off.
if (ch < 0x20)
continue;

if (ch != '\n')
m_buffer.push_back(ch);

if (ch == '\n' || m_buffer.size() >= 4096)
{
Console.WriteLn(conColor, m_buffer);
m_buffer.clear();
}
}

Expand Down

0 comments on commit 0a03c36

Please sign in to comment.