mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-12 00:59:11 +01:00
f2a5fd1973
There's an annoying problem with the DSP HLE wx window that blocks some input and places it in a queue. For example if you have loaded the window and press X on the main window, that action is blocked an placed in some kind of queue and not executed until you have closed the debugging window. This is also why the main Dolphin-Debugger window does not show up until you close the sound window. If someone find a fix to this I guess it could be convenient. There is another way to show the window, m_frame->Show() that is normally supposed to remove this kind of on-focus lock, but in a dll it seemingly breaks because it makes Dllmain call DLL_PROCESS_DETACH immediately after DLL_PROCESS_ATTACH so the window has to be killed or we crash. Also, otherwise unnecessarily I had to disable the new DSP HLE debug window in Release mode because I could not access the SConfig::GetInstance().m_LocalCoreStartupParameter.m_strDSPPlugin.c_str() string that I need to start it (if I tried it crashed). Very annoying and strange. I could not access m_strDSPPlugin or m_strVideoPlugin either, but all other values in m_LocalCoreStartupParameter seemed to work fine. I'll have to leave it to someone else to figure out why. TODO: Later I'll add function to the debugging buttons, currently only update have a function. I'll add some option to show a custom console window (that actually worked better that the wx window to show the current parameters status, it had less flicker on frequent updates). I'll also add some custom log file saving option. Also, the reason I placed Logging.cpp in its own dir is because I plan to add more files to it. There were problems with some build modes, win32 with debugging crashed on booting a game, I don't know if it's my fault. And I could not build Debug win64 because of some wx linking problem. git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@722 8ced0084-cf51-0410-be5f-012b33b47a6e
169 lines
5.0 KiB
C++
169 lines
5.0 KiB
C++
// 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/
|
|
|
|
|
|
#include "PBView.h"
|
|
|
|
#include <iostream>
|
|
#include <string>
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------------------
|
|
// external declarations
|
|
extern const char* GetGRPName(unsigned int index);
|
|
|
|
// No buttons or events so far
|
|
BEGIN_EVENT_TABLE(CPBView, wxListCtrl)
|
|
|
|
END_EVENT_TABLE()
|
|
// ---------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
CPBView::CPBView(wxWindow* parent, const wxWindowID id, const wxPoint& pos, const wxSize& size, long style)
|
|
: wxListCtrl(parent, id, pos, size, style)
|
|
{
|
|
InsertColumn(1, wxT("upd4"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("upd3"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("upd2"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("upd1"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("upd0"), wxLIST_FORMAT_LEFT, 90);
|
|
|
|
InsertColumn(1, wxT("r_lo"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("r_hi"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("ratio"), wxLIST_FORMAT_LEFT, 90);
|
|
|
|
InsertColumn(1, wxT("frac"), wxLIST_FORMAT_LEFT, 90);
|
|
|
|
InsertColumn(1, wxT("coef"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("src_t"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("form"), wxLIST_FORMAT_LEFT, 90);
|
|
|
|
InsertColumn(1, wxT("isstr"), wxLIST_FORMAT_LEFT, 90);
|
|
|
|
InsertColumn(1, wxT("yn2"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("yn1"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("pred_s"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("isloop"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("volr"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("voll"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("loopto"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(1, wxT("end"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(0, wxT("pos"), wxLIST_FORMAT_LEFT, 90);
|
|
InsertColumn(0, wxT("run"), wxLIST_FORMAT_RIGHT, 50);
|
|
InsertColumn(0, wxT("Block"), wxLIST_FORMAT_CENTER, 40);
|
|
|
|
SetFont(wxFont(8, wxSWISS, wxNORMAL, wxNORMAL, false, wxT("Segoe UI")));
|
|
|
|
for (int i = 0; i < 64; i++)
|
|
{
|
|
|
|
// Print values from 0 to 63
|
|
char buffer [33];
|
|
itoa(i, buffer, 10);
|
|
sprintf(buffer, "%02i", i);
|
|
int Item = InsertItem(0, buffer);
|
|
|
|
|
|
wxListItem item;
|
|
item.SetId(Item);
|
|
item.SetBackgroundColour(0xFFFFFF);
|
|
item.SetData(i);
|
|
SetItem(item);
|
|
}
|
|
|
|
// This is a wx call that leads to MSWDrawSubItem
|
|
Refresh();
|
|
}
|
|
|
|
|
|
void
|
|
CPBView::Update()
|
|
{
|
|
|
|
Refresh();
|
|
|
|
}
|
|
|
|
|
|
bool
|
|
CPBView::MSWDrawSubItem(wxPaintDC& rPainDC, int item, int subitem)
|
|
{
|
|
bool Result = false;
|
|
|
|
// don't change 0, it has the block values
|
|
if(subitem > 0)
|
|
{
|
|
//#ifdef __WXMSW__ // what's this? should I use that?
|
|
|
|
// =======================================================================================
|
|
const wxChar* bgColor = _T("#ffffff");
|
|
wxBrush bgBrush(bgColor);
|
|
wxPen bgPen(bgColor);
|
|
|
|
wxRect SubItemRect;
|
|
this->GetSubItemRect(item, subitem, SubItemRect);
|
|
rPainDC.SetBrush(bgBrush);
|
|
rPainDC.SetPen(bgPen);
|
|
rPainDC.DrawRectangle(SubItemRect);
|
|
// =======================================================================================
|
|
|
|
// =======================================================================================
|
|
// A somewhat primitive attempt to show the playing history for a certain block.
|
|
// ---------------------------------------------------------------------------------------
|
|
wxString text;
|
|
// ---------------------------------------------------------------------------------------
|
|
if(subitem == 1)
|
|
{
|
|
char cbuff [33];
|
|
|
|
sprintf(cbuff, "%08i", m_CachedRegs[subitem][item]);
|
|
std::string c = cbuff;
|
|
int n[8];
|
|
|
|
for (int j = 0; j < 8; j++)
|
|
{
|
|
|
|
n[j] = atoi( c.substr(j, 1).c_str());
|
|
// 149 = dot, 160 = space
|
|
if (n[j] == 1){
|
|
n[j] = 149;} else {n[j] = 160;}
|
|
}
|
|
// pretty neat huh?
|
|
text.Printf(wxT("%c%c%c%c%c%c%c%c"), n[0],n[1],n[2],n[3],n[4],n[5],n[6],n[7]);
|
|
|
|
}
|
|
else
|
|
{
|
|
text.Printf(wxT("0x%08x"), m_CachedRegs[subitem][item]);
|
|
}
|
|
rPainDC.DrawText(text, SubItemRect.GetLeft() + 10, SubItemRect.GetTop() + 4);
|
|
// =======================================================================================
|
|
|
|
|
|
return(true);
|
|
}
|
|
else
|
|
{
|
|
// what does this mean?
|
|
return(Result);
|
|
}
|
|
}
|
|
|
|
|