Skip to content

Commit b0b1e07

Browse files
authored
Merge pull request #9 from warmenhoven/warmenhoven/pr/apple
Add osx, ios, tvos builds
2 parents a60fb21 + ddde61e commit b0b1e07

File tree

5 files changed

+46
-27
lines changed

5 files changed

+46
-27
lines changed

.gitlab-ci.yml

+24-24
Original file line numberDiff line numberDiff line change
@@ -31,21 +31,21 @@ include:
3131
# file: '/linux-i686.yml'
3232

3333
# MacOS 64-bit
34-
#- project: 'libretro-infrastructure/ci-templates'
35-
# file: '/osx-x64.yml'
34+
- project: 'libretro-infrastructure/ci-templates'
35+
file: '/osx-x64.yml'
3636

3737
# MacOS ARM 64-bit
38-
#- project: 'libretro-infrastructure/ci-templates'
39-
# file: '/osx-arm64.yml'
38+
- project: 'libretro-infrastructure/ci-templates'
39+
file: '/osx-arm64.yml'
4040

4141
################################## CELLULAR ################################
4242
# Android
4343
#- project: 'libretro-infrastructure/ci-templates'
4444
# file: '/android-jni.yml'
4545

4646
# iOS
47-
#- project: 'libretro-infrastructure/ci-templates'
48-
# file: '/ios-arm64.yml'
47+
- project: 'libretro-infrastructure/ci-templates'
48+
file: '/ios-arm64.yml'
4949

5050
# iOS (armv7)
5151
#- project: 'libretro-infrastructure/ci-templates'
@@ -77,8 +77,8 @@ include:
7777
# file: '/libnx-static.yml'
7878

7979
# tvOS (AppleTV)
80-
#- project: 'libretro-infrastructure/ci-templates'
81-
# file: '/tvos-arm64.yml'
80+
- project: 'libretro-infrastructure/ci-templates'
81+
file: '/tvos-arm64.yml'
8282

8383
# OpenDingux
8484
#- project: 'libretro-infrastructure/ci-templates'
@@ -129,16 +129,16 @@ libretro-build-linux-x64:
129129
# - .core-defs
130130

131131
# MacOS 64-bit
132-
#libretro-build-osx-x64:
133-
# extends:
134-
# - .libretro-osx-x64-make-default
135-
# - .core-defs
132+
libretro-build-osx-x64:
133+
extends:
134+
- .libretro-osx-x64-make-default
135+
- .core-defs
136136

137137
# MacOS ARM 64-bit
138-
#libretro-build-osx-arm64:
139-
# extends:
140-
# - .libretro-osx-arm64-make-default
141-
# - .core-defs
138+
libretro-build-osx-arm64:
139+
extends:
140+
- .libretro-osx-arm64-make-default
141+
- .core-defs
142142

143143
################################### CELLULAR #################################
144144
# Android ARMv7a
@@ -166,10 +166,10 @@ libretro-build-linux-x64:
166166
# - .core-defs
167167

168168
# iOS
169-
#libretro-build-ios-arm64:
170-
# extends:
171-
# - .libretro-ios-arm64-make-default
172-
# - .core-defs
169+
libretro-build-ios-arm64:
170+
extends:
171+
- .libretro-ios-arm64-make-default
172+
- .core-defs
173173

174174
# iOS (armv7) [iOS 9 and up]
175175
#libretro-build-ios9:
@@ -178,10 +178,10 @@ libretro-build-linux-x64:
178178
# - .core-defs
179179

180180
# tvOS
181-
#libretro-build-tvos-arm64:
182-
# extends:
183-
# - .libretro-tvos-arm64-make-default
184-
# - .core-defs
181+
libretro-build-tvos-arm64:
182+
extends:
183+
- .libretro-tvos-arm64-make-default
184+
- .core-defs
185185

186186
################################### CONSOLES #################################
187187
# PlayStation Vita

src/libretro/Makefile

