scripts/wrapper.in
author Oron Peled <oron@actcom.co.il>
Mon Aug 03 00:49:25 2009 +0200 (2009-08-03)
changeset 1449 8ad2773e7ae3
parent 1402 146c62142e1b
child 1960 8307ceabe5c0
permissions -rw-r--r--
[complib:mpfr] Fix building MPFR in some weird cases

The tmul test uses a compiled-in input file in $(srcdir).
The problem is that the Makefile passes it unquoted. The C code
tries to stringify it using clever macros, which may *usually* work.

In my case the source directory was named:
.../toolchain-powerpc-e500v2-linux-gnuspe-1.0-2.fc10/.../tests
And guess what? During testing I found out the program fails because
it tries to open:
.../toolchain-powerpc-e500v2-1-gnuspe-1.0-2.fc10/.../tests

Yes, CPP tokenized the macro before stringifying it and not surprisingly
the 'linux' part was converted to 1.
[on Fedora-10: cpp (GCC) 4.3.2 20081105 (Red Hat 4.3.2-7)]

So the attached patch simplify the macros and pass the path as string
from the Makefile.
yann@1402
     1
#!/bin/sh
yann@1401
     2
bartvdrmeulen@1434
     3
canonicalizedname=$(readlink -nm "${0}")
bartvdrmeulen@1434
     4
dirname="$(dirname "${canonicalizedname}")"
bartvdrmeulen@1434
     5
basename="$(basename "${canonicalizedname}")"
yann@1401
     6
yann@1401
     7
ld_lib_path="$(dirname "${dirname}")/lib"
yann@1401
     8
yann@1401
     9
case ":${LD_LIBRARY_PATH}:" in
yann@1401
    10
    *":${ld_lib_path}:"*)   ;;
yann@1401
    11
    *)  LD_LIBRARY_PATH="${ld_lib_path}${LD_LIBRARY_PATH:+:${LD_LIBRARY_PATH}}";;
yann@1401
    12
esac
yann@1401
    13
yann@1401
    14
export LD_LIBRARY_PATH
yann@1402
    15
exec "${dirname}/.${basename}" "$@"