#!/bin/sh #************************************************************************* # # $RCSfile: macosx-create-bundle,v $ # # $Revision: 1.3 $ # # last change: $Author: hr $ $Date: 2006-10-24 13:26:03 $ # # The Contents of this file are made available subject to # the terms of GNU Lesser General Public License Version 2.1. # # # GNU Lesser General Public License Version 2.1 # ============================================= # Copyright 2005 by Sun Microsystems, Inc. # 901 San Antonio Road, Palo Alto, CA 94303, USA # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License version 2.1, as published by the Free Software Foundation. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, # MA 02111-1307 USA # #************************************************************************* # Documentation # ------------- # # The purpose of this script to take Mac OS X executables and shared libraries # and package them into the required Mac OS X bundle format. # # This script has the following usage: # macosx-create-bundle file1 [file2] ... [fileN] # # Note that file1 through fileN can in either of the following formats: # - A file name # - A file name and a directory to look for missing files. To use this option, # use the following format: # filename=directory # # The file argument is the file that you want to package into a Mac OS X # bundle. Currently, this script will only package executables and shared # libraries. # # The output for each executable will be a bundle named .app and # the output for each shared library will be a symlink from libfoo.jnilib # back to libfoo.dylib. # These output directories will be in the same directory as the executable or # shared library. # Code # ---- # Parse command line arguments if [ $# = 0 ]; then printf "macosx-create-bundle: error: incorrect number of arguments\n" >&2 printf "Usage: macosx-create-bundle file1 [file2] ... [fileN]\n" >&2 exit 1 fi while [ $# != 0 ]; do inputfile=`echo "$1" | awk -F= '{print $1}'` sourcedir=`echo "$1" | awk -F= '{print $2}'` shift inputfilename=`basename "$inputfile"` outputdir=`dirname "$inputfile"` solverlibdir="$SOLARVERSION/$INPATH/lib" locallibdir="../../../../lib" solverbindir="$SOLARVERSION/$INPATH/bin" localbindir="../../.." # Determine file type filetype=`file -L "$inputfile"` # Create bundle based on file type if printf "$filetype" | grep -q 'Mach-O executable'; then # Do nothing as this step is obsolete : elif printf "$filetype" | grep -q 'Mach-O dynamically linked shared library'; then # Screen out lib\w+static libraries as they are not used directly if ! printf "$inputfilename" | grep -q -x -E 'lib\w+static.*\.dylib'; then # Set the install_name of the *.dylib file install_name_tool -id "@executable_path/$inputfilename" $inputfile # Create jnilib link inputjnilibname="`basename $inputfilename .dylib`.jnilib" if [ ! -L "$outputdir/$inputjnilibname" ]; then rm -Rf "$outputdir/$inputjnilibname" fi # Link jnilib ln -sf "$inputfilename" "$outputdir/$inputjnilibname" printf "macosx-create-bundle: $outputdir/$inputjnilibname successfully created\n" fi else printf "macosx-create-bundle: error: file is not an executable or shared library.\n" >&2 exit 1 fi done