2008-12-08 05:25:12 +00:00
|
|
|
|
// Copyright (C) 2003-2008 Dolphin Project.
|
|
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
|
// the Free Software Foundation, version 2.0.
|
|
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
|
|
// Official SVN repository and contact information can be found at
|
|
|
|
|
// http://code.google.com/p/dolphin-emu/
|
|
|
|
|
|
2009-01-06 01:50:57 +00:00
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
// Includes
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2008-12-08 05:25:12 +00:00
|
|
|
|
#if defined(HAVE_WX) && HAVE_WX
|
2009-01-06 01:50:57 +00:00
|
|
|
|
#include <wx/wx.h>
|
|
|
|
|
#include <wx/filepicker.h>
|
|
|
|
|
#include <wx/notebook.h>
|
|
|
|
|
#include <wx/dialog.h>
|
|
|
|
|
#include <wx/aboutdlg.h>
|
2008-12-08 05:25:12 +00:00
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#include "Globals.h"
|
|
|
|
|
|
|
|
|
|
#include "pluginspecs_video.h"
|
|
|
|
|
#include "main.h"
|
|
|
|
|
|
|
|
|
|
#include "IniFile.h"
|
|
|
|
|
#include <assert.h>
|
2009-01-06 01:50:57 +00:00
|
|
|
|
/////////////////////////////////////
|
|
|
|
|
|
2008-12-08 05:25:12 +00:00
|
|
|
|
|
2009-01-06 01:50:57 +00:00
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
// Declarations and definitions
|
|
|
|
|
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2008-12-08 05:25:12 +00:00
|
|
|
|
#ifdef _WIN32
|
|
|
|
|
|
2009-01-06 01:50:57 +00:00
|
|
|
|
// The Windows console handle. The one for Linux is in Linux/Linux.cpp
|
2008-12-08 05:25:12 +00:00
|
|
|
|
static HANDLE hConsole = NULL;
|
2009-01-06 01:50:57 +00:00
|
|
|
|
//////////////////////////////////
|
|
|
|
|
|
2008-12-08 05:25:12 +00:00
|
|
|
|
|
|
|
|
|
void OpenConsole()
|
|
|
|
|
{
|
|
|
|
|
COORD csize;
|
|
|
|
|
CONSOLE_SCREEN_BUFFER_INFO csbiInfo;
|
|
|
|
|
SMALL_RECT srect;
|
|
|
|
|
|
|
|
|
|
if (hConsole)
|
|
|
|
|
return;
|
|
|
|
|
AllocConsole();
|
|
|
|
|
SetConsoleTitle("Opengl Plugin Output");
|
|
|
|
|
|
|
|
|
|
// set width and height
|
|
|
|
|
csize.X = 155; // this fits on 1280 pixels TODO: make it adjustable from the wx debugging window
|
|
|
|
|
csize.Y = 300; // 300 rows
|
|
|
|
|
SetConsoleScreenBufferSize(GetStdHandle(STD_OUTPUT_HANDLE), csize);
|
|
|
|
|
|
|
|
|
|
// make the internal buffer match the width we set
|
|
|
|
|
GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &csbiInfo);
|
|
|
|
|
srect = csbiInfo.srWindow;
|
|
|
|
|
srect.Right = srect.Left + csize.X - 1; // match
|
|
|
|
|
srect.Bottom = srect.Top + 44;
|
|
|
|
|
SetConsoleWindowInfo(GetStdHandle(STD_OUTPUT_HANDLE), TRUE, &srect);
|
|
|
|
|
|
|
|
|
|
hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void CloseConsole()
|
|
|
|
|
{
|
|
|
|
|
if (hConsole == NULL)
|
|
|
|
|
return;
|
|
|
|
|
FreeConsole();
|
|
|
|
|
hConsole = NULL;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
static FILE* pfLog = NULL;
|
|
|
|
|
void __Log(const char *fmt, ...)
|
|
|
|
|
{
|
|
|
|
|
char* Msg = (char*)alloca(strlen(fmt)+512);
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
|
|
va_start( ap, fmt );
|
|
|
|
|
vsnprintf( Msg, strlen(fmt)+512, fmt, ap );
|
|
|
|
|
va_end( ap );
|
|
|
|
|
|
|
|
|
|
g_VideoInitialize.pLog(Msg, FALSE);
|
|
|
|
|
|
|
|
|
|
if (pfLog == NULL)
|
|
|
|
|
pfLog = fopen(FULL_LOGS_DIR "oglgfx.txt", "w");
|
|
|
|
|
|
|
|
|
|
if (pfLog != NULL)
|
|
|
|
|
fwrite(Msg, strlen(Msg), 1, pfLog);
|
2009-01-06 01:50:57 +00:00
|
|
|
|
#ifdef _WIN32
|
|
|
|
|
DWORD tmp;
|
|
|
|
|
WriteConsole(hConsole, Msg, (DWORD)strlen(Msg), &tmp, 0);
|
|
|
|
|
#else
|
2008-12-08 05:25:12 +00:00
|
|
|
|
//printf("%s", Msg);
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void __Log(int type, const char *fmt, ...)
|
|
|
|
|
{
|
|
|
|
|
char* Msg = (char*)alloca(strlen(fmt)+512);
|
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
|
|
va_start( ap, fmt );
|
|
|
|
|
vsnprintf( Msg, strlen(fmt)+512, fmt, ap );
|
|
|
|
|
va_end( ap );
|
|
|
|
|
|
|
|
|
|
g_VideoInitialize.pLog(Msg, FALSE);
|
|
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
|
DWORD tmp;
|
|
|
|
|
WriteConsole(hConsole, Msg, (DWORD)strlen(Msg), &tmp, 0);
|
|
|
|
|
#endif
|
|
|
|
|
}
|