Question

I have a problem with a Mac OSX app bundle. If I want to run my app bundle nothing happens (double clicking myApp.app).

I can run the app by executing ./myApp.app/Contents/MacOS/myApp without any problem.

The directory structure:

myApp.app/
    Contents/
        Info.plist
        PkgInfo
        Resources/
        Frameworks/
        MacOS/
            myApp

My Info.plist:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>CFBundleDevelopmentRegion</key>
    <string>en</string>
    <key>CFBundleExecutable</key>
    <string>myApp</string>
    <key>CFBundleIconFile</key>
    <string>icon</string>
    <key>CFBundleIdentifier</key>
    <string>com.whatever.test</string>
    <key>CFBundleInfoDictionaryVersion</key>
    <string>6.0</string>
    <key>CFBundleName</key>
    <string>${PRODUCT_NAME}</string>
    <key>CFBundlePackageType</key>
    <string>APPL</string>
    <key>CFBundleShortVersionString</key>
    <string>1.0.0</string>
    <key>CFBundleSignature</key>
    <string>com.whatever.test</string>
    <key>CFBundleVersion</key>
    <string>1.0.0</string>
    <key>LSMinimumSystemVersion</key>
    <string>${MACOSX_DEPLOYMENT_TARGET}</string>
    <key>NSHumanReadableCopyright</key>
    <string>Copyright © 2014. All rights reserved.</string>
</dict>
</plist>

Edit:

Console.app result:

08.02.14 16:30:45,041 com.apple.launchd.peruser.501[1077]: (com.whatever.test.72544[20350]) Job failed to exec(3) for weird reason: 13
08.02.14 16:30:45,043 Finder[1094]: 8837325: Attempting to SIGCONT to pid #20350 failed, with errno=#3, or the process failed to actually start
08.02.14 16:30:45,046 Dock[1091]: no information back from LS about running process LSASN:{hi=0x0;lo=0x168168}
Was it helpful?

Solution 3

It was a working directory problem. using getcwd while executing "myApp.app" gives /

I fixed it by using the bundle dir instead of getcwd:

#include <CoreFoundation/CoreFoundation.h>

std::string getBundleDir()
{
    CFBundleRef mainBundle = CFBundleGetMainBundle();
    CFURLRef resourcesURL = CFBundleCopyResourcesDirectoryURL(mainBundle);
    char path[PATH_MAX];
    if (!CFURLGetFileSystemRepresentation(resourcesURL, TRUE, (UInt8 *)path, PATH_MAX))
        return "";

    CFRelease(resourcesURL);

    chdir(path);

    return path;
}

OTHER TIPS

I don't think you have your code properly signed, given you're missing a _CodeSignature directory. Thus GateKeeper may be blocking the code from running.

You have two options:

  • Code sign your code.
  • Controlclick the app bundle and then choose Open - it'll bypass the code signature check.

This line:

08.02.14 16:30:45,041 com.apple.launchd.peruser.501[1077]: (com.whatever.test.72544[20350]) Job failed to exec(3) for weird reason: 13

Is leading me to think that you have a Permission Denied problem based on this man page:

https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man2/intro.2.html

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top