Hello list, Lately, I've been playing around with an old system (NeXTSTEP 3.3) whose ar(1) implementation truncates member names to 15 characters. Generally this hasn't posed a problem, but in building the iODBC libraries with Libtool 2.4.2, I encountered linking issues traceable to this. iODBC builds a large library from a couple of smaller libraries using the Automake _LIBADD directive. I was doing a static build, so ar(1) is involved. I noticed that after Libtool unpacked the component libraries, certain members did not appear in the ar(1) invocation to create the new, combined library. As it happens, the missing members were those whose filenames were truncated. When Libtool links the new library, it ignores any file that does not match *.$objext; the all-important ".o" part was missing from these members. Attached is a proposed, first-cut patch against libtool-2.4.2 that renames truncated members in extracted-library directories, such that no further special handling is needed. This addresses 15- and 16-character truncations (per the GNU ar(1) man page, the limitation is usually one of these two), and explicitly skips a spurious file "__.SYMDEF SORTED????" that is created when unpacking archive libraries on this platform. (There may be other examples of the latter, of course.) iODBC still doesn't build for me, but at least now it's for reasons other than a craptastic ar(1) utility. --Daniel -- Daniel Richard G. || skunk@iSKUNK.ORG My ASCII-art .sig got a bad case of Times New Roman.