mirror of https://github.com/PCSX2/pcsx2.git
Change the console functions so that the terminal actually has colored text in Linux. (And doesn't have blue underlined text for most of FFX...)
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@2159 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
61b2ab7583
commit
190f66186f
|
@ -1,6 +1,6 @@
|
||||||
/* PCSX2 - PS2 Emulator for PCs
|
/* PCSX2 - PS2 Emulator for PCs
|
||||||
* Copyright (C) 2002-2009 PCSX2 Dev Team
|
* Copyright (C) 2002-2009 PCSX2 Dev Team
|
||||||
*
|
*
|
||||||
* PCSX2 is free software: you can redistribute it and/or modify it under the terms
|
* PCSX2 is free software: you can redistribute it and/or modify it under the terms
|
||||||
* of the GNU Lesser General Public License as published by the Free Software Found-
|
* of the GNU Lesser General Public License as published by the Free Software Found-
|
||||||
* ation, either version 3 of the License, or (at your option) any later version.
|
* ation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
@ -33,7 +33,7 @@ void Console_SetActiveHandler( const IConsoleWriter& writer, FILE* flushfp )
|
||||||
(writer.SetColor != NULL) && (writer.ClearColor != NULL),
|
(writer.SetColor != NULL) && (writer.ClearColor != NULL),
|
||||||
"Invalid IConsoleWriter object! All function pointer interfaces must be implemented."
|
"Invalid IConsoleWriter object! All function pointer interfaces must be implemented."
|
||||||
);
|
);
|
||||||
|
|
||||||
if( !ConsoleBuffer_Get().IsEmpty() )
|
if( !ConsoleBuffer_Get().IsEmpty() )
|
||||||
writer.DoWriteLn( ConsoleBuffer_Get() );
|
writer.DoWriteLn( ConsoleBuffer_Get() );
|
||||||
|
|
||||||
|
@ -75,6 +75,29 @@ const IConsoleWriter ConsoleWriter_Null =
|
||||||
// Console_Stdio
|
// Console_Stdio
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#ifdef __LINUX__
|
||||||
|
static wxString tbl_color_codes[] =
|
||||||
|
{
|
||||||
|
L"\033[30m" // black
|
||||||
|
, L"\033[31m" // red
|
||||||
|
, L"\033[32m" // green
|
||||||
|
, L"\033[33m" // yellow
|
||||||
|
, L"\033[34m" // blue
|
||||||
|
, L"\033[35m" // magenta
|
||||||
|
, L"\033[36m" // cyan
|
||||||
|
, L"\033[37m" // white!
|
||||||
|
, L"\033[30m\033[1m" // strong black
|
||||||
|
, L"\033[31m\033[1m" // strong red
|
||||||
|
, L"\033[32m\033[1m" // strong green
|
||||||
|
, L"\033[33m\033[1m" // strong yellow
|
||||||
|
, L"\033[34m\033[1m" // strong blue
|
||||||
|
, L"\033[35m\033[1m" // strong magenta
|
||||||
|
, L"\033[36m\033[1m" // strong cyan
|
||||||
|
, L"\033[37m\033[1m" // strong white!
|
||||||
|
, L"\033[0m" // Back to default.
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
// One possible default write action at startup and shutdown is to use the stdout.
|
// One possible default write action at startup and shutdown is to use the stdout.
|
||||||
static void __concall ConsoleStdio_DoWrite( const wxString& fmt )
|
static void __concall ConsoleStdio_DoWrite( const wxString& fmt )
|
||||||
{
|
{
|
||||||
|
@ -87,16 +110,62 @@ static void __concall ConsoleStdio_DoWriteLn( const wxString& fmt )
|
||||||
wxPrintf( fmt + L"\n" );
|
wxPrintf( fmt + L"\n" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleStdio_Newline()
|
||||||
|
{
|
||||||
|
wxPrintf( L"\n" );
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleStdio_SetColor( ConsoleColors color )
|
||||||
|
{
|
||||||
|
#ifdef __LINUX__
|
||||||
|
wxPrintf(tbl_color_codes[16]);
|
||||||
|
switch (color)
|
||||||
|
{
|
||||||
|
case Color_Black: wxPrintf(tbl_color_codes[0]); break;
|
||||||
|
case Color_Green: wxPrintf(tbl_color_codes[2]); break;
|
||||||
|
case Color_Red: wxPrintf(tbl_color_codes[1]); break;
|
||||||
|
case Color_Blue: wxPrintf(tbl_color_codes[4]); break;
|
||||||
|
case Color_Magenta: wxPrintf(tbl_color_codes[5]); break;
|
||||||
|
case Color_Orange: wxPrintf(tbl_color_codes[5]); break; // No orange, so use magenta.
|
||||||
|
case Color_Gray: wxPrintf(tbl_color_codes[7]); break; // Use white instead of grey.
|
||||||
|
case Color_Cyan: wxPrintf(tbl_color_codes[6]); break;
|
||||||
|
case Color_Yellow: wxPrintf(tbl_color_codes[3]); break;
|
||||||
|
case Color_White: wxPrintf(tbl_color_codes[7]); break;
|
||||||
|
case Color_StrongBlack: wxPrintf(tbl_color_codes[8]); break;
|
||||||
|
case Color_StrongRed: wxPrintf(tbl_color_codes[9]); break;
|
||||||
|
case Color_StrongGreen: wxPrintf(tbl_color_codes[10]); break;
|
||||||
|
case Color_StrongBlue: wxPrintf(tbl_color_codes[12]); break;
|
||||||
|
case Color_StrongOrange: wxPrintf(tbl_color_codes[13]); break; // strong magenta.
|
||||||
|
default: wxPrintf(tbl_color_codes[16]); break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void __concall ConsoleStdio_SetTitle( const wxString& title )
|
||||||
|
{
|
||||||
|
#ifdef __LINUX__
|
||||||
|
wxPrintf(L"\033]0;" + title + L"\007");
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleStdio_ClearColor()
|
||||||
|
{
|
||||||
|
#ifdef __LINUX__
|
||||||
|
wxPrintf(tbl_color_codes[17]);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
const IConsoleWriter ConsoleWriter_Stdio =
|
const IConsoleWriter ConsoleWriter_Stdio =
|
||||||
{
|
{
|
||||||
ConsoleStdio_DoWrite, // Writes without newlines go to buffer to avoid error log spam.
|
ConsoleStdio_DoWrite, // Writes without newlines go to buffer to avoid error log spam.
|
||||||
ConsoleStdio_DoWriteLn,
|
ConsoleStdio_DoWriteLn,
|
||||||
|
|
||||||
ConsoleNull_Newline,
|
ConsoleStdio_Newline,
|
||||||
|
|
||||||
ConsoleNull_SetTitle,
|
ConsoleStdio_SetTitle,
|
||||||
ConsoleNull_SetColor,
|
ConsoleStdio_SetColor,
|
||||||
ConsoleNull_ClearColor,
|
ConsoleStdio_ClearColor,
|
||||||
};
|
};
|
||||||
|
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
@ -209,7 +278,7 @@ class FormatBuffer : public Mutex
|
||||||
public:
|
public:
|
||||||
bool& clearbit;
|
bool& clearbit;
|
||||||
SafeArray<CharType> buffer;
|
SafeArray<CharType> buffer;
|
||||||
|
|
||||||
FormatBuffer( bool& bit_to_clear_on_destruction ) :
|
FormatBuffer( bool& bit_to_clear_on_destruction ) :
|
||||||
clearbit( bit_to_clear_on_destruction )
|
clearbit( bit_to_clear_on_destruction )
|
||||||
, buffer( 4096, wxsFormat( L"%s Format Buffer", (sizeof(CharType)==1) ? "Ascii" : "Unicode" ) )
|
, buffer( 4096, wxsFormat( L"%s Format Buffer", (sizeof(CharType)==1) ? "Ascii" : "Unicode" ) )
|
||||||
|
@ -221,7 +290,7 @@ public:
|
||||||
clearbit = true;
|
clearbit = true;
|
||||||
Wait(); // lock the mutex, just in case.
|
Wait(); // lock the mutex, just in case.
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool ascii_buffer_is_deleted = false;
|
static bool ascii_buffer_is_deleted = false;
|
||||||
|
|
|
@ -638,18 +638,19 @@ void Pcsx2App::ProgramLog_PostEvent( wxEvent& evt )
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
// ConsoleImpl_ToFile
|
// ConsoleImpl_ToFile
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
static void __concall _immediate_logger( const char* src )
|
|
||||||
|
static void __concall _immediate_logger( wxString src )
|
||||||
{
|
{
|
||||||
#ifdef __LINUX__
|
#ifdef __LINUX__
|
||||||
fputs( src, stdout );
|
ConsoleWriter_Stdio.DoWrite(src);
|
||||||
#endif
|
#endif
|
||||||
px_fputs( emuLog, src );
|
px_fputs( emuLog, src.ToUTF8() );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __concall ConsoleToFile_Newline()
|
static void __concall ConsoleToFile_Newline()
|
||||||
{
|
{
|
||||||
#ifdef __LINUX__
|
#ifdef __LINUX__
|
||||||
fputc( '\n', stdout );
|
ConsoleWriter_Stdio.Newline();
|
||||||
fputc( '\n', emuLog );
|
fputc( '\n', emuLog );
|
||||||
#else
|
#else
|
||||||
fputs( "\r\n", emuLog );
|
fputs( "\r\n", emuLog );
|
||||||
|
@ -658,28 +659,43 @@ static void __concall ConsoleToFile_Newline()
|
||||||
|
|
||||||
static void __concall ConsoleToFile_DoWrite( const wxString& fmt )
|
static void __concall ConsoleToFile_DoWrite( const wxString& fmt )
|
||||||
{
|
{
|
||||||
_immediate_logger( fmt.ToUTF8() );
|
_immediate_logger( fmt );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __concall ConsoleToFile_DoWriteLn( const wxString& fmt )
|
static void __concall ConsoleToFile_DoWriteLn( const wxString& fmt )
|
||||||
{
|
{
|
||||||
_immediate_logger( fmt.ToUTF8() );
|
_immediate_logger( fmt );
|
||||||
ConsoleToFile_Newline();
|
ConsoleToFile_Newline();
|
||||||
|
|
||||||
if( emuLog != NULL )
|
if( emuLog != NULL )
|
||||||
fflush( emuLog );
|
fflush( emuLog );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleToFile_SetTitle( const wxString& title )
|
||||||
|
{
|
||||||
|
ConsoleWriter_Stdio.SetTitle(title);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleToFile_SetColor( ConsoleColors color )
|
||||||
|
{
|
||||||
|
ConsoleWriter_Stdio.SetColor(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void __concall ConsoleToFile_ClearColor()
|
||||||
|
{
|
||||||
|
ConsoleWriter_Stdio.ClearColor();
|
||||||
|
}
|
||||||
|
|
||||||
extern const IConsoleWriter ConsoleWriter_File;
|
extern const IConsoleWriter ConsoleWriter_File;
|
||||||
const IConsoleWriter ConsoleWriter_File =
|
const IConsoleWriter ConsoleWriter_File =
|
||||||
{
|
{
|
||||||
ConsoleToFile_DoWrite,
|
ConsoleToFile_DoWrite,
|
||||||
ConsoleToFile_DoWriteLn,
|
ConsoleToFile_DoWriteLn,
|
||||||
ConsoleToFile_Newline,
|
ConsoleToFile_Newline,
|
||||||
|
|
||||||
ConsoleWriter_Null.SetTitle,
|
ConsoleToFile_SetTitle,
|
||||||
ConsoleWriter_Null.SetColor,
|
ConsoleToFile_SetColor,
|
||||||
ConsoleWriter_Null.ClearColor,
|
ConsoleToFile_ClearColor,
|
||||||
};
|
};
|
||||||
|
|
||||||
// thread-local console color storage.
|
// thread-local console color storage.
|
||||||
|
@ -688,20 +704,26 @@ static __threadlocal ConsoleColors th_CurrentColor = DefaultConsoleColor;
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
// ConsoleToWindow Implementations
|
// ConsoleToWindow Implementations
|
||||||
// --------------------------------------------------------------------------------------
|
// --------------------------------------------------------------------------------------
|
||||||
|
template< const IConsoleWriter& secondary >
|
||||||
static void __concall ConsoleToWindow_SetTitle( const wxString& title )
|
static void __concall ConsoleToWindow_SetTitle( const wxString& title )
|
||||||
{
|
{
|
||||||
|
secondary.SetTitle(title);
|
||||||
wxCommandEvent evt( wxEVT_SetTitleText );
|
wxCommandEvent evt( wxEVT_SetTitleText );
|
||||||
evt.SetString( title );
|
evt.SetString( title );
|
||||||
wxGetApp().ProgramLog_PostEvent( evt );
|
wxGetApp().ProgramLog_PostEvent( evt );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template< const IConsoleWriter& secondary >
|
||||||
static void __concall ConsoleToWindow_SetColor( ConsoleColors color )
|
static void __concall ConsoleToWindow_SetColor( ConsoleColors color )
|
||||||
{
|
{
|
||||||
|
secondary.SetColor(color);
|
||||||
th_CurrentColor = color;
|
th_CurrentColor = color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template< const IConsoleWriter& secondary >
|
||||||
static void __concall ConsoleToWindow_ClearColor()
|
static void __concall ConsoleToWindow_ClearColor()
|
||||||
{
|
{
|
||||||
|
secondary.ClearColor();
|
||||||
th_CurrentColor = DefaultConsoleColor;
|
th_CurrentColor = DefaultConsoleColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -734,9 +756,9 @@ static const IConsoleWriter ConsoleWriter_Window =
|
||||||
ConsoleToWindow_DoWriteLn<ConsoleWriter_Null>,
|
ConsoleToWindow_DoWriteLn<ConsoleWriter_Null>,
|
||||||
ConsoleToWindow_Newline<ConsoleWriter_Null>,
|
ConsoleToWindow_Newline<ConsoleWriter_Null>,
|
||||||
|
|
||||||
ConsoleToWindow_SetTitle,
|
ConsoleToWindow_SetTitle<ConsoleWriter_Null>,
|
||||||
ConsoleToWindow_SetColor,
|
ConsoleToWindow_SetColor<ConsoleWriter_Null>,
|
||||||
ConsoleToWindow_ClearColor,
|
ConsoleToWindow_ClearColor<ConsoleWriter_Null>,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const IConsoleWriter ConsoleWriter_WindowAndFile =
|
static const IConsoleWriter ConsoleWriter_WindowAndFile =
|
||||||
|
@ -745,9 +767,9 @@ static const IConsoleWriter ConsoleWriter_WindowAndFile =
|
||||||
ConsoleToWindow_DoWriteLn<ConsoleWriter_File>,
|
ConsoleToWindow_DoWriteLn<ConsoleWriter_File>,
|
||||||
ConsoleToWindow_Newline<ConsoleWriter_File>,
|
ConsoleToWindow_Newline<ConsoleWriter_File>,
|
||||||
|
|
||||||
ConsoleToWindow_SetTitle,
|
ConsoleToWindow_SetTitle<ConsoleWriter_File>,
|
||||||
ConsoleToWindow_SetColor,
|
ConsoleToWindow_SetColor<ConsoleWriter_File>,
|
||||||
ConsoleToWindow_ClearColor,
|
ConsoleToWindow_ClearColor<ConsoleWriter_File>,
|
||||||
};
|
};
|
||||||
|
|
||||||
void Pcsx2App::EnableAllLogging() const
|
void Pcsx2App::EnableAllLogging() const
|
||||||
|
|
Loading…
Reference in New Issue