TODO   [plain text]


In the near future:
********************

* Check whether the version of libtool.m4 is compatible with
ltconfig/ltmain.sh.  Meanwhile, the recommended approach for
developers using automake is to insert libtool.m4 in acinclude.m4.

* Inter-library dependencies should be fully tracked by libtool and
need to work for ltlibraries too. This requires looking up installed
libtool libraries for transparent support.  Support for this feature
is under development, and is expected to be available in libtool 1.4.

* We could have an option to hardcode paths into libraries, as well as
binaries: `... -Wl,-soname -Wl,/tmp/libtest.so.0 ...'.  This is not
possible on all platforms, and is in part obviated by the ability of
linking libtool libraries specified with -lname, but it might still
be desirable.

* Lists of exported symbols should be stored in the pseudo library
so that the size of lt_preloaded_symbols can be reduced.

In the future:
**************

* Godmar Back writes:
  libltdl uses such stdio functions as fopen, fgets, feof, fclose, and others.
  These functions are not async-signal-safe. While this does not make 
  libltdl unusable, it restricts its usefulness and puts an 
  unnecessary burden on the user.

  As a remedy, I'd recommend to replace those functions with functions
  that POSIX says are async-signal-safe, such as open, read, close.
  This will require you to handle interrupted system calls and implement
  fgets, but the former isn't hard and there's plenty of implementations
  out from which you can steal the latter.

  I believe relying on async-signal-safe functions to the greatest extent
  possible would greatly improve libltdl's ability to be embedded in and 
  used by other systems.

* Arrange that EXEEXT suffixes are stripped from wrapper script names
only when needed, and that a timestamp file or a wrapper program is
created with the EXEEXT suffix, so that `make' doesn't build it every
time.

* Figure out how to use data items in dlls with win32.
The difficult part is compiling each object which will be linked with an
import lib differently than if it will be linked with a static lib.  This will
almost definitely require that automake pass some hints about linkage in to
each object compilation line.

* Resolve the name clash between import libs and static libs on win32.
Probably the best way to do this is to create lib$name-dll.a for the import
library, and continue to use lib$name.a for the static lib.  libtool
--mode=link can then favour -dll.a over .a if there is a choice.  No point in
doing this until we can export data items (above).

* If not cross-compiling, have the static flag test run the resulting
binary to make sure everything works.

* Implement full multi-language support.  Currently, this is only for
C++, but there are beginnings of this in the manual (Other Languages).
This includes writing libtool not to be so dependent on the compiler
used to configure it.

We especially need this for C++ linking, for which libtool currently
does not handle static constructors properly, even on operating
systems that support them.  ``Don't use static constructors'' is no
longer a satisfactory answer.

* We need some mechanism to allow users to pass flags to the linker
and/or to the compiler, when creating libtool archives.  We could
recognize linker flags such as `-Wl,flag' and `-Xlinker flag' in
libtool's command line, and passing them down to the linker, if "$wl"
is `-Wl,', or stripping the `-Wl,' part if we're calling `ld'
directly.  We could also introduce `-Wc,flag' and `-Xcompiler flag' to
allow unrecognized flags to be passed to the compiler, after stripping
by libtool.  This is already implemented in the CVS tree.

* Another form of convenience library is to have undocumented utility
libraries, where only the shared version is installed.

* We could use libtool object convenience libraries that resolve
symbols to be included in a libtool archive.  This would require some
sort of -whole-archive option, as well.

* Currently, convenience libraries (.al) are built from .lo objects,
except when --disable-shared.  When we can build both shared and
static libraries, we should probably create a .al out of .lo objects
and also a .a out of .o objects.  The .al would only be used to create
shared libraries, whereas the .a would be used for creating static
libraries and programs.  We could also explicitly support `empty'
convenience libraries, that behave as macros that expand to a set of
-Rs, -Ls and -ls switches.

* We should include tests with convenience libraries and reloadable
objects in the testsuite.

* Try to find a work-around for -[all-]static and libltdl on platforms
that will fail to find dlopening functions in this case.  Maybe
creating an alternate libltdl that provides only for dlpreopening, or
creating an additional static library to provide dummy implementations
of the functions that can't be linked statically.  This could hardly
be made completely transparent, though.

* Need to finalize the documentation, and give a specification of
`.la' files so that people can depend on their format.  This would be
a good thing to put before the maintainance notes.

* Filenames containing shell meta-characters are not properly handled
by libtool.  Compiling a file named "a;b.c", for example, fails.

* We could introduce a mechanism to allow for soname rewriting, to
ease multi-libc support.  Installers could specify a prefix, suffix or
sed command to modify the soname, and libtool would create the
corresponding link.  This would allow for rebuilding a library with
the same version number, but depending on different versions of libc,
for example.  In the future, we might even have an option to encode
the sonames of all dependencies of a library into its soname.

Things to think about:
**********************

* Talk with RMS about his so-called `automatic package generation
tool.'  This is probably what Thomas has been murmuring about for the
Hurd.  We'll need to integrate package-supplied programs such as
libtool into that scheme, since it manages some of the preinstall and
postinstall commands, but isn't installed itself.  Probably, things
like libtool should be distributed as part of such a binary package.

* Maybe implement full support for other orthogonal library types
(libhello_g, libhello_p, 64 vs 32-bit ABI's, etc).  Make these types
configurable.