Date: Sat, 13 Apr 2002 01:00:34 -0600 (MDT) From: "M. Warner Losh" <imp@village.org> To: roam@ringlet.net Cc: dima@sinp.msu.ru, freebsd-hackers@FreeBSD.ORG Subject: Re: dynamic libraries Message-ID: <20020413.010034.64370390.imp@village.org> In-Reply-To: <20020413095747.E352@straylight.oblivion.bg> References: <20020413092834.A352@straylight.oblivion.bg> <20020413.004859.00083529.imp@village.org> <20020413095747.E352@straylight.oblivion.bg>
next in thread | previous in thread | raw e-mail | index | archive | help
In message: <20020413095747.E352@straylight.oblivion.bg>
Peter Pentchev <roam@ringlet.net> writes:
: On Sat, Apr 13, 2002 at 12:48:59AM -0600, M. Warner Losh wrote:
: > In message: <20020413092834.A352@straylight.oblivion.bg>
: > Peter Pentchev <roam@ringlet.net> writes:
: > : On Fri, Apr 12, 2002 at 10:09:16PM -0600, M. Warner Losh wrote:
: > : > In message: <Pine.BSF.4.43.0204121308470.4449-100000@BigKing.sinp.msu.ru>
: > : > Dmitry Mottl <dima@sinp.msu.ru> writes:
: > : > : How can I link C program with different versions of the same library?
: > : >
: > : > You can't.
: > :
: > : Okay; what exactly is it that you cannot do - link a program against
: > : two versions of the same library simultaneously (I thought so), or
: > : link a program against a *specified* version of a library (what, I think,
: > : the original poster clarifies he wants to do, for no specific reason)?
: >
: > You can't, generally, link against two different versions of the same
: > library. The reason is that you get mutiply defined symbols because
: > it is very very very rare that two different versions of the same
: > library wouldn't have any symbols that overlap.
:
: Well, actually, your 'full path' suggestion gave me an idea..
:
: [roam@straylight:p6 ~/c/misc/foo]$ cc -o foo18 foo18.c /usr/lib/libncurses.so.5 /usr/lib/compat/libncurses.so.3
: [roam@straylight:p6 ~/c/misc/foo]$ ldd ./foo18
: ./foo18:
: libncurses.so.5 => /usr/lib/libncurses.so.5 (0x28065000)
: libncurses.so.3 => /usr/lib/compat/libncurses.so.3 (0x280a7000)
: libc.so.4 => /usr/lib/libc.so.4 (0x280b8000)
: libmytinfo.so.2 => /usr/lib/compat/libmytinfo.so.2 (0x28151000)
: [roam@straylight:p6 ~/c/misc/foo]$
:
: Duplicate symbols are not a problem - AFAIK, symbols are resolved
: in the order the libraries were specified on the linker command line,
: and, consequently, in the order the dependencies are recorded into
: the resulting executable file. So, if foo18 calls an ncurses.5 routine,
: it will be invoked from ncurses.5; if foo18 calls a routine that is
: not present in ncurses.5, it will be invoked from ncurses.3.
:
: So it is actually possible; not that I have ANY idea what the point
: would be..
Ah, this just hides the problem of incompatible interfaces :-(.
that's why the libraries have different version numbers: they have a
different API.
Warner
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20020413.010034.64370390.imp>
