Drop Dolphin-specific patch to wxWindows

This removes a Dolphin-specific patch to the wxWidgets3 code
for the following reasons:

* Calling wxWindowGTK::DoSetSize on a top-level window can end up
  calling wxTopLevelWindowGTK::DoMoveWindow, which triggers an assert
  because it is not supposed to be called for a top-level wxWindow.

* We should not be patching the wxWidgets code because that means the
  toolbars will still be broken if someone builds without using the
  WX that is in our Externals.

Instead, we now use a derived class for wxAuiToolBar and override
DoSetSize() to remove the problematic behaviour to get the same effect
(fixing toolbars) but without changing Externals code and without
causing asserts and other issues.
This commit is contained in:
Léo Lam 2016-07-15 23:59:05 +02:00
parent b2dcbbf884
commit e8cb4119b8
9 changed files with 42 additions and 22 deletions

View File

@ -3072,9 +3072,7 @@ void wxWindowGTK::DoSetClientSize( int width, int height )
const wxSize size = GetSize(); const wxSize size = GetSize();
const wxSize clientSize = GetClientSize(); const wxSize clientSize = GetClientSize();
// XXX: Dolphin: This is an internal call, it should never trigger the SetSize path in derived classes. SetSize(width + (size.x - clientSize.x), height + (size.y - clientSize.y));
// This fixes wxAuiToolbar setting itself to 21 pixels wide regardless of content.
wxWindowGTK::DoSetSize(wxDefaultCoord, wxDefaultCoord, width + (size.x - clientSize.x), height + (size.y - clientSize.y), wxSIZE_USE_EXISTING);
} }
void wxWindowGTK::DoGetClientSize( int *width, int *height ) const void wxWindowGTK::DoGetClientSize( int *width, int *height ) const

View File

@ -1212,8 +1212,7 @@ void wxWindowMac::DoSetClientSize(int clientwidth, int clientheight)
GetClientSize( &currentclientwidth , &currentclientheight ) ; GetClientSize( &currentclientwidth , &currentclientheight ) ;
GetSize( &currentwidth , &currentheight ) ; GetSize( &currentwidth , &currentheight ) ;
// XXX: Dolphin. Do not allow internal semantic call to become visible to derived classes. DoSetSize( wxDefaultCoord , wxDefaultCoord , currentwidth + clientwidth - currentclientwidth ,
wxWindowMac::DoSetSize( wxDefaultCoord , wxDefaultCoord , currentwidth + clientwidth - currentclientwidth ,
currentheight + clientheight - currentclientheight , wxSIZE_USE_EXISTING ) ; currentheight + clientheight - currentclientheight , wxSIZE_USE_EXISTING ) ;
} }
} }

View File

@ -0,0 +1,22 @@
// Copyright 2016 Dolphin Emulator Project
// Licensed under GPLv2+
// Refer to the license.txt file included.
#include <wx/aui/auibar.h>
#include <wx/window.h>
// This fixes wxAuiToolBar setting itself to 21 pixels wide regardless of content
// because of a wxWidgets issue as described here: https://dolp.in/pr4013#issuecomment-233096214
// It overrides DoSetSize() to remove the clamping in the original WX code
// which is causing display issues on Linux and OS X.
class DolphinAuiToolBar : public wxAuiToolBar
{
public:
using wxAuiToolBar::wxAuiToolBar;
protected:
void DoSetSize(int x, int y, int width, int height, int size_flags) override
{
wxWindow::DoSetSize(x, y, width, height, size_flags);
}
};

View File

