Standalone bundle for OSX (w/ dependencies!)

This commit is contained in:
Pavel Puchkin 2015-03-10 19:29:13 +02:00 committed by Loic Blot
parent 7685969274
commit ca5df44edb
5 changed files with 48 additions and 52 deletions

@ -41,7 +41,7 @@ else()
endif() endif()
set(BUILD_CLIENT 1 CACHE BOOL "Build client") set(BUILD_CLIENT 1 CACHE BOOL "Build client")
if(WIN32) if(WIN32 OR APPLE)
set(BUILD_SERVER 0 CACHE BOOL "Build server") set(BUILD_SERVER 0 CACHE BOOL "Build server")
else() else()
set(BUILD_SERVER 1 CACHE BOOL "Build server") set(BUILD_SERVER 1 CACHE BOOL "Build server")
@ -72,11 +72,13 @@ if(WIN32)
set(EXAMPLE_CONF_DIR ".") set(EXAMPLE_CONF_DIR ".")
set(LOCALEDIR "locale") set(LOCALEDIR "locale")
elseif(APPLE) elseif(APPLE)
set(SHAREDIR ".") set(BUNDLE_NAME ${PROJECT_NAME}.app)
set(BINDIR ".") set(BUNDLE_PATH "${BUNDLE_NAME}")
set(DOCDIR "./doc/${PROJECT_NAME}") set(BINDIR ${BUNDLE_NAME}/Contents/MacOS)
set(SHAREDIR ${BUNDLE_NAME}/Contents/Resources)
set(DOCDIR "${SHAREDIR}/${PROJECT_NAME}")
set(EXAMPLE_CONF_DIR ${DOCDIR}) set(EXAMPLE_CONF_DIR ${DOCDIR})
set(LOCALEDIR "locale") set(LOCALEDIR "${SHAREDIR}/locale")
elseif(UNIX) # Linux, BSD etc elseif(UNIX) # Linux, BSD etc
if(RUN_IN_PLACE) if(RUN_IN_PLACE)
set(SHAREDIR ".") set(SHAREDIR ".")
@ -176,6 +178,11 @@ if(UNIX AND NOT APPLE)
install(FILES "misc/minetest-icon.svg" DESTINATION "${ICONDIR}/hicolor/scalable/apps") install(FILES "misc/minetest-icon.svg" DESTINATION "${ICONDIR}/hicolor/scalable/apps")
endif() endif()
if(APPLE)
install(FILES "misc/minetest-icon.icns" DESTINATION "${SHAREDIR}")
install(FILES "misc/Info.plist" DESTINATION "${BUNDLE_PATH}/Contents")
endif()
# #
# Subdirectories # Subdirectories
# Be sure to add all relevant definitions above this # Be sure to add all relevant definitions above this
@ -193,15 +200,6 @@ set(CPACK_PACKAGE_VENDOR "celeron55")
set(CPACK_PACKAGE_CONTACT "Perttu Ahola <celeron55@gmail.com>") set(CPACK_PACKAGE_CONTACT "Perttu Ahola <celeron55@gmail.com>")
if(WIN32) if(WIN32)
# For some reason these aren't copied otherwise
# NOTE: For some reason now it seems to work without these
#if(BUILD_CLIENT)
# install(FILES bin/minetest.exe DESTINATION bin)
#endif()
#if(BUILD_SERVER)
# install(FILES bin/minetestserver.exe DESTINATION bin)
#endif()
if(CMAKE_SIZEOF_VOID_P EQUAL 8) if(CMAKE_SIZEOF_VOID_P EQUAL 8)
set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-win64") set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-win64")
else(CMAKE_SIZEOF_VOID_P EQUAL 8) else(CMAKE_SIZEOF_VOID_P EQUAL 8)
@ -209,16 +207,10 @@ if(WIN32)
endif(CMAKE_SIZEOF_VOID_P EQUAL 8) endif(CMAKE_SIZEOF_VOID_P EQUAL 8)
set(CPACK_GENERATOR ZIP) set(CPACK_GENERATOR ZIP)
# This might be needed for some installer
#set(CPACK_PACKAGE_EXECUTABLES bin/minetest.exe "Minetest" bin/minetestserver.exe "Minetest Server")
elseif(APPLE) elseif(APPLE)
set(CPACK_INCLUDE_TOPLEVEL_DIRECTORY 0)
set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-osx") set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-osx")
set(CPACK_PACKAGE_ICON ${CMAKE_CURRENT_SOURCE_DIR}/misc/minetest-icon.icns) set(CPACK_GENERATOR ZIP)
set(CPACK_BUNDLE_NAME ${PROJECT_NAME})
set(CPACK_BUNDLE_ICON ${CPACK_PACKAGE_ICON})
set(CPACK_BUNDLE_PLIST ${CMAKE_CURRENT_SOURCE_DIR}/misc/Info.plist)
set(CPACK_GENERATOR "Bundle")
else() else()
set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-linux") set(CPACK_PACKAGE_FILE_NAME "${PROJECT_NAME}-${VERSION_STRING}-linux")
set(CPACK_GENERATOR TGZ) set(CPACK_GENERATOR TGZ)

