Hi all,

I'm experiencing some trouble using libtool inside the GNU autotools 
collection. My compiled objects do not find their shared libraries that are 
installed in non-standard library paths.

I wrote a C++ library, called rtcom for argument's sake, and used SWIG to make 
it available as a Python module, rtcom.py. Now SWIG generates some glue C++ 
code which should be compiled as _rtcom.so. This shared object must lie 
somewhere in Python's search path. _rtcom.so obviously needs to link at 
runtime to rtcom.so, the original C++ library. 

For various reasons, however, I do not want to install rtcom.so in the 
standard library directories. This generally is not a problem, as linking an 
object using ld --rpath <LibraryPath>, it is possible to tell the dynamic 
linker where to find a shared library.

As I understand it, this is a typical libtool task. I used the following 
Makefile.am to generate the tools:

############## Makefile.am #########################
BUILT_SOURCES = rtcom_wrap.cpp rtcom_wrap.h
SWIG_SOURCES = rtcom.i

pkgpython_PYTHON = rtcom.py
pkgpyexec_LTLIBRARIES = _rtcom.la
_rtcom_la_SOURCES = $(BUILT_SOURCES) $(SWIG_SOURCES)
_rtcom_la_CPPFLAGS = $(SWIG_PYTHON_CPPFLAGS) -I$(top_srcdir)
_rtcom_la_LDFLAGS = -module
_rtcom_la_LIBADD = ../librtcom.la

-include $(DEPDIR)/rtcom_wrap.d
rtcom_wrap.cpp: $(SWIG_SOURCES)
        $(SWIG) $(SWIG_PYTHON_OPT) -I$(top_srcdir) \
                -MMD -MF $(DEPDIR)/rtcom_wrap.d -o $@ $<

rtcom_wrap.h: $(SWIG_SOURCES)
        $(SWIG) $(SWIG_PYTHON_OPT) -I$(top_srcdir) \
                -MMD -MF $(DEPDIR)/rtcom_wrap.d -oh $@ $<
##################################################

make install calls:
../libtool --mode=install /usr/bin/install -c  '_rtcom.la' \
        '/opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.la'
which in turn calls:
/bin/sh ../libtool  --tag=CXX --mode=relink g++ -g -O2 \
        -o _rtcom.la \
        -rpath /opt/etherlab/lib/python2.5/site-packages/rtcom \
        -module _rtcom_la-rtcom_wrap.lo ../librtcom.la -lexpat
The relink calls g++, however _without_ the necessary 
"-Wl,--rpath -Wl,/opt/etherlab/lib" options to g++

The complete install log is attached.

It is then no surprise that loading the module under Python fails:
---------------------------------------------------
>>> import sys
>>> sys.path.append('/opt/etherlab/lib/python2.5/site-packages/rtcom')
>>> import rtcom
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/opt/etherlab/lib/python2.5/site-packages/rtcom/rtcom.py", line 5, in 
<module>
    import _rtcom
ImportError: librtcom.so.2: cannot open shared object file: No such file or 
directory
---------------------------------------------------


As a workaround, I replace _rtcom_la_LDFLAGS in Makefile.am with:
_rtcom_la_LDFLAGS = -module -Wl,--rpath -Wl,$(libdir)
Then it works.

As I understand it, this should be libtool's task. All the necessary 
information about where rtcom.so is installed is contained in the rtcom.la 
file. What am I missing out on here?

My autotools configuration is:
autoconf-2.60-21
automake-1.9.6-35
libtool-1.5.22-34

I am also using ac_pkg_swig.m4  ac_python_devel.m4  swig_enable_cxx.m4  
swig_python.m4 downloaded from http://autoconf-archive.cryp.to/

Many thanks in advance for any help.

- Richard
make  install-am
make[1]: Entering directory `/home/rich/msr-gate/rtcom/pyext'
make[2]: Entering directory `/home/rich/msr-gate/rtcom/pyext'
test -z "/opt/etherlab/lib/python2.5/site-packages/rtcom" || mkdir -p -- "/opt/etherlab/lib/python2.5/site-packages/rtcom"
 /bin/sh ../libtool --mode=install /usr/bin/install -c  '_rtcom.la' '/opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.la'
libtool: install: warning: relinking `_rtcom.la'
(cd /home/rich/msr-gate/rtcom/pyext; /bin/sh ../libtool  --tag=CXX --mode=relink g++ -g -O2 -o _rtcom.la -rpath /opt/etherlab/lib/python2.5/site-packages/rtcom -module _rtcom_la-rtcom_wrap.lo ../librtcom.la -lexpat )
g++ -shared -nostdlib /usr/lib/gcc/i586-suse-linux/4.1.2/../../../crti.o /usr/lib/gcc/i586-suse-linux/4.1.2/crtbeginS.o  .libs/_rtcom_la-rtcom_wrap.o  -L/opt/etherlab/lib -lrtcom -lexpat -L/usr/lib/gcc/i586-suse-linux/4.1.2 -L/usr/lib/gcc/i586-suse-linux/4.1.2/../../../../i586-suse-linux/lib -L/usr/lib/gcc/i586-suse-linux/4.1.2/../../.. -lstdc++ -lm -lc -lgcc_s /usr/lib/gcc/i586-suse-linux/4.1.2/crtendS.o /usr/lib/gcc/i586-suse-linux/4.1.2/../../../crtn.o  -Wl,-soname -Wl,_rtcom.so.0 -o .libs/_rtcom.so.0.0.0
/usr/bin/install -c .libs/_rtcom.so.0.0.0T /opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.so.0.0.0
(cd /opt/etherlab/lib/python2.5/site-packages/rtcom && { ln -s -f _rtcom.so.0.0.0 _rtcom.so.0 || { rm -f _rtcom.so.0 && ln -s _rtcom.so.0.0.0 _rtcom.so.0; }; })
(cd /opt/etherlab/lib/python2.5/site-packages/rtcom && { ln -s -f _rtcom.so.0.0.0 _rtcom.so || { rm -f _rtcom.so && ln -s _rtcom.so.0.0.0 _rtcom.so; }; })
/usr/bin/install -c .libs/_rtcom.lai /opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.la
/usr/bin/install -c .libs/_rtcom.a /opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.a
chmod 644 /opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.a
ranlib /opt/etherlab/lib/python2.5/site-packages/rtcom/_rtcom.a
PATH="$PATH:/sbin" ldconfig -n /opt/etherlab/lib/python2.5/site-packages/rtcom
----------------------------------------------------------------------
Libraries have been installed in:
   /opt/etherlab/lib/python2.5/site-packages/rtcom

If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the `-LLIBDIR'
flag during linking and do at least one of the following:
   - add LIBDIR to the `LD_LIBRARY_PATH' environment variable
     during execution
   - add LIBDIR to the `LD_RUN_PATH' environment variable
     during linking
   - use the `-Wl,--rpath -Wl,LIBDIR' linker flag
   - have your system administrator add LIBDIR to `/etc/ld.so.conf'

See any operating system documentation about shared libraries for
more information, such as the ld(1) and ld.so(8) manual pages.
----------------------------------------------------------------------
test -z "/opt/etherlab/lib/python2.5/site-packages/rtcom" || mkdir -p -- "/opt/etherlab/lib/python2.5/site-packages/rtcom"
 /usr/bin/install -c -m 644 'rtcom.py' '/opt/etherlab/lib/python2.5/site-packages/rtcom/rtcom.py'
Byte-compiling python modules...
rtcom.py
Byte-compiling python modules (optimized versions) ...
rtcom.py
make[2]: Leaving directory `/home/rich/msr-gate/rtcom/pyext'
make[1]: Leaving directory `/home/rich/msr-gate/rtcom/pyext'
_______________________________________________
http://lists.gnu.org/mailman/listinfo/libtool

Reply via email to