]> git.saurik.com Git - cycript.git/blobdiff - trampoline.sh
Clean up a couple #include and build dependencies.
[cycript.git] / trampoline.sh
index 824a4486440717049b9e6b5537b0ffaf2fb8ff56..fd4be0d768038b5d3bbb9062ce3077a56c6c229a 100755 (executable)
@@ -2,35 +2,39 @@
 
 set -e
 
-shopt -s extglob
-
 hpp=$1
 object=$2
 name=$3
 sed=$4
-otool=$5
-lipo=$6
-nm=$7
-shift 7
-
-#shift 1
-#set /Developer/Platforms/iPhoneOS.platform/Developer/usr/bin/gcc-4.2 -I/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS3.1.3.sdk/usr/include "$@"
+lipo=$5
+nm=$6
+otool=$7
 
-"$@"
+exec >"${hpp}"
 
 detailed=$("${lipo}" -detailed_info "${object}")
 
-{
+regex=$'\nNon-fat file: .* is architecture: (.*)'
+if [[ ${detailed} =~ ${regex} ]]; then
+    archs=(${BASH_REMATCH[1]})
+    unset detailed
+else
+    archs=($(echo "${detailed}" | "${sed}" -e '/^architecture / { s/^architecture //; p; }; d;'))
+fi
 
 echo '#include "Trampoline.hpp"'
 
-for arch in $(echo "${detailed}" | "${sed}" -e '/^architecture / { s/^architecture //; p; }; d;'); do
-    offset=$(echo "${detailed}" | "${sed}" -e '
-        /^architecture / { x; s/.*/0/; x; };
-        /^architecture '${arch}'$/ { x; s/.*/1/; x; };
-        x; /^1$/ { x; /^ *offset / { s/^ *offset //; p; }; x; }; x;
-        d;
-    ')
+for arch in "${archs[@]}"; do
+    if [[ "${detailed+@}" ]]; then
+        offset=$(echo "${detailed}" | "${sed}" -e '
+            /^architecture / { x; s/.*/0/; x; };
+            /^architecture '${arch}'$/ { x; s/.*/1/; x; };
+            x; /^1$/ { x; /^ *offset / { s/^ *offset //; p; }; x; }; x;
+            d;
+        ')
+    else
+        offset=0
+    fi
 
     file=($("${otool}" -arch "${arch}" -l "${object}" | "${sed}" -e '
         x; /^1$/ { x;
@@ -39,7 +43,7 @@ for arch in $(echo "${detailed}" | "${sed}" -e '/^architecture / { s/^architectu
         x; }; x;
 
         /^ *cmd LC_SEGMENT/ { x; s/.*/1/; x; };
-        
+
         d;
     '))
 
@@ -78,7 +82,7 @@ for arch in $(echo "${detailed}" | "${sed}" -e '/^architecture / { s/^architectu
 
     echo
     echo "/*"
-    "${otool}" -vVt -arch "${arch}" "${object}"
+    "${otool}" -arch "${arch}" -vVt "${object}"
     echo "*/"
 
     echo
@@ -87,8 +91,5 @@ for arch in $(echo "${detailed}" | "${sed}" -e '/^architecture / { s/^architectu
     echo "    sizeof(${name}_${arch}_data_),"
     echo "    ${name}_${arch}_entry_,"
     echo "};"
-done
-
-} >"${hpp}"
 
-#rm -f "${object}"
+done