Actualizado Makefile macos_release

This commit is contained in:
2022-11-11 13:50:25 +01:00
parent f2869049e0
commit 44ff0fed91
3 changed files with 38 additions and 24 deletions

3
.gitignore vendored
View File

@@ -5,3 +5,6 @@ thumbs.db
*.exe *.exe
*_macos *_macos
*_linux *_linux
*.dmg
*.tar.gz
*.zip

View File

@@ -1,15 +1,23 @@
executable = jaildoctors_dilemma executable = jaildoctors_dilemma
source = source/*.cpp source/common/*.cpp source = source/*.cpp source/common/*.cpp
appName = JailDoctor's Dilemma appName = JailDoctor's Dilemma
macosReleaseFolder = ../jaildoctors_dilemma_release releaseFolder = jdd_release
linuxReleaseFolder = jdd_release_linux
windows: windows:
@echo off @echo off
if not exist data\config (mkdir data\config) if exist data\config (Remove-Item data\config -Recurse -Force)
if not exist data\config (New-Item data\config -ItemType Directory)
g++ $(source) -std=c++11 -Wall -Os -lmingw32 -lSDL2main -lSDL2 -ffunction-sections -fdata-sections -Wl,--gc-sections -static-libstdc++ -Wl,-subsystem,windows -o $(executable).exe g++ $(source) -std=c++11 -Wall -Os -lmingw32 -lSDL2main -lSDL2 -ffunction-sections -fdata-sections -Wl,--gc-sections -static-libstdc++ -Wl,-subsystem,windows -o $(executable).exe
strip -s -R .comment -R .gnu.version $(executable).exe --strip-unneeded strip -s -R .comment -R .gnu.version $(executable).exe --strip-unneeded
windows_release:
@echo off
# Remove data
if exist data\config (Remove-Item data\config -Recurse -Force)
if not exist data\config (New-Item data\config -ItemType Directory)
g++ $(source) -D RELEASE -std=c++11 -Wall -Os -lmingw32 -lSDL2main -lSDL2 -ffunction-sections -fdata-sections -Wl,--gc-sections -static-libstdc++ -Wl,-subsystem,windows -o $(executable).exe
strip -s -R .comment -R .gnu.version $(executable).exe --strip-unneeded
macos: macos:
rm -rdf data/config rm -rdf data/config
mkdir -p data/config mkdir -p data/config
@@ -18,24 +26,30 @@ macos:
macos_release: macos_release:
# Remove data # Remove data
rm -rdf data/config rm -rdf data/config
rm -rdf "$(macosReleaseFolder)/$(appName).app" rm -rdf "$(releaseFolder)
# Create folders # Create folders
mkdir -p data/config mkdir -p data/config
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/Frameworks" mkdir -p "$(releaseFolder)/$(appName).app/Contents/Frameworks"
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/MacOS" mkdir -p "$(releaseFolder)/$(appName).app/Contents/MacOS"
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/Resources" mkdir -p "$(releaseFolder)/$(appName).app/Contents/Resources"
mkdir -p Frameworks mkdir -p Frameworks
# Copy folders # Copy folders
cp -R data "$(macosReleaseFolder)/$(appName).app/Contents/Resources" cp -R data "$(releaseFolder)/$(appName).app/Contents/Resources"
cp -R /Library/Frameworks/SDL2.framework "$(macosReleaseFolder)/$(appName).app/Contents/Frameworks" cp -R /Library/Frameworks/SDL2.framework "$(releaseFolder)/$(appName).app/Contents/Frameworks"
cp -R /Library/Frameworks/SDL2.framework Frameworks cp -R /Library/Frameworks/SDL2.framework Frameworks
# Copy files # Copy files
cp release/*.icns "$(macosReleaseFolder)/$(appName).app/Contents/Resources" cp release/*.icns "$(releaseFolder)/$(appName).app/Contents/Resources"
cp release/Info.plist "$(macosReleaseFolder)/$(appName).app/Contents" cp release/Info.plist "$(releaseFolder)/$(appName).app/Contents"
# Build # Build
clang++ $(source) -std=c++11 -Wall -Os -framework SDL2 -F ./Frameworks -ffunction-sections -fdata-sections -o "$(macosReleaseFolder)/$(appName).app/Contents/MacOS/$(executable)" -rpath @executable_path/../Frameworks/ -target x86_64-apple-macos10.12 clang++ $(source) -D RELEASE -D MACOS_BUNDLE -std=c++11 -Wall -Os -framework SDL2 -F ./Frameworks -ffunction-sections -fdata-sections -o "$(releaseFolder)/$(appName).app/Contents/MacOS/$(executable)" -rpath @executable_path/../Frameworks/ -target x86_64-apple-macos10.12
# Remove folders # Remove folders
rm -rdf Frameworks rm -rdf Frameworks
# Build DMG
hdiutil create tmp.dmg -ov -volname "$(appName)" -fs HFS+ -srcfolder "$(releaseFolder)"
hdiutil convert tmp.dmg -format UDZO -o "$(appName).dmg"
# Remove data
rm -rdf "$(releaseFolder)"
rm tmp.dmg
linux: linux:
rm -rdf data/config rm -rdf data/config
@@ -46,18 +60,18 @@ linux:
linux_release: linux_release:
# Remove data # Remove data
rm -rdf data/config rm -rdf data/config
rm -rdf $(linuxReleaseFolder) rm -rdf $(releaseFolder)
# Create folders # Create folders
mkdir -p data/config mkdir -p data/config
mkdir -p $(linuxReleaseFolder) mkdir -p $(releaseFolder)
# Copy data # Copy data
cp -R data $(linuxReleaseFolder) cp -R data $(releaseFolder)
cp LICENSE $(linuxReleaseFolder) cp LICENSE $(releaseFolder)
cp README.md $(linuxReleaseFolder) cp README.md $(releaseFolder)
# Build # Build
g++ $(source) -D RELEASE -std=c++11 -Wall -Os -lSDL2 -ffunction-sections -fdata-sections -Wl,--gc-sections -o $(linuxReleaseFolder)/$(executable) g++ $(source) -D RELEASE -std=c++11 -Wall -Os -lSDL2 -ffunction-sections -fdata-sections -Wl,--gc-sections -o $(releaseFolder)/$(executable)
strip -s -R .comment -R .gnu.version $(executable)_linux --strip-unneeded strip -s -R .comment -R .gnu.version $(executable)_linux --strip-unneeded
# Pack files # Pack files
cd $(linuxReleaseFolder) && tar -czvf ../$(executable).tar.gz * cd $(releaseFolder) && tar -czvf ../$(executable).tar.gz *
# Remove data # Remove data
rm -rdf $(linuxReleaseFolder) rm -rdf $(releaseFolder)

View File

@@ -7,9 +7,6 @@
#ifndef CONST_H #ifndef CONST_H
#define CONST_H #define CONST_H
//#define MACOS_BUNDLE
//#define RELEASE
// Textos // Textos
#define WINDOW_CAPTION "JailDoctor's Dilemma" #define WINDOW_CAPTION "JailDoctor's Dilemma"
#define TEXT_COPYRIGHT "@2022 JailDesigner" #define TEXT_COPYRIGHT "@2022 JailDesigner"