]> git.saurik.com Git - cycript.git/blobdiff - xcode.mk
Add a makefile mechanism for automatic deployment.
[cycript.git] / xcode.mk
index 053503a4fd3aad8ed7e31abfe06fc551b593ecf5..b72d40d40d81a2edf74ff2f0bd1f5deabfc2b380 100644 (file)
--- a/xcode.mk
+++ b/xcode.mk
@@ -24,33 +24,39 @@ include codesign.mk
 
 lipo := $(shell xcrun --sdk iphoneos -f lipo)
 
+monotonic := $(shell git log -1 --pretty=format:%ct)
 version := $(shell git describe --always --tags --dirty="+" --match="v*" | sed -e 's@-\([^-]*\)-\([^-]*\)$$@+\1.\2@;s@^v@@;s@%@~@g')
+
 deb := cycript_$(version)_iphoneos-arm.deb
+zip := cycript_$(version).zip
 
 cycript := 
 cycript += Cycript.lib/cycript
 cycript += Cycript.lib/cycript0.9
 cycript += Cycript.lib/libcycript.dylib
-cycript += Cycript.lib/libcycript-any.dylib
 cycript += Cycript.lib/libcycript-sys.dylib
 cycript += Cycript.lib/libcycript-sim.dylib
 
 framework := 
-framework += Cycript.framework/Cycript
-framework += Cycript.framework/Headers/Cycript.h
+framework += Cycript
+framework += Headers/Cycript.h
+
+framework := $(foreach os,ios osx,$(foreach file,$(framework),Cycript.$(os)/Cycript.framework/$(file)))
 
 links := 
 links += Cycript.lib/libsubstrate.dylib
 links += Cycript.lib/cycript0.9
 
-all: cycript $(cycript) $(framework)
+all := cycript $(cycript) $(framework)
+all: $(all)
 
-cycript.zip: all
+$(zip): $(all)
        rm -f $@
-       zip -r9y $@ cycript Cycript.lib Cycript.framework $(patsubst %,--exclude %,$(links))
+       zip -r9y $@ cycript Cycript.lib Cycript.{ios,osx} $(patsubst %,--exclude %,$(links))
        zip -r9 $@ $(links)
 
-package: cycript.zip
+zip: $(zip)
+       ln -sf $< cycript.zip
 
 $(deb): Cycript.lib/cycript Cycript.lib/libcycript.dylib
        rm -rf package
@@ -72,38 +78,37 @@ clean:
 # make stubbornly refuses to believe that these @'s are bugs
 # http://osdir.com/ml/help-make-gnu/2012-04/msg00008.html
 
-define build_mac
-.PHONY: build-mac-$(1)
-build-mac-$(1):
-       $(MAKE) -C build.mac-$(1)
-build.mac-$(1)/.libs/cycript: build-mac-$(1)
+define build_any
+.PHONY: build-$(1)-$(2)
+build-$(1)-$(2):
+       $(MAKE) -C build.$(1)-$(2)
+build.$(1)-$(2)/.libs/libcycript.a: build-$(1)-$(2)
        @
-build.mac-$(1)/.libs/libcycript.dylib: build-mac-$(1)
+endef
+
+define build_lib
+build.$(1)-$(2)/.libs/libcycript.dylib: build-$(1)-$(2)
        @
-build.mac-$(1)/.libs/libcycript-any.dylib: build-mac-$(1)
+endef
+
+define build_osx
+$(call build_any,osx,$(1))
+$(call build_lib,osx,$(1))
+build.osx-$(1)/.libs/cycript: build-osx-$(1)
        @
 endef
 
-$(foreach arch,i386 x86_64,$(eval $(call build_mac,$(arch))))
+$(foreach arch,i386 x86_64,$(eval $(call build_osx,$(arch))))
 
 define build_ios
-.PHONY: build-ios-$(1)
-build-ios-$(1):
-       $(MAKE) -C build.ios-$(1)
-build.ios-$(1)/.libs/libcycript.a: build-ios-$(1)
-       @
+$(call build_any,ios,$(1))
 endef
 
 $(foreach arch,armv6 armv7 armv7s arm64,$(eval $(call build_ios,$(arch))))
 
 define build_sim
