summaryrefslogtreecommitdiffstats
path: root/shave.in
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2009-02-24 11:43:15 +0100
committerLennart Poettering <lennart@poettering.net>2009-02-24 11:43:15 +0100
commit7f5fff943f36c8dcb856bf2b3c77b0da9bf581e9 (patch)
tree75b285406f7f5998b955efd45a71abebddb58adb /shave.in
parent71263929cb825acc1fed15fa33e110d77b2c37a7 (diff)
parent16bb6580be39d8a3930f5c9860d4313e36c729a9 (diff)
Merge commit 'elmarco/shave'
Diffstat (limited to 'shave.in')
-rw-r--r--shave.in70
1 files changed, 70 insertions, 0 deletions
diff --git a/shave.in b/shave.in
new file mode 100644
index 00000000..dc46ec96
--- /dev/null
+++ b/shave.in
@@ -0,0 +1,70 @@
+#!/bin/sh
+
+# we need sed
+SED=@SED@
+if test -z "$SED" ; then
+SED=sed
+fi
+
+lt_unmangle ()
+{
+ last_result=`echo $1 | $SED -e 's#.libs/##' -e 's#[0-9a-zA-Z_]\*_la-##'`
+}
+
+# the tool to wrap (cc, cxx, ar, ranlib, ..)
+tool="$1"
+shift
+
+# the reel tool (to call)
+REEL_TOOL="$1"
+shift
+
+pass_through=0
+preserved_args=
+while test "$#" -gt 0; do
+ opt="$1"
+ shift
+
+ case $opt in
+ --shave-mode=*)
+ mode=`echo $opt | $SED -e 's/[-_a-zA-Z0-9]*=//'`
+ ;;
+ -o)
+ lt_output="$1"
+ preserved_args="$preserved_args $opt"
+ ;;
+ *)
+ preserved_args="$preserved_args $opt"
+ ;;
+ esac
+done
+
+# mode=link is handled in the libtool wrapper
+case "$mode,$tool" in
+link,*)
+ pass_through=1
+ ;;
+*,cxx)
+ Q=" CXX "
+ ;;
+*,cc)
+ Q=" CC "
+ ;;
+*,*)
+ # should not happen
+ Q=" CC "
+ ;;
+esac
+
+lt_unmangle "$lt_output"
+output=$last_result
+
+if test -z $V; then
+ if test $pass_through -eq 0; then
+ echo "$Q$output"
+ fi
+ $REEL_TOOL $preserved_args
+else
+ echo $REEL_TOOL $preserved_args
+ $REEL_TOOL $preserved_args
+fi