diff --git a/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj b/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj index 4943f0682..761fa642a 100644 --- a/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj +++ b/Apple/MultiCraft/MultiCraft.xcodeproj/project.pbxproj @@ -147,6 +147,7 @@ 84BE974528CA129C004E8CEC /* CoreHaptics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 84BE974428CA129C004E8CEC /* CoreHaptics.framework */; }; 84C2AB5328DA7776001968EE /* libpng.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 84C2AB5228DA7770001968EE /* libpng.a */; }; 84DE114525D55D2400EDB067 /* event.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 84A1F9A8252E616A00000717 /* event.cpp */; }; + 84E33D882A7BBEE900609F77 /* wrapper.m in Sources */ = {isa = PBXBuildFile; fileRef = 84E33D872A7BBEE900609F77 /* wrapper.m */; }; 84F20D5925D52790009562A9 /* static_text.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 84F20D5525D52790009562A9 /* static_text.cpp */; }; 84F20D5A25D52790009562A9 /* CGUITTFont.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 84F20D5725D52790009562A9 /* CGUITTFont.cpp */; }; 84F20DA225D527C5009562A9 /* serverpackethandler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 84F20D9325D527C4009562A9 /* serverpackethandler.cpp */; }; @@ -598,6 +599,8 @@ 84BE974228CA1291004E8CEC /* GameController.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = GameController.framework; path = System/Library/Frameworks/GameController.framework; sourceTree = SDKROOT; }; 84BE974428CA129C004E8CEC /* CoreHaptics.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreHaptics.framework; path = System/Library/Frameworks/CoreHaptics.framework; sourceTree = SDKROOT; }; 84C2AB5228DA7770001968EE /* libpng.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libpng.a; path = ../deps/libpng/libpng.a; sourceTree = ""; }; + 84E33D862A7BBEC100609F77 /* wrapper.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = wrapper.h; sourceTree = ""; }; + 84E33D872A7BBEE900609F77 /* wrapper.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = wrapper.m; sourceTree = ""; }; 84EEE5E62782728E00F61929 /* libintl.a */ = {isa = PBXFileReference; lastKnownFileType = archive.ar; name = libintl.a; path = ../deps/gettext/libintl.a; sourceTree = ""; }; 84F20D5425D52790009562A9 /* irrUString.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = irrUString.h; path = ../../../src/irrlicht_changes/irrUString.h; sourceTree = ""; }; 84F20D5525D52790009562A9 /* static_text.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = static_text.cpp; path = ../../../src/irrlicht_changes/static_text.cpp; sourceTree = ""; }; @@ -1108,6 +1111,7 @@ 845856B724B1322D0040BA4F /* Info.plist */, 845856BA24B1322D0040BA4F /* MultiCraft.entitlements */, 848ADEF627BD68AE001C60F3 /* Localizable.strings */, + 84E33D852A7BBEA200609F77 /* Supporting Files */, 84585CD524B138F50040BA4F /* src */, ); path = MultiCraft; @@ -1670,6 +1674,15 @@ name = lua_api; sourceTree = ""; }; + 84E33D852A7BBEA200609F77 /* Supporting Files */ = { + isa = PBXGroup; + children = ( + 84E33D862A7BBEC100609F77 /* wrapper.h */, + 84E33D872A7BBEE900609F77 /* wrapper.m */, + ); + name = "Supporting Files"; + sourceTree = ""; + }; 84F20D5B25D5279D009562A9 /* mapgen */ = { isa = PBXGroup; children = ( @@ -1738,7 +1751,7 @@ isa = PBXProject; attributes = { BuildIndependentTargetsInParallel = YES; - LastUpgradeCheck = 1250; + LastUpgradeCheck = 1430; ORGANIZATIONNAME = "MultiCraft Studio OÜ"; TargetAttributes = { 845856A824B1322C0040BA4F = { @@ -2022,6 +2035,7 @@ 84F20EA625D528C5009562A9 /* sidebyside.cpp in Sources */, 84F20E8325D52868009562A9 /* metricsbackend.cpp in Sources */, 84135C2425D526D700CA4DCF /* content_mapblock.cpp in Sources */, + 84E33D882A7BBEE900609F77 /* wrapper.m in Sources */, 84F20E3225D5282A009562A9 /* l_nodetimer.cpp in Sources */, 84135B7325D5264B00CA4DCF /* inventorymanager.cpp in Sources */, 84135C1825D526D700CA4DCF /* filecache.cpp in Sources */, @@ -2186,6 +2200,7 @@ isa = XCBuildConfiguration; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = MultiCraft/MultiCraft.entitlements; CODE_SIGN_IDENTITY = "Apple Development"; COMBINE_HIDPI_IMAGES = YES; @@ -2253,6 +2268,7 @@ isa = XCBuildConfiguration; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = MultiCraft/MultiCraft.entitlements; CODE_SIGN_IDENTITY = "Apple Development"; COMBINE_HIDPI_IMAGES = YES; diff --git a/Apple/MultiCraft/MultiCraft/wrapper.h b/Apple/MultiCraft/MultiCraft/wrapper.h new file mode 100644 index 000000000..f82c4e963 --- /dev/null +++ b/Apple/MultiCraft/MultiCraft/wrapper.h @@ -0,0 +1,11 @@ +#pragma once + +#ifdef __cplusplus +extern "C" { +#endif + +const char *get_secret_key(const char *key); + +#ifdef __cplusplus +} +#endif diff --git a/Apple/MultiCraft/MultiCraft/wrapper.m b/Apple/MultiCraft/MultiCraft/wrapper.m new file mode 100644 index 000000000..d09aec1ec --- /dev/null +++ b/Apple/MultiCraft/MultiCraft/wrapper.m @@ -0,0 +1,8 @@ +@import Foundation; + +#import "wrapper.h" + +const char *get_secret_key(const char *key) +{ + return "dummy"; +} diff --git a/Apple/scripts/SDL2.sh b/Apple/scripts/SDL2.sh index 15cf0972a..9c47bebf2 100755 --- a/Apple/scripts/SDL2.sh +++ b/Apple/scripts/SDL2.sh @@ -1,15 +1,15 @@ #!/bin/bash -e -SDL2_VERSION=2.28.0 +SDL2_VERSION=release-2.28.2 . scripts/sdk.sh mkdir -p deps; cd deps if [ ! -d SDL2-src ]; then - wget https://github.com/libsdl-org/SDL/archive/release-$SDL2_VERSION.tar.gz - tar -xzvf release-$SDL2_VERSION.tar.gz - mv SDL-release-$SDL2_VERSION SDL2-src - rm release-$SDL2_VERSION.tar.gz + wget https://github.com/libsdl-org/SDL/archive/$SDL2_VERSION.tar.gz + tar -xzf $SDL2_VERSION.tar.gz + mv SDL-$SDL2_VERSION SDL2-src + rm $SDL2_VERSION.tar.gz # Disable some features that are not needed sed -i '' 's/#define SDL_AUDIO_DRIVER_COREAUDIO 1/#define SDL_AUDIO_DRIVER_COREAUDIO 0/g' SDL2-src/include/SDL_config_macosx.h sed -i '' 's/#define SDL_AUDIO_DRIVER_DISK 1/#define SDL_AUDIO_DRIVER_DISK 0/g' SDL2-src/include/SDL_config_macosx.h diff --git a/Apple/scripts/freetype.sh b/Apple/scripts/freetype.sh index 386e5a77a..a3e7e60bd 100755 --- a/Apple/scripts/freetype.sh +++ b/Apple/scripts/freetype.sh @@ -7,7 +7,7 @@ mkdir -p deps; cd deps if [ ! -d freetype-src ]; then wget http://download.savannah.gnu.org/releases/freetype/freetype-$FREETYPE_VERSION.tar.gz - tar -xzvf freetype-$FREETYPE_VERSION.tar.gz + tar -xzf freetype-$FREETYPE_VERSION.tar.gz mv freetype-$FREETYPE_VERSION freetype-src rm freetype-$FREETYPE_VERSION.tar.gz mkdir freetype-src/build diff --git a/Apple/scripts/gettext.sh b/Apple/scripts/gettext.sh index 802c6b29c..061a28833 100755 --- a/Apple/scripts/gettext.sh +++ b/Apple/scripts/gettext.sh @@ -7,7 +7,7 @@ mkdir -p deps; cd deps if [ ! -d gettext-src ]; then wget https://ftp.gnu.org/pub/gnu/gettext/gettext-$GETTEXT_VERSION.tar.gz - tar -xzvf gettext-$GETTEXT_VERSION.tar.gz + tar -xzf gettext-$GETTEXT_VERSION.tar.gz mv gettext-$GETTEXT_VERSION gettext-src rm gettext-$GETTEXT_VERSION.tar.gz fi diff --git a/Apple/scripts/libjpeg.sh b/Apple/scripts/libjpeg.sh index acc20a498..faec12a4e 100755 --- a/Apple/scripts/libjpeg.sh +++ b/Apple/scripts/libjpeg.sh @@ -1,13 +1,13 @@ #!/bin/bash -e -JPEG_VERSION=2.1.5.1 +JPEG_VERSION=3.0.0 . scripts/sdk.sh mkdir -p deps; cd deps if [ ! -d libjpeg-src ]; then wget https://download.sourceforge.net/libjpeg-turbo/libjpeg-turbo-$JPEG_VERSION.tar.gz - tar -xzvf libjpeg-turbo-$JPEG_VERSION.tar.gz + tar -xzf libjpeg-turbo-$JPEG_VERSION.tar.gz mv libjpeg-turbo-$JPEG_VERSION libjpeg-src rm libjpeg-turbo-$JPEG_VERSION.tar.gz fi diff --git a/Apple/scripts/libpng.sh b/Apple/scripts/libpng.sh index 6c5188a62..992476335 100755 --- a/Apple/scripts/libpng.sh +++ b/Apple/scripts/libpng.sh @@ -7,7 +7,7 @@ mkdir -p deps; cd deps if [ ! -d libpng-src ]; then wget https://download.sourceforge.net/libpng/libpng-$PNG_VERSION.tar.gz - tar -xzvf libpng-$PNG_VERSION.tar.gz + tar -xzf libpng-$PNG_VERSION.tar.gz mv libpng-$PNG_VERSION libpng-src rm libpng-$PNG_VERSION.tar.gz fi diff --git a/Apple/scripts/sdk.sh b/Apple/scripts/sdk.sh index 19de3b018..de9e597f5 100755 --- a/Apple/scripts/sdk.sh +++ b/Apple/scripts/sdk.sh @@ -1,14 +1,12 @@ #!/bin/bash -e # This file sets the appropriate compiler and flags for compiling for macOS -sdk=macosx export OSX_OSVER=10.11 export OSX_ARCHES="x86_64 arm64" export OSX_ARCHITECTURES="x86_64;arm64" export OSX_ARCH="-arch x86_64 -arch arm64" -export OSX_COMPILER=$(xcrun --sdk $sdk --find clang) -export OSX_CC=$OSX_COMPILER -export OSX_CXX=$OSX_COMPILER -export OSX_FLAGS="-isysroot $(xcrun --sdk $sdk --show-sdk-path) -mmacosx-version-min=$OSX_OSVER -fdata-sections -ffunction-sections -Ofast" +export OSX_CC=$(xcrun --sdk macosx --find clang) +export OSX_CXX=$(xcrun --sdk macosx --find clang++) +export OSX_FLAGS="-isysroot $(xcrun --sdk macosx --show-sdk-path) -mmacosx-version-min=$OSX_OSVER -fdata-sections -ffunction-sections -Ofast" diff --git a/src/content/subgames.cpp b/src/content/subgames.cpp index 840ed4796..97a3964e0 100644 --- a/src/content/subgames.cpp +++ b/src/content/subgames.cpp @@ -82,6 +82,13 @@ SubgameSpec findSubgame(const std::string &id) find_paths.emplace_back(path, false); } +#ifdef __APPLE__ + std::string path = porting::path_cache + DIR_DELIM + "games" + DIR_DELIM + id; + find_paths.emplace_back(path, false); + path.append("_game"); + find_paths.emplace_back(path, false); +#endif + std::string game_base = DIR_DELIM; game_base = game_base.append("games").append(DIR_DELIM).append(id); std::string game_suffixed = game_base + "_game"; @@ -177,6 +184,9 @@ std::set getAvailableGameIds() std::set gamespaths; gamespaths.insert(porting::path_share + DIR_DELIM + "games"); gamespaths.insert(porting::path_user + DIR_DELIM + "games"); +#ifdef __APPLE__ + gamespaths.insert(porting::path_cache + DIR_DELIM + "games"); +#endif Strfnd search_paths(getSubgamePathEnv()); diff --git a/src/porting.cpp b/src/porting.cpp index 64fcc26df..28627f838 100644 --- a/src/porting.cpp +++ b/src/porting.cpp @@ -742,6 +742,13 @@ bool open_url(const std::string &url) return open_uri(url); } +#if defined(__APPLE__) +std::string getSecretKey(const std::string &key) +{ + return std::string(get_secret_key(key.c_str())); +} +#endif + bool open_directory(const std::string &path) { if (!fs::IsDir(path)) { diff --git a/src/porting.h b/src/porting.h index 4e34452c3..bf97c2ad7 100644 --- a/src/porting.h +++ b/src/porting.h @@ -126,6 +126,10 @@ with this program; if not, write to the Free Software Foundation, Inc., #endif #endif +#if defined(__APPLE__) + #include "wrapper.h" +#endif + namespace porting { @@ -353,6 +357,11 @@ bool open_url(const std::string &url); * @param path Path to directory * @return true on success, false on failure */ + +#if defined(__APPLE__) +std::string getSecretKey(const std::string &key); +#endif + bool open_directory(const std::string &path); } // namespace porting diff --git a/src/script/lua_api/l_util.cpp b/src/script/lua_api/l_util.cpp index 2ae653b5c..41d7f9605 100644 --- a/src/script/lua_api/l_util.cpp +++ b/src/script/lua_api/l_util.cpp @@ -509,12 +509,12 @@ int ModApiUtil::l_upgrade(lua_State *L) int ModApiUtil::l_get_secret_key(lua_State *L) { NO_MAP_LOCK_REQUIRED; -#if defined(__ANDROID__) || defined(__IOS__) +#if defined(__ANDROID__) || defined(__APPLE__) const std::string secret_name = luaL_checkstring(L, 1); const std::string res = porting::getSecretKey(secret_name); lua_pushlstring(L, res.c_str(), res.size()); #else - // Not implemented on desktop platforms + // Not implemented on other platforms lua_pushstring(L, ""); #endif