-.PHONY: build-sim-$(1)
-build-sim-$(1):
-       $(MAKE) -C build.sim-$(1)
-build.sim-$(1)/.libs/libcycript.dylib: build-sim-$(1)
-       @
-build.sim-$(1)/.libs/libcycript.a: build-sim-$(1)
-       @
+$(call build_any,sim,$(1))
+$(call build_lib,sim,$(1))
 endef
 
 $(foreach arch,i386 x86_64,$(eval $(call build_sim,$(arch))))
@@ -116,13 +121,12 @@ endef
 $(foreach arch,armv6,$(eval $(call build_arm,$(arch))))
 
 define build_arm
-build.ios-$(1)/.libs/libcycript.dylib: build-ios-$(1)
-       @
+$(call build_lib,ios,$(1))
 endef
 
 $(foreach arch,armv6 arm64,$(eval $(call build_arm,$(arch))))
 
-Cycript.lib/%.dylib: build.mac-i386/.libs/%.dylib build.mac-x86_64/.libs/%.dylib build.ios-armv6/.libs/%.dylib build.ios-arm64/.libs/%.dylib
+Cycript.lib/libcycript.dylib: build.osx-i386/.libs/libcycript.dylib build.osx-x86_64/.libs/libcycript.dylib build.ios-armv6/.libs/libcycript.dylib build.ios-arm64/.libs/libcycript.dylib
        @mkdir -p $(dir $@)
        $(lipo) -create -output $@ $^
        install_name_tool -change /System/Library/{,Private}Frameworks/JavaScriptCore.framework/JavaScriptCore $@
@@ -133,7 +137,7 @@ Cycript.lib/%.dylib: build.mac-i386/.libs/%.dylib build.mac-x86_64/.libs/%.dylib
        install_name_tool -change /System/Library/{,Private}Frameworks/JavaScriptCore.framework/JavaScriptCore $@
        codesign -s $(codesign) --entitlement cycript-$(word 2,$(subst ., ,$(subst -, ,$*))).xml $@
 
-Cycript.lib/%: build.mac-i386/.libs/%_ build.mac-x86_64/.libs/%_ build.ios-armv6/.libs/%_
+Cycript.lib/%: build.osx-i386/.libs/%_ build.osx-x86_64/.libs/%_ build.ios-armv6/.libs/%_
        @mkdir -p $(dir $@)
        $(lipo) -create -output $@ $^
 
@@ -150,14 +154,17 @@ libcycript-%.o: build.%/.libs/libcycript.a xcode.map
        @mkdir -p $(dir $@)
        ld -r -arch $$($(lipo) -detailed_info $< | sed -e '/^Non-fat file: / ! d; s/.*: //') -o $@ -all_load -exported_symbols_list xcode.map $< libffi.a
 
-libcycript.o: libcycript-ios-armv6.o libcycript-ios-armv7.o libcycript-ios-armv7s.o libcycript-ios-arm64.o libcycript-sim-i386.o libcycript-sim-x86_64.o
+libcycript-ios.o: libcycript-ios-armv6.o libcycript-ios-armv7.o libcycript-ios-armv7s.o libcycript-ios-arm64.o libcycript-sim-i386.o libcycript-sim-x86_64.o
+       $(lipo) -create -output $@ $^
+
+libcycript-osx.o: libcycript-osx-i386.o libcycript-osx-x86_64.o
        $(lipo) -create -output $@ $^
 
-Cycript.framework/Cycript: libcycript.o
+Cycript.%/Cycript.framework/Cycript: libcycript-%.o
        @mkdir -p $(dir $@)
        cp -a $< $@
 
-Cycript.framework/Headers/Cycript.h: Cycript.h
+Cycript.%/Cycript.framework/Headers/Cycript.h: Cycript.h
        @mkdir -p $(dir $@)
        cp -a $< $@
 
@@ -169,4 +176,12 @@ cycript: cycript.in
        cp -af $< $@
        chmod 755 $@
 
-.PHONY: all clean package
+install: Cycript.lib/cycript Cycript.lib/libcycript.dylib Cycript.lib/libcycript-sys.dylib Cycript.lib/libcycript-sim.dylib
+       sudo cp -af $(filter-out %.dylib,$^) /usr/bin
+       sudo cp -af $(filter %.dylib,$^) /usr/lib
+
+
+cast: $(zip)
+       appcast.sh cycript/mac $(monotonic) $(version) $< "$(CYCRIPT_CHANGES)"
+
+.PHONY: all cast clean install zip