@ -1,4 +1,4 @@
Minetest Minetest
======== ========
An InfiniMiner/Minecraft inspired game. An InfiniMiner/Minecraft inspired game.
@ -78,9 +78,9 @@ $share = /usr/share/minetest
$user = ~/.minetest $user = ~/.minetest
OS X: OS X:
$bin = ? $bin = Contents/MacOS
$share = ? $share = Contents/Resources
$user = ~/Library/Application Support/minetest $user = Contents/User OR ~/Library/Application Support/minetest
World directory World directory
---------------- ----------------

@ -5,9 +5,9 @@
<key>CFBundleDevelopmentRegion</key> <key>CFBundleDevelopmentRegion</key>
<string>English</string> <string>English</string>
<key>CFBundleExecutable</key> <key>CFBundleExecutable</key>
<string>../Resources/minetest</string> <string>minetest</string>
<key>CFBundleIconFile</key> <key>CFBundleIconFile</key>
<string>minetest.icns</string> <string>minetest-icon.icns</string>
<key>CFBundleIdentifier</key> <key>CFBundleIdentifier</key>
<string>net.minetest.minetest</string> <string>net.minetest.minetest</string>
</dict> </dict>

@ -737,7 +737,20 @@ if(WIN32)
endif() endif()
if(BUILD_CLIENT) if(BUILD_CLIENT)
install(TARGETS ${PROJECT_NAME} DESTINATION ${BINDIR}) install(TARGETS ${PROJECT_NAME}
RUNTIME DESTINATION ${BINDIR}
LIBRARY DESTINATION ${BINDIR}
ARCHIVE DESTINATION ${BINDIR}
BUNDLE DESTINATION .
)
if(APPLE)
install(CODE "
set(BU_CHMOD_BUNDLE_ITEMS ON)
include(BundleUtilities)
fixup_bundle(\"\${CMAKE_INSTALL_PREFIX}/${BUNDLE_PATH}\" \"\" \"\${CMAKE_INSTALL_PREFIX}/${BINDIR}\")
" COMPONENT Runtime)
endif()
if(USE_GETTEXT) if(USE_GETTEXT)
foreach(LOCALE ${GETTEXT_AVAILABLE_LOCALES}) foreach(LOCALE ${GETTEXT_AVAILABLE_LOCALES})

@ -387,16 +387,16 @@ void initializePaths()
*/ */
#elif defined(__APPLE__) #elif defined(__APPLE__)
//https://developer.apple.com/library/mac/#documentation/Darwin/Reference/ManPages/man3/dyld.3.html CFBundleRef main_bundle = CFBundleGetMainBundle();
//TODO: Test this code CFURLRef resources_url = CFBundleCopyResourcesDirectoryURL(main_bundle);
char buf[BUFSIZ]; char path[PATH_MAX];
uint32_t len = sizeof(buf); if (CFURLGetFileSystemRepresentation(resources_url, TRUE, (UInt8 *)path, PATH_MAX)) {
FATAL_ERROR_IF(_NSGetExecutablePath(buf, &len) == -1, ""); path_share = std::string(path);
path_user = std::string(path) + "/../User";
pathRemoveFile(buf, '/'); } else {
dstream << "WARNING: Could not determine bundle resource path" << std::endl;
path_share = std::string(buf) + "/.."; }
path_user = std::string(buf) + "/.."; CFRelease(resources_url);
/* /*
FreeBSD FreeBSD
@ -523,24 +523,15 @@ void initializePaths()
*/ */
#elif defined(__APPLE__) #elif defined(__APPLE__)
// Code based on
// http://stackoverflow.com/questions/516200/relative-paths-not-working-in-xcode-c
CFBundleRef main_bundle = CFBundleGetMainBundle(); CFBundleRef main_bundle = CFBundleGetMainBundle();
CFURLRef resources_url = CFBundleCopyResourcesDirectoryURL(main_bundle); CFURLRef resources_url = CFBundleCopyResourcesDirectoryURL(main_bundle);
char path[PATH_MAX]; char path[PATH_MAX];
if(CFURLGetFileSystemRepresentation(resources_url, TRUE, (UInt8 *)path, PATH_MAX)) if (CFURLGetFileSystemRepresentation(resources_url, TRUE, (UInt8 *)path, PATH_MAX)) {
{ path_share = std::string(path);
dstream<<"Bundle resource path: "<<path<<std::endl; } else {
//chdir(path);
path_share = std::string(path) + DIR_DELIM + STATIC_SHAREDIR;
}
else
{
// error!
dstream << "WARNING: Could not determine bundle resource path" << std::endl; dstream << "WARNING: Could not determine bundle resource path" << std::endl;
} }
CFRelease(resources_url); CFRelease(resources_url);
path_user = std::string(getenv("HOME")) + "/Library/Application Support/" + PROJECT_NAME; path_user = std::string(getenv("HOME")) + "/Library/Application Support/" + PROJECT_NAME;
#else // FreeBSD, and probably many other POSIX-like systems. #else // FreeBSD, and probably many other POSIX-like systems.