mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-24 14:49:42 -06:00
- Added message queue to DX9 plugin.
- Added plugin interface function Video_AddMessage to both plugins and to the plugin specs. - Added handling of the Video_AddMessage interface export from the core side. - Added a print on Core::Init for testing purposes (might not be the best place). git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@176 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
@ -133,6 +133,9 @@ bool Init(const SCoreStartupParameter _CoreParameter)
|
||||
emuThreadGoing.Shutdown();
|
||||
// all right ... here we go
|
||||
Host_SetWaitCursor(false);
|
||||
|
||||
PluginVideo::Video_AddMessage("Emulation started.",3000);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -33,6 +33,9 @@ typedef void (__cdecl* TVideo_UpdateXFB)(BYTE*, DWORD, DWORD);
|
||||
typedef BOOL (__cdecl* TVideo_Screenshot)(TCHAR*);
|
||||
typedef void (__cdecl* TVideo_EnterLoop)();
|
||||
|
||||
typedef void (__cdecl* TVideo_AddMessage)(const char* pstr, unsigned int milliseconds);
|
||||
|
||||
|
||||
//! Function Pointer
|
||||
TGetDllInfo g_GetDllInfo = 0;
|
||||
TDllAbout g_DllAbout = 0;
|
||||
@ -44,6 +47,7 @@ TVideo_SendFifoData g_Video_SendFifoData = 0;
|
||||
TVideo_UpdateXFB g_Video_UpdateXFB = 0;
|
||||
TVideo_Screenshot g_Video_Screenshot = 0;
|
||||
TVideo_EnterLoop g_Video_EnterLoop = 0;
|
||||
TVideo_AddMessage g_Video_AddMessage = 0;
|
||||
|
||||
//! Library Instance
|
||||
DynamicLibrary plugin;
|
||||
@ -64,6 +68,7 @@ void UnloadPlugin()
|
||||
g_Video_Shutdown = 0;
|
||||
g_Video_SendFifoData = 0;
|
||||
g_Video_UpdateXFB = 0;
|
||||
g_Video_AddMessage = 0;
|
||||
|
||||
plugin.Unload();
|
||||
}
|
||||
@ -82,6 +87,7 @@ bool LoadPlugin(const char *_Filename)
|
||||
g_Video_UpdateXFB = reinterpret_cast<TVideo_UpdateXFB> (plugin.Get("Video_UpdateXFB"));
|
||||
g_Video_Screenshot = reinterpret_cast<TVideo_Screenshot> (plugin.Get("Video_Screenshot"));
|
||||
g_Video_EnterLoop = reinterpret_cast<TVideo_EnterLoop> (plugin.Get("Video_EnterLoop"));
|
||||
g_Video_AddMessage = reinterpret_cast<TVideo_AddMessage> (plugin.Get("Video_AddMessage"));
|
||||
|
||||
if ((g_GetDllInfo != 0) &&
|
||||
(g_DllAbout != 0) &&
|
||||
@ -92,7 +98,8 @@ bool LoadPlugin(const char *_Filename)
|
||||
(g_Video_SendFifoData != 0) &&
|
||||
(g_Video_UpdateXFB != 0) &&
|
||||
(g_Video_EnterLoop != 0) &&
|
||||
(g_Video_Screenshot != 0))
|
||||
(g_Video_Screenshot != 0) &&
|
||||
(g_Video_AddMessage != 0))
|
||||
{
|
||||
return true;
|
||||
}
|
||||
@ -159,4 +166,9 @@ void Video_EnterLoop()
|
||||
g_Video_EnterLoop();
|
||||
}
|
||||
|
||||
void Video_AddMessage(const char* pstr, unsigned int milliseconds)
|
||||
{
|
||||
g_Video_AddMessage(pstr,milliseconds);
|
||||
}
|
||||
|
||||
} // end of namespace PluginVideo
|
||||
|
@ -40,6 +40,7 @@ void Video_EnterLoop();
|
||||
void Video_SendFifoData(BYTE *_uData);
|
||||
void Video_UpdateXFB(BYTE* _pXFB, DWORD _dwHeight, DWORD _dwWidth);
|
||||
bool Video_Screenshot(TCHAR* _szFilename);
|
||||
void Video_AddMessage(const char* pstr, unsigned int milliseconds);
|
||||
|
||||
} // end of namespace PluginVideo
|
||||
|
||||
|
Reference in New Issue
Block a user