Skip to content

Commit 8f56d48

Browse files
committed
Support single arch builds on macOS
1 parent a2162c0 commit 8f56d48

File tree

1 file changed

+11
-9
lines changed

1 file changed

+11
-9
lines changed

make-mac.mk

+11-9
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,8 @@ TOPDIR=$(shell pwd)
55
INCLUDES=-I$(shell pwd)/rustybits/target -isystem $(TOPDIR)/ext -I$(TOPDIR)/ext/prometheus-cpp-lite-1.0/core/include -I$(TOPDIR)/ext-prometheus-cpp-lite-1.0/3rdparty/http-client-lite/include -I$(TOPDIR)/ext/prometheus-cpp-lite-1.0/simpleapi/include
66
DEFS=
77
LIBS=
8-
ARCH_FLAGS=-arch x86_64 -arch arm64
8+
ARCH := x86_64 arm64
9+
ARCH_FLAGS=$(addprefix -arch ,$(ARCH))
910

1011
CODESIGN=echo
1112
PRODUCTSIGN=echo
@@ -58,7 +59,7 @@ ifeq ($(ZT_CONTROLLER),1)
5859
MACOS_VERSION_MIN=10.15
5960
override CXXFLAGS=$(CFLAGS) -std=c++17 -stdlib=libc++
6061
LIBS+=-L/usr/local/opt/libpqxx/lib -L/usr/local/opt/libpq/lib -L/usr/local/opt/openssl/lib/ -lpqxx -lpq -lssl -lcrypto -lgssapi_krb5 ext/redis-plus-plus-1.1.1/install/macos/lib/libredis++.a ext/hiredis-0.14.1/lib/macos/libhiredis.a
61-
DEFS+=-DZT_CONTROLLER_USE_LIBPQ -DZT_CONTROLLER_USE_REDIS -DZT_CONTROLLER
62+
DEFS+=-DZT_CONTROLLER_USE_LIBPQ -DZT_CONTROLLER_USE_REDIS -DZT_CONTROLLER
6263
INCLUDES+=-I/usr/local/opt/libpq/include -I/usr/local/opt/libpqxx/include -Iext/hiredis-0.14.1/include/ -Iext/redis-plus-plus-1.1.1/install/macos/include/sw/
6364
else
6465
MACOS_VERSION_MIN=10.13
@@ -74,6 +75,7 @@ endif
7475
# Debug mode -- dump trace output, build binary with -g
7576
ifeq ($(ZT_DEBUG),1)
7677
ZT_TRACE=1
78+
ARCH=
7779
ARCH_FLAGS=
7880
CFLAGS+=-Wall -g $(INCLUDES) $(DEFS) $(ARCH_FLAGS)
7981
STRIP=echo
@@ -113,9 +115,9 @@ mac-agent: FORCE
113115
$(CODESIGN) -f --options=runtime -s $(CODESIGN_APP_CERT) MacEthernetTapAgent
114116

115117
osdep/MacDNSHelper.o: osdep/MacDNSHelper.mm
116-
$(CXX) $(CXXFLAGS) -c osdep/MacDNSHelper.mm -o osdep/MacDNSHelper.o
118+
$(CXX) $(CXXFLAGS) -c osdep/MacDNSHelper.mm -o osdep/MacDNSHelper.o
117119

118-
one: zeroidc $(CORE_OBJS) $(ONE_OBJS) one.o mac-agent
120+
one: zeroidc $(CORE_OBJS) $(ONE_OBJS) one.o mac-agent
119121
$(CXX) $(CXXFLAGS) -o zerotier-one $(CORE_OBJS) $(ONE_OBJS) one.o $(LIBS) rustybits/target/libzeroidc.a
120122
# $(STRIP) zerotier-one
121123
ln -sf zerotier-one zerotier-idtool
@@ -127,12 +129,12 @@ zerotier-one: one
127129
zeroidc: rustybits/target/libzeroidc.a
128130

129131
rustybits/target/libzeroidc.a: FORCE
130-
cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=x86_64-apple-darwin $(EXTRA_CARGO_FLAGS)
131-
cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=aarch64-apple-darwin $(EXTRA_CARGO_FLAGS)
132-
cd rustybits && lipo -create target/x86_64-apple-darwin/$(RUST_VARIANT)/libzeroidc.a target/aarch64-apple-darwin/$(RUST_VARIANT)/libzeroidc.a -output target/libzeroidc.a
132+
if [[ "$(ARCH)" == *"x86_64"* ]]; then cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=x86_64-apple-darwin $(EXTRA_CARGO_FLAGS); fi
133+
if [[ "$(ARCH)" == *"arm64"* ]]; then cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=aarch64-apple-darwin $(EXTRA_CARGO_FLAGS); fi
134+
cd rustybits && lipo -create target/*/$(RUST_VARIANT)/libzeroidc.a -output target/libzeroidc.a
133135

134136
central-controller:
135-
make ARCH_FLAGS="-arch x86_64" ZT_CONTROLLER=1 one
137+
make ARCH=x86_64 ZT_CONTROLLER=1 one
136138

137139
zerotier-idtool: one
138140

@@ -197,7 +199,7 @@ central-controller-docker: _buildx FORCE
197199

198200
docker-release: _buildx
199201
docker buildx build --platform linux/386,linux/amd64,linux/arm/v7,linux/arm64,linux/mips64le,linux/ppc64le,linux/s390x -t zerotier/zerotier:${RELEASE_DOCKER_TAG} -t zerotier/zerotier:latest --build-arg VERSION=${RELEASE_VERSION} -f Dockerfile.release . --push
200-
202+
201203
clean:
202204
rm -rf MacEthernetTapAgent *.dSYM build-* *.a *.pkg *.dmg *.o node/*.o controller/*.o service/*.o osdep/*.o ext/http-parser/*.o $(CORE_OBJS) $(ONE_OBJS) zerotier-one zerotier-idtool zerotier-selftest zerotier-cli zerotier doc/node_modules zt1_update_$(ZT_BUILD_PLATFORM)_$(ZT_BUILD_ARCHITECTURE)_* rustybits/target/
203205

0 commit comments

Comments
 (0)