Subject: Re: pkg/29030
To: None <darwin-pkg-people@netbsd.org, gnats-admin@netbsd.org,>
From: John D. Baker <jdbaker@mylinuxisp.com>
List: pkgsrc-bugs
Date: 12/13/2005 21:50:02
The following reply was made to PR pkg/29030; it has been noted by GNATS.

From: "John D. Baker" <jdbaker@mylinuxisp.com>
To: gnats-bugs@NetBSD.org
Cc: 
Subject: Re: pkg/29030
Date: Tue, 13 Dec 2005 15:47:17 -0600 (CST)

 After some experimentation, I believe I have determined is the root of
 the issue with the multiply-defined symbols.  'libtool' is constructing
 a command line with the libraries in the wrong order.
 
 MacOS X 'ld' is a single-pass linker.  As such, program object modules,
 local libraries (static or dynamic) should be specified first, and system
 libraries and frameworks should be specified last.  This is documented in
 Apple's Developer Documentation for Mac OS X and the 'ld' man page on
 MacOS X systems.
 
 The command line used to link 'scanimage' is of the form:
 
     gcc -pipe -o .libs/scanimage scanimage.o stiff.o -framework CoreServices \
       -framework IOKit -L <path to sane-backends local library> \
       ../lib/liblib.a <...>
 
 'liblib.a' contains local implementations of variables and functions about
 which the linker is complaining.  The error occurs because the library is
 specified AFTER the -framework directives, which satisifies the references
 from the system libraries.  When it then encounters 'liblib.a', it finds
 multiple definitions of the symbols.
 
 If the -framework directives are moved to the end of the command line,
 linking proceeds without error as the locally-defined symbols satisfy
 the references before the system libraries are searched, as is appropriate.
 
 So, this PR is not a problem with graphics/sane-backends per se, but a
 problem with libtool's behavior/implementation when used on MacOS X.
 
 -- 
 John D. Baker, KN5UKS                    NetBSD     Darwin/MacOS X
 jdbaker(at)mylinuxisp(dot)com                 OpenBSD            FreeBSD
 BSD -- It just sits there and _works_!
 GPG fingerprint:  D703 4A7E 479F 63F8 D3F4  BD99 9572 8F23 E4AD 1645