#include #include #include #ifndef _WIN32 #include #else #endif #include "Common.h" #include "FileUtil.h" #ifdef __APPLE__ #include #endif #if defined(HAVE_COCOA) && HAVE_COCOA #import "cocoaApp.h" #endif #include "Globals.h" #include "Host.h" #include "ISOFile.h" #include "CPUDetect.h" #include "cmdline.h" #include "Thread.h" #include "PowerPC/PowerPC.h" #include "PluginManager.h" #include "BootManager.h" void* g_pCodeWindow = NULL; void* main_frame = NULL; LogManager *logManager = NULL; // OK, this thread boundary is DANGEROUS on linux // wxPostEvent / wxAddPendingEvent is the solution. void Host_NotifyMapLoaded(){} void Host_UpdateLogDisplay(){} void Host_UpdateDisasmDialog(){} Common::Event updateMainFrameEvent; void Host_UpdateMainFrame() { updateMainFrameEvent.Set(); } void Host_UpdateBreakPointView(){} void Host_UpdateMemoryView(){} void Host_SetDebugMode(bool){} void Host_SetWaitCursor(bool enable){} void Host_UpdateStatusBar(const char* _pText, int Filed){} void Host_SysMessage(const char *fmt, ...) { va_list list; char msg[512]; va_start(list, fmt); vsprintf(msg, fmt, list); va_end(list); size_t len = strlen(msg); if (msg[len - 1] != '\n') { msg[len - 1] = '\n'; msg[len] = '\0'; } fprintf(stderr, msg); } void Host_UpdateLeds(int led_bits) { } void Host_UpdateSpeakerStatus(int index, int speaker_bits) { } void Host_UpdateStatus() { } void Host_SetWiiMoteConnectionState(int _State) {} //for cocoa we need to hijack the main to get event #if defined(HAVE_COCOA) && HAVE_COCOA @interface CocoaThread : NSObject { } - (void)cocoaThreadStart; - (void)cocoaThreadRun:(id)sender; - (void)cocoaThreadQuit:(NSNotification*)note; @end static NSString *CocoaThreadHaveFinish = @"CocoaThreadHaveFinish"; int cocoaArgc; char **cocoaArgv; int appleMain(int argc, char *argv[]); @implementation CocoaThread - (void)cocoaThreadStart { [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(cocoaThreadQuit:) name:CocoaThreadHaveFinish object:nil]; [NSThread detachNewThreadSelector:@selector(cocoaThreadRun:) toTarget:self withObject:nil]; } - (void)cocoaThreadRun:(id)sender { NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init]; //launch main appleMain(cocoaArgc,cocoaArgv); [[NSNotificationCenter defaultCenter] postNotificationName:CocoaThreadHaveFinish object:nil]; [pool release]; } - (void)cocoaThreadQuit:(NSNotification*)note { [[NSNotificationCenter defaultCenter] removeObserver:self]; } @end int main(int argc, char *argv[]) { cocoaArgc = argc; cocoaArgv = argv; cocoaCreateApp(); NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; CocoaThread *thread = [[CocoaThread alloc] init]; NSEvent *event = [[NSEvent alloc] init]; [thread cocoaThreadStart]; //cocoa event loop while(true) { event = [NSApp nextEventMatchingMask:NSAnyEventMask untilDate:[NSDate distantPast] inMode:NSDefaultRunLoopMode dequeue:YES ]; cocoaSendEvent(event); } [event release]; [thread release]; [pool release]; } int appleMain(int argc, char *argv[]) #else // Include SDL header so it can hijack main(). #if defined(USE_SDL) && USE_SDL #include #endif int main(int argc, char* argv[]) #endif { gengetopt_args_info args_info; if (cmdline_parser (argc, argv, &args_info) != 0) return(1); if (args_info.inputs_num < 1) { fprintf(stderr, "Please supply at least one argument - the ISO to boot.\n"); return(1); } std::string bootFile(args_info.inputs[0]); logManager = (LogManager *)CPluginManager::GetInstance().GetGlobals()->logManager; updateMainFrameEvent.Init(); cpu_info.Detect(); CPluginManager::GetInstance().ScanForPlugins(); // check to see if ~/Library/Application Support/Dolphin exists; if not, create it char AppSupportDir[MAXPATHLEN]; snprintf(AppSupportDir, sizeof(AppSupportDir), "%s/Library/Application Support", getenv("HOME")); if (!File::Exists(AppSupportDir) || !File::IsDirectory(AppSupportDir)) PanicAlert("Could not open ~/Library/Application Support"); strncat(AppSupportDir, "/Dolphin", sizeof(AppSupportDir)); if (!File::Exists(AppSupportDir)) File::CreateDir(AppSupportDir); if (!File::IsDirectory(AppSupportDir)) PanicAlert("~/Library/Application Support/Dolphin exists, but is not a directory"); chdir(AppSupportDir); BootManager::BootCore(bootFile); while (PowerPC::GetState() != PowerPC::CPU_POWERDOWN) { updateMainFrameEvent.Wait(); } cmdline_parser_free (&args_info); return(0); }