mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-16 02:59:11 +01:00
7baabe99d1
This is something that should be the responsibility of the frontend booting the game. Making this part of the host 'interface' inherently requires frontends to leak internal details (much like the other UI-related functions in the interface). This also decouples more behavior from the debugger and the initialization process in the wx frontend. This also eliminates several usages of the parent menubar in the debugger code window.
128 lines
2.4 KiB
C++
128 lines
2.4 KiB
C++
// Copyright 2015 Dolphin Emulator Project
|
|
// Licensed under GPLv2+
|
|
// Refer to the license.txt file included.
|
|
|
|
#include <QAbstractEventDispatcher>
|
|
#include <QApplication>
|
|
#include <QMutexLocker>
|
|
|
|
#include "Common/Common.h"
|
|
#include "Core/Host.h"
|
|
#include "DolphinQt2/Host.h"
|
|
#include "DolphinQt2/MainWindow.h"
|
|
|
|
Host* Host::m_instance = nullptr;
|
|
|
|
Host* Host::GetInstance()
|
|
{
|
|
if (m_instance == nullptr)
|
|
m_instance = new Host();
|
|
return m_instance;
|
|
}
|
|
|
|
void* Host::GetRenderHandle()
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
return m_render_handle;
|
|
}
|
|
|
|
void Host::SetRenderHandle(void* handle)
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
m_render_handle = handle;
|
|
}
|
|
|
|
bool Host::GetRenderFocus()
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
return m_render_focus;
|
|
}
|
|
|
|
void Host::SetRenderFocus(bool focus)
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
m_render_focus = focus;
|
|
}
|
|
|
|
bool Host::GetRenderFullscreen()
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
return m_render_fullscreen;
|
|
}
|
|
|
|
void Host::SetRenderFullscreen(bool fullscreen)
|
|
{
|
|
QMutexLocker locker(&m_lock);
|
|
m_render_fullscreen = fullscreen;
|
|
}
|
|
|
|
void Host_Message(int id)
|
|
{
|
|
if (id == WM_USER_STOP)
|
|
{
|
|
emit Host::GetInstance()->RequestStop();
|
|
}
|
|
else if (id == WM_USER_JOB_DISPATCH)
|
|
{
|
|
// Just poke the main thread to get it to wake up, job dispatch
|
|
// will happen automatically before it goes back to sleep again.
|
|
QAbstractEventDispatcher::instance(qApp->thread())->wakeUp();
|
|
}
|
|
}
|
|
|
|
void Host_UpdateTitle(const std::string& title)
|
|
{
|
|
emit Host::GetInstance()->RequestTitle(QString::fromStdString(title));
|
|
}
|
|
|
|
void* Host_GetRenderHandle()
|
|
{
|
|
return Host::GetInstance()->GetRenderHandle();
|
|
}
|
|
|
|
bool Host_RendererHasFocus()
|
|
{
|
|
return Host::GetInstance()->GetRenderFocus();
|
|
}
|
|
|
|
bool Host_RendererIsFullscreen()
|
|
{
|
|
return Host::GetInstance()->GetRenderFullscreen();
|
|
}
|
|
void Host_YieldToUI()
|
|
{
|
|
qApp->processEvents(QEventLoop::ExcludeUserInputEvents);
|
|
}
|
|
|
|
// We ignore these, and their purpose should be questioned individually.
|
|
// In particular, RequestRenderWindowSize, RequestFullscreen, and
|
|
// UpdateMainFrame should almost certainly be removed.
|
|
void Host_UpdateMainFrame()
|
|
{
|
|
}
|
|
void Host_RequestRenderWindowSize(int w, int h)
|
|
{
|
|
}
|
|
bool Host_UIHasFocus()
|
|
{
|
|
return false;
|
|
}
|
|
void Host_NotifyMapLoaded()
|
|
{
|
|
}
|
|
void Host_UpdateDisasmDialog()
|
|
{
|
|
}
|
|
void Host_SetWiiMoteConnectionState(int state)
|
|
{
|
|
}
|
|
void Host_ConnectWiimote(int wm_idx, bool connect)
|
|
{
|
|
}
|
|
void Host_ShowVideoConfig(void* parent, const std::string& backend_name)
|
|
{
|
|
}
|
|
void Host_RefreshDSPDebuggerWindow()
|
|
{
|
|
}
|