From 2667a469fbcc4b6c7da0a59ccbb4532a1b0564ec Mon Sep 17 00:00:00 2001 From: death2droid Date: Sat, 14 Nov 2009 08:53:16 +0000 Subject: [PATCH] Dolphin: System Information(InfoWindow.cpp) - Added a method to check what Windows OS you are running(I do not know of a method to check what linux OS someone is using) and also added a extended version of the cpu_summarize. Plugin manager - Temporarily fixed a problem that caused a crashing when pressing Stop reported in Issue 1656 git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@4561 8ced0084-cf51-0410-be5f-012b33b47a6e --- Source/Core/Common/Src/CPUDetect.cpp | 20 ++++++++ Source/Core/Common/Src/CPUDetect.h | 3 ++ Source/Core/Core/Src/PluginManager.cpp | 4 +- Source/Core/DolphinWX/Src/InfoWindow.cpp | 3 +- Source/Core/DolphinWX/Src/Summarize.h | 64 +++++++++++++++++++++++- 5 files changed, 89 insertions(+), 5 deletions(-) diff --git a/Source/Core/Common/Src/CPUDetect.cpp b/Source/Core/Common/Src/CPUDetect.cpp index cd77d37346..b09570283d 100644 --- a/Source/Core/Common/Src/CPUDetect.cpp +++ b/Source/Core/Common/Src/CPUDetect.cpp @@ -201,3 +201,23 @@ std::string CPUInfo::Summarize() if (bLongMode) sum += ", 64-bit support"; return sum; } + +// Turn the cpu info into a string we can show(This version uses headings and line breaks) +std::string CPUInfo::Summarize_long() +{ + std::string sum; + sum = StringFromFormat("CPU Brand: %s\n",cpu_string); + + sum += StringFromFormat("Number of cores: %i \n ",num_cores); + + sum+= "Supported instruction sets:\n"; + + if (bSSE) sum += " -SSE\n"; + if (bSSE2) sum += " -SSE2\n"; + if (bSSE3) sum += " -SSE3\n"; + if (bSSSE3) sum += " -SSSE3\n"; + if (bSSE4_1) sum += " -SSE4.1\n"; + if (bSSE4_2) sum += " -SSE4.2\n"; + if (bLongMode) sum += "64-bit supported"; + return sum; +} \ No newline at end of file diff --git a/Source/Core/Common/Src/CPUDetect.h b/Source/Core/Common/Src/CPUDetect.h index 55a0de93c9..7d3796f5a8 100644 --- a/Source/Core/Common/Src/CPUDetect.h +++ b/Source/Core/Common/Src/CPUDetect.h @@ -58,6 +58,9 @@ struct CPUInfo // Turn the cpu info into a string we can show std::string Summarize(); + + // Turn the cpu info into a string we can show(This version uses headings and line breaks) + std::string Summarize_long(); }; extern CPUInfo cpu_info; diff --git a/Source/Core/Core/Src/PluginManager.cpp b/Source/Core/Core/Src/PluginManager.cpp index 13b265c710..a7c1493cdd 100644 --- a/Source/Core/Core/Src/PluginManager.cpp +++ b/Source/Core/Core/Src/PluginManager.cpp @@ -164,7 +164,7 @@ void CPluginManager::ShutdownPlugins() if (m_pad[i]) { m_pad[i]->Shutdown(); - delete m_pad[i]; + //delete m_pad[i]; Causes crash on stop } m_pad[i] = NULL; } @@ -301,7 +301,7 @@ void *CPluginManager::LoadPlugin(const char *_rFilename, int Number) PanicAlert("Can't open %s, it has a missing function", _rFilename); return NULL; } - + // Call the DLL function SetGlobals plugin->SetGlobals(m_PluginGlobals); return plugin; diff --git a/Source/Core/DolphinWX/Src/InfoWindow.cpp b/Source/Core/DolphinWX/Src/InfoWindow.cpp index 7b2d4e56f0..0a947b1633 100644 --- a/Source/Core/DolphinWX/Src/InfoWindow.cpp +++ b/Source/Core/DolphinWX/Src/InfoWindow.cpp @@ -57,7 +57,8 @@ void wxInfoWindow::Init_ChildControls() Info.append(StringFromFormat( - "\n\n%s\n%s\n%s\n\n%s\n\n", + "\n\n_-Computer Information-_\n\n%s\n%s\n%s\n\n_-Dolphin Information-_\n\n%s\n\n%s\n\n", + Summarize_OS().c_str(), Summarize_Drives().c_str(), Summarize_CPU().c_str(), Summarize_Plug().c_str(), diff --git a/Source/Core/DolphinWX/Src/Summarize.h b/Source/Core/DolphinWX/Src/Summarize.h index 71fc925fd4..685e59a489 100644 --- a/Source/Core/DolphinWX/Src/Summarize.h +++ b/Source/Core/DolphinWX/Src/Summarize.h @@ -18,6 +18,9 @@ #ifndef __SUMMARIZE_H__ #define __SUMMARIZE_H__ +#include +#include + std::string Summarize_Plug() { return StringFromFormat( @@ -104,7 +107,7 @@ std::string Summarize_CPU() { return StringFromFormat( "Processor Information: \n%s\n", - cpu_info.Summarize().c_str() + cpu_info.Summarize_long().c_str() ); } @@ -124,4 +127,61 @@ std::string Summarize_Drives() return drive; } -#endif //__SUMMARIZE_H__ \ No newline at end of file + +std::string Summarize_OS(void) +{ + + std::string operatingSystem = "Operating System: "; +#ifdef _WIN32 + OSVERSIONINFO osver; + osver.dwOSVersionInfoSize = sizeof(osver); + + if (GetVersionEx(&osver)) + { + switch(osver.dwMajorVersion) + { + case 6: + switch(osver.dwMinorVersion) + { + case 1: + if(osver.dwPlatformId == VER_NT_WORKSTATION) + operatingSystem += "Windows 7"; + else + operatingSystem += "Windows Server 2008 R2"; + break; + case 0: + if(osver.dwPlatformId == VER_NT_WORKSTATION) + operatingSystem += "Windows Vista"; + else + operatingSystem += "Windows Server 2008"; + break; + } + break; + case 5: + switch(osver.dwMinorVersion) + { + case 2: + if(GetSystemMetrics(SM_SERVERR2) != 0) + operatingSystem += "Windows Server 2003 R2"; + else + operatingSystem += "Windows Server 2003"; + break; + case 1: + operatingSystem += "Windows XP"; + break; + case 0: + operatingSystem += "Windows 2000"; + break; + } + break; + } + } +#else + operatingSystem = std::string("Non Windows operating system"); +#endif + + return operatingSystem; +} + + +#endif //__SUMMARIZE_H__