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
*_macos
*_linux
*.dmg
*.tar.gz
*.zip

View File

@@ -1,15 +1,23 @@
executable = jaildoctors_dilemma
source = source/*.cpp source/common/*.cpp
appName = JailDoctor's Dilemma
macosReleaseFolder = ../jaildoctors_dilemma_release
linuxReleaseFolder = jdd_release_linux
releaseFolder = jdd_release
windows:
@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
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:
rm -rdf data/config
mkdir -p data/config
@@ -18,24 +26,30 @@ macos:
macos_release:
# Remove data
rm -rdf data/config
rm -rdf "$(macosReleaseFolder)/$(appName).app"
rm -rdf "$(releaseFolder)
# Create folders
mkdir -p data/config
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/Frameworks"
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/MacOS"
mkdir -p "$(macosReleaseFolder)/$(appName).app/Contents/Resources"
mkdir -p "$(releaseFolder)/$(appName).app/Contents/Frameworks"
mkdir -p "$(releaseFolder)/$(appName).app/Contents/MacOS"
mkdir -p "$(releaseFolder)/$(appName).app/Contents/Resources"
mkdir -p Frameworks
# Copy folders
cp -R data "$(macosReleaseFolder)/$(appName).app/Contents/Resources"
cp -R /Library/Frameworks/SDL2.framework "$(macosReleaseFolder)/$(appName).app/Contents/Frameworks"
cp -R data "$(releaseFolder)/$(appName).app/Contents/Resources"
cp -R /Library/Frameworks/SDL2.framework "$(releaseFolder)/$(appName).app/Contents/Frameworks"
cp -R /Library/Frameworks/SDL2.framework Frameworks
# Copy files
cp release/*.icns "$(macosReleaseFolder)/$(appName).app/Contents/Resources"
cp release/Info.plist "$(macosReleaseFolder)/$(appName).app/Contents"
cp release/*.icns "$(releaseFolder)/$(appName).app/Contents/Resources"
cp release/Info.plist "$(releaseFolder)/$(appName).app/Contents"
# 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
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:
rm -rdf data/config
@@ -46,18 +60,18 @@ linux:
linux_release:
# Remove data
rm -rdf data/config
rm -rdf $(linuxReleaseFolder)
rm -rdf $(releaseFolder)
# Create folders
mkdir -p data/config
mkdir -p $(linuxReleaseFolder)
mkdir -p $(releaseFolder)
# Copy data
cp -R data $(linuxReleaseFolder)
cp LICENSE $(linuxReleaseFolder)
cp README.md $(linuxReleaseFolder)
cp -R data $(releaseFolder)
cp LICENSE $(releaseFolder)
cp README.md $(releaseFolder)
# 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
# Pack files
cd $(linuxReleaseFolder) && tar -czvf ../$(executable).tar.gz *
cd $(releaseFolder) && tar -czvf ../$(executable).tar.gz *
# Remove data
rm -rdf $(linuxReleaseFolder)
rm -rdf $(releaseFolder)

View File

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