| \input texinfo @c -*-texinfo-*- |
| @c %**start of header |
| @setfilename libtool.info |
| @settitle Libtool |
| @c For double-sided printing, uncomment: |
| @c @setchapternewpage odd |
| @c %**end of header |
| |
| @include version.texi |
| @set BUGADDR the libtool mailing list @email{bug-libtool@@gnu.org} |
| @set objdir .libs |
| |
| @dircategory GNU programming tools |
| @direntry |
| * Libtool: (libtool). Generic shared library support script. |
| @end direntry |
| |
| @dircategory Individual utilities |
| @direntry |
| * libtoolize: (libtool)Invoking libtoolize. Adding libtool support. |
| @end direntry |
| |
| @ifinfo |
| This file documents GNU Libtool @value{VERSION} |
| |
| Copyright (C) 1996-1998 Free Software Foundation, Inc. |
| |
| Permission is granted to make and distribute verbatim copies of this |
| manual provided the copyright notice and this permission notice are |
| preserved on all copies. |
| |
| @ignore |
| Permission is granted to process this file through TeX and print the |
| results, provided the printed document carries copying permission notice |
| identical to this one except for the removal of this paragraph |
| |
| |
| @end ignore |
| Permission is granted to copy and distribute modified versions of this |
| manual under the conditions for verbatim copying, provided that the |
| entire resulting derived work is distributed under the terms of a |
| permission notice identical to this one. |
| |
| Permission is granted to copy and distribute translations of this manual |
| into another language, under the above conditions for modified versions, |
| except that this permission notice may be stated in a translation |
| approved by the Foundation. |
| @end ifinfo |
| |
| |
| @titlepage |
| @title GNU Libtool |
| @subtitle For version @value{VERSION}, @value{UPDATED} |
| @author Gordon Matzigkeit |
| |
| @page |
| @vskip 0pt plus 1filll |
| Copyright @copyright{} 1996-1998 Free Software Foundation, Inc. |
| |
| Permission is granted to make and distribute verbatim copies of this |
| manual provided the copyright notice and this permission notice are |
| preserved on all copies. |
| |
| Permission is granted to copy and distribute modified versions of this |
| manual under the conditions for verbatim copying, provided that the |
| entire resulting derived work is distributed under the terms of a |
| permission notice identical to this one. |
| |
| Permission is granted to copy and distribute translations of this manual |
| into another language, under the above conditions for modified versions, |
| except that this permission notice may be stated in a translation |
| approved by the Free Software Foundation. |
| @end titlepage |
| |
| @c Put everything in one index (arbitrarily chosen to be the concept index). |
| @syncodeindex vr cp |
| @syncodeindex fn cp |
| @syncodeindex tp cp |
| @synindex pg cp |
| |
| @ifinfo |
| @node Top, Introduction, (dir), (dir) |
| @comment node-name, next, previous, up |
| @top Shared library support for GNU |
| |
| This file documents GNU Libtool, a script that allows package developers |
| to provide generic shared library support. This edition documents |
| version @value{VERSION}. |
| |
| @xref{Reporting bugs}, for information on how to report problems with |
| libtool. |
| |
| @menu |
| * Introduction:: What the heck is libtool? |
| * Libtool paradigm:: How libtool's view of libraries is different. |
| * Using libtool:: Example of using libtool to build libraries. |
| * Invoking libtool:: Running the @code{libtool} script. |
| * Integrating libtool:: Using libtool in your own packages. |
| * Versioning:: Using library interface versions. |
| * Library tips:: Tips for library interface design. |
| * Inter-library dependencies:: Libraries that depend on other libraries. |
| * Dlopened modules:: @code{dlopen}ing libtool-created libraries. |
| * Other languages:: Using libtool without a C compiler. |
| * Troubleshooting:: When libtool doesn't work as advertised. |
| * Maintaining:: Information used by the libtool maintainer. |
| * Index:: Full index. |
| |
| @detailmenu --- The Detailed Node Listing --- |
| |
| Introduction |
| |
| * Motivation:: Why does GNU need a libtool? |
| * Issues:: The problems that need to be addressed. |
| * Other implementations:: How other people have solved these issues. |
| * Postmortem:: Learning from past difficulties. |
| |
| Using libtool |
| |
| * Creating object files:: Compiling object files for libraries. |
| * Linking libraries:: Creating libraries from object files. |
| * Linking executables:: Linking object files against libtool libraries. |
| * Debugging executables:: Running GDB on libtool-generated programs. |
| * Installing libraries:: Making libraries available to users. |
| * Installing executables:: Making programs available to users. |
| * Static libraries:: When shared libraries are not wanted. |
| |
| Invoking @code{libtool} |
| |
| * Compile mode:: Creating library object files. |
| * Link mode:: Generating executables and libraries. |
| * Execute mode:: Debugging libtool-generated programs. |
| * Install mode:: Making libraries and executables public. |
| * Finish mode:: Completing a library installation. |
| * Uninstall mode:: Removing executables and libraries. |
| |
| Integrating libtool with your package |
| |
| * Makefile rules:: Writing @file{Makefile} rules for libtool. |
| * Using Automake:: Automatically supporting libtool. |
| * Configuring:: Configuring libtool for a host system. |
| * Distributing:: What files to distribute with your package. |
| * Static-only libraries:: Sometimes shared libraries are just a pain. |
| |
| Configuring libtool |
| |
| * Invoking ltconfig:: @code{ltconfig} command line options. |
| * ltconfig example:: Manually configuring a @code{libtool}. |
| * AM_PROG_LIBTOOL:: Configuring @code{libtool} in @file{configure.in}. |
| |
| Including libtool in your package |
| |
| * Invoking libtoolize:: @code{libtoolize} command line options. |
| * Autoconf .o macros:: Autoconf macros that set object file names. |
| |
| Library interface versions |
| |
| * Interfaces:: What are library interfaces? |
| * Libtool versioning:: Libtool's versioning system. |
| * Updating version info:: Changing version information before releases. |
| * Release numbers:: Breaking binary compatibility for aesthetics. |
| |
| Tips for interface design |
| |
| * C header files:: How to write portable include files. |
| |
| Dlopened modules |
| |
| * Building modules:: Creating dlopenable objects and libraries. |
| * Dlpreopening:: Dlopening that works on static platforms. |
| * Finding the dlname:: Choosing the right file to @code{dlopen}. |
| * Dlopen issues:: Unresolved problems that need your attention. |
| |
| Using libtool with other languages |
| |
| * C++ libraries:: |
| |
| Troubleshooting |
| |
| * Libtool test suite:: Libtool's self-tests. |
| * Reporting bugs:: How to report problems with libtool. |
| |
| The libtool test suite |
| |
| * Test descriptions:: The contents of the test suite. |
| * When tests fail:: What to do when a test fails. |
| |
| Maintenance notes for libtool |
| |
| * New ports:: How to port libtool to new systems. |
| * Tested platforms:: When libtool was last tested. |
| * Platform quirks:: Information about different library systems. |
| * libtool script contents:: Configuration information that libtool uses. |
| * Cheap tricks:: Making libtool maintainership easier. |
| |
| Platform quirks |
| |
| * References:: Finding more information. |
| * Compilers:: Creating object files from source files. |
| * Reloadable objects:: Binding object files together. |
| * Archivers:: Programs that create static archives. |
| |
| @end detailmenu |
| @end menu |
| |
| @end ifinfo |
| |
| @node Introduction |
| @chapter Introduction |
| |
| In the past, if a source code package developer wanted to take advantage |
| of the power of shared libraries, he needed to write custom support code |
| for each platform on which his package ran. He also had to design a |
| configuration interface so that the package installer could choose what sort of |
| libraries were built. |
| |
| GNU Libtool simplifies the developer's job by encapsulating both the |
| platform-specific dependencies, and the user interface, in a single |
| script. GNU Libtool is designed so that the complete functionality of |
| each host type is available via a generic interface, but nasty quirks |
| are hidden from the programmer. |
| |
| GNU Libtool's consistent interface is reassuring@dots{} users don't need |
| to read obscure documentation in order to have their favorite source |
| package build shared libraries. They just run your package |
| @code{configure} script (or equivalent), and libtool does all the dirty |
| work. |
| |
| There are several examples throughout this document. All assume the |
| same environment: we want to build a library, @file{libhello}, in a |
| generic way. |
| |
| @file{libhello} could be a shared library, a static library, or |
| both@dots{} whatever is available on the host system, as long as libtool |
| has been ported to it. |
| |
| This chapter explains the original design philosophy of libtool. Feel |
| free to skip to the next chapter, unless you are interested in history, |
| or want to write code to extend libtool in a consistent way. |
| |
| @menu |
| * Motivation:: Why does GNU need a libtool? |
| * Issues:: The problems that need to be addressed. |
| * Other implementations:: How other people have solved these issues. |
| * Postmortem:: Learning from past difficulties. |
| @end menu |
| |
| @node Motivation |
| @section Motivation for writing libtool |
| |
| @cindex motivation for writing libtool |
| @cindex design philosophy |
| Since early 1995, several different GNU developers have recognized the |
| importance of having shared library support for their packages. The |
| primary motivation for such a change is to encourage modularity and |
| reuse of code (both conceptually and physically) in GNU programs. |
| |
| Such a demand means that the way libraries are built in GNU packages |
| needs to be general, to allow for any library type the package installer |
| might want. The problem is compounded by the absence of a standard |
| procedure for creating shared libraries on different platforms. |
| |
| The following sections outline the major issues facing shared library |
| support in GNU, and how shared library support could be standardized |
| with libtool. |
| |
| @cindex specifications for libtool |
| @cindex libtool specifications |
| The following specifications were used in developing and evaluating this |
| system: |
| |
| @enumerate |
| @item |
| The system must be as elegant as possible. |
| |
| @item |
| The system must be fully integrated with the GNU Autoconf and Automake |
| utilities, so that it will be easy for GNU maintainers to use. However, |
| the system must not require these tools, so that it can be used by |
| non-GNU packages. |
| |
| @item |
| Portability to other (non-GNU) architectures and tools is desirable. |
| @end enumerate |
| |
| @node Issues |
| @section Implementation issues |
| |
| @cindex tricky design issues |
| @cindex design issues |
| The following issues need to be addressed in any reusable shared library |
| system, specifically libtool: |
| |
| @enumerate |
| @item |
| The package installer should be able to control what sort of libraries |
| are built. |
| |
| @item |
| It can be tricky to run dynamically linked programs whose libraries have |
| not yet been installed. @code{LD_LIBRARY_PATH} must be set properly (if |
| it is supported), or programs fail to run. |
| |
| @item |
| The system must operate consistently even on hosts which don't support |
| shared libraries. |
| |
| @item |
| The commands required to build shared libraries may differ wildly from |
| host to host. These need to be determined at configure time in |
| a consistent way. |
| |
| @item |
| It is not always obvious with which suffix a shared library should be |
| installed. This makes it difficult for @file{Makefile} rules, since they |
| generally assume that file names are the same from host to host. |
| |
| @item |
| The system needs a simple library version number abstraction, so that |
| shared libraries can be upgraded in place. The programmer should be |
| informed how to design the interfaces to the library to maximize binary |
| compatibility. |
| |
| @item |
| The install @file{Makefile} target should warn the package installer to set |
| the proper environment variables (@code{LD_LIBRARY_PATH} or equivalent), |
| or run @code{ldconfig}. |
| @end enumerate |
| |
| @node Other implementations |
| @section Other implementations |
| |
| Even before libtool was developed, many free software packages built and |
| installed their own shared libraries. At first, these packages were |
| examined to avoid reinventing existing features. |
| |
| Now it is clear that none of these packages have documented the details |
| of shared library systems that libtool requires. So, other packages |
| have been more or less abandoned as influences. |
| |
| @node Postmortem |
| @section A postmortem analysis of other implementations |
| |
| @cindex other implementations, flaws in |
| @cindex reusability of library systems |
| In all fairness, each of the implementations that were examined do the |
| job that they were intended to do, for a number of different host |
| systems. However, none of these solutions seem to function well as a |
| generalized, reusable component. |
| |
| @cindex complexity of library systems |
| Most were too complex to use (much less modify) without understanding |
| exactly what the implementation does, and they were generally not |
| documented. |
| |
| The main difficulty is that different vendors have different views of |
| what libraries are, and none of the packages which were examined seemed |
| to be confident enough to settle on a single paradigm that just |
| @emph{works}. |
| |
| Ideally, libtool would be a standard that would be implemented as series |
| of extensions and modifications to existing library systems to make them |
| work consistently. However, it is not an easy task to convince |
| operating system developers to mend their evil ways, and people want to |
| build shared libraries right now, even on buggy, broken, confused |
| operating systems. |
| |
| For this reason, libtool was designed as an independent shell script. |
| It isolates the problems and inconsistencies in library building that |
| plague @file{Makefile} writers by wrapping the compiler suite on |
| different platforms with a consistent, powerful interface. |
| |
| With luck, libtool will be useful to and used by the GNU community, and |
| that the lessons that were learned in writing it will be taken up by |
| designers of future library systems. |
| |
| @node Libtool paradigm |
| @chapter The libtool paradigm |
| |
| At first, libtool was designed to support an arbitrary number of library |
| object types. After libtool was ported to more platforms, a new |
| paradigm gradually developed for describing the relationship between |
| libraries and programs. |
| |
| @cindex definition of libraries |
| @cindex libraries, definition of |
| In summary, ``libraries are programs with multiple entry points, and |
| more formally defined interfaces.'' |
| |
| Version 0.7 of libtool was a complete redesign and rewrite of libtool to |
| reflect this new paradigm. So far, it has proved to be successful: |
| libtool is simpler and more useful than before. |
| |
| The best way to introduce the libtool paradigm is to contrast it with |
| the paradigm of existing library systems, with examples from each. It |
| is a new way of thinking, so it may take a little time to absorb, but |
| when you understand it, the world becomes simpler. |
| |
| @node Using libtool |
| @chapter Using libtool |
| |
| @cindex examples of using libtool |
| @cindex libtool examples |
| It makes little sense to talk about using libtool in your own packages |
| until you have seen how it makes your life simpler. The examples in |
| this chapter introduce the main features of libtool by comparing the |
| standard library building procedure to libtool's operation on two |
| different platforms: |
| |
| @table @samp |
| @item a23 |
| An Ultrix 4.2 platform with only static libraries. |
| |
| @item burger |
| A NetBSD/i386 1.2 platform with shared libraries. |
| @end table |
| |
| You can follow these examples on your own platform, using the |
| preconfigured libtool script that was installed with libtool |
| (@pxref{Configuring}). |
| |
| Source files for the following examples are taken from the @file{demo} |
| subdirectory of the libtool distribution. Assume that we are building a |
| library, @file{libhello}, out of the files @file{foo.c} and |
| @file{hello.c}. |
| |
| Note that the @file{foo.c} source file uses the @code{cos} math library |
| function, which is usually found in the standalone math library, and not |
| the C library (@pxref{Trig Functions, , Trigonometric Functions, libc, |
| The GNU C Library Reference Manual}). So, we need to add @kbd{-lm} to |
| the end of the link line whenever we link @file{foo.o} or @file{foo.lo} |
| into an executable or a library (@pxref{Inter-library dependencies}). |
| |
| The same rule applies whenever you use functions that don't appear in |
| the standard C library@dots{} you need to add the appropriate |
| @kbd{-l@var{name}} flag to the end of the link line when you link |
| against those objects. |
| |
| After we have built that library, we want to create a program by linking |
| @file{main.o} against @file{libhello}. |
| |
| @menu |
| * Creating object files:: Compiling object files for libraries. |
| * Linking libraries:: Creating libraries from object files. |
| * Linking executables:: Linking object files against libtool libraries. |
| * Debugging executables:: Running GDB on libtool-generated programs. |
| * Installing libraries:: Making libraries available to users. |
| * Installing executables:: Making programs available to users. |
| * Static libraries:: When shared libraries are not wanted. |
| @end menu |
| |
| @node Creating object files |
| @section Creating object files |
| |
| @cindex compiling object files |
| @cindex object files, compiling |
| To create an object file from a source file, the compiler is invoked |
| with the `-c' flag (and any other desired flags): |
| |
| @example |
| burger$ @kbd{gcc -g -O -c main.c} |
| burger$ |
| @end example |
| |
| The above compiler command produces an object file, @file{main.o}, from |
| the source file @file{main.c}. |
| |
| For most library systems, creating object files that become part of a |
| static library is as simple as creating object files that are linked to |
| form an executable: |
| |
| @example |
| burger$ @kbd{gcc -g -O -c foo.c} |
| burger$ @kbd{gcc -g -O -c hello.c} |
| burger$ |
| @end example |
| |
| @cindex position-independent code |
| @cindex PIC (position-independent code) |
| Shared libraries, however, may only be built from |
| @dfn{position-independent code} (PIC). So, special flags must be passed |
| to the compiler to tell it to generate PIC rather than the standard |
| position-dependent code. |
| |
| @cindex library object file |
| @cindex @samp{.lo} files |
| @cindex object files, library |
| Since this is a library implementation detail, libtool hides the |
| complexity of PIC compiler flags by using separate library object files |
| (which end in @samp{.lo} instead of @samp{.o}). On systems without shared |
| libraries (or without special PIC compiler flags), these library object |
| files are identical to ``standard'' object files. |
| |
| To create library object files for @file{foo.c} and @file{hello.c}, |
| simply invoke libtool with the standard compilation command as |
| arguments (@pxref{Compile mode}): |
| |
| @example |
| a23$ @kbd{libtool gcc -g -O -c foo.c} |
| gcc -g -O -c foo.c |
| echo timestamp > foo.lo |
| a23$ @kbd{libtool gcc -g -O -c hello.c} |
| gcc -g -O -c hello.c |
| echo timestamp > hello.lo |
| a23$ |
| @end example |
| |
| Note that libtool creates two files for each invocation. The @samp{.lo} |
| file is a library object, which may be built into a shared library, and |
| the @samp{.o} file is a standard object file. On @samp{a23}, the |
| library objects are just timestamps, because only static libraries are |
| supported. |
| |
| On shared library systems, libtool automatically inserts the PIC |
| generation flags into the compilation command, so that the library |
| object and the standard object differ: |
| |
| @example |
| burger$ @kbd{libtool gcc -g -O -c foo.c} |
| gcc -g -O -c -fPIC -DPIC foo.c |
| mv -f foo.o foo.lo |
| gcc -g -O -c foo.c >/dev/null 2>&1 |
| burger$ @kbd{libtool gcc -g -O -c hello.c} |
| gcc -g -O -c -fPIC -DPIC hello.c |
| mv -f hello.o hello.lo |
| gcc -g -O -c hello.c >/dev/null 2>&1 |
| burger$ |
| @end example |
| |
| Notice that the second run of GCC has its output discarded. This is |
| done so that compiler warnings aren't annoyingly duplicated. |
| |
| @node Linking libraries |
| @section Linking libraries |
| |
| @pindex ar |
| Without libtool, the programmer would invoke the @code{ar} command to |
| create a static library: |
| |
| @example |
| burger$ @kbd{ar cru libhello.a hello.o foo.o} |
| burger$ |
| @end example |
| |
| @pindex ranlib |
| But of course, that would be too simple, so many systems require that |
| you run the @code{ranlib} command on the resulting library (to give it |
| better karma, or something): |
| |
| @example |
| burger$ @kbd{ranlib libhello.a} |
| burger$ |
| @end example |
| |
| It seems more natural to use the C compiler for this task, given |
| libtool's ``libraries are programs'' approach. So, on platforms without |
| shared libraries, libtool simply acts as a wrapper for the system |
| @code{ar} (and possibly @code{ranlib}) commands. |
| |
| @cindex libtool libraries |
| @cindex @samp{.la} files |
| Again, the libtool library name differs from the standard name (it has a |
| @samp{.la} suffix instead of a @samp{.a} suffix). The arguments to libtool are |
| the same ones you would use to produce an executable named |
| @file{libhello.la} with your compiler (@pxref{Link mode}): |
| |
| @example |
| a23$ @kbd{libtool gcc -g -O -o libhello.la foo.o hello.o} |
| libtool: cannot build libtool library `libhello.la' from non-libtool \ |
| objects |
| a23$ |
| @end example |
| |
| Aha! Libtool caught a common error@dots{} trying to build a library |
| from standard objects instead of library objects. This doesn't matter |
| for static libraries, but on shared library systems, it is of great |
| importance. |
| |
| So, let's try again, this time with the library object files. Remember |
| also that we need to add @kbd{-lm} to the link command line because |
| @file{foo.c} uses the @code{cos} math library function (@pxref{Using |
| libtool}). |
| |
| Another complication in building shared libraries is that we need to |
| specify the path to the directory in which they (eventually) will be |
| installed (in this case, @file{/usr/local/lib})@footnote{If you don't |
| specify an @code{rpath}, then libtool builds a libtool convenience |
| archive, not a shared library (@pxref{Static libraries}).}: |
| |
| @example |
| a23$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \ |
| -rpath /usr/local/lib -lm} |
| mkdir @value{objdir} |
| ar cru @value{objdir}/libhello.a foo.o hello.o |
| ranlib @value{objdir}/libhello.a |
| creating libhello.la |
| a23$ |
| @end example |
| |
| Now, let's try the same trick on the shared library platform: |
| |
| @example |
| burger$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \ |
| -rpath /usr/local/lib -lm} |
| mkdir @value{objdir} |
| ld -Bshareable -o @value{objdir}/libhello.so.0.0 foo.lo hello.lo -lm |
| ar cru @value{objdir}/libhello.a foo.o hello.o |
| ranlib @value{objdir}/libhello.a |
| creating libhello.la |
| burger$ |
| @end example |
| |
| Now that's significantly cooler@dots{} libtool just ran an obscure |
| @code{ld} command to create a shared library, as well as the static |
| library. |
| |
| @cindex @file{@value{objdir}} subdirectory |
| Note how libtool creates extra files in the @file{@value{objdir}} |
| subdirectory, rather than the current directory. This feature is to |
| make it easier to clean up the build directory, and to help ensure that |
| other programs fail horribly if you accidentally forget to use libtool |
| when you should. |
| |
| @node Linking executables |
| @section Linking executables |
| |
| @cindex linking against installed libraries |
| If you choose at this point to @dfn{install} the library (put it in a |
| permanent location) before linking executables against it, then you |
| don't need to use libtool to do the linking. Simply use the appropriate |
| @samp{-L} and @samp{-l} flags to specify the library's location. |
| |
| @cindex buggy system linkers |
| Some system linkers insist on encoding the full directory name of each |
| shared library in the resulting executable. Libtool has to work around |
| this misfeature by special magic to ensure that only permanent directory |
| names are put into installed executables. |
| |
| @cindex security problems with buggy linkers |
| @cindex bugs, subtle ones caused by buggy linkers |
| The importance of this bug must not be overlooked: it won't cause |
| programs to crash in obvious ways. It creates a security hole, |
| and possibly even worse, if you are modifying the library source code |
| after you have installed the package, you will change the behaviour of |
| the installed programs! |
| |
| So, if you want to link programs against the library before you install |
| it, you must use libtool to do the linking. |
| |
| @cindex linking against uninstalled libraries |
| Here's the old way of linking against an uninstalled library: |
| |
| @example |
| burger$ @kbd{gcc -g -O -o hell.old main.o libhello.a -lm} |
| burger$ |
| @end example |
| |
| Libtool's way is almost the same@footnote{However, you should never use |
| @samp{-L} or @samp{-l} flags to link against an uninstalled libtool |
| library. Just specify the relative path to the @samp{.la} file, such as |
| @file{../intl/libintl.la}. This is a design decision to eliminate any |
| ambiguity when linking against uninstalled shared libraries.} |
| (@pxref{Link mode}): |
| |
| @example |
| a23$ @kbd{libtool gcc -g -O -o hell main.o libhello.la -lm} |
| gcc -g -O -o hell main.o ./@value{objdir}/libhello.a -lm |
| a23$ |
| @end example |
| |
| That looks too simple to be true. All libtool did was transform |
| @file{libhello.la} to @file{./@value{objdir}/libhello.a}, but remember |
| that @samp{a23} has no shared libraries. |
| |
| On @samp{burger} the situation is different: |
| |
| @example |
| burger$ @kbd{libtool gcc -g -O -o hell main.o libhello.la -lm} |
| gcc -g -O -o @value{objdir}/hell main.o -L./@value{objdir} -R/usr/local/lib -lhello -lm |
| creating hell |
| burger$ |
| @end example |
| |
| @cindex wrapper scripts for programs |
| @cindex program wrapper scripts |
| Notice that the executable, @code{hell}, was actually created in the |
| @file{@value{objdir}} subdirectory. Then, a wrapper script was created |
| in the current directory. |
| |
| On NetBSD 1.2, libtool encodes the installation directory of |
| @file{libhello}, by using the @samp{-R/usr/local/lib} compiler flag. |
| Then, the wrapper script guarantees that the executable finds the |
| correct shared library (the one in @file{./@value{objdir}}) until it is |
| properly installed. |
| |
| Let's compare the two different programs: |
| |
| @example |
| burger$ @kbd{time ./hell.old} |
| Welcome to GNU Hell! |
| ** This is not GNU Hello. There is no built-in mail reader. ** |
| 0.21 real 0.02 user 0.08 sys |
| burger$ @kbd{time ./hell} |
| Welcome to GNU Hell! |
| ** This is not GNU Hello. There is no built-in mail reader. ** |
| 0.63 real 0.09 user 0.59 sys |
| burger$ |
| @end example |
| |
| The wrapper script takes significantly longer to execute, but at least |
| the results are correct, even though the shared library hasn't been |
| installed yet. |
| |
| So, what about all the space savings that shared libraries are supposed |
| to yield? |
| |
| @example |
| burger$ @kbd{ls -l hell.old libhello.a} |
| -rwxr-xr-x 1 gord gord 15481 Nov 14 12:11 hell.old |
| -rw-r--r-- 1 gord gord 4274 Nov 13 18:02 libhello.a |
| burger$ @kbd{ls -l @value{objdir}/hell @value{objdir}/libhello.*} |
| -rwxr-xr-x 1 gord gord 11647 Nov 14 12:10 @value{objdir}/hell |
| -rw-r--r-- 1 gord gord 4274 Nov 13 18:44 @value{objdir}/libhello.a |
| -rwxr-xr-x 1 gord gord 12205 Nov 13 18:44 @value{objdir}/libhello.so.0.0 |
| burger$ |
| @end example |
| |
| Well, that sucks. Maybe I should just scrap this project and take up |
| basket weaving. |
| |
| Actually, it just proves an important point: shared libraries incur |
| overhead because of their (relative) complexity. In this situation, the |
| price of being dynamic is eight kilobytes, and the payoff is about four |
| kilobytes. So, having a shared @file{libhello} won't be an advantage |
| until we link it against at least a few more programs. |
| |
| @node Debugging executables |
| @section Debugging executables |
| |
| If @file{hell} was a complicated program, you would certainly want to |
| test and debug it before installing it on your system. In the above |
| section, you saw how the libtool wrapper script makes it possible to run |
| the program directly, but unfortunately, this mechanism interferes with |
| the debugger: |
| |
| @example |
| burger$ @kbd{gdb hell} |
| GDB is free software and you are welcome to distribute copies of it |
| under certain conditions; type "show copying" to see the conditions. |
| There is no warranty for GDB; type "show warranty" for details. |
| GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc. |
| |
| "hell": not in executable format: File format not recognized |
| |
| (gdb) @kbd{quit} |
| burger$ |
| @end example |
| |
| Sad. It doesn't work because GDB doesn't know where the executable |
| lives. So, let's try again, by invoking GDB directly on the executable: |
| |
| @example |
| burger$ @kbd{gdb @value{objdir}/hell} |
| trick:/home/src/libtool/demo$ gdb .libs/hell |
| GDB is free software and you are welcome to distribute copies of it |
| under certain conditions; type "show copying" to see the conditions. |
| There is no warranty for GDB; type "show warranty" for details. |
| GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc. |
| (gdb) @kbd{break main} |
| Breakpoint 1 at 0x8048547: file main.c, line 29. |
| (gdb) @kbd{run} |
| Starting program: /home/src/libtool/demo/.libs/hell |
| /home/src/libtool/demo/.libs/hell: can't load library 'libhello.so.2' |
| |
| Program exited with code 020. |
| (gdb) @kbd{quit} |
| burger$ |
| @end example |
| |
| Argh. Now GDB complains because it cannot find the shared library that |
| @file{hell} is linked against. So, we must use libtool in order to |
| properly set the library path and run the debugger. Fortunately, we can |
| forget all about the @file{@value{objdir}} directory, and just run it on |
| the executable wrapper (@pxref{Execute mode}): |
| |
| @example |
| burger$ @kbd{libtool gdb hell} |
| GDB is free software and you are welcome to distribute copies of it |
| under certain conditions; type "show copying" to see the conditions. |
| There is no warranty for GDB; type "show warranty" for details. |
| GDB 4.16 (i386-unknown-netbsd), (C) 1996 Free Software Foundation, Inc. |
| (gdb) @kbd{break main} |
| Breakpoint 1 at 0x8048547: file main.c, line 29. |
| (gdb) @kbd{run} |
| Starting program: /home/src/libtool/demo/.libs/hell |
| |
| Breakpoint 1, main (argc=1, argv=0xbffffc40) at main.c:29 |
| 29 printf ("Welcome to GNU Hell!\n"); |
| (gdb) @kbd{quit} |
| The program is running. Quit anyway (and kill it)? (y or n) @kbd{y} |
| burger$ |
| @end example |
| |
| @node Installing libraries |
| @section Installing libraries |
| |
| @pindex strip |
| Installing libraries on a non-libtool system is quite |
| straightforward@dots{} just copy them into place:@footnote{Don't |
| accidentally strip the libraries, though, or they will be unusable.} |
| |
| @pindex su |
| @example |
| burger$ @kbd{su} |
| Password: @kbd{********} |
| burger# @kbd{cp libhello.a /usr/local/lib/libhello.a} |
| burger# |
| @end example |
| |
| Oops, don't forget the @code{ranlib} command: |
| |
| @example |
| burger# @kbd{ranlib /usr/local/lib/libhello.a} |
| burger# |
| @end example |
| |
| @pindex install |
| Libtool installation is quite simple, as well. Just use the |
| @code{install} or @code{cp} command that you normally would |
| (@pxref{Install mode}): |
| |
| @example |
| a23# @kbd{libtool cp libhello.la /usr/local/lib/libhello.la} |
| cp libhello.la /usr/local/lib/libhello.la |
| cp @value{objdir}/libhello.a /usr/local/lib/libhello.a |
| ranlib /usr/local/lib/libhello.a |
| a23# |
| @end example |
| |
| Note that the libtool library @file{libhello.la} is also installed, to |
| help libtool with uninstallation (@pxref{Uninstall mode}) and to help |
| programs with dlopening (@pxref{Dlopened modules}). |
| |
| Here is the shared library example: |
| |
| @example |
| burger# @kbd{libtool install -c libhello.la /usr/local/lib/libhello.la} |
| install -c @value{objdir}/libhello.so.0.0 /usr/local/lib/libhello.so.0.0 |
| install -c libhello.la /usr/local/lib/libhello.la |
| install -c @value{objdir}/libhello.a /usr/local/lib/libhello.a |
| ranlib /usr/local/lib/libhello.a |
| burger# |
| @end example |
| |
| @cindex stripping libraries |
| @cindex libraries, stripping |
| It is safe to specify the @samp{-s} (strip symbols) flag if you use a |
| BSD-compatible install program when installing libraries. |
| Libtool will either ignore the @samp{-s} flag, or will run a program |
| that will strip only debugging and compiler symbols from the library. |
| |
| Once the libraries have been put in place, there may be some additional |
| configuration that you need to do before using them. First, you must |
| make sure that where the library is installed actually agrees with the |
| @samp{-rpath} flag you used to build it. |
| |
| @cindex postinstallation |
| @cindex installation, finishing |
| @cindex libraries, finishing installation |
| Then, running @samp{libtool -n --finish @var{libdir}} can give you |
| further hints on what to do (@pxref{Finish mode}): |
| |
| @example |
| burger# @kbd{libtool -n --finish /usr/local/lib} |
| PATH="$PATH:/sbin" ldconfig -m /usr/local/lib |
| ----------------------------------------------------------------- |
| Libraries have been installed in: |
| /usr/local/lib |
| |
| To link against installed libraries in a given directory, LIBDIR, |
| you must use the `-LLIBDIR' flag during linking. |
| |
| You will also need to do 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 `-RLIBDIR' linker flag |
| |
| See any operating system documentation about shared libraries for |
| more information, such as the ld and ld.so manual pages. |
| ----------------------------------------------------------------- |
| burger# |
| @end example |
| |
| After you have completed these steps, you can go on to begin using the |
| installed libraries. You may also install any executables that depend |
| on libraries you created. |
| |
| @node Installing executables |
| @section Installing executables |
| |
| If you used libtool to link any executables against uninstalled libtool |
| libraries (@pxref{Linking executables}), you need to use libtool to |
| install the executables after the libraries have been installed |
| (@pxref{Installing libraries}). |
| |
| So, for our Ultrix example, we would run: |
| |
| @example |
| a23# libtool install -c hell /usr/local/bin/hell |
| install -c hell /usr/local/bin/hell |
| a23# |
| @end example |
| |
| On shared library systems, libtool just ignores the wrapper script and |
| installs the correct binary: |
| |
| @example |
| burger# libtool install -c hell /usr/local/bin/hell |
| install -c @value{objdir}/hell /usr/local/bin/hell |
| burger# |
| @end example |
| |
| @node Static libraries |
| @section Linking static libraries |
| |
| @cindex static linking |
| @cindex convenience libraries |
| Why return to @code{ar} and @code{ranlib} silliness when you've had a |
| taste of libtool? Well, sometimes it is desirable to create a static |
| archive that can never be shared. The most frequent case is when you |
| have a ``convenience library'' that is a collection of related object |
| files without a really nice interface. |
| |
| If you create a libtool library (@samp{.la} file) without using the |
| @samp{-rpath} flag, then a libtool convenience library is generated. |
| You can use these libraries just as if they were libtool object files: |
| you can even use them to build other libtool libraries. |
| |
| If you just want a static convenience library, then you should just |
| ignore libtool entirely, and use the old @code{ar} and @code{ranlib} |
| commands. |
| |
| If you want to install a convenience library (but you probably don't), |
| then you may use libtool: |
| |
| @example |
| burger$ @kbd{libtool ./install-sh -c libhello.a /local/lib/libhello.a} |
| ./install-sh -c libhello.a /local/lib/libhello.a |
| ranlib /local/lib/libhello.a |
| burger$ |
| @end example |
| |
| Using libtool for static library installation protects your library from |
| being accidentally stripped (if the installer used the @samp{-s} flag), |
| as well as automatically running the correct @code{ranlib} command. |
| |
| @cindex standalone binaries |
| Another common situation where static linking is desirable is in |
| creating a standalone binary. Use libtool to do the linking and add the |
| @samp{-all-static} flag. |
| |
| @node Invoking libtool |
| @chapter Invoking @code{libtool} |
| @pindex libtool |
| @cindex libtool command options |
| @cindex options, libtool command |
| @cindex command options, libtool |
| |
| The @code{libtool} program has the following synopsis: |
| |
| @example |
| libtool [@var{option}]@dots{} [@var{mode-arg}]@dots{} |
| @end example |
| |
| @noindent |
| and accepts the following options: |
| |
| @table @samp |
| @item --config |
| Display libtool configuration variables and exit. |
| |
| @item --debug |
| Dump a trace of shell script execution to standard output. This |
| produces a lot of output, so you may wish to pipe it to @code{less} (or |
| @code{more}) or redirect to a file. |
| |
| @item -n |
| @itemx --dry-run |
| Don't create, modify, or delete any files, just show what commands would |
| be executed by libtool. |
| |
| @item --features |
| Display basic configuration options. This provides a way for packages |
| to determine whether shared or static libraries will be built. |
| |
| @item --finish |
| Same as @samp{--mode=finish}. |
| |
| @item --help |
| Display a help message and exit. If @samp{--mode=@var{mode}} is |
| specified, then detailed help for @var{mode} is |
| displayed. |
| |
| @item --mode=@var{mode} |
| Use @var{mode} as the operation mode. By default, the operation mode is |
| inferred from the @var{mode-args}. |
| |
| If @var{mode} is specified, it must be one of the following: |
| |
| @table @samp |
| @item compile |
| Compile a source file into a libtool object. |
| |
| @item execute |
| Automatically set the library path so that another program can use |
| uninstalled libtool-generated programs or libraries. |
| |
| @item finish |
| Complete the installation of libtool libraries on the system. |
| |
| @item install |
| Install libraries or executables. |
| |
| @item link |
| Create a library or an executable. |
| |
| @item uninstall |
| Delete libraries or executables. |
| @end table |
| |
| @item --version |
| Print libtool version information and exit. |
| @end table |
| |
| The @var{mode-args} are a variable number of arguments, depending on the |
| selected operation mode. In general, each @var{mode-arg} is interpreted |
| by programs libtool invokes, rather than libtool itself. |
| |
| @menu |
| * Compile mode:: Creating library object files. |
| * Link mode:: Generating executables and libraries. |
| * Execute mode:: Debugging libtool-generated programs. |
| * Install mode:: Making libraries and executables public. |
| * Finish mode:: Completing a library installation. |
| * Uninstall mode:: Removing executables and libraries. |
| @end menu |
| |
| @node Compile mode |
| @section Compile mode |
| @cindex mode, compile |
| @cindex compile mode |
| |
| For @dfn{compile} mode, @var{mode-args} is a compiler command to be used |
| in creating a `standard' object file. These arguments should begin with |
| the name of the C compiler, and contain the @samp{-c} compiler flag so |
| that only an object file is created. |
| |
| Libtool determines the name of the output file by removing the directory |
| component from the source file name, then substituting the C source code |
| suffix @samp{.c} with the library object suffix, @samp{.lo}. |
| |
| If shared libraries are being built, any necessary PIC generation flags |
| are substituted into the compilation command. |
| |
| If the @samp{-static} option is given, then a @samp{.o} file is built, |
| even if libtool was configured with @samp{--disable-static}. |
| |
| Note that the @samp{-o} option is not supported for compile mode, |
| because it cannot be implemented properly for all platforms. It is far |
| easier just to change your Makefiles to create all the output files in |
| the current working directory. |
| |
| @node Link mode |
| @section Link mode |
| @cindex link mode |
| @cindex mode, link |
| |
| @dfn{Link} mode links together object files (including library |
| objects) to form another library or to create an executable program. |
| |
| @var{mode-args} consist of a command using the C compiler to create an |
| output file (with the @samp{-o} flag) from several object files. |
| |
| The following components of @var{mode-args} are treated specially: |
| |
| @table @samp |
| @cindex undefined symbols, allowing |
| @cindex unresolved symbols, allowing |
| @item -all-static |
| If @var{output-file} is a program, then do not link it against any |
| shared libraries at all. If @var{output-file} is a library, then only |
| create a static library. |
| |
| @item -dlopen @var{file} |
| Same as @samp{-dlpreopen @var{file}}, if native dlopening is not |
| supported on the host platform (@pxref{Dlopened modules}). Otherwise, |
| no effect. |
| |
| @item -dlpreopen @var{file} |
| Link @var{file} into the output program, and add its symbols to |
| @var{dld_preloaded_symbols} (@pxref{Dlpreopening}). |
| |
| @item -export-dynamic |
| Allow symbols from @var{output-file} to be resolved with @code{dlsym} |
| (@pxref{Dlopened modules}). |
| |
| @item -L@var{libdir} |
| Search @var{libdir} for required libraries that have already been |
| installed. |
| |
| @item -l@var{name} |
| @var{output-file} requires the installed library @file{lib@var{name}}. |
| This option is required even when @var{output-file} is not an |
| executable. |
| |
| @item -no-undefined |
| Declare that @var{output-file} does not depend on any other libraries. |
| Some platforms cannot create shared libraries that depend on other |
| libraries (@pxref{Inter-library dependencies}). |
| |
| @item -o @var{output-file} |
| Create @var{output-file} from the specified objects and libraries. |
| |
| @item -release @var{release} |
| Specify that the library was generated by release @var{release} of your |
| package, so that users can easily tell which versions are newer than |
| others. Be warned that no two releases of your package will be binary |
| compatible if you use this flag. If you want binary compatibility, use |
| the @samp{-version-info} flag instead (@pxref{Versioning}). |
| |
| @item -rpath @var{libdir} |
| If @var{output-file} is a library, it will eventually be installed in |
| @var{libdir}. |
| |
| @item -static |
| If @var{output-file} is a program, then do not link it against any |
| uninstalled shared libtool libraries. If @var{output-file} is a |
| library, then only create a static library. |
| |
| @item -version-info @var{current}[:@var{revision}[:@var{age}]] |
| If @var{output-file} is a libtool library, use interface version |
| information @var{current}, @var{revision}, and @var{age} to build it |
| (@pxref{Versioning}). Do @strong{not} use this flag to specify package |
| release information, rather see the @samp{-release} flag. |
| @end table |
| |
| If the @var{output-file} ends in @samp{.la}, then a libtool library is |
| created, which must be built only from library objects (@samp{.lo} files). |
| The @samp{-rpath} option is required. In the current implementation, |
| libtool libraries may not depend on other uninstalled libtool libraries |
| (@pxref{Inter-library dependencies}). |
| |
| If the @var{output-file} ends in @samp{.a}, then a standard library is |
| created using @code{ar} and possibly @code{ranlib}. |
| |
| @cindex partial linking |
| @cindex linking, partial |
| If @var{output-file} ends in @samp{.o} or @samp{.lo}, then a reloadable object |
| file is created from the input files (generally using @samp{ld -r}). |
| This method is often called @dfn{partial linking}. |
| |
| Otherwise, an executable program is created. |
| |
| @node Execute mode |
| @section Execute mode |
| @cindex execute mode |
| @cindex mode, execute |
| |
| For @dfn{execute} mode, the library path is automatically set, then a |
| program is executed. |
| |
| The first of the @var{mode-args} is treated as a program name, with the |
| rest as arguments to that program. |
| |
| The following components of @var{mode-args} are treated specially: |
| |
| @table @samp |
| @item -dlopen @var{file} |
| Add the directory containing @var{file} to the library path. |
| @end table |
| |
| This mode sets the library path environment variable according to any |
| @samp{-dlopen} flags. |
| |
| If any of the @var{args} are libtool executable wrappers, then they are |
| translated into the name of their corresponding uninstalled binary, and |
| any of their required library directories are added to the library path. |
| |
| @node Install mode |
| @section Install mode |
| @cindex install mode |
| @cindex mode, install |
| |
| In @dfn{install} mode, libtool interprets @var{mode-args} as an |
| installation command beginning with @code{cp}, or a BSD-compatible |
| @code{install} program. |
| |
| The rest of the @var{mode-args} are interpreted as arguments to that |
| command. |
| |
| The command is run, and any necessary unprivileged post-installation |
| commands are also completed. |
| |
| @node Finish mode |
| @section Finish mode |
| @cindex finish mode |
| @cindex mode, finish |
| |
| @dfn{Finish} mode helps system administrators install libtool libraries |
| so that they can be located and linked into user programs. |
| |
| Each @var{mode-arg} is interpreted as the name of a library directory. |
| Running this command may require superuser privileges, so the |
| @samp{--dry-run} option may be useful. |
| |
| @node Uninstall mode |
| @section Uninstall mode |
| @cindex uninstall mode |
| @cindex mode, uninstall |
| |
| @dfn{Uninstall} mode deletes installed libraries (and other files). |
| |
| The first @var{mode-arg} is the name of the program to use to delete |
| files (typically @file{/bin/rm}). |
| |
| The remaining @var{mode-args} are either flags for the deletion program |
| (beginning with a `-'), or the names of files to delete. |
| |
| @node Integrating libtool |
| @chapter Integrating libtool with your package |
| |
| This chapter describes how to integrate libtool with your packages so |
| that your users can install hassle-free shared libraries. |
| |
| @menu |
| * Makefile rules:: Writing @file{Makefile} rules for libtool. |
| * Using Automake:: Automatically supporting libtool. |
| * Configuring:: Configuring libtool for a host system. |
| * Distributing:: What files to distribute with your package. |
| * Static-only libraries:: Sometimes shared libraries are just a pain. |
| @end menu |
| |
| @node Makefile rules |
| @section Writing @file{Makefile} rules for libtool |
| @cindex Makefile |
| @cindex Makefile.am |
| @cindex Makefile.in |
| |
| Libtool is fully integrated with Automake (@pxref{Top,, Introduction, |
| automake, The Automake Manual}), starting with Automake version 1.2. |
| |
| If you want to use libtool in a regular @file{Makefile} (or |
| @file{Makefile.in}), you are on your own. If you're not using Automake |
| 1.2, and you don't know how to incorporate libtool into your package you |
| need to do one of the following: |
| |
| @enumerate 1 |
| @item |
| Download Automake (version 1.2 or later) from your nearest GNU mirror, |
| install it, and start using it. |
| |
| @item |
| Learn how to write @file{Makefile} rules by hand. They're sometimes complex, |
| but if you're clever enough to write rules for compiling your old |
| libraries, then you should be able to figure out new rules for libtool |
| libraries (hint: examine the @file{Makefile.in} in the @file{demo} |
| subdirectory of the libtool distribution@dots{} note especially that it |
| was automatically generated from the @file{Makefile.am} by Automake). |
| @end enumerate |
| |
| @node Using Automake |
| @section Using Automake with libtool |
| |
| @vindex LTLIBRARIES |
| Libtool library support is implemented under the @samp{LTLIBRARIES} |
| primary. |
| |
| Here are some samples from the Automake @file{Makefile.am} in the |
| libtool distribution's @file{demo} subdirectory. |
| |
| First, to link a program against a libtool library, just use the |
| @samp{program_LDADD} variable: |
| |
| @example |
| bin_PROGRAMS = hell hell.debug |
| |
| # Build hell from main.c and libhello.la |
| hell_SOURCES = main.c |
| hell_LDADD = libhello.la |
| |
| # Create an easier-to-debug version of hell. |
| hell_debug_SOURCES = main.c |
| hell_debug_LDADD = libhello.la |
| hell_debug_LDFLAGS = -static |
| @end example |
| |
| You may use the @samp{program_LDFLAGS} variable to stuff in any flags |
| you want to pass to libtool while linking @samp{program} (such as |
| @samp{-static} to avoid linking uninstalled shared libtool libraries). |
| |
| Building a libtool library is almost as trivial@dots{} note the use of |
| @samp{libhello_la_LDFLAGS} to pass the @samp{-version-info} |
| (@pxref{Versioning}) option to libtool: |
| |
| @example |
| # Build a libtool library, libhello.la for installation in libdir. |
| lib_LTLIBRARIES = libhello.la |
| libhello_la_SOURCES = hello.c foo.c |
| libhello_la_LDFLAGS = -version-info 3:12:1 |
| @end example |
| |
| The @samp{-rpath} option is passed automatically by Automake, so you |
| should not specify it. |
| |
| @xref{A Shared Library, Building a Shared Library, The Automake Manual, |
| automake, The Automake Manual}, for more information. |
| |
| @node Configuring |
| @section Configuring libtool |
| @cindex configuring libtool |
| |
| Libtool requires intimate knowledge of your compiler suite and operating |
| system in order to be able to create shared libraries and link against |
| them properly. When you install the libtool distribution, a |
| system-specific libtool script is installed into your binary directory. |
| |
| However, when you distribute libtool with your own packages |
| (@pxref{Distributing}), you do not always know which compiler suite and |
| operating system are used to compile your package. |
| |
| For this reason, libtool must be @dfn{configured} before it can be |
| used. This idea should be familiar to anybody who has used a GNU |
| @code{configure} script. @code{configure} runs a number of tests for |
| system features, then generates the @file{Makefiles} (and possibly a |
| @file{config.h} header file), after which you can run @code{make} and |
| build the package. |
| |
| Libtool has its own equivalent to the @code{configure} script, |
| @code{ltconfig}. |
| |
| @menu |
| * Invoking ltconfig:: @code{ltconfig} command line options. |
| * ltconfig example:: Manually configuring a @code{libtool}. |
| * AM_PROG_LIBTOOL:: Configuring @code{libtool} in @file{configure.in}. |
| @end menu |
| |
| @node Invoking ltconfig |
| @subsection Invoking @code{ltconfig} |
| @pindex ltconfig |
| @cindex ltconfig command options |
| @cindex options, ltconfig command |
| @cindex command options, ltconfig |
| |
| @code{ltconfig} runs a series of configuration tests, then creates a |
| system-specific @code{libtool} in the current directory. The |
| @code{ltconfig} program has the following synopsis: |
| |
| @example |
| ltconfig [@var{option}]@dots{} @var{ltmain} [@var{host}] |
| @end example |
| |
| @noindent |
| and accepts the following options: |
| |
| @table @samp |
| @item --debug |
| Dump a trace of shell script execution to standard output. This |
| produces a lot of output, so you may wish to pipe it to @code{less} (or |
| @code{more}) or redirect to a file. |
| |
| @item --disable-shared |
| Create a @code{libtool} that only builds static libraries. |
| |
| @item --disable-static |
| Create a @code{libtool} that builds only shared libraries if they are |
| available. If only static libraries can be built, then this flag has |
| no effect. |
| |
| @item --help |
| Display a help message and exit. |
| |
| @item --no-verify |
| Do not use @code{config.sub} to verify that @var{host} is a valid |
| canonical host system name. |
| |
| @item --output=@var{file} |
| @item -o @var{file} |
| Instead of creating a libtool script called @code{libtool}, create one |
| called @var{file}. This can be useful if you want to create libtool |
| scripts for cross-compilers, or you want to have more than one libtool |
| in the same directory. |
| |
| @item --quiet |
| @itemx --silent |
| Do not print informational messages when running configuration tests. |
| |
| @item --srcdir=@var{dir} |
| Look for @code{config.guess} and @code{config.sub} in @var{dir}. |
| |
| @item --version |
| Print @code{ltconfig} version information and exit. |
| |
| @item --with-gcc |
| Assume that the GNU C compiler will be used when invoking the created |
| @code{libtool} to compile and link object files. |
| @end table |
| |
| @var{ltmain} is the @code{ltmain.sh} shell script fragment that provides |
| the basic libtool functionality (@pxref{Distributing}). |
| |
| @var{host} is the canonical host system name, which by default is |
| guessed by running @code{config.guess}. |
| |
| @code{ltconfig} also recognizes the following environment variables: |
| |
| @defvar CC |
| The C compiler that will be used by the generated @code{libtool}. |
| @end defvar |
| |
| @defvar CFLAGS |
| Compiler flags used to generate standard object files. |
| @end defvar |
| |
| @defvar CPPFLAGS |
| C preprocessor flags. |
| @end defvar |
| |
| @defvar LD |
| The system linker to use (if the generated @code{libtool} requires one). |
| @end defvar |
| |
| @defvar RANLIB |
| Program to use rather than checking for @code{ranlib}. |
| @end defvar |
| |
| @node ltconfig example |
| @subsection Using @code{ltconfig} |
| |
| Here is a simple example of using @code{ltconfig} to configure libtool |
| on a NetBSD/i386 1.2 system: |
| |
| @example |
| burger$ @kbd{./ltconfig ltmain.sh} |
| checking host system type... i386-unknown-netbsd1.2 |
| checking for ranlib... ranlib |
| checking for gcc... gcc |
| checking whether we are using GNU C... yes |
| checking for gcc option to produce PIC... -fPIC -DPIC |
| checking for gcc option to statically link programs... -static |
| checking if ld is GNU ld... no |
| checking if ld supports shared libraries... yes |
| checking dynamic linker characteristics... netbsd1.2 ld.so |
| checking if libtool supports shared libraries... yes |
| checking whether to build shared libraries... yes |
| creating libtool |
| burger$ |
| @end example |
| |
| This example shows how to configure @code{libtool} for cross-compiling |
| to a i486 GNU/Hurd 0.1 system (assuming compiler tools reside in |
| @file{/local/i486-gnu/bin}): |
| |
| @example |
| burger$ export PATH=/local/i486-gnu/bin:$PATH |
| burger$ ./ltconfig ltmain.sh i486-gnu0.1 |
| checking host system type... i486-unknown-gnu0.1 |
| checking for ranlib... ranlib |
| checking for gcc... gcc |
| checking whether we are using GNU C... yes |
| checking for gcc option to produce PIC... -fPIC -DPIC |
| checking for gcc option to statically link programs... -static |
| checking if ld is GNU ld... yes |
| checking if GNU ld supports shared libraries... yes |
| checking dynamic linker characteristics... gnu0.1 ld.so |
| checking if libtool supports shared libraries... yes |
| checking whether to build shared libraries... yes |
| creating libtool |
| burger$ |
| @end example |
| |
| @node AM_PROG_LIBTOOL |
| @subsection The @code{AM_PROG_LIBTOOL} macro |
| |
| If you are using GNU Autoconf (or Automake), you should add a call to |
| @code{AM_PROG_LIBTOOL} to your @file{configure.in} file. This macro |
| offers seamless integration between the @code{configure} script and |
| @code{ltconfig}: |
| |
| @defmac AM_PROG_LIBTOOL |
| Add support for the @samp{--enable-shared} and @samp{--disable-shared} |
| @code{configure} flags. Invoke @code{ltconfig} with the correct |
| arguments to configure the package (@pxref{Invoking |
| ltconfig}).@footnote{@code{AM_PROG_LIBTOOL} requires that you define the |
| @file{Makefile} variable @code{top_builddir} in your @file{Makefile.in}. |
| Automake does this automatically, but Autoconf users should set it to |
| the relative path to the top of your build directory (@file{../..}, for |
| example).} |
| |
| By default, this macro turns on shared libraries if they are available, |
| and also enables static libraries if they don't conflict with the shared |
| libraries. You can modify these defaults by calling either the |
| @code{AM_DISABLE_SHARED} or @code{AM_DISABLE_STATIC} macros: |
| |
| @example |
| # Turn off shared libraries during beta-testing, since they |
| # make the build process take too long. |
| AM_DISABLE_SHARED |
| AM_PROG_LIBTOOL |
| @end example |
| |
| The user may specify modified forms of both the @samp{--enable-shared} |
| and @samp{--enable-static} flags to choose whether shared or static |
| libraries are built based on the name of the package. For example, to |
| have shared @samp{bfd} and @samp{gdb} libraries built, but not shared |
| @samp{libg++}, you can run all three @code{configure} scripts as |
| follows: |
| |
| @example |
| trick$ ./configure --enable-shared=bfd,gdb |
| @end example |
| |
| In general, specifying @samp{--enable-shared=@var{pkgs}} is the same as |
| specifying @samp{--enable-shared} to every package named in the |
| comma-separated @var{pkgs} list, and @samp{--disable-shared} to every |
| other package. The @samp{--enable-static=@var{pkgs}} flag behaves |
| similarly, but it uses @samp{--enable-static} and |
| @samp{--disable-static}. |
| |
| The package name @samp{default} matches any packages which have not set |
| their name in the @code{PACKAGE} environment variable. |
| @end defmac |
| |
| @defmac AM_DISABLE_SHARED |
| Change the default behaviour for @code{AM_PROG_LIBTOOL} to disable |
| shared libraries. The user may still override this default by |
| specifying @samp{--enable-shared}. |
| @end defmac |
| |
| @defmac AM_DISABLE_STATIC |
| Change the default behaviour for @code{AM_PROG_LIBTOOL} to disable |
| static libraries. The user may still override this default by |
| specifying @samp{--enable-static}. |
| @end defmac |
| |
| @pindex aclocal |
| When you invoke the @code{libtoolize} program (@pxref{Invoking |
| libtoolize}), it will tell you where to find a definition of |
| @code{AM_PROG_LIBTOOL}. If you use Automake, the @code{aclocal} program |
| will automatically add @code{AM_PROG_LIBTOOL} support to your |
| @code{configure} script. |
| |
| @node Distributing |
| @section Including libtool in your package |
| |
| In order to use libtool, you need to include the following files with |
| your package: |
| |
| @table @file |
| @item config.guess |
| @pindex config.guess |
| Attempt to guess a canonical system name. |
| |
| @item config.sub |
| @pindex config.sub |
| Canonical system name validation subroutine script. |
| |
| @item ltconfig |
| Generate a libtool script for a given system. |
| |
| @item ltmain.sh |
| @pindex ltmain.sh |
| A generic script implementing basic libtool functionality. |
| @end table |
| |
| Note that the libtool script itself should @emph{not} be included with |
| your package. @xref{Configuring}. |
| |
| You should use the @code{libtoolize} program, rather than manually |
| copying these files into your package. |
| |
| @menu |
| * Invoking libtoolize:: @code{libtoolize} command line options. |
| * Autoconf .o macros:: Autoconf macros that set object file names. |
| @end menu |
| |
| @node Invoking libtoolize |
| @subsection Invoking @code{libtoolize} |
| @pindex libtoolize |
| @cindex libtoolize command options |
| @cindex command options, libtoolize |
| @cindex options, libtoolize command |
| |
| The @code{libtoolize} program provides a standard way to add libtool |
| support to your package. In the future, it may implement better usage |
| checking, or other features to make libtool even easier to use. |
| |
| The @code{libtoolize} program has the following synopsis: |
| |
| @example |
| libtoolize [@var{option}]@dots{} |
| @end example |
| |
| @noindent |
| and accepts the following options: |
| |
| @table @samp |
| @item --automake |
| Work silently, and assume that Automake libtool support is used. |
| |
| @samp{libtoolize --automake} is used by Automake to add libtool files to |
| your package, when @code{AM_PROG_LIBTOOL} appears in your |
| @file{configure.in}. |
| |
| @item --copy |
| @itemx -c |
| Copy files from the libtool data directory rather than creating |
| symlinks. |
| |
| @item --debug |
| Dump a trace of shell script execution to standard output. This |
| produces a lot of output, so you may wish to pipe it to @code{less} (or |
| @code{more}) or redirect to a file. |
| |
| @item --dry-run |
| @itemx -n |
| Don't run any commands that modify the file system, just print them |
| out. |
| |
| @item --force |
| @itemx -f |
| Replace existing libtool files. By default, @code{libtoolize} won't |
| overwrite existing files. |
| |
| @item --help |
| Display a help message and exit. |
| |
| @item --version |
| Print @code{libtoolize} version information and exit. |
| @end table |
| |
| @findex AC_CONFIG_AUX_DIR |
| If @code{libtoolize} detects an explicit call to |
| @code{AC_CONFIG_AUX_DIR} (@pxref{Input, , The Autoconf Manual, |
| autoconf, The Autoconf Manual}) in your @file{configure.in}, it |
| will put the files in the specified directory. |
| |
| @code{libtoolize} displays hints for adding libtool support to your |
| package, as well. |
| |
| @node Autoconf .o macros |
| @subsection Autoconf @samp{.o} macros |
| |
| The Autoconf package comes with a few macros that run tests, then set a |
| variable corresponding to the name of an object file. Sometimes it is |
| necessary to use corresponding names for libtool objects. |
| |
| Here are the names of variables that list libtool objects: |
| |
| @defvar LTALLOCA |
| @findex AC_FUNC_ALLOCA |
| Substituted by @code{AC_FUNC_ALLOCA} (@pxref{Particular Functions, Particular |
| Function Checks, The Autoconf Manual, autoconf, The Autoconf |
| Manual}). Is either empty, or contains @samp{alloca.lo}. |
| @end defvar |
| |
| @defvar LTLIBOBJS |
| @findex AC_REPLACE_FUNCS |
| Substituted by @code{AC_REPLACE_FUNCS} (@pxref{Generic Functions, Generic |
| Function Checks, The Autoconf Manual, autoconf, The Autoconf |
| Manual}), and a few other functions. |
| @end defvar |
| |
| Unfortunately, the most recent version of Autoconf (2.12, at the time of |
| this writing) does not have any way for libtool to provide support for |
| these variables. So, if you depend on them, use the following code |
| immediately before the call to @code{AC_OUTPUT} in your |
| @file{configure.in}: |
| |
| @example |
| LTLIBOBJS=`echo "$LIBOBJS" | sed 's/\.o/.lo/g'` |
| AC_SUBST(LTLIBOBJS) |
| LTALLOCA=`echo "$ALLOCA" | sed 's/\.o/.lo/g'` |
| AC_SUBST(LTALLOCA) |
| AC_OUTPUT(@dots{}) |
| @end example |
| |
| @node Static-only libraries |
| @section Static-only libraries |
| @cindex debugging libraries |
| @cindex developing libraries |
| @cindex double-compilation, avoiding |
| @cindex avoiding shared libraries |
| @cindex eliding shared libraries |
| @cindex using shared libraries, not |
| @cindex shared libraries, not using |
| @cindex time, saving |
| @cindex saving time |
| |
| When you are developing a package, it is often worthwhile to configure |
| your package with the @samp{--disable-shared} flag, or to override the |
| defaults for @code{AM_PROG_LIBTOOL} by using the |
| @code{AM_DISABLE_SHARED} Autoconf macro (@pxref{AM_PROG_LIBTOOL, , The |
| @code{AM_PROG_LIBTOOL} macro}). This prevents libtool from building |
| shared libraries, which has several advantages: |
| |
| @itemize @bullet |
| @item |
| compilation is twice as fast, which can speed up your development cycle, |
| |
| @item |
| debugging is easier because you don't need to deal with any complexities |
| added by shared libraries, and |
| |
| @item |
| you can see how libtool behaves on static-only platforms. |
| @end itemize |
| |
| You may want to put a small note in your package @file{README} to let |
| other developers know that @samp{--disable-shared} can save them time. |
| The following example note is taken from the GIMP@footnote{GNU Image |
| Manipulation Program, for those who haven't taken the plunge. See |
| @url{http://www.gimp.org/}.} distribution @file{README}: |
| |
| @example |
| The GIMP uses GNU Libtool in order to build shared libraries on a |
| variety of systems. While this is very nice for making usable |
| binaries, it can be a pain when trying to debug a program. For that |
| reason, compilation of shared libraries can be turned off by |
| specifying the @samp{--disable-shared} option to @file{configure}. |
| @end example |
| |
| @node Versioning |
| @chapter Library interface versions |
| @cindex dynamic dependencies |
| @cindex dependency versioning |
| @cindex shared library versions |
| |
| The most difficult issue introduced by shared libraries is that of |
| creating and resolving runtime dependencies. Dependencies on programs |
| and libraries are often described in terms of a single name, such as |
| @code{sed}. So, one may say ``libtool depends on sed,'' and that is |
| good enough for most purposes. |
| |
| However, when an interface changes regularly, we need to be more |
| specific: ``Gnus 5.1 requires Emacs 19.28 or above.'' Here, the |
| description of an interface consists of a name, and a ``version |
| number.'' |
| |
| Even that sort of description is not accurate enough for some purposes. |
| What if Emacs 20 changes enough to break Gnus 5.1? |
| |
| The same problem exists in shared libraries: we require a formal version |
| system to describe the sorts of dependencies that programs have on |
| shared libraries, so that the dynamic linker can guarantee that programs |
| are linked only against libraries that provide the interface they |
| require. |
| |
| @menu |
| * Interfaces:: What are library interfaces? |
| * Libtool versioning:: Libtool's versioning system. |
| * Updating version info:: Changing version information before releases. |
| * Release numbers:: Breaking binary compatibility for aesthetics. |
| @end menu |
| |
| @node Interfaces |
| @section What are library interfaces? |
| @cindex library interfaces |
| |
| Interfaces for libraries may be any of the following (and more): |
| |
| @itemize @bullet |
| @item |
| global variables: both names and types |
| |
| @item |
| global functions: argument types and number, return types, and function names |
| |
| @item |
| standard input, standard output, standard error, and file formats |
| |
| @item |
| sockets, pipes, and other inter-process communication protocol formats |
| @end itemize |
| |
| Note that static functions do not count as interfaces, because they are |
| not directly available to the user of the library. |
| |
| @node Libtool versioning |
| @section Libtool's versioning system |
| @cindex libtool library versions |
| @cindex formal versioning |
| @cindex versioning, formal |
| |
| Libtool has its own formal versioning system. It is not as flexible as |
| some, but it is definitely the simplest of the more powerful versioning |
| systems. |
| |
| Think of a library as exporting several sets of interfaces, arbitrarily |
| represented by integers. When a program is linked against a library, it |
| may use any subset of those interfaces. |
| |
| Libtool's description of the interfaces that a program uses is simple: |
| it encodes the least and the greatest interface numbers in the resulting |
| binary (@var{first-interface}, @var{last-interface}). |
| |
| The dynamic linker is guaranteed that if a library supports @emph{every} |
| interface number between @var{first-interface} and @var{last-interface}, |
| then the program can be relinked against that library. |
| |
| Note that this can cause problems because libtool's compatibility |
| requirements are actually stricter than is necessary. |
| |
| Say @file{libhello} supports interfaces 5, 16, 17, 18, and 19, and that |
| libtool is used to link @file{test} against @file{libhello}. |
| |
| Libtool encodes the numbers 5 and 19 in @file{test}, and the dynamic |
| linker will only link @file{test} against libraries that support |
| @emph{every} interface between 5 and 19. So, the dynamic linker refuses |
| to link @file{test} against @file{libhello}! |
| |
| In order to eliminate this problem, libtool only allows libraries to |
| declare consecutive interface numbers. So, @file{libhello} can declare at |
| most that it supports interfaces 16 through 19. Then, the dynamic |
| linker will link @file{test} against @file{libhello}. |
| |
| So, libtool library versions are described by three integers: |
| |
| @table @var |
| @item current |
| The most recent interface number that this library implements. |
| |
| @item revision |
| The implementation number of the @var{current} interface. |
| |
| @item age |
| The difference between the newest and oldest interfaces that this |
| library implements. In other words, the library implements all the |
| interface numbers in the range from number @code{@var{current} - |
| @var{age}} to @code{@var{current}}. |
| @end table |
| |
| If two libraries have identical @var{current} and @var{age} numbers, |
| then the dynamic linker chooses the library with the greater |
| @var{revision} number. |
| |
| @node Updating version info |
| @section Updating library version information |
| |
| If you want to use libtool's versioning system, then you must specify |
| the version information to libtool using the @samp{-version-info} flag |
| during link mode (@pxref{Link mode}). |
| |
| This flag accepts an argument of the form |
| @samp{@var{current}[:@var{revision}[:@var{age}]]}. So, passing |
| @samp{-version-info 3:12:1} sets @var{current} to 3, @var{revision} to |
| 12, and @var{age} to 1. |
| |
| If either @var{revision} or @var{age} are omitted, they default to 0. |
| Also note that @var{age} must be less than or equal to the @var{current} |
| interface number. |
| |
| Here are a set of rules to help you update your library version |
| information: |
| |
| @enumerate 1 |
| @item |
| Start with version information of @samp{0:0:0} for each libtool library. |
| |
| @item |
| Update the version information only immediately before a public release |
| of your software. More frequent updates are unnecessary, and only |
| guarantee that the current interface number gets larger faster. |
| |
| @item |
| If the library source code has changed at all since the last update, |
| then increment @var{revision} (@samp{@var{c}:@var{r}:@var{a}} becomes |
| @samp{@var{c}:@math{r+1}:@var{a}}). |
| |
| @item |
| If any interfaces have been added, removed, or changed since the last |
| update, increment @var{current}, and set @var{revision} to 0. |
| |
| @item |
| If any interfaces have been added since the last public release, then |
| increment @var{age}. |
| |
| @item |
| If any interfaces have been removed since the last public release, then |
| set @var{age} to 0. |
| @end enumerate |
| |
| @strong{@emph{Never}} try to set the interface numbers so that they |
| correspond to the release number of your package. This is an abuse that |
| only fosters misunderstanding of the purpose of library versions. |
| Instead, use the @samp{-release} flag (@pxref{Release numbers}), but be |
| warned that every release of your package will not be binary compatible |
| with any other release. |
| |
| @node Release numbers |
| @section Managing release information |
| |
| Often, people want to encode the name of the package release into the |
| shared library so that it is obvious to the user which package their |
| programs are linked against. This convention is used especially on |
| GNU/Linux: |
| |
| @example |
| trick$ @kbd{ls /usr/lib/libbfd*} |
| /usr/lib/libbfd.a /usr/lib/libbfd.so.2.7.0.2 |
| /usr/lib/libbfd.so |
| trick$ |
| @end example |
| |
| On @samp{trick}, @file{/usr/lib/libbfd.so} is a symbolic link to |
| @file{libbfd.so.2.7.0.2}, which was distributed as a part of |
| @samp{binutils-2.7.0.2}. |
| |
| Unfortunately, this convention conflicts directly with libtool's idea of |
| library interface versions, because the library interface rarely changes |
| at the same time that the release number does, and the library suffix is |
| never the same across all platforms. |
| |
| So, in order to accomodate both views, you can use the @samp{-release} |
| flag in order to set release information for libraries which you do not |
| want to use @samp{-version-info}. For the @file{libbfd} example, the |
| next release which uses libtool should be built with @samp{-release |
| 2.9.0}, which will produce the following files on GNU/Linux: |
| |
| @example |
| trick$ @kbd{ls /usr/lib/libbfd*} |
| /usr/lib/libbfd-2.9.0.so /usr/lib/libbfd.a |
| /usr/lib/libbfd.so |
| trick$ |
| @end example |
| |
| In this case, @file{/usr/lib/libbfd.so} is a symbolic link to |
| @file{libbfd-2.9.0.so}. This makes it obvious that the user is dealing |
| with @samp{binutils-2.9.0}, without compromising libtool's idea of |
| interface versions. |
| |
| Note that this option causes a modification of the library name, so do |
| not use it unless you want to break binary compatibility with any past |
| library releases. In general, you should only use @samp{-release} for |
| package-internal libraries or for ones whose interfaces change very |
| frequently. |
| |
| @node Library tips |
| @chapter Tips for interface design |
| @cindex library interfaces, design |
| @cindex design of library interfaces |
| |
| Writing a good library interface takes a lot of practice and thorough |
| understanding of the problem that the library is intended to solve. |
| |
| If you design a good interface, it won't have to change often, you won't |
| have to keep updating documentation, and users won't have to keep |
| relearning how to use the library. |
| |
| Here is a brief list of tips for library interface design, which may |
| help you in your exploits: |
| |
| @table @asis |
| @item Plan ahead |
| Try to make every interface truly minimal, so that you won't need to |
| delete entry points very often. |
| |
| @item Avoid interface changes |
| @cindex renaming interface functions |
| Some people love redesigning and changing entry points just for the heck |
| of it (note: @emph{renaming} a function is considered changing an entry |
| point). Don't be one of those people. If you must redesign an |
| interface, then try to leave compatibility functions behind so that |
| users don't need to rewrite their existing code. |
| |
| @item Use opaque data types |
| @cindex opaque data types |
| The fewer data type definitions a library user has access to, the |
| better. If possible, design your functions to accept a generic pointer |
| (which you can cast to an internal data type), and provide access |
| functions rather than allowing the library user to directly manipulate |
| the data. |
| That way, you have the freedom to change the data structures without |
| changing the interface. |
| |
| This is essentially the same thing as using abstract data types and |
| inheritance in an object-oriented system. |
| |
| @item Use header files |
| @cindex header files |
| If you are careful to document each of your library's global functions |
| and variables in header files, and include them in your library source |
| files, then the compiler will let you know if you make any interface |
| changes by accident (@pxref{C header files}). |
| |
| @item Use the @code{static} keyword (or equivalent) whenever possible |
| @cindex global functions |
| The fewer global functions your library has, the more flexibility you'll |
| have in changing them. Static functions and variables may change forms |
| as often as you like@dots{} your users cannot access them, so they |
| aren't interface changes. |
| @end table |
| |
| @menu |
| * C header files:: How to write portable include files. |
| @end menu |
| |
| @node C header files |
| @section Writing C header files |
| @cindex portable C headers |
| @cindex C header files, portable |
| @cindex include files, portable |
| |
| Writing portable C header files can be difficult, since they may be read |
| by different types of compilers: |
| |
| @table @asis |
| @item C++ compilers |
| C++ compilers require that functions be declared with full prototypes, |
| since C++ is more strongly typed than C. C functions and variables also |
| need to be declared with the @code{extern "C"} directive, so that the |
| names aren't mangled. @xref{C++ libraries}, for other issues relevant |
| to using C++ with libtool. |
| |
| @item ANSI C compilers |
| ANSI C compilers are not as strict as C++ compilers, but functions |
| should be prototyped to avoid unnecessary warnings when the header file |
| is @code{#include}d. |
| |
| @item non-ANSI C compilers |
| Non-ANSI compilers will report errors if functions are prototyped. |
| @end table |
| |
| These complications mean that your library interface headers must use |
| some C preprocessor magic in order to be usable by each of the above |
| compilers. |
| |
| @file{foo.h} in the @file{demo} subdirectory of the libtool distribution |
| serves as an example for how to write a header file that can be |
| safely installed in a system directory. |
| |
| Here are the relevant portions of that file: |
| |
| @example |
| /* __BEGIN_DECLS should be used at the beginning of your declarations, |
| so that C++ compilers don't mangle their names. Use __END_DECLS at |
| the end of C declarations. */ |
| #undef __BEGIN_DECLS |
| #undef __END_DECLS |
| #ifdef __cplusplus |
| # define __BEGIN_DECLS extern "C" @{ |
| # define __END_DECLS @} |
| #else |
| # define __BEGIN_DECLS /* empty */ |
| # define __END_DECLS /* empty */ |
| #endif |
| |
| /* __P is a macro used to wrap function prototypes, so that compilers |
| that don't understand ANSI C prototypes still work, and ANSI C |
| compilers can issue warnings about type mismatches. */ |
| #undef __P |
| #if defined (__STDC__) || defined (_AIX) \ |
| || (defined (__mips) && defined (_SYSTYPE_SVR4)) \ |
| || defined(WIN32) || defined(__cplusplus) |
| # define __P(protos) protos |
| #else |
| # define __P(protos) () |
| #endif |
| @end example |
| |
| These macros are used in @file{foo.h} as follows: |
| |
| @example |
| #ifndef _FOO_H_ |
| #define _FOO_H_ 1 |
| |
| /* The above macro definitions. */ |
| @dots{} |
| |
| __BEGIN_DECLS |
| int foo __P((void)); |
| int hello __P((void)); |
| __END_DECLS |
| |
| #endif /* !_FOO_H_ */ |
| @end example |
| |
| Note that the @file{#ifndef _FOO_H_} prevents the body of @file{foo.h} |
| from being read more than once in a given compilation. |
| |
| Feel free to copy the definitions of @code{__P}, @code{__BEGIN_DECLS}, |
| and @code{__END_DECLS} into your own headers. Then, you may use them to |
| create header files that are valid for C++, ANSI, and non-ANSI |
| compilers. |
| |
| Do not be naive about writing portable code. Following the tips given |
| above will help you miss the most obvious problems, but there are |
| definitely other subtle portability issues. You may need to cope with |
| some of the following issues: |
| |
| @itemize @bullet |
| @item |
| Pre-ANSI compilers do not always support the @code{void *} generic |
| pointer type, and so need to use @code{char *} in its place. |
| |
| @item |
| The @code{const} and @code{signed} keywords are not supported by some |
| compilers, especially pre-ANSI compilers. |
| |
| @item |
| The @code{long double} type is not supported by many compilers. |
| @end itemize |
| |
| @node Inter-library dependencies |
| @chapter Inter-library dependencies |
| @cindex dependencies between libraries |
| @cindex inter-library dependencies |
| |
| By definition, every shared library system provides a way for |
| executables to depend on libraries, so that symbol resolution is |
| deferred until runtime. |
| |
| An @dfn{inter-library dependency} is one in which a library depends on |
| other libraries. For example, if the libtool library @file{libhello} |
| uses the @code{cos} function, then it has an inter-library dependency |
| on @file{libm}, the math library that implements @code{cos}. |
| |
| Some shared library systems provide this feature in an |
| internally-consistent way: these systems allow chains of dependencies of |
| potentially infinite length. |
| |
| However, most shared library systems are restricted in that they only |
| allow a single level of dependencies. In these systems, programs may |
| depend on shared libraries, but shared libraries may not depend on other |
| shared libraries. |
| |
| In any event, libtool provides a simple mechanism for you to declare |
| inter-library dependencies: for every library @file{lib@var{name}} that |
| your own library depends on, simply add a corresponding |
| @code{-l@var{name}} option to the link line when you create your |
| library.@footnote{Unfortunately, as of libtool version @value{VERSION}, |
| there is no way to specify inter-library dependencies on libtool |
| libraries that have not yet been installed.} To make an example of our |
| @file{libhello} that depends on @file{libm}: |
| |
| @example |
| burger$ @kbd{libtool gcc -g -O -o libhello.la foo.lo hello.lo \ |
| -rpath /usr/local/lib -lm} |
| burger$ |
| @end example |
| |
| In order to link a program against @file{libhello}, you need to specify |
| the same @samp{-l} options, in order to guarantee that all the required |
| libraries are found. This restriction is only necessary to preserve |
| compatibility with static library systems and simple dynamic library |
| systems. |
| |
| Some platforms, such as AIX and Windows 95, do not even allow you this |
| flexibility. In order to build a shared library, it must be entirely |
| self-contained (that is, have references only to symbols that are found |
| in the @samp{.lo} files or the specified @samp{-l} libraries), and you |
| need to specify the @var{-no-undefined} flag. By default, libtool |
| builds only static libraries on these kinds of platforms. |
| |
| @node Dlopened modules |
| @chapter Dlopened modules |
| @findex dlopen |
| @findex dlsym |
| @findex dlclose |
| @findex shl_load |
| @cindex dynamic linking, applications |
| @cindex dlopening modules |
| @cindex modules, dynamic |
| @cindex application-level dynamic linking |
| |
| It can sometimes be confusing to discuss @dfn{dynamic linking}, because |
| the term is used to refer to two different concepts: |
| |
| @enumerate 1 |
| @item |
| Compiling and linking a program against a shared library, which is |
| resolved automatically at run time by the dynamic linker. In this |
| process, dynamic linking is transparent to the application. |
| |
| @item |
| The application calling functions such as @code{dlopen},@footnote{HP-UX, |
| to be different, uses a function named @code{shl_load}.} which load |
| arbitrary, user-specified modules at runtime. This type of dynamic |
| linking is explicitly controlled by the application. |
| @end enumerate |
| |
| To mitigate confusion, this manual refers to the second type of dynamic |
| linking as @dfn{dlopening} a module. |
| |
| The main benefit to dlopening object modules is the ability to access |
| compiled object code to extend your program, rather than using an |
| interpreted language. In fact, dlopen calls are frequently used in |
| language interpreters to provide an efficient way to extend the |
| language. |
| |
| As of version @value{VERSION}, libtool provides experimental support for |
| dlopened modules, which does not radically simplify the development of |
| dlopening applications. However, this support is designed to be a |
| portable foundation for generic, higher-level dlopen functions. |
| |
| This chapter discusses the preliminary support that libtool offers, and |
| how you as a dlopen application developer might use libtool to generate |
| dlopen-accessible modules. It is important to remember that these are |
| experimental features, and not to rely on them for easy answers to the |
| problems associated with dlopened modules. |
| |
| @menu |
| * Building modules:: Creating dlopenable objects and libraries. |
| * Dlpreopening:: Dlopening that works on static platforms. |
| * Finding the dlname:: Choosing the right file to @code{dlopen}. |
| * Dlopen issues:: Unresolved problems that need your attention. |
| @end menu |
| |
| @node Building modules |
| @section Building modules to dlopen |
| |
| On some operating systems, a program symbol must be specially declared |
| in order to be dynamically resolved with the @code{dlsym} (or |
| equivalent) function. |
| |
| Libtool provides the @samp{-export-dynamic} link flag (@pxref{Link |
| mode}), which does this declaration. You need to use this flag if you |
| are linking an application program that dlopens other modules or a |
| libtool library that will also be dlopened. |
| |
| For example, if we wanted to build a shared library, @file{libhello}, |
| that would later be dlopened by an application, we would add |
| @samp{-export-dynamic} to the other link flags: |
| |
| @example |
| burger$ @kbd{libtool gcc -export-dynamic -o libhello.la foo.lo \ |
| hello.lo -rpath /usr/local/lib -lm} |
| burger$ |
| @end example |
| |
| Another situation where you would use @samp{-export-dynamic} is if |
| symbols from your @emph{executable} are needed to satisfy unresolved |
| references in a library you want to dlopen. In this case, you should |
| use @samp{-export-dynamic} while linking the executable that calls |
| dlopen: |
| |
| @example |
| burger$ @kbd{libtool gcc -export-dynamic -o hell-dlopener main.o} |
| burger$ |
| @end example |
| |
| @node Dlpreopening |
| @section Dlpreopening |
| |
| Libtool provides special support for dlopening libtool object and |
| libtool library files, so that their symbols can be resolved @emph{even |
| on platforms without any @code{dlopen} and @code{dlsym} |
| functions.}. |
| |
| Consider the following alternative ways of loading code into your |
| program, in order of increasing ``laziness'': |
| |
| @enumerate 1 |
| @item |
| Linking against object files that become part of the program executable, |
| whether or not they are referenced. If an object file cannot be found, |
| then the linker refuses to create the executable. |
| |
| @item |
| Declaring a static library to the linker, so that it is searched at link |
| time in order to satisfy any undefined references in the above object |
| files. If the static library cannot be found, then the linker refuses |
| to link the executable. |
| |
| @item |
| Declaring a shared library to the runtime linker, so that it is searched |
| at runtime in order to satisfy any undefined references in the above |
| files. If the shared library cannot be found, then the dynamic linker |
| aborts the program before it runs. |
| |
| @item |
| Dlopening a module, so that the application can resolve its own, |
| dynamically-computed references. If there is an error opening the |
| module, or the module is not found, then the application can recover |
| without crashing. |
| @end enumerate |
| |
| Libtool emulates @samp{-export-dynamic} on static platforms by linking |
| objects into the program at compile time, and creating data structures |
| that represent the program's symbol table. |
| |
| In order to use this feature, you must declare the objects you want your |
| application to dlopen by using the @samp{-dlopen} or @samp{-dlpreopen} |
| flags when you link your program (@pxref{Link mode}). |
| |
| @deftypefn {Structure} {typedef struct} dld_symbol @{ @w{char *@var{name};} @w{ptr_t @var{address};} @} |
| The @var{name} attribute is a zero-terminated character string of the |
| symbol name, such as @code{"fprintf"}. The @var{address} attribute is a |
| generic pointer to the appropriate object, such as @code{&fprintf}. |
| @end deftypefn |
| |
| @deftypevar {dld_symbol *} dld_preloaded_symbols |
| An array of @var{dld_symbol} structures, representing all the preloaded |
| symbols linked into the program. The last element has a @var{name} of |
| @code{0}. |
| @end deftypevar |
| |
| @deftypevar int dld_preloaded_symbol_count |
| The number of elements in @var{dld_preloaded_symbols}, if it is sorted |
| in ascending order by @var{name}. Otherwise, @code{-1}, to indicate |
| that the application needs to sort and count @var{dld_preloaded_symbols} |
| itself, or search it linearly. |
| @end deftypevar |
| |
| Some compilers may allow identifiers which are not valid in ANSI C, such |
| as dollar signs. Libtool only recognizes valid ANSI C symbols (an |
| initial ASCII letter or underscore, followed by zero or more ASCII |
| letters, digits, and underscores), so non-ANSI symbols will not appear |
| in @var{dld_preloaded_symbols}. |
| |
| @node Finding the dlname |
| @section Finding the correct name to dlopen |
| @cindex names of dynamic modules |
| @cindex dynamic modules, names |
| |
| After a library has been linked with @samp{-export-dynamic}, it can be |
| dlopened. Unfortunately, because of the variation in library names, |
| your package needs to determine the correct file to dlopen. |
| |
| The most straightforward and flexible implementation is to determine the |
| name at runtime, by finding the installed @samp{.la} file, and searching |
| it for the following lines: |
| |
| @example |
| # The name that we can @code{dlopen}. |
| dlname='@var{dlname}' |
| @end example |
| |
| If @var{dlname} is empty, then the library cannot be dlopened. |
| Otherwise, it gives the dlname of the library. So, if the library was |
| installed as @file{/usr/local/lib/libhello.la}, and the @var{dlname} was |
| @file{libhello.so.3}, then @file{/usr/local/lib/libhello.so.3} should be |
| dlopened. |
| |
| If your program uses this approach, then it should search the |
| directories listed in the @code{LD_LIBRARY_PATH}@footnote{@code{LIBPATH} |
| on AIX, and @code{SHLIB_PATH} on HP-UX.} environment variable, as well as |
| the directory where libraries will eventually be installed. Searching |
| this variable (or equivalent) will guarantee that your program can find |
| its dlopened modules, even before installation, provided you have linked |
| them using libtool. |
| |
| @node Dlopen issues |
| @section Unresolved dlopen issues |
| @cindex pitfalls with dlopen |
| @cindex dlopening, pitfalls |
| @cindex trouble with dlopen |
| |
| The following problems are not solved by using libtool's dlopen support: |
| |
| @itemize @bullet |
| @item |
| Dlopen functions are generally only available on shared library |
| platforms. If you want your package to be portable to static platforms, |
| you have to develop your own alternatives to dlopening dynamic code. |
| Most reasonable solutions involve writing wrapper functions for the |
| @code{dlopen} family, which do package-specific tricks when dlopening |
| is unsupported or not available on a given platform. |
| |
| @item |
| There are major differences in implementations of the @code{dlopen} |
| family of functions. Some platforms do not even use the same function |
| names (notably HP-UX, with its @code{shl_load} family). |
| |
| @item |
| The application developer must write a custom search function in order |
| to discover the correct module filename to supply to @code{dlopen}. |
| @end itemize |
| |
| Each of these limitations will be addressed in GNU DLD |
| 4.@footnote{Unfortunately, the DLD maintainer is also the libtool |
| maintainer, so time spent on one of these projects takes time away from |
| the other. When libtool is reasonably stable, DLD 4 development will |
| proceed.} |
| |
| @node Other languages |
| @chapter Using libtool with other languages |
| @cindex C, not using |
| @cindex languages, non-C |
| @cindex C++, using |
| |
| Libtool was first implemented in order to add support for writing shared |
| libraries in the C language. However, over time, libtool is being |
| integrated with other languages, so that programmers are free to reap |
| the benefits of shared libraries in their favorite programming language. |
| |
| This chapter describes how libtool interacts with other languages, |
| and what special considerations you need to make if you do not use C. |
| |
| @menu |
| * C++ libraries:: |
| @end menu |
| |
| @node C++ libraries |
| @section Writing libraries for C++ |
| @c FIXME: in the TOC, the ++ is too large (seems to be math mode) |
| @cindex trouble with C++ |
| @cindex pitfalls using C++ |
| @cindex C++, pitfalls |
| |
| Creating libraries of C++ code is a fairly straightforward process, and |
| differs from C code in only two ways: |
| |
| @enumerate 1 |
| @item |
| Because of name mangling, C++ libraries are only usable by the C++ |
| compiler that created them. This decision was made by the designers of |
| C++ in order to protect users from conflicting implementations of |
| features such as constructors, exception handling, and RTTI. |
| |
| @item |
| On some systems, notably SunOS 4, the dynamic linker does not call |
| non-constant initializers. This can lead to hard-to-pinpoint bugs in |
| your library. GCC 2.7 and later versions work around this problem, but |
| previous versions and other compilers do not. |
| @end enumerate |
| |
| This second issue is complex. Basically, you should avoid any global or |
| static variable initializations that would cause an ``initializer |
| element is not constant'' error if you compiled them with a standard C |
| compiler. |
| |
| There are other ways of working around this problem, but they are beyond |
| the scope of this manual. |
| |
| @node Troubleshooting |
| @chapter Troubleshooting |
| @cindex troubleshooting |
| @cindex problems, solving |
| @cindex solving problems |
| @cindex problems, blaming somebody else for |
| |
| Libtool is under constant development, changing to remain up-to-date |
| with modern operating systems. If libtool doesn't work the way you |
| think it should on your platform, you should read this chapter to help |
| determine what the problem is, and how to resolve it. |
| |
| @menu |
| * Libtool test suite:: Libtool's self-tests. |
| * Reporting bugs:: How to report problems with libtool. |
| @end menu |
| |
| @node Libtool test suite |
| @section The libtool test suite |
| @cindex test suite |
| |
| Libtool comes with its own set of programs that test its capabilities, |
| and report obvious bugs in the libtool program. These tests, too, are |
| constantly evolving, based on past problems with libtool, and known |
| deficiencies in other operating systems. |
| |
| As described in the @file{INSTALL} file, you may run @kbd{make check} |
| after you have built libtool (possibly before you install it) in order |
| to make sure that it meets basic functional requirements. |
| |
| @menu |
| * Test descriptions:: The contents of the test suite. |
| * When tests fail:: What to do when a test fails. |
| @end menu |
| |
| @node Test descriptions |
| @subsection Description of test suite |
| |
| Here is a list of the current programs in the test suite, and what they |
| test for: |
| |
| @table @file |
| @item demo-conf.test |
| @itemx demo-exec.test |
| @itemx demo-inst.test |
| @itemx demo-make.test |
| @itemx demo-unst.test |
| @pindex demo-conf.test |
| @pindex demo-exec.test |
| @pindex demo-inst.test |
| @pindex demo-make.test |
| @pindex demo-unst.test |
| These programs check to see that the @file{demo} subdirectory of the |
| libtool distribution can be configured, built, installed, and |
| uninstalled correctly. |
| |
| The @file{demo} subdirectory contains a demonstration of a trivial |
| package that uses libtool. |
| |
| @item hardcode.test |
| @pindex hardcode.test |
| On all systems with shared libraries, the location of the library can be |
| encoded in executables that are linked against it @pxref{Linking |
| executables}. This test checks the conditions under which your system |
| linker hardcodes the library location, and guarantees that they |
| correspond to libtool's own notion of how your linker behaves. |
| |
| @item link.test |
| @pindex link.test |
| This test guarantees that linking directly against a non-libtool static |
| library works properly. |
| |
| @item link-2.test |
| @pindex link-2.test |
| This test makes sure that files ending in @samp{.lo} are never linked |
| directly into a program file. |
| |
| @item suffix.test |
| @pindex suffix.test |
| When other programming languages are used with libtool (@pxref{Other |
| languages}), the source files may end in suffixes other than @samp{.c}. |
| This test validates that libtool can handle suffixes for all the file |
| types that it supports, and that it fails when the suffix is invalid. |
| |
| @item test-e.test |
| @pindex test-e.test |
| This program checks that the @code{test -e} construct is @emph{never} |
| used in the libtool scripts. Checking for the existence of a file can |
| only be done in a portable way by using @code{test -f}. |
| @end table |
| |
| @node When tests fail |
| @subsection When tests fail |
| @cindex failed tests |
| @cindex tests, failed |
| |
| Each of the above tests are designed to produce no output when they are |
| run via @kbd{make check}. The exit status of each program tells the |
| @file{Makefile} whether or not the test succeeded. |
| |
| If a test fails, it means that there is either a programming error in |
| libtool, or in the test program itself. |
| |
| To investigate a particular test, you may run it directly, as you would |
| a normal program. When the test is invoked in this way, it produces |
| output which may be useful in determining what the problem is. |
| |
| Another way to have the test programs produce output is to set the |
| @var{VERBOSE} environment variable to @samp{yes} before running them. |
| For example, @kbd{env VERBOSE=yes make check} runs all the tests, and |
| has each of them display debugging information. |
| |
| @node Reporting bugs |
| @section Reporting bugs |
| @cindex bug reports |
| @cindex reporting bugs |
| @cindex problem reports |
| |
| If you think you have discovered a bug in libtool, you should think |
| twice: the libtool maintainer is notorious for passing the buck (or |
| maybe that should be ``passing the bug''). Libtool was invented to fix |
| known deficiencies in shared library implementations, so, in a way, most |
| of the bugs in libtool are actually bugs in other operating systems. |
| However, the libtool maintainer would definitely be happy to add support |
| for somebody else's buggy operating system. [I wish there was a good |
| way to do winking smiley-faces in Texinfo.] |
| |
| Genuine bugs in libtool include problems with shell script portability, |
| documentation errors, and failures in the test suite (@pxref{Libtool |
| test suite}). |
| |
| First, check the documentation and help screens to make sure that the |
| behaviour you think is a problem is not already mentioned as a feature. |
| |
| Then, you should read the Emacs guide to reporting bugs (@pxref{Bugs, , |
| Reporting Bugs, emacs, The Emacs Manual}). Some of the details |
| listed there are specific to Emacs, but the principle behind them is a |
| general one. |
| |
| Finally, send a bug report to @value{BUGADDR} with any appropriate |
| @emph{facts}, such as test suite output (@pxref{When tests fail}), all |
| the details needed to reproduce the bug, and a brief description of why |
| you think the behaviour is a bug. Be sure to include the word |
| ``libtool'' in the subject line, as well as the version number you are |
| using (which can be found by typing @kbd{ltconfig --version}). |
| |
| @node Maintaining |
| @chapter Maintenance notes for libtool |
| |
| This chapter contains information that the libtool maintainer finds |
| important. It will be of no use to you unless you are considering |
| porting libtool to new systems, or writing your own libtool. |
| |
| @menu |
| * New ports:: How to port libtool to new systems. |
| * Tested platforms:: When libtool was last tested. |
| * Platform quirks:: Information about different library systems. |
| * libtool script contents:: Configuration information that libtool uses. |
| * Cheap tricks:: Making libtool maintainership easier. |
| @end menu |
| |
| @node New ports |
| @section Porting libtool to new systems |
| |
| Before you embark on porting libtool to an unsupported system, it is |
| worthwhile to send e-mail to @value{BUGADDR}, to make sure that you are |
| not duplicating existing work. |
| |
| Once it is clear that a new port is necessary, you'll generally need the |
| following information: |
| |
| @table @asis |
| @item canonical system name |
| You need the output of @code{config.guess} for this system, so that you |
| can make changes to the libtool configuration process without affecting |
| other systems. |
| |
| @item man pages for @code{ld} and @code{cc} |
| These generally describe what flags are used to generate PIC, to create |
| shared libraries, and to link against only static libraries. You may |
| need to follow some cross references to find the information that is |
| required. |
| |
| @item man pages for @code{ld.so}, @code{rtld}, or equivalent |
| These are a valuable resource for understanding how shared libraries are |
| loaded on the system. |
| |
| @item man page for @code{ldconfig}, or equivalent |
| This page usually describes how to install shared libraries. |
| |
| @item output from @kbd{ls -l /lib /usr/lib} |
| This shows the naming convention for shared libraries on the system, |
| including which names should be symbolic links. |
| |
| @item any additional documentation |
| Some systems have special documentation on how to build and install |
| shared libraries. |
| @end table |
| |
| If you know how to program the Bourne shell, then you can complete the |
| port yourself; otherwise, you'll have to find somebody with the relevant |
| skills who will do the work. People on the libtool mailing list are |
| usually willing to volunteer to help you with new ports, so you can send |
| the information to them. |
| |
| To do the port yourself, you'll definitely need to modify the |
| @code{ltconfig} script in order to make platform-specific changes to the |
| configuration process. You should search the script for the |
| @code{PORTME} keyword, which will give you some hints on what you'll |
| need to change. In general, all that is involved is modifying the |
| appropriate configuration variables (@pxref{libtool script contents}). |
| |
| Your best bet is to find an already-supported system that is similar to |
| yours, and make your changes based on that. In some cases, however, |
| your system will differ significantly from every other supported system, |
| and it may be necessary to add new configuration variables, and modify |
| the @code{ltmain.sh} script accordingly. Be sure to write to the |
| mailing list before you make changes to @code{ltmain.sh}, since they may |
| have advice on the most effective way of accomplishing what you want. |
| |
| |
| @node Tested platforms |
| @section Tested platforms |
| |
| This table describes when libtool was last known to be tested on |
| platforms where it claims to support shared libraries: |
| |
| @example |
| @include PLATFORMS |
| @end example |
| |
| @node Platform quirks |
| @section Platform quirks |
| |
| This section is dedicated to the sanity of the libtool maintainer. It |
| describes the programs that libtool uses, how they vary from system to |
| system, and how to test for them. |
| |
| Because libtool is a shell script, it can be difficult to understand |
| just by reading it from top to bottom. This section helps show why |
| libtool does things a certain way. Combined with the scripts |
| themselves, you should have a better sense of how to improve libtool, or |
| write your own. |
| |
| @menu |
| * References:: Finding more information. |
| * Compilers:: Creating object files from source files. |
| * Reloadable objects:: Binding object files together. |
| * Archivers:: Programs that create static archives. |
| @end menu |
| |
| @node References |
| @subsection References |
| |
| The following is a list of valuable documentation references: |
| |
| @itemize @bullet |
| @item |
| SGI's IRIX Manual Pages, which can be found at |
| @url{http://techpubs.sgi.com/cgi-bin/infosrch.cgi?cmd=browse&db=man}. |
| |
| @item |
| Sun's free service area |
| (@url{http://www.sun.com/service/online/free.html}) and documentation |
| server (@url{http://docs.sun.com/}). |
| @end itemize |
| |
| @node Compilers |
| @subsection Compilers |
| |
| The only compiler characteristics that affect libtool are the flags |
| needed (if any) to generate PIC objects. In general, if a C compiler |
| supports certain PIC flags, then any derivative compilers support the |
| same flags. Until there are some noteworthy exceptions to this rule, |
| this section will document only C compilers. |
| |
| The following C compilers have standard command line options, regardless |
| of the platform: |
| |
| @table @code |
| @item gcc |
| |
| This is the GNU C compiler, which is also the system compiler for many |
| free operating systems (FreeBSD, GNU/Hurd, GNU/Linux, Lites, NetBSD, and |
| OpenBSD, to name a few). |
| |
| The @samp{-fpic} or @samp{-fPIC} flags can be used to generate |
| position-independent code. @samp{-fPIC} is guaranteed to generate |
| working code, but the code is slower on m68k, m88k, and Sparc chips. |
| However, using @samp{-fpic} on those chips imposes arbitrary size limits |
| on the shared libraries. |
| @end table |
| |
| The rest of this subsection lists compilers by the operating system that |
| they are bundled with: |
| |
| @c FIXME these should all be better-documented |
| |
| @table @code |
| @item aix3* |
| @itemx aix4* |
| AIX compilers have no PIC flags, since AIX has been ported only to |
| PowerPC and RS/6000 chips. @footnote{All code compiled for the PowerPC |
| and RS/6000 chips (@code{powerpc-*-*}, @code{powerpcle-*-*}, and |
| @code{rs6000-*-*}) is position-independent, regardless of the operating |
| system or compiler suite. So, ``regular objects'' can be used to build |
| shared libraries on these systems and no special PIC compiler flags are |
| required.} |
| |
| @item hpux10* |
| Use @samp{+Z} to generate PIC. |
| |
| @item osf3* |
| Digital/UNIX 3.x does not have PIC flags, at least not on the PowerPC |
| platform. |
| |
| @item solaris2* |
| Use @samp{-KPIC} to generate PIC. |
| |
| @item sunos4* |
| Use @samp{-PIC} to generate PIC. |
| @end table |
| |
| @node Reloadable objects |
| @subsection Reloadable objects |
| |
| On all known systems, a reloadable object can be created by running |
| @kbd{ld -r -o @var{output}.o @var{input1}.o @var{input2}.o}. This |
| reloadable object may be treated as exactly equivalent to other |
| objects. |
| |
| @node Archivers |
| @subsection Archivers |
| |
| On all known systems, building a static library can be accomplished by |
| running @kbd{ar cru lib@var{name}.a @var{obj1}.o @var{obj2}.o @dots{}}, |
| where the @samp{.a} file is the output library, and each @samp{.o} file is an |
| object file. |
| |
| On all known systems, if there is a program named @code{ranlib}, then it |
| must be used to ``bless'' the created library before linking against it, |
| with the @kbd{ranlib lib@var{name}.a} command. Some systems, like Irix, |
| use the @code{ar ts} command, instead. |
| |
| @node libtool script contents |
| @section @code{libtool} script contents |
| @cindex implementation of libtool |
| @cindex libtool implementation |
| |
| The @code{libtool} script is generated by @code{ltconfig} |
| (@pxref{Configuring}). From libtool version 0.7 to 1.0, this script |
| simply set shell variables, then sourced the libtool backend, |
| @code{ltmain.sh}. @code{ltconfig} from libtool version 1.1 and later |
| inlines the contents of @code{ltmain.sh} into the generated |
| @code{libtool}, which improves performance on many systems. |
| |
| Here is a listing of each of the configuration variables, and how they |
| are used within @code{ltmain.sh}: |
| |
| @defvar AR |
| The name of the system library archiver. |
| @end defvar |
| |
| @defvar CC |
| The name of the C compiler used to configure libtool. |
| @end defvar |
| |
| @defvar LD |
| The name of the linker that libtool should use internally for reloadable |
| linking and possibly shared libraries. |
| @end defvar |
| |
| @defvar LTCONFIG_VERSION |
| This is set to the version number of the @code{ltconfig} script, to |
| prevent mismatches between the configuration information in |
| @code{libtool}, and how that information is used in @code{ltmain.sh}. |
| @end defvar |
| |
| @defvar NM |
| The name of a BSD-compatible @code{nm} program, which produces listings |
| of global symbols in one the following formats: |
| |
| @example |
| @var{address} C @var{global-variable-name} |
| @var{address} D @var{global-variable-name} |
| @var{address} T @var{global-function-name} |
| @end example |
| @end defvar |
| |
| @defvar RANLIB |
| Set to the name of the ranlib program, if any. |
| @end defvar |
| |
| @defvar allow_undefined_flag |
| The flag that is used by @samp{archive_cmds} in order to declare that |
| there will be unresolved symbols in the resulting shared library. |
| Empty, if no such flag is required. Set to @samp{unsupported} if there |
| is no way to generate a shared library with references to symbols that |
| aren't defined in that library. |
| @end defvar |
| |
| @defvar archive_cmds |
| @defvarx old_archive_cmds |
| Commands used to create shared and static libraries, respectively. |
| @end defvar |
| |
| @defvar build_libtool_libs |
| Whether libtool should build shared libraries on this system. Set to |
| @samp{yes} or @samp{no}. |
| @end defvar |
| |
| @defvar build_old_libs |
| Whether libtool should build static libraries on this system. Set to |
| @samp{yes} or @samp{no}. |
| @end defvar |
| |
| @defvar echo |
| An @code{echo} program which does not interpret backslashes as an |
| escape character. |
| @end defvar |
| |
| @defvar export_dynamic_flag_spec |
| Compiler link flag that allows a dlopened shared library to reference |
| symbols that are defined in the program. |
| @end defvar |
| |
| @defvar finish_cmds |
| Commands to tell the dynamic linker how to find shared libraries in a |
| specific directory. |
| @end defvar |
| |
| @defvar finish_eval |
| Same as @var{finish_cmds}, except the commands are not displayed. |
| @end defvar |
| |
| @defvar global_symbol_pipe |
| A pipeline that takes the output of @var{NM}, and produces a listing of |
| raw symbols followed by their C names. For example: |
| |
| @example |
| $ @kbd{$NM | $global_symbol_pipe} |
| @var{symbol1} @var{C-symbol1} |
| @var{symbol2} @var{C-symbol2} |
| @var{symbol3} @var{C-symbol3} |
| @dots{} |
| $ |
| @end example |
| @end defvar |
| |
| @defvar hardcode_action |
| Either @samp{immediate} or @samp{relink}, depending on whether shared |
| library paths can be hardcoded into executables before they are installed, |
| or if they need to be relinked. |
| @end defvar |
| |
| @defvar hardcode_direct |
| Set to @samp{yes} or @samp{no}, depending on whether the linker |
| hardcodes directories if a library is directly specified on the command |
| line (such as @samp{@var{dir}/lib@var{name}.a}). |
| @end defvar |
| |
| @defvar hardcode_libdir_flag_spec |
| Flag to hardcode a @var{libdir} variable into a binary, so that the |
| dynamic linker searches @var{libdir} for shared libraries at runtime. |
| @end defvar |
| |
| @defvar hardcode_libdir_separator |
| If the compiler only accepts a single @var{hardcode_libdir_flag}, then |
| this variable contains the string that should separate multiple |
| arguments to that flag. |
| @end defvar |
| |
| @defvar hardcode_minus_L |
| Set to @samp{yes} or @samp{no}, depending on whether the linker |
| hardcodes directories specified by @samp{-L} flags into the resulting |
| executable. |
| @end defvar |
| |
| @defvar hardcode_shlibpath_var |
| Set to @samp{yes} or @samp{no}, depending on whether the linker |
| hardcodes directories by writing the contents of @samp{$shlibpath_var} |
| into the resulting executable. Set to @samp{unsupported} if directories |
| specified by @samp{$shlibpath_var} are searched at run time, but not at |
| link time. |
| @end defvar |
| |
| @defvar host |
| @defvarx host_alias |
| For information purposes, set to the specified and canonical names of |
| the system that libtool was configured for. |
| @end defvar |
| |
| @defvar libname_spec |
| The format of a library name prefix. On all Unix systems, static |
| libraries are called @samp{lib@var{name}.a}, but on some systems (such |
| as OS/2 or MS-DOS), the library is just called @samp{@var{name}.a}. |
| @end defvar |
| |
| @defvar library_names_spec |
| A list of shared library names. The first is the name of the file, |
| the rest are symbolic links to the file. The name in the list is |
| the file name that the linker finds when given @samp{-l@var{name}}. |
| @end defvar |
| |
| @defvar link_static_flag |
| Linker flag (passed through the C compiler) used to prevent dynamic |
| linking. |
| @end defvar |
| |
| @defvar no_builtin_flag |
| Compiler flag to disable builtin functions that conflict with declaring |
| external global symbols as @code{char}. |
| @end defvar |
| |
| @defvar no_undefined_flag |
| The flag that is used by @samp{archive_cmds} in order to declare that |
| there will be no unresolved symbols in the resulting shared library. |
| Empty, if no such flag is required. |
| @end defvar |
| |
| @defvar pic_flag |
| Any additional compiler flags for building library object files. |
| @end defvar |
| |
| @defvar postinstall_cmds |
| @defvarx old_postinstall_cmds |
| Commands run after installing a shared or static library, respectively. |
| @end defvar |
| |
| @defvar reload_cmds |
| @defvarx reload_flag |
| Commands to create a reloadable object. |
| @end defvar |
| |
| @defvar runpath_var |
| The environment variable that tells the linker which directories to |
| hardcode in the resulting executable. |
| @end defvar |
| |
| @defvar shlibpath_var |
| The environment variable that tells the dynamic linker where to find |
| shared libraries. |
| @end defvar |
| |
| @defvar soname_spec |
| The name coded into shared libraries, if different from the real name of |
| the file. |
| @end defvar |
| |
| @defvar version_type |
| The library version numbering type. One of @samp{libtool}, |
| @samp{linux}, @samp{osf}, @samp{sunos}, or @samp{none}. |
| @end defvar |
| |
| @defvar whole_archive_flag_spec |
| Compiler flag to generate shared objects from convenience archives. |
| @end defvar |
| |
| @defvar wl |
| The C compiler flag that allows libtool to pass a flag directly to the |
| linker. Used as: @code{$@{wl@}@var{some-flag}}. |
| @end defvar |
| |
| Variables ending in @samp{_cmds} or @samp{_eval} contain a |
| semicolon-separated list of commands that are @code{eval}ed one after |
| another. If any of the commands return a nonzero exit status, libtool |
| generally exits with an error message. |
| |
| Variables ending in @samp{_spec} are @code{eval}ed before being used by |
| libtool. |
| |
| @node Cheap tricks |
| @section Cheap tricks |
| |
| Here are a few tricks that you can use in order to make maintainership |
| easier: |
| |
| @itemize @bullet |
| @item |
| When people report bugs, ask them to use the @samp{--config}, |
| @samp{--debug}, or @samp{--features} flags, if you think they will help |
| you. These flags are there to help you get information directly, rather |
| than having to trust second-hand observation. |
| |
| @item |
| Rather than reconfiguring libtool every time I make a change to |
| @code{ltconfig.in} or @code{ltmain.in}, I keep a permanent |
| @code{libtool} script in my @var{PATH}, which sources @code{ltmain.in} |
| directly. |
| |
| The following steps describe how to create such a script, where |
| @code{/home/src/libtool} is the directory containing the libtool source |
| tree, @code{/home/src/libtool/libtool} is a libtool script that has been |
| configured for your platform, and @code{~/bin} is a directory in your |
| @var{PATH}: |
| |
| @example |
| trick$ @kbd{cd ~/bin} |
| trick$ @kbd{sed '/^# ltmain\.sh/q' /home/src/libtool/libtool > libtool} |
| trick$ @kbd{cat >> libtool |
| LTCONFIG_VERSION="@@VERSION@@" |
| . /home/src/libtool/ltmain.in |
| ^D} |
| trick$ @kbd{chmod +x libtool} |
| trick$ @kbd{libtool --version} |
| ltmain.sh (GNU @@PACKAGE@@) @@VERSION@@ |
| trick$ |
| @end example |
| @end itemize |
| |
| The output of the final @samp{libtool --version} command shows that the |
| @code{ltmain.in} script is being used directly. Now, modify |
| @code{~/bin/libtool} or @code{/home/src/libtool/ltmain.in} directly in |
| order to test new changes without having to rerun @code{ltconfig}. |
| |
| @page |
| @node Index |
| @unnumbered Index |
| |
| @printindex cp |
| |
| @c summarycontents |
| @contents |
| @bye |