summaryrefslogtreecommitdiff
path: root/scripts/osx_fixbundle.sh
diff options
context:
space:
mode:
authorsaurabhb172020-02-26 16:40:14 +0530
committerGitHub2020-02-26 16:40:14 +0530
commit02c614b4e64b68758f223391cb5357b3eec78cac (patch)
treead18839d8b4eb1f13419d07878cc4ec4c9b70032 /scripts/osx_fixbundle.sh
parentb77f5d9d8097c38159c6f60917995d6af13bbe1c (diff)
parent07a8c86216b6b1f694b136ec64c281d62941952e (diff)
downloadKiCad-eSim-02c614b4e64b68758f223391cb5357b3eec78cac.tar.gz
KiCad-eSim-02c614b4e64b68758f223391cb5357b3eec78cac.tar.bz2
KiCad-eSim-02c614b4e64b68758f223391cb5357b3eec78cac.zip
Merge pull request #6 from saurabhb17/master
minor additions
Diffstat (limited to 'scripts/osx_fixbundle.sh')
-rwxr-xr-xscripts/osx_fixbundle.sh129
1 files changed, 129 insertions, 0 deletions
diff --git a/scripts/osx_fixbundle.sh b/scripts/osx_fixbundle.sh
new file mode 100755
index 0000000..a1f21de
--- /dev/null
+++ b/scripts/osx_fixbundle.sh
@@ -0,0 +1,129 @@
+#!/bin/bash
+# v 1.1 Supports migration of links (limited to the same directory) - I should add checks..
+# usage osx_fixbundle.sh <bundle-name> <bzr_root>
+
+if [[ ! -f version.h ]]; then
+ echo "**"
+ echo "** ERROR: $0 doesn't seems to be launched from the kicad's bzr root !!!"
+ echo "** Go in the bzr root directory and launch: scripts/osx_fixbundle.sh"
+ echo "**"
+ exit 1
+fi
+
+EXECUTABLES="`find . -name '*.app'`"
+
+#
+# Copies libraries under <bzr_root> in the bundle and relocates them in the binary
+#
+
+function fixbundle() {
+ exec="$1"
+ bzroot="$2"
+ execpath="$3"
+ binary="$4"
+
+ LIBRARIES="`otool -L ${binary} | cut -d' ' -f1`"
+
+ for library in $LIBRARIES; do
+
+ mkdir -p ${execpath}${exec}.app/Contents/Frameworks
+ if [[ "$library" =~ "$bzroot" ]]; then
+ echo "${exec}: Migrating `basename $library` in the bundle"
+ if [ ! -f ${exec}.app/Contents/Frameworks/`basename $library` ]; then
+ if [ ! -L $library ]; then
+ cp -f $library ${execpath}${exec}.app/Contents/Frameworks
+ else
+ resolvelink "$library" "`dirname $library`" "${execpath}/${exec}.app/Contents/Frameworks"
+ fi
+ fi
+ install_name_tool -change $library @executable_path/../Frameworks/`basename $library` ${binary}
+ fi
+ done
+
+ # Resolve issue in python modules (.so)
+ cd ${execpath}
+ MODULES="`find ${exec}.app -name '*.so'`"
+
+ for module in $MODULES; do
+ LIBRARIES="`otool -L $module | cut -d' ' -f1`"
+ mkdir -p ${exec}.app/Contents/Frameworks
+
+ for library in $LIBRARIES; do
+ if [[ "$library" =~ "$bzroot" ]]; then
+ if [ ! -f ${exec}.app/Contents/Frameworks/`basename $library` ]; then
+ if [ ! -L $library ]; then
+ cp -f $library ${exec}.app/Contents/Frameworks
+ else
+ resolvelink "$library" "`dirname $library`" "${execpath}/${exec}.app/Contents/Frameworks"
+ fi
+ fi
+ install_name_tool -change $library @executable_path/../Frameworks/`basename $library` $module
+ fi
+ done
+ echo "${exec}: elaborated module `basename ${module}`"
+ done
+
+ # Resolve issue between DYNLIBS
+ dynlib_migrate="1";
+ dynlib_cycle="0";
+
+ while [ $dynlib_migrate -gt 0 ]; do
+ dynlib_migrate="0";
+ (( dynlib_cycle += 1 ))
+ DYNLIBS="`find ${exec}.app -name '*.dylib'`"
+
+ for dynlib in $DYNLIBS; do
+ LIBRARIES="`otool -L $dynlib | cut -d' ' -f1`"
+ mkdir -p ${exec}.app/Contents/Frameworks
+
+ for library in $LIBRARIES; do
+ if [[ "$library" =~ "$bzroot" ]]; then
+ if [ ! -f ${exec}.app/Contents/Frameworks/`basename $library` ]; then
+ if [ ! -L $library ]; then
+ cp -f $library ${exec}.app/Contents/Frameworks
+ else
+ resolvelink "$library" "`dirname $library`" "${execpath}/${exec}.app/Contents/Frameworks"
+ fi
+ echo "copied `basename $library` into bundle"
+ (( dynlib_migrate += 1))
+ fi
+
+ install_name_tool -change $library @executable_path/../Frameworks/`basename $library` $dynlib
+ fi
+ done
+ done
+ echo "${exec}: bundle dynlib dependencies migration Pass $dynlib_cycle: Migrated $dynlib_migrate libraries in bundle"
+ done
+ cd - >/dev/null
+}
+
+#
+# This supports only links on the same dir (TODO ?)
+#
+
+function resolvelink() {
+ local srclib="`basename $1`"
+ local srcpath="$2"
+ local destpath="$3"
+
+ #if is a file i expect a pointed ""
+ local pointed="`readlink ${srcpath}/${srclib}`"
+
+ if [ ! -f ${pointed} ]; then
+ resolvelink "${pointed}" "${srcpath}" "${destpath}"
+ echo "Link ${srclib} -> ${pointed} "
+ (cd "${destpath}"; ln -s "${pointed}" "${srclib}" )
+ else
+ echo "Copy ${srcpath}/${srclib} -> ${destpath} "
+ cp "${srcpath}/${srclib}" ${destpath}
+ fi
+}
+
+for executable in $EXECUTABLES;
+do
+ myexecpath="`dirname ${executable}`/"
+ myexec="`basename ${executable}|sed -e 's/\.app//'`"
+
+ fixbundle "${myexec}" "$1" "${myexecpath}" "${myexecpath}${myexec}.app/Contents/MacOS/${myexec}"
+ fixbundle "${myexec}" "$1" "${myexecpath}" "${myexecpath}${myexec}.app/Contents/MacOS/_${myexec}.kiface"
+done