+13-2
Original file line numberDiff line numberDiff line change
@@ -77,6 +77,8 @@ else ifeq ($(platform), osx)
7777
OSX_LT_MAVERICKS = `(( $(OSXVER) <= 9)) && echo "YES"`
7878
ifeq ($(OSX_LT_MAVERICKS),"YES")
7979
MINVERSION = -mmacosx-version-min=10.5
80+
else
81+
MINVERSION = -mmacosx-version-min=10.12
8082
endif
8183
fpic += $(MINVERSION)
8284

@@ -88,8 +90,8 @@ else ifeq ($(platform), osx)
8890
LDFLAGS += $(TARGET_RULE)
8991
endif
9092

91-
CFLAGS += $(ARCHFLAGS)
92-
CXXFLAGS += $(ARCHFLAGS)
93+
CFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY
94+
CXXFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY
9395
LDFLAGS += $(ARCHFLAGS)
9496

9597
# iOS
@@ -120,6 +122,10 @@ else
120122
endif
121123
PLATFORM_DEFINES := $(MINVERSION)
122124

125+
CFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY -DIOS
126+
CXXFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY -DIOS
127+
LDFLAGS += $(ARCHFLAGS)
128+
123129
# tvOS
124130
else ifeq ($(platform), tvos-arm64)
125131
TARGET := $(TARGET_NAME)_libretro_tvos.dylib
@@ -134,6 +140,11 @@ else ifeq ($(platform), tvos-arm64)
134140
CC_AS = perl ./tools/gas-preprocessor.pl $(CC)
135141
CXX = c++ -arch arm64 -isysroot $(IOSSDK)
136142

143+
PLATFORM_DEFINES := -mappletvos-version-min=11.0
144+
145+
CFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY -DIOS
146+
CXXFLAGS += $(ARCHFLAGS) -DSYSTEM_HAVE_STRLCPY -DIOS
147+
LDFLAGS += $(ARCHFLAGS)
137148

138149
# Lightweight PS3 Homebrew SDK
139150
else ifneq (,$(filter $(platform), ps3 psl1ght))

src/libretro/Makefile.common

+1-1
Original file line numberDiff line numberDiff line change
@@ -55,7 +55,7 @@ SOURCES_C := \
5555
$(CORE_DIR)/shared/c/path.c \
5656

5757

58-
ifneq (,$(findstring osx,$(platform)))
58+
ifneq (,$(filter osx ios-arm64 tvos-arm64,$(platform)))
5959
SOURCES_CPP += \
6060
$(CORE_DIR)/shared/c/system_osx.cpp \
6161

src/shared/c/system_osx.cpp

+7
Original file line numberDiff line numberDiff line change
@@ -20,14 +20,21 @@
2020
#include <vector>
2121
#include <string>
2222
#include <mach/mach_time.h>
23+
#include <pthread.h>
24+
#ifndef IOS
2325
#include <sys/proc_info.h>
26+
#else
27+
#include <TargetConditionals.h>
28+
#endif
2429
//#define THREAD_NAME_SIZE (MAXTHREADNAMESIZE)
2530

2631
//////////////////////////////////////////////////////////////////////////
2732
//////////////////////////////////////////////////////////////////////////
2833

2934
/* If true, use `atos' to get higher-quality backtrace symbols. */
35+
#ifndef IOS
3036
#define USE_ATOS 1
37+
#endif
3138

3239
//////////////////////////////////////////////////////////////////////////
3340
//////////////////////////////////////////////////////////////////////////

src/shared/h/shared/system.h

+1
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@
1313
#include <stddef.h>
1414
#include <stdarg.h>
1515
#include <stdlib.h>
16+
#include <errno.h>
1617
#ifdef _MSC_VER
1718
// This is the relevant part of intrin.h. Don't #include it; it is somewhat slow
1819
// to parse (for whatever reason) and it saves a few seconds in a full rebuild

0 commit comments

Comments
 (0)