]> git.saurik.com Git - cydia.git/blobdiff - makefile
Add some new (and old :/) section remaps (*sigh*).
[cydia.git] / makefile
index 574c6fa5120b4c370be78c1d6f77e244b6488556..f4834cef1912713fd702f56f2625a69b83ee6c59 100644 (file)
--- a/makefile
+++ b/makefile
@@ -1,56 +1,52 @@
-sdks := /Developer/Platforms/iPhoneOS.platform/Developer/SDKs
-ioss := $(sort $(patsubst $(sdks)/iPhoneOS%.sdk,%,$(wildcard $(sdks)/iPhoneOS*.sdk)))
-
-ios := $(word $(words $(ioss)),$(ioss))
-gcc := 4.2
+gxx := $(shell xcrun --sdk iphoneos -f g++)
+sdk := $(shell xcodebuild -sdk iphoneos -version Path)
 
 flags := 
 link := 
+libs := 
 
-ifeq (o,O) # gzip is actually better
-dpkg := /Library/Cydia/bin/dpkg-deb
-ifeq ($(wildcard $(dpkg)),$(dpkg))
-dpkg := $(dpkg) -zlzma
-else
-dpkg := dpkg-deb -zbzip2
-endif
-else
-dpkg := dpkg-deb
-endif
-
-sdk := $(sdks)/iPhoneOS$(ios).sdk
+dpkg := dpkg-deb -Zlzma
 
 flags += -F$(sdk)/System/Library/PrivateFrameworks
-flags += -I. -isystem sysroot/usr/include -Lsysroot/usr/lib
-flags += -Wall -Werror -Wno-deprecated-declarations
+flags += -I. -isystem sysroot/usr/include
 flags += -fmessage-length=0
 flags += -g0 -O2
-flags += -fobjc-exceptions
-flags += -fno-guess-branch-probability
 flags += -fvisibility=hidden
 
+flags += -idirafter icu/icuSources/common
+flags += -idirafter icu/icuSources/i18n
+
+flags += -Wall
+
+flags += -Wno-unknown-warning-option
+flags += -Wno-logical-op-parentheses
+flags += -Wno-dangling-else
+flags += -Wno-shift-op-parentheses
+flags += -Wno-deprecated-declarations
+
 xflags :=
 xflags += -fobjc-call-cxx-cdtors
 xflags += -fvisibility-inlines-hidden
 
-link += -framework CoreFoundation
-link += -framework CoreGraphics
-link += -framework Foundation
-link += -framework GraphicsServices
-link += -framework IOKit
-link += -framework JavaScriptCore
-link += -framework QuartzCore
-link += -framework SpringBoardServices
-link += -framework SystemConfiguration
-link += -framework WebCore
-link += -framework WebKit
-
-link += -lapr-1
-link += -lapt-pkg
-link += -lpcre
-
+link += -Lsysroot/usr/lib
 link += -multiply_defined suppress
 
+libs += -framework CoreFoundation
+libs += -framework CoreGraphics
+libs += -framework Foundation
+libs += -framework GraphicsServices
+libs += -framework IOKit
+libs += -framework QuartzCore
+libs += -framework SpringBoardServices
+libs += -framework SystemConfiguration
+libs += -framework WebCore
+libs += -framework WebKit
+
+libs += -lapr-1
+libs += -lapt-pkg
+libs += -licucore
+libs += -lpcre
+
 uikit := 
 uikit += -framework UIKit
 
@@ -59,17 +55,18 @@ backrow += -FAppleTV -framework BackRow -framework AppleTV
 
 version := $(shell ./version.sh)
 
-#cycc = cycc -r4.2 -i$(ios) -o$@
-gxx := /Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/g++-$(gcc)
-cycc = $(gxx) -mthumb -arch armv6 -o $@ -mcpu=arm1176jzf-s -miphoneos-version-min=2.0 -isysroot $(sdk) -idirafter /usr/include -F{sysroot,}/Library/Frameworks
+cycc = $(gxx) -arch armv6 -o $@ -miphoneos-version-min=2.0 -isysroot $(sdk) -idirafter /usr/include -F{sysroot,}/Library/Frameworks
 