@ -4,7 +4,6 @@
// clang-format off // clang-format off
#include <wx/bitmap.h> #include <wx/bitmap.h>
#include <wx/aui/auibar.h>
#include <wx/aui/framemanager.h> #include <wx/aui/framemanager.h>
#include <wx/image.h> #include <wx/image.h>
#include <wx/listbase.h> #include <wx/listbase.h>
@ -23,14 +22,15 @@
#include "DolphinWX/Debugger/BreakpointWindow.h" #include "DolphinWX/Debugger/BreakpointWindow.h"
#include "DolphinWX/Debugger/CodeWindow.h" #include "DolphinWX/Debugger/CodeWindow.h"
#include "DolphinWX/Debugger/MemoryCheckDlg.h" #include "DolphinWX/Debugger/MemoryCheckDlg.h"
#include "DolphinWX/AuiToolBar.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
class CBreakPointBar : public wxAuiToolBar class CBreakPointBar : public DolphinAuiToolBar
{ {
public: public:
CBreakPointBar(CBreakPointWindow* parent, const wxWindowID id) CBreakPointBar(CBreakPointWindow* parent, const wxWindowID id)
: wxAuiToolBar(parent, id, wxDefaultPosition, wxDefaultSize, : DolphinAuiToolBar(parent, id, wxDefaultPosition, wxDefaultSize,
wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_TEXT) wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_TEXT)
{ {
SetToolBitmapSize(wxSize(24, 24)); SetToolBitmapSize(wxSize(24, 24));

View File

@ -8,7 +8,6 @@
// clang-format off // clang-format off
#include <wx/bitmap.h> #include <wx/bitmap.h>
#include <wx/aui/auibar.h>
#include <wx/image.h> #include <wx/image.h>
#include <wx/listbox.h> #include <wx/listbox.h>
#include <wx/menu.h> #include <wx/menu.h>
@ -19,6 +18,7 @@
#include <wx/textdlg.h> #include <wx/textdlg.h>
#include <wx/thread.h> #include <wx/thread.h>
#include <wx/toolbar.h> #include <wx/toolbar.h>
#include <wx/aui/auibar.h>
#include <wx/aui/dockart.h> #include <wx/aui/dockart.h>
// clang-format on // clang-format on
@ -45,6 +45,7 @@
#include "DolphinWX/Debugger/JitWindow.h" #include "DolphinWX/Debugger/JitWindow.h"
#include "DolphinWX/Debugger/RegisterWindow.h" #include "DolphinWX/Debugger/RegisterWindow.h"
#include "DolphinWX/Debugger/WatchWindow.h" #include "DolphinWX/Debugger/WatchWindow.h"
#include "DolphinWX/AuiToolBar.h"
#include "DolphinWX/Frame.h" #include "DolphinWX/Frame.h"
#include "DolphinWX/Globals.h" #include "DolphinWX/Globals.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
@ -74,8 +75,8 @@ CCodeWindow::CCodeWindow(const SConfig& _LocalCoreStartupParameter, CFrame* pare
callers = new wxListBox(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0, nullptr, wxLB_SORT); callers = new wxListBox(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, 0, nullptr, wxLB_SORT);
callers->Bind(wxEVT_LISTBOX, &CCodeWindow::OnCallersListChange, this); callers->Bind(wxEVT_LISTBOX, &CCodeWindow::OnCallersListChange, this);
m_aui_toolbar = new wxAuiToolBar(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, m_aui_toolbar = new DolphinAuiToolBar(this, wxID_ANY, wxDefaultPosition, wxDefaultSize,
wxAUI_TB_HORIZONTAL | wxAUI_TB_PLAIN_BACKGROUND); wxAUI_TB_HORIZONTAL | wxAUI_TB_PLAIN_BACKGROUND);
wxSearchCtrl* const address_searchctrl = new wxSearchCtrl(m_aui_toolbar, IDM_ADDRBOX); wxSearchCtrl* const address_searchctrl = new wxSearchCtrl(m_aui_toolbar, IDM_ADDRBOX);
address_searchctrl->Bind(wxEVT_TEXT, &CCodeWindow::OnAddrBoxChange, this); address_searchctrl->Bind(wxEVT_TEXT, &CCodeWindow::OnAddrBoxChange, this);

View File

@ -23,7 +23,7 @@ class DSPDebuggerLLE;
class GFXDebuggerPanel; class GFXDebuggerPanel;
struct SConfig; struct SConfig;
class wxAuiToolBar; class DolphinAuiToolBar;
class wxListBox; class wxListBox;
class wxMenu; class wxMenu;
class wxMenuBar; class wxMenuBar;
@ -125,5 +125,5 @@ private:
Common::Event sync_event; Common::Event sync_event;
wxAuiManager m_aui_manager; wxAuiManager m_aui_manager;
wxAuiToolBar* m_aui_toolbar; DolphinAuiToolBar* m_aui_toolbar;
}; };

View File

@ -4,7 +4,6 @@
#include <cstdio> #include <cstdio>
#include <wx/artprov.h> #include <wx/artprov.h>
#include <wx/aui/auibar.h>
#include <wx/aui/auibook.h> #include <wx/aui/auibook.h>
#include <wx/aui/framemanager.h> #include <wx/aui/framemanager.h>
#include <wx/listbox.h> #include <wx/listbox.h>
@ -20,6 +19,7 @@
#include "Core/HW/DSPLLE/DSPDebugInterface.h" #include "Core/HW/DSPLLE/DSPDebugInterface.h"
#include "Core/HW/DSPLLE/DSPSymbols.h" #include "Core/HW/DSPLLE/DSPSymbols.h"
#include "Core/Host.h" #include "Core/Host.h"
#include "DolphinWX/AuiToolBar.h"
#include "DolphinWX/Debugger/CodeView.h" #include "DolphinWX/Debugger/CodeView.h"
#include "DolphinWX/Debugger/DSPDebugWindow.h" #include "DolphinWX/Debugger/DSPDebugWindow.h"
#include "DolphinWX/Debugger/DSPRegisterView.h" #include "DolphinWX/Debugger/DSPRegisterView.h"
@ -42,7 +42,7 @@ DSPDebuggerLLE::DSPDebuggerLLE(wxWindow* parent, wxWindowID id)
m_mgr.SetFlags(wxAUI_MGR_DEFAULT | wxAUI_MGR_LIVE_RESIZE); m_mgr.SetFlags(wxAUI_MGR_DEFAULT | wxAUI_MGR_LIVE_RESIZE);
m_Toolbar = m_Toolbar =
new wxAuiToolBar(this, ID_TOOLBAR, wxDefaultPosition, wxDefaultSize, wxAUI_TB_HORZ_TEXT); new DolphinAuiToolBar(this, ID_TOOLBAR, wxDefaultPosition, wxDefaultSize, wxAUI_TB_HORZ_TEXT);
m_Toolbar->AddTool(ID_RUNTOOL, _("Pause"), m_Toolbar->AddTool(ID_RUNTOOL, _("Pause"),
wxArtProvider::GetBitmap(wxART_TICK_MARK, wxART_OTHER, wxSize(10, 10))); wxArtProvider::GetBitmap(wxART_TICK_MARK, wxART_OTHER, wxSize(10, 10)));
m_Toolbar->AddTool(ID_STEPTOOL, _("Step"), m_Toolbar->AddTool(ID_STEPTOOL, _("Step"),

View File

@ -14,7 +14,7 @@ class DSPRegisterView;
class CCodeView; class CCodeView;
class CMemoryView; class CMemoryView;
class wxAuiNotebook; class wxAuiNotebook;
class wxAuiToolBar; class DolphinAuiToolBar;
class wxListBox; class wxListBox;
class DSPDebuggerLLE : public wxPanel class DSPDebuggerLLE : public wxPanel
@ -45,7 +45,7 @@ private:
// GUI items // GUI items
wxAuiManager m_mgr; wxAuiManager m_mgr;
wxAuiToolBar* m_Toolbar; DolphinAuiToolBar* m_Toolbar;
CCodeView* m_CodeView; CCodeView* m_CodeView;
CMemoryView* m_MemView; CMemoryView* m_MemView;
DSPRegisterView* m_Regs; DSPRegisterView* m_Regs;

View File

@ -6,7 +6,6 @@
// clang-format off // clang-format off
#include <wx/bitmap.h> #include <wx/bitmap.h>
#include <wx/aui/auibar.h>
#include <wx/panel.h> #include <wx/panel.h>
// clang-format on // clang-format on
@ -16,14 +15,15 @@
#include "Core/PowerPC/PowerPC.h" #include "Core/PowerPC/PowerPC.h"
#include "DolphinWX/Debugger/WatchView.h" #include "DolphinWX/Debugger/WatchView.h"
#include "DolphinWX/Debugger/WatchWindow.h" #include "DolphinWX/Debugger/WatchWindow.h"
#include "DolphinWX/AuiToolBar.h"
#include "DolphinWX/WxUtils.h" #include "DolphinWX/WxUtils.h"
class CWatchToolbar : public wxAuiToolBar class CWatchToolbar : public DolphinAuiToolBar
{ {
public: public:
CWatchToolbar(CWatchWindow* parent, const wxWindowID id) CWatchToolbar(CWatchWindow* parent, const wxWindowID id)
: wxAuiToolBar(parent, id, wxDefaultPosition, wxDefaultSize, : DolphinAuiToolBar(parent, id, wxDefaultPosition, wxDefaultSize,
wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_TEXT) wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_TEXT)
{ {
SetToolBitmapSize(wxSize(16, 16)); SetToolBitmapSize(wxSize(16, 16));