@@ -5,7 +5,8 @@ TOPDIR=$(shell pwd)
55INCLUDES =-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
66DEFS =
77LIBS =
8- ARCH_FLAGS =-arch x86_64 -arch arm64
8+ ARCH := x86_64 arm64
9+ ARCH_FLAGS =$(addprefix -arch ,$(ARCH ) )
910
1011CODESIGN =echo
1112PRODUCTSIGN =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/
6364else
6465 MACOS_VERSION_MIN=10.13
7475# Debug mode -- dump trace output, build binary with -g
7576ifeq ($(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
115117osdep/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
127129zeroidc : rustybits/target/libzeroidc.a
128130
129131rustybits/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
134136central-controller :
135- make ARCH_FLAGS= " -arch x86_64" ZT_CONTROLLER=1 one
137+ make ARCH= x86_64 ZT_CONTROLLER=1 one
136138
137139zerotier-idtool : one
138140
@@ -197,7 +199,7 @@ central-controller-docker: _buildx FORCE
197199
198200docker-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+
201203clean :
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