-flags += -DCYDIA_VERSION='"$(version)"'
+cycc += -marm # @synchronized
+cycc += -mcpu=arm1176jzf-s
+cycc += -mllvm -arm-reserve-r9
+link += -lgcc_s.1
 
 dirs := Menes CyteKit Cydia SDURLCache
 
 code := $(foreach dir,$(dirs),$(wildcard $(foreach ext,h hpp c cpp m mm,$(dir)/*.$(ext))))
 code := $(filter-out SDURLCache/SDURLCacheTests.m,$(code))
-code += MobileCydia.mm iPhonePrivate.h Cytore.hpp lookup3.c
+code += MobileCydia.mm Version.mm iPhonePrivate.h Cytore.hpp lookup3.c Sources.h Sources.mm
 
 source := $(filter %.m,$(code)) $(filter %.mm,$(code))
 source += $(filter %.c,$(code)) $(filter %.cpp,$(code))
@@ -82,7 +79,7 @@ object := $(object:.m=.o)
 object := $(object:.mm=.o)
 object := $(object:%=Objects/%)
 
-images := $(shell find MobileCydia.app -name '*.png')
+images := $(shell find MobileCydia.app/ -type f -name '*.png')
 images := $(images:%=Images/%)
 
 lproj_deb := debs/cydia-lproj_$(version)_iphoneos-arm.deb
@@ -90,52 +87,71 @@ lproj_deb := debs/cydia-lproj_$(version)_iphoneos-arm.deb
 all: MobileCydia
 
 clean:
-       rm -f MobileCydia
+       rm -f MobileCydia postinst
        rm -rf Objects/ Images/
 
 Objects/%.o: %.c $(header)
        @mkdir -p $(dir $@)
        @echo "[cycc] $<"
-       @$(cycc) -c -o $@ -x c $<
+       @$(cycc) -c -x c $<
 
 Objects/%.o: %.m $(header)
        @mkdir -p $(dir $@)
        @echo "[cycc] $<"
-       @$(cycc) -c -o $@ $< $(flags)
+       @$(cycc) -c $< $(flags)
 
 Objects/%.o: %.mm $(header)
        @mkdir -p $(dir $@)
        @echo "[cycc] $<"
-       @$(cycc) -c -o $@ $< $(flags) $(xflags)
+       @$(cycc) -std=c++11 -c $< $(flags) $(xflags)
+
+Objects/Version.o: Version.h
 
 Images/%.png: %.png
        @mkdir -p $(dir $@)
        @echo "[pngc] $<"
        @./pngcrush.sh $< $@
 
-sysroot:
-       @echo "Please read compiling.txt: you do not have a ./sysroot/ folder with the on-device requirements." 1>&2
+sysroot: sysroot.sh
+       @echo "Your ./sysroot/ is either missing or out of date. Please read compiling.txt for help." 1>&2
        @echo 1>&2
        @exit 1
 
-MobileCydia: sysroot $(object)
+MobileCydia: sysroot $(object) entitlements.xml
        @echo "[link] $(object:Objects/%=%)"
-       @$(cycc) $(filter %.o,$^) $(flags) $(link) $(uikit)
+       @$(cycc) $(filter %.o,$^) $(flags) $(link) $(libs) $(uikit) -Wl,-sdk_version,7.0
+       @mkdir -p bins
+       @cp -a $@ bins/$@-$(version)
        @echo "[strp] $@"
        @strip -no_uuid $@
+       @echo "[uikt] $@"
+       @./uikit.sh $@
        @echo "[sign] $@"
-       @ldid -T0 -Slaunch.xml $@ || { rm -f $@ && false; }
+       @ldid -T0 -Sentitlements.xml $@ || { rm -f $@ && false; }
 
 CydiaAppliance: CydiaAppliance.mm
-       $(cycc) $(filter %.mm,$^) $(flags) -bundle $(link) $(backrow)
+       $(cycc) $(filter %.mm,$^) $(flags) $(link) -bundle $(libs) $(backrow)
+
+cfversion: cfversion.mm
+       $(cycc) $(filter %.mm,$^) $(flags) $(link) -framework CoreFoundation
+       @ldid -T0 -S $@
 
-debs/cydia_$(version)_iphoneos-arm.deb: MobileCydia $(images) $(shell find MobileCydia.app)
+postinst: postinst.mm Sources.mm Sources.h CyteKit/stringWithUTF8Bytes.mm CyteKit/stringWithUTF8Bytes.h CyteKit/UCPlatform.h
+       $(cycc) $(filter %.mm,$^) $(flags) $(link) -framework CoreFoundation -framework Foundation -framework UIKit -lpcre
+       @ldid -T0 -S $@
+
+debs/cydia_$(version)_iphoneos-arm.deb: MobileCydia preinst postinst cfversion $(images) $(shell find MobileCydia.app) cydia.control Library/firmware.sh Library/startup
        sudo rm -rf _
        mkdir -p _/var/lib/cydia
        
+       mkdir -p _/etc/apt
+       cp -a Trusted.gpg _/etc/apt/trusted.gpg.d
+       cp -a Sources.list _/etc/apt/sources.list.d
+       
        mkdir -p _/usr/libexec
        cp -a Library _/usr/libexec/cydia
        cp -a sysroot/usr/bin/du _/usr/libexec/cydia
+       cp -a cfversion _/usr/libexec/cydia
        
        mkdir -p _/System/Library
        cp -a LaunchDaemons _/System/Library/LaunchDaemons
@@ -147,6 +163,10 @@ debs/cydia_$(version)_iphoneos-arm.deb: MobileCydia $(images) $(shell find Mobil
        
        cd MobileCydia.app && find . -name '*.png' -exec cp -af ../Images/MobileCydia.app/{} ../_/Applications/Cydia.app/{} ';'
        
+       mkdir -p _/Applications/Cydia.app/Sources
+       ln -s /usr/share/bigboss/icons/bigboss.png _/Applications/Cydia.app/Sources/apt.bigboss.us.com.png
+       ln -s /usr/share/bigboss/icons/planetiphones.png _/Applications/Cydia.app/Sections/"Planet-iPhones Mods.png"
+       
        #mkdir -p _/Applications/AppleTV.app/Appliances
        #cp -a Cydia.frappliance _/Applications/AppleTV.app/Appliances
        #cp -a CydiaAppliance _/Applications/AppleTV.app/Appliances/Cydia.frappliance
@@ -156,7 +176,7 @@ debs/cydia_$(version)_iphoneos-arm.deb: MobileCydia $(images) $(shell find Mobil
        
        mkdir -p _/DEBIAN
        ./control.sh cydia.control _ >_/DEBIAN/control
-       cp -a preinst _/DEBIAN/
+       cp -a preinst postinst _/DEBIAN/
        
        find _ -exec touch -t "$$(date -j -f "%s" +"%Y%m%d%H%M.%S" "$$(git show --format='format:%ct' | head -n 1)")" {} ';'
        
@@ -169,7 +189,7 @@ debs/cydia_$(version)_iphoneos-arm.deb: MobileCydia $(images) $(shell find Mobil
        $(dpkg) -b _ Cydia.deb
        @echo "$$(stat -L -f "%z" Cydia.deb) $$(stat -f "%Y" Cydia.deb)"
 
-$(lproj_deb): $(shell find MobileCydia.app -name '*.strings')
+$(lproj_deb): $(shell find MobileCydia.app -name '*.strings') cydia-lproj.control
        sudo rm -rf __
        mkdir -p __/Applications/Cydia.app
        
@@ -177,7 +197,6 @@ $(lproj_deb): $(shell find MobileCydia.app -name '*.strings')
        
        mkdir -p __/DEBIAN
        ./control.sh cydia-lproj.control __ >__/DEBIAN/control
-       cp -a preinst __/DEBIAN/
        
        sudo chown -R 0 __
        sudo chgrp -R 0 __
@@ -189,4 +208,4 @@ $(lproj_deb): $(shell find MobileCydia.app -name '*.strings')
        
 package: debs/cydia_$(version)_iphoneos-arm.deb $(lproj_deb)
 
-.PHONY: all clean package sign
+.PHONY: all clean package