Hi Ralf,
 
Thanks for the response, much appreciated.  Please see my comments below.
 
> * Wintaki Hagabashi wrote on Tue, Oct 23, 2007 at 08:21:57PM CEST:> > > > We 
> are using libtool 1.5.6.> > The current release is 1.5.24. Not that it has 
> much to do with your> issue, but otherwise there are many changes since. 
> Please update.
I will look into doing this, unfortunately this is a large corporation and 
doing so may take a long time.
 > > How can we disable libtools use of rpath?> > One possibility is to install 
 > > all libraries in a directory that the> runtime linker will search by 
 > > default, such as /usr/lib[1]. Then> libtool will not add run paths to 
 > > libraries or executables, unless they> also link against other libraries 
 > > installed in unusual locations.> > The use of run paths ensures that the 
 > > installed programs can be> executed. I understand that they are not 
 > > relocatable that way.> I also understand that, since you are using Linux 
 > > and Solaris only,> there are better possibilities wrt. relocatability on 
 > > these two systems.> But they are not portable to other systems.
I understand this and think it makes perfect sense in some situations.  If I am 
building a new server and installing package X, it works perfect.  But what if 
you are releasing binaries?  Say you are Oracle for a minute, and you build you 
code into /development/build/release-1.  Now you package and ship to thousands 
of people who will install your software in any number of places.  Isn't 
LD_LIBRARY_PATH the thing to do here?  I'm not sure how else you could handle 
this?
 
See, in this particular case the customer does not have a compiler, linker, or 
make tools.  They want a tar file with binaries that they untar and run.  While 
not disagreeing with you about LD_LIBRARY_PATH, most every commercial package I 
have used required modifying LD_LIBRARY_PATH.
> For portable relocatable packages you can look into the gnulib modules> named 
> relocatable-{lib,prog} and some more.
Do you know where I could learn more about these?
 > > It is causing us trouble. The problem is we are building libraries> > that 
 > > are then later shipped and installed on other systems. We can> > not 
 > > control where they get installed since it is a customer's system. > > Now 
 > > what happened was the rpath embedded in our .so's happened to> > partially 
 > > match a broken NFS mount on a customers site. This then> > caused the 
 > > system to hang for a long time when trying to start the> > apps because 
 > > the system tried to look in the rpath that was not valid. > > Really this 
 > > is a problem with the customer's system setup.
Yes, I would agree, but when the customer calls me up and then says "well why 
the hell are you looking in /development/build anyway?" I'm not sure what my 
response is.  True, it is technically a customer issue but in this case, it 
took them some time to figure it out.  Even ldd would hang trying to mount 
/development.
 > > I really don't see the need for rpath at all, maybe it makes sense on> > 
 > > other systems, but we are on Linux & Solaris. > > Well, if I install a 
 > > shared library in /opt/foo-package/lib and link a> program against it 
 > > without an rpath, how will the runtime linker find> it otherwise? Setting 
 > > LD_LIBRARY_PATH is very bad, for many reasons.> > Moreover, if I want to 
 > > execute an uninstalled program that links against> the just-build 
 > > (uninstalled) libraries, then not using rpaths at all> makes this very 
 > > error-prone, or just breaks it. Libtool takes care of> this, and it's 
 > > typically needed for "make check", for test programs and> so on.
Yes, this I agree is great for development.  I have no issues at all here and 
love this ability.  However, I don't see how it is useful though when releasing 
binaries.
 > > Is there a way to disable this? I googled a bit but most of the> > 
 > > discussions seem to be from around 1999 on the debian mailing list. > > 
 > > Well, likely because it is not a good idea to disable this globally.> > 
 > > Besides the two possibilities mentioned above (install in searched> 
 > > directories, use the gnulib modules), there is a very hacky way to get> 
 > > libtool not to add rpaths at all. After configure, in the generated> 
 > > libtool script, set hardcode_libdir_flag_spec to " ", once near the> 
 > > beginning and several times at the end of the script. But if you go> that 
 > > way, then please don't complain if things break (and please> mention it if 
 > > you do).
Thanks, I did see that but wanted to avoid hacking libtool if I could.
 > Hope that helps.> > Cheers,> Ralf> 
Thanks for the reply, much appreciated.
 
 
_________________________________________________________________
News, entertainment and everything you care about at Live.com. Get it now!
http://www.live.com/getstarted.aspx
_______________________________________________
http://lists.gnu.org/mailman/listinfo/libtool

Reply via email to