diff --git a/src/macosx/Info-StellaOSX__Upgraded_.plist b/src/macosx/Info-StellaOSX.plist similarity index 100% rename from src/macosx/Info-StellaOSX__Upgraded_.plist rename to src/macosx/Info-StellaOSX.plist diff --git a/src/macosx/OSystemMACOSX.cxx b/src/macosx/OSystemMACOSX.cxx index 9369fd42b..79e67cf46 100644 --- a/src/macosx/OSystemMACOSX.cxx +++ b/src/macosx/OSystemMACOSX.cxx @@ -33,8 +33,6 @@ extern "C" { void macOpenConsole(char *romname); - uInt16 macOSXDisplayWidth(void); - uInt16 macOSXDisplayHeight(void); void setEmulationMenus(void); void setLauncherMenus(void); void setOptionsMenus(void); @@ -98,13 +96,6 @@ OSystemMACOSX::~OSystemMACOSX() { } -// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -void OSystemMACOSX::getScreenDimensions(int& width, int& height) -{ - width = (int)macOSXDisplayWidth(); - height = (int)macOSXDisplayHeight(); -} - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - void OSystemMACOSX::stateChanged(EventHandler::State state) { diff --git a/src/macosx/OSystemMACOSX.hxx b/src/macosx/OSystemMACOSX.hxx index 6fd49bf96..2e9c8bd01 100644 --- a/src/macosx/OSystemMACOSX.hxx +++ b/src/macosx/OSystemMACOSX.hxx @@ -42,11 +42,6 @@ class OSystemMACOSX : public OSystem virtual ~OSystemMACOSX(); public: - /** - This method queries the dimensions of the screen for this hardware. - */ - virtual void getScreenDimensions(int& width, int& height); - /** Informs the OSystem of a change in EventHandler state. */ diff --git a/src/macosx/SDLMain.m b/src/macosx/SDLMain.m index 8fc545be5..8a14dc7d2 100755 --- a/src/macosx/SDLMain.m +++ b/src/macosx/SDLMain.m @@ -12,37 +12,94 @@ #import /* for MAXPATHLEN */ #import +#define SDL_main stellaMain + extern int stellaMain(int argc, char* argv[]); void macOpenConsole(char *romname); + +/* For some reaon, Apple removed setAppleMenu from the headers in 10.4, + but the method still is there and works. To avoid warnings, we declare + it ourselves here. */ +@interface NSApplication(SDL_Missing_Methods) +- (void)setAppleMenu:(NSMenu *)menu; +@end + +/* Use this flag to determine whether we use SDLMain.nib or not */ +#define SDL_USE_NIB_FILE 1 + +/* Use this flag to determine whether we use CPS (docking) or not */ +#define SDL_USE_CPS 1 +#ifdef SDL_USE_CPS +/* Portions of CPS.h */ +typedef struct CPSProcessSerNum +{ + UInt32 lo; + UInt32 hi; +} CPSProcessSerNum; + +extern OSErr CPSGetCurrentProcess( CPSProcessSerNum *psn); +extern OSErr CPSEnableForegroundOperation( CPSProcessSerNum *psn, UInt32 _arg2, UInt32 _arg3, UInt32 _arg4, UInt32 _arg5); +extern OSErr CPSSetFrontProcess( CPSProcessSerNum *psn); + +#endif /* SDL_USE_CPS */ + static int gArgc; static char **gArgv; -BOOL gFinderLaunch; -static BOOL started=NO; -static char startupFile[FILENAME_MAX]; +static BOOL gFinderLaunch; +static BOOL gCalledAppMainline = FALSE; +//static BOOL started=NO; +//static char startupFile[FILENAME_MAX]; + int fileToLoad = FALSE; char parentdir[MAXPATHLEN]; -unsigned short macOSXDisplayWidth(void) +// -------------------------------------------------------------------------------- +static NSString *getApplicationName(void) { - return(CGDisplayPixelsWide(kCGDirectMainDisplay)); -} - -unsigned short macOSXDisplayHeight(void) -{ - return(CGDisplayPixelsHigh(kCGDirectMainDisplay)); + const NSDictionary *dict; + NSString *appName = 0; + + /* Determine the application name */ + dict = (const NSDictionary *)CFBundleGetInfoDictionary(CFBundleGetMainBundle()); + if (dict) + appName = [dict objectForKey: @"CFBundleName"]; + + if (![appName length]) + appName = [[NSProcessInfo processInfo] processName]; + + return appName; } +#if 0 +// -------------------------------------------------------------------------------- +/* Routine to center the application window */ +void centerAppWindow(void) +{ + [[[SDLApplication sharedApplication] keyWindow] center]; +} + + +/////// FIXME ////////////////////////////// + +char *appName = "StellaOSX"; +#endif + +#if SDL_USE_NIB_FILE +// -------------------------------------------------------------------------------- /* A helper category for NSString */ @interface NSString (ReplaceSubString) - (NSString *)stringByReplacingRange:(NSRange)aRange with:(NSString *)aString; @end +#endif -@interface SDLApplication : NSApplication +// -------------------------------------------------------------------------------- +@interface NSApplication (SDLApplication) @end -@implementation SDLApplication +// -------------------------------------------------------------------------------- +@implementation NSApplication (SDLApplication) /* Invoked from the Quit menu item */ - (void)terminate:(id)sender { @@ -57,23 +114,44 @@ unsigned short macOSXDisplayHeight(void) /* The main class of the application, the application's delegate */ @implementation SDLMain +// -------------------------------------------------------------------------------- static SDLMain *sharedInstance = nil; + (SDLMain *)sharedInstance { return sharedInstance; } +// -------------------------------------------------------------------------------- +/* Set the working directory to the .app's parent directory */ +- (void) setupWorkingDirectory:(BOOL)shouldChdir +{ + if (shouldChdir) + { + char parentdir[MAXPATHLEN]; + CFURLRef url = CFBundleCopyBundleURL(CFBundleGetMainBundle()); + CFURLRef url2 = CFURLCreateCopyDeletingLastPathComponent(0, url); + if (CFURLGetFileSystemRepresentation(url2, 1, (UInt8 *)parentdir, MAXPATHLEN)) { + chdir(parentdir); /* chdir to the binary app's parent */ + } + CFRelease(url); + CFRelease(url2); + } +} + + +#if SDL_USE_NIB_FILE +// -------------------------------------------------------------------------------- /* Fix menu to contain the real app name instead of "SDL App" */ - (void)fixMenu:(NSMenu *)aMenu withAppName:(NSString *)appName { NSRange aRange; NSEnumerator *enumerator; NSMenuItem *menuItem; - + aRange = [[aMenu title] rangeOfString:@"SDL App"]; if (aRange.length != 0) [aMenu setTitle: [[aMenu title] stringByReplacingRange:aRange with:appName]]; - + enumerator = [[aMenu itemArray] objectEnumerator]; while ((menuItem = [enumerator nextObject])) { @@ -83,23 +161,226 @@ static SDLMain *sharedInstance = nil; if ([menuItem hasSubmenu]) [self fixMenu:[menuItem submenu] withAppName:appName]; } -/* SA [ aMenu sizeToFit ]; */ } -char *appName = "StellaOSX"; +#else +// -------------------------------------------------------------------------------- +static void setApplicationMenu(void) +{ + /* warning: this code is very odd */ + NSMenu *appleMenu; + NSMenuItem *menuItem; + NSString *title; + NSString *appName; + + appName = getApplicationName(); + appleMenu = [[NSMenu alloc] initWithTitle:@""]; + + /* Add menu items */ + title = [@"About " stringByAppendingString:appName]; + [appleMenu addItemWithTitle:title action:@selector(orderFrontStandardAboutPanel:) keyEquivalent:@""]; + + [appleMenu addItem:[NSMenuItem separatorItem]]; + + title = [@"Hide " stringByAppendingString:appName]; + [appleMenu addItemWithTitle:title action:@selector(hide:) keyEquivalent:@"h"]; + + menuItem = (NSMenuItem *)[appleMenu addItemWithTitle:@"Hide Others" action:@selector(hideOtherApplications:) keyEquivalent:@"h"]; + [menuItem setKeyEquivalentModifierMask:(NSAlternateKeyMask|NSCommandKeyMask)]; + + [appleMenu addItemWithTitle:@"Show All" action:@selector(unhideAllApplications:) keyEquivalent:@""]; + + [appleMenu addItem:[NSMenuItem separatorItem]]; + + title = [@"Quit " stringByAppendingString:appName]; + [appleMenu addItemWithTitle:title action:@selector(terminate:) keyEquivalent:@"q"]; + + + /* Put menu into the menubar */ + menuItem = [[NSMenuItem alloc] initWithTitle:@"" action:nil keyEquivalent:@""]; + [menuItem setSubmenu:appleMenu]; + [[NSApp mainMenu] addItem:menuItem]; + + /* Tell the application object that this is now the application menu */ + [NSApp setAppleMenu:appleMenu]; + + /* Finally give up our references to the objects */ + [appleMenu release]; + [menuItem release]; +} + + +// -------------------------------------------------------------------------------- +/* Create a window menu */ +static void setupWindowMenu(void) +{ + NSMenu *windowMenu; + NSMenuItem *windowMenuItem; + NSMenuItem *menuItem; + + windowMenu = [[NSMenu alloc] initWithTitle:@"Window"]; + + /* "Minimize" item */ + menuItem = [[NSMenuItem alloc] initWithTitle:@"Minimize" action:@selector(performMiniaturize:) keyEquivalent:@"m"]; + [windowMenu addItem:menuItem]; + [menuItem release]; + + /* Put menu into the menubar */ + windowMenuItem = [[NSMenuItem alloc] initWithTitle:@"Window" action:nil keyEquivalent:@""]; + [windowMenuItem setSubmenu:windowMenu]; + [[NSApp mainMenu] addItem:windowMenuItem]; + + /* Tell the application object that this is now the window menu */ + [NSApp setWindowsMenu:windowMenu]; + + /* Finally give up our references to the objects */ + [windowMenu release]; + [windowMenuItem release]; +} + + +// -------------------------------------------------------------------------------- +/* Replacement for NSApplicationMain */ +static void CustomApplicationMain (int argc, char **argv) +{ + NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; + SDLMain *sdlMain; + + /* Ensure the application object is initialised */ + [NSApplication sharedApplication]; + +#ifdef SDL_USE_CPS + { + CPSProcessSerNum PSN; + /* Tell the dock about us */ + if (!CPSGetCurrentProcess(&PSN)) + if (!CPSEnableForegroundOperation(&PSN,0x03,0x3C,0x2C,0x1103)) + if (!CPSSetFrontProcess(&PSN)) + [NSApplication sharedApplication]; + } +#endif /* SDL_USE_CPS */ + + /* Set up the menubar */ + [NSApp setMainMenu:[[NSMenu alloc] init]]; + setApplicationMenu(); + setupWindowMenu(); + + /* Create SDLMain and make it the app delegate */ + sdlMain = [[SDLMain alloc] init]; + [NSApp setDelegate:sdlMain]; + + /* Start the main event loop */ + [NSApp run]; + + [sdlMain release]; + [pool release]; +} + +#endif + + +// -------------------------------------------------------------------------------- +/* + * Catch document open requests...this lets us notice files when the app + * was launched by double-clicking a document, or when a document was + * dragged/dropped on the app's icon. You need to have a + * CFBundleDocumentsType section in your Info.plist to get this message, + * apparently. + * + * Files are added to gArgv, so to the app, they'll look like command line + * arguments. Previously, apps launched from the finder had nothing but + * an argv[0]. + * + * This message may be received multiple times to open several docs on launch. + * + * This message is ignored once the app's mainline has been called. + */ +- (BOOL)application:(NSApplication *)theApplication openFile:(NSString *)filename +{ + const char *temparg; + size_t arglen; + char *arg; + char **newargv; + + if (!gFinderLaunch) /* MacOS is passing command line args. */ + return FALSE; + + if (gCalledAppMainline) /* app has started, ignore this document. */ + return FALSE; + + temparg = [filename UTF8String]; + arglen = SDL_strlen(temparg) + 1; + arg = (char *) SDL_malloc(arglen); + if (arg == NULL) + return FALSE; + + newargv = (char **) realloc(gArgv, sizeof (char *) * (gArgc + 2)); + if (newargv == NULL) + { + SDL_free(arg); + return FALSE; + } + gArgv = newargv; + + SDL_strlcpy(arg, temparg, arglen); + gArgv[gArgc++] = arg; + gArgv[gArgc] = NULL; + return TRUE; +} +/* OLD VERSION +- (BOOL)application:(NSApplication *)theApplication openFile:(NSString *)filename +{ + if (started) + { + char cFilename[FILENAME_MAX]; + strncpy(cFilename, [filename cStringUsingEncoding: NSASCIIStringEncoding], FILENAME_MAX-1); + if (strlen(cFilename) > 0) + macOpenConsole(cFilename); + } + else + { + fileToLoad = TRUE; + strncpy(startupFile, [filename cStringUsingEncoding: NSASCIIStringEncoding], FILENAME_MAX-1); + } + + return(FALSE); +} +*/ + +// -------------------------------------------------------------------------------- /* Called when the internal event loop has just started running */ - (void) applicationDidFinishLaunching: (NSNotification *) note +{ + int status; + + /* Set the working directory to the .app's parent directory */ + [self setupWorkingDirectory:gFinderLaunch]; + +#if SDL_USE_NIB_FILE + /* Set the main menu to contain the real app name instead of "SDL App" */ + [self fixMenu:[NSApp mainMenu] withAppName:getApplicationName()]; +#endif + + /* Hand off to main application code */ + gCalledAppMainline = TRUE; + status = SDL_main (gArgc, gArgv); + + /* We're done, thank you for playing */ + exit(status); +} +/* OLD VERSION +- (void) applicationDidFinishLaunching: (NSNotification *) note { int status; char *args[2]; started = YES; - /* Set the main menu to contain the real app name instead of "SDL App" */ + // Set the main menu to contain the real app name instead of "SDL App" [self fixMenu:[NSApp mainMenu] withAppName:[[NSProcessInfo processInfo] processName]]; - /* Hand off to main application code */ + // Hand off to main application code args[0] = appName; if (fileToLoad) { @@ -111,31 +392,10 @@ char *appName = "StellaOSX"; status = stellaMain(1,args); } - /* We're done, thank you for playing */ + // We're done, thank you for playing exit(status); } - -/*------------------------------------------------------------------------------ -* application openFile - Open a file dragged to the application. -*-----------------------------------------------------------------------------*/ -- (BOOL)application:(NSApplication *)theApplication openFile:(NSString *)filename -{ - if (started) - { - char cFilename[FILENAME_MAX]; - strncpy(cFilename, [filename cStringUsingEncoding: NSASCIIStringEncoding], FILENAME_MAX-1); - if (strlen(cFilename) > 0) - macOpenConsole(cFilename); - } - else - { - fileToLoad = TRUE; - strncpy(startupFile, [filename cStringUsingEncoding: NSASCIIStringEncoding], FILENAME_MAX-1); - } - - return(FALSE); -} - +*/ @end @@ -149,9 +409,9 @@ char *appName = "StellaOSX"; unichar *buffer; NSRange localRange; NSString *result; - + bufferSize = selfLen + aStringLen - aRange.length; - buffer = NSAllocateMemoryPages(bufferSize*sizeof(unichar)); + buffer = (unichar *)NSAllocateMemoryPages(bufferSize*sizeof(unichar)); /* Get first part into buffer */ localRange.location = 0; @@ -162,7 +422,7 @@ char *appName = "StellaOSX"; localRange.location = 0; localRange.length = aStringLen; [aString getCharacters:(buffer+aRange.location) range:localRange]; - + /* Get last part into buffer */ localRange.location = aRange.location + aRange.length; localRange.length = selfLen - localRange.location; @@ -184,56 +444,35 @@ char *appName = "StellaOSX"; # undef main #endif -void setupParentDirectory(void) -{ - char *c; - - strncpy ( parentdir, gArgv[0], sizeof(parentdir) ); - c = (char*) parentdir; - - while (*c != '\0') /* go to end */ - c++; - - while (*c != '/') /* back up to parent */ - c--; - - *c++ = '\0'; /* cut off last part (binary name) */ - -} /* Main entry point to executable - should *not* be SDL_main! */ int main (int argc, char **argv) { - static Preferences *myPrefs; - /* Copy the arguments into a global variable */ - int i; + static Preferences *myPrefs; + /* Copy the arguments into a global variable */ /* This is passed if we are launched by double-clicking */ if ( argc >= 2 && strncmp (argv[1], "-psn", 4) == 0 ) { + gArgv = (char **) SDL_malloc(sizeof (char *) * 2); + gArgv[0] = argv[0]; + gArgv[1] = NULL; gArgc = 1; - gFinderLaunch = YES; + gFinderLaunch = YES; } else { + int i; gArgc = argc; - gFinderLaunch = NO; + gArgv = (char **) SDL_malloc(sizeof (char *) * (argc+1)); + for (i = 0; i <= argc; i++) + gArgv[i] = argv[i]; + gFinderLaunch = NO; } - gArgv = (char**) malloc (sizeof(*gArgv) * (gArgc+1)); - assert (gArgv != NULL); - for (i = 0; i < gArgc; i++) - gArgv[i] = argv[i]; - gArgv[i] = NULL; + + myPrefs = [Preferences sharedInstance]; - myPrefs = [Preferences sharedInstance]; - - setupParentDirectory(); - - [SDLApplication poseAsClass:[NSApplication class]]; +#if SDL_USE_NIB_FILE NSApplicationMain (argc, (const char **)argv); +#else + CustomApplicationMain (argc, argv); +#endif return 0; } - -/* Routine to center the application window */ -void centerAppWindow(void) -{ - [[[SDLApplication sharedApplication] keyWindow] center]; -} - diff --git a/src/macosx/StellaOSX.xcconfig b/src/macosx/StellaOSX.xcconfig deleted file mode 100644 index e69de29bb..000000000 diff --git a/src/macosx/stella.xcodeproj/project.pbxproj b/src/macosx/stella.xcodeproj/project.pbxproj index caba41346..456a2caba 100644 --- a/src/macosx/stella.xcodeproj/project.pbxproj +++ b/src/macosx/stella.xcodeproj/project.pbxproj @@ -255,7 +255,6 @@ 2D91751109BA90380026E9FF /* SDL.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2D4764C806683C5F00F63D87 /* SDL.framework */; }; 2D91751209BA90380026E9FF /* ApplicationServices.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 2D17D98E08BC398400E47F69 /* ApplicationServices.framework */; }; 2D91751409BA90380026E9FF /* SDL.framework in CopyFiles */ = {isa = PBXBuildFile; fileRef = 2D4764C806683C5F00F63D87 /* SDL.framework */; }; - 2D91753809BA91BC0026E9FF /* StellaOSX.xcconfig in Resources */ = {isa = PBXBuildFile; fileRef = 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */; }; 2DEFB40C09C3386F00754289 /* Cart.icns in Resources */ = {isa = PBXBuildFile; fileRef = 2DEFB40B09C3386F00754289 /* Cart.icns */; }; DC07A3C80CAD738A009B4BC9 /* StateManager.cxx in Sources */ = {isa = PBXBuildFile; fileRef = DC07A3C60CAD738A009B4BC9 /* StateManager.cxx */; }; DC07A3C90CAD738A009B4BC9 /* StateManager.hxx in Headers */ = {isa = PBXBuildFile; fileRef = DC07A3C70CAD738A009B4BC9 /* StateManager.hxx */; }; @@ -269,6 +268,7 @@ DC173F770E2CAC1E00320F94 /* ContextMenu.hxx in Headers */ = {isa = PBXBuildFile; fileRef = DC173F750E2CAC1E00320F94 /* ContextMenu.hxx */; }; DC1FC18A0DB3B2C7009B3DF7 /* SerialPortMACOSX.cxx in Sources */ = {isa = PBXBuildFile; fileRef = DC1FC1880DB3B2C7009B3DF7 /* SerialPortMACOSX.cxx */; }; DC1FC18B0DB3B2C7009B3DF7 /* SerialPortMACOSX.hxx in Headers */ = {isa = PBXBuildFile; fileRef = DC1FC1890DB3B2C7009B3DF7 /* SerialPortMACOSX.hxx */; }; + DC419D82108E10A3006E8687 /* Info-StellaOSX.plist in Resources */ = {isa = PBXBuildFile; fileRef = DC419D81108E10A3006E8687 /* Info-StellaOSX.plist */; }; DC4613670D92C03600D8DAB9 /* RomAuditDialog.cxx in Sources */ = {isa = PBXBuildFile; fileRef = DC4613650D92C03600D8DAB9 /* RomAuditDialog.cxx */; }; DC4613680D92C03600D8DAB9 /* RomAuditDialog.hxx in Headers */ = {isa = PBXBuildFile; fileRef = DC4613660D92C03600D8DAB9 /* RomAuditDialog.hxx */; }; DC47455509C34BFA00EDDA3A /* BankRomCheat.cxx in Sources */ = {isa = PBXBuildFile; fileRef = DC47454A09C34BFA00EDDA3A /* BankRomCheat.cxx */; }; @@ -473,9 +473,7 @@ 2D73959508C3EB4E0060BB99 /* CommandMenu.cxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = CommandMenu.cxx; path = ../gui/CommandMenu.cxx; sourceTree = SOURCE_ROOT; }; 2D73959608C3EB4E0060BB99 /* CommandMenu.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; name = CommandMenu.hxx; path = ../gui/CommandMenu.hxx; sourceTree = SOURCE_ROOT; }; 2D7B4F6C063B513200579B93 /* Credits.html */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = text.html; path = Credits.html; sourceTree = SOURCE_ROOT; }; - 2D91751A09BA90380026E9FF /* Info-StellaOSX__Upgraded_.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info-StellaOSX__Upgraded_.plist"; sourceTree = ""; }; 2D91751E09BA90390026E9FF /* StellaOSX.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = StellaOSX.app; sourceTree = BUILT_PRODUCTS_DIR; }; - 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = text.xcconfig; path = StellaOSX.xcconfig; sourceTree = SOURCE_ROOT; }; 2D9217FA0857CC88001D664B /* ConsoleFont.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; name = ConsoleFont.hxx; path = ../gui/ConsoleFont.hxx; sourceTree = SOURCE_ROOT; }; 2D9217FB0857CC88001D664B /* Font.cxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = Font.cxx; path = ../gui/Font.cxx; sourceTree = SOURCE_ROOT; }; 2D9217FC0857CC88001D664B /* Font.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; name = Font.hxx; path = ../gui/Font.hxx; sourceTree = SOURCE_ROOT; }; @@ -648,6 +646,7 @@ DC173F750E2CAC1E00320F94 /* ContextMenu.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; name = ContextMenu.hxx; path = ../gui/ContextMenu.hxx; sourceTree = SOURCE_ROOT; }; DC1FC1880DB3B2C7009B3DF7 /* SerialPortMACOSX.cxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; path = SerialPortMACOSX.cxx; sourceTree = ""; }; DC1FC1890DB3B2C7009B3DF7 /* SerialPortMACOSX.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; path = SerialPortMACOSX.hxx; sourceTree = ""; }; + DC419D81108E10A3006E8687 /* Info-StellaOSX.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = "Info-StellaOSX.plist"; sourceTree = ""; }; DC4613650D92C03600D8DAB9 /* RomAuditDialog.cxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = RomAuditDialog.cxx; path = ../gui/RomAuditDialog.cxx; sourceTree = SOURCE_ROOT; }; DC4613660D92C03600D8DAB9 /* RomAuditDialog.hxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.h; name = RomAuditDialog.hxx; path = ../gui/RomAuditDialog.hxx; sourceTree = SOURCE_ROOT; }; DC47454A09C34BFA00EDDA3A /* BankRomCheat.cxx */ = {isa = PBXFileReference; fileEncoding = 30; lastKnownFileType = sourcecode.cpp.cpp; name = BankRomCheat.cxx; path = ../cheat/BankRomCheat.cxx; sourceTree = SOURCE_ROOT; }; @@ -782,8 +781,7 @@ 29B97317FDCFA39411CA2CEA /* Resources */, 29B97323FDCFA39411CA2CEA /* Frameworks */, 19C28FACFE9D520D11CA2CBB /* Products */, - 2D91751A09BA90380026E9FF /* Info-StellaOSX__Upgraded_.plist */, - 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */, + DC419D81108E10A3006E8687 /* Info-StellaOSX.plist */, ); name = "«PROJECTNAMEASXML»"; sourceTree = ""; @@ -1436,8 +1434,8 @@ 2D91747009BA90380026E9FF /* Credits.html in Resources */, 2D91747109BA90380026E9FF /* ../../docs in Resources */, 2D91747209BA90380026E9FF /* AboutBox.nib in Resources */, - 2D91753809BA91BC0026E9FF /* StellaOSX.xcconfig in Resources */, 2DEFB40C09C3386F00754289 /* Cart.icns in Resources */, + DC419D82108E10A3006E8687 /* Info-StellaOSX.plist in Resources */, ); runOnlyForDeploymentPostprocessing = 0; }; @@ -1643,7 +1641,6 @@ /* Begin XCBuildConfiguration section */ 2D91751709BA90380026E9FF /* Development */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */; buildSettings = { FRAMEWORK_SEARCH_PATHS = ( ., @@ -1702,7 +1699,6 @@ }; 2D91751809BA90380026E9FF /* Deployment */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */; buildSettings = { FRAMEWORK_SEARCH_PATHS = ( ., @@ -1827,7 +1823,6 @@ }; 2D91752309BA903B0026E9FF /* Deployment */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 2D91753709BA91BC0026E9FF /* StellaOSX.xcconfig */; buildSettings = { ARCHS = "$(ARCHS_STANDARD_32_BIT)"; FRAMEWORK_SEARCH_PATHS = (