summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorticktock35 <ticktock35@e8e0d7a0-c8d9-11dd-a880-a1081c7ac358>2008-12-14 23:52:22 (EST)
committer ticktock35 <ticktock35@e8e0d7a0-c8d9-11dd-a880-a1081c7ac358>2008-12-14 23:52:22 (EST)
commitd879963c09e74fed1d1ad2168d2d1fa1aa01f442 (patch)
tree11211400d6f3d10db0bdd8d9095bbdf969312ea1
parentdba0a0abdfbd89539090ccb41590e48fefc49c9b (diff)
opkg:
* remove generated files * add autogen.sh * move ChangeLog to ChangeLog.ipkg and start new ChangeLog for our changes * remove familiar directory git-svn-id: http://opkg.googlecode.com/svn/trunk@43 e8e0d7a0-c8d9-11dd-a880-a1081c7ac358
-rw-r--r--ChangeLog1761
-rw-r--r--ChangeLog.ipkg1761
-rwxr-xr-xautogen.sh5
-rwxr-xr-xcompile142
-rwxr-xr-xconfig.guess1466
-rwxr-xr-xconfig.sub1579
-rwxr-xr-xdepcomp522
-rw-r--r--familiar/Makefile.am1
-rw-r--r--familiar/control-unstripped.in22
-rw-r--r--familiar/control.in21
-rw-r--r--familiar/libopkg-control.in21
-rw-r--r--familiar/libopkg-dev-control.in21
-rwxr-xr-xinstall-sh294
-rw-r--r--ltmain.sh6530
-rwxr-xr-xmissing336
-rwxr-xr-xmkinstalldirs111
16 files changed, 1766 insertions, 12827 deletions
diff --git a/ChangeLog b/ChangeLog
index d13b3fb..e69de29 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,1761 +0,0 @@
-2006-05-30 pigi ( pigi@frumar.it)
- * Version update to 0.99.163
- * Fixed a bug in GNU_TAR_EXTENSION of unarchive.c. This fix #1666
-
-2006-05-04 pigi ( pigi@frumar.it)
- * Fixed a little bug in makefile that inhibit the compilation from .tar.gz ( missing intercept dir )
-
-2006-04-20 pigi ( pigi@frumar.it)
- * Version update to 0.99.162
- * Fixed a bad bug introduced in .160 that was blocking the install of a package
-
-2006-04-18 pigi ( pigi@frumar.it)
- * Version update to 0.99.161
-
-2006-04-18 pigi ( pigi@frumar.it)
- * Another little fix for the upgrade part.Now alse the prerm and postrm scripts gets deleted before upgrading.
- wishing this fix the last troubles in upgrade part.
- * Fix for #1585 after the bug introduced with the modify for offline root. ( Again )
-
-2006-03-30 pigi ( pigi@frumar.it)
- * Activated the patch from Gunter@ohrner.net for the md5 check of package
- * Another change in the upgrade part, to handle the ghosts files from an upgraded package
-
-2006-03-30 pigi ( pigi@frumar.it)
- * Version update to 0.99.160
- * Fix for #1585 after the bug introduced with the modify for offline root.
- * Patch from Gunter@ohrner.net that fix a memory leak
- * Not yet activated, but inserted a patch from Gunter@ohrner.net for the md5 check of package
-
-2006-02-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.159
- * Another change in the upgrade part, to handle the ghosts files from an upgraded package
- * Now it should be ok. Thanks to pb_ for pointing out where to look at.
-
-2006-02-02 pigi ( pigi@frumar.it)
- * Version update to 0.99.158
- * Modified the way upgrade handle the removing of a package, to be sure that opkg doesn't break busybox upgrade
- * this should fix #1503
-
-2006-01-30 pigi ( pigi@frumar.it)
- * applied patch from pb_ for speed up things in boot ( to avoid multiple configure execution )
- * applied patch from <r.schwebel@pengutronix.de> for 100+ filenames in tar file ( again )!
- * applied patch from <r.schwebel@pengutronix.de> to avoid trouble in offlineroot installations.
-
-2006-01-22 pigi ( pigi@frumar.it)
- * Version update to 0.99.157
-
-2006-01-17 pigi ( pigi@frumar.it)
- * Added a check to avoid reading feed files with several options. This should fix #1458 and speed up a lot of executions.
-
-2006-01-12 pigi ( pigi@frumar.it)
- * Version update to 0.99.156
- * Fixed a length problem for strncpy when "Installing" option added. This fix bug #1456. Thanks to hrw for signaling
-
-2005-12-15 pigi ( pigi@frumar.it)
- * Version update to 0.99.155
- * Added a function to remove the package that is being upgraded.
- * Fixed a problem when installing by hand. Now opkg knows that a package has been selected by hand,
- * and, if every check returns ok, it install the wanted package, instead of selecting one from feed.
- * Moreover, now downgrade should works again.
- * Fixed the "Replaces" bug. Now opkg is able to replace a package also if it doesn't conflict.
- * Other minor changes in debug options
-
-2005-09-15 pigi ( pigi@frumar.it)
- * Version update to 0.99.154
- * Corrected a problem when removing a package, caused by an off by one alignement with the "Provides:" String
- * Patched for the "depends:" bug introduced after the "Provides:" fix. This fix #1393
- * Added a little fix for an off-by-one error in checking for depends.
-
-2005-07-29 pigi ( pigi@frumar.it)
- * Applied a patch for the GNU tar compatibility . Now opkg can handle filenames > 100 char.
-
-2005-07-29 pigi ( pigi@frumar.it)
- * Version update to 0.99.153
- * Fixed a problem with Provides:. Now opkg is able to install foo when foo is provided by bar, and is able to determine the best candidate based on
- * package name. This also fix #1328
-
-2005-07-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.152
- * Fixed a length problem for strncpy after "Downgrading" option added. This fix bug #1373. Thanks to steven.scholz@imc-berlin.de for signaling
-
-2005-06-16 pigi ( pigi@frumar.it)
- * Version update to 0.99.151
- * Fixed a missing check for null pointers . This fix bug #1358
-
-2005-06-05 pigi ( pigi@frumar.it)
- * Version update to 0.99.150
- * Added the -force-downgrade option to allow the downgrade of a package
-
-2005-05-11 pigi ( pigi@frumar.it)
- * Version update to 0.99.149
- * Added the possibility to choice the opkglibdir from configure ( --with-libopkgdir )
-
-2005-04-10 pigi ( pigi@frumar.it)
- * Version update to 0.99.148
-
-2005-04-09 pigi ( pigi@frumar.it)
- * Found a bug in output from error_list. Now every error is printed, also if the functions don't return an error.
- * Added a patch to Makefile from Robert Schwebel <r.schwebel@pengutronix.de>, cleaning things a bit. Thanks to Schwebel
-
-2005-03-30 pigi ( pigi@frumar.it)
- * Version update to 0.99.147
- * Found a bug in opkg_install when freeing a cursor
-
-2005-03-28 pigi ( pigi@frumar.it)
- * Version update to 0.99.146
- * Modified the opkg_error messaging to collect all the messages at the end of the program
-
-2005-03-26 pigi ( pigi@frumar.it)
- * Little bug in message when "depends broken"
-
-2005-03-14 pigi ( pigi@frumar.it)
- * Version update to 0.99.145
- * Found a bug in opkg remove when a package was depending in itself and opkg where asked to "-recursive"
- This fix bug # 1301
- * A very little beautify in args.c
-
-2005-03-07 pigi ( pigi@frumar.it)
- * Added the check for md5 in resolv_conf_file. Now opkg ask for confirmation only it the files differ
-
-2005-02-22 pigi ( pigi@frumar.it)
- * Version update to 0.99.144
- * A little fix suggested by drw in opkg_conf.c
- * Changed the opkg.h to be build in automake for oe mechanism . This will enhance the building phase
- by honouring the lib hierarchy choose by users
- * Changes in automake to honour the new building mechanism
-
-2005-02-20 pigi ( pigi@frumar.it)
- * Version update to 0.99.143
- * libopkg.h: reverting the previous modify
- * opkg_conf.c: fixing a probable bug in list_dir that fix problems with opie-packagemanager ( tanks to drw for signaling)
-
-2005-02-20 pigi ( pigi@frumar.it)
- * libopkg.h: added some define to fix the broken external interface after 0.99.139 and lists_dir
-
-2005-02-17 pigi ( pigi@frumar.it)
- * pkg_depends.c: applied patch from rjt@cambridgebroadband.com to remove some c99ism
-
-2005-02-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.142
- * Fixed the definition of full_write and full_read as per bug #1280
-
-2005-02-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.141
- * Added space in opkg_message to give more readible messages
- * Corrected a problem when creating the directories in pkg_dest_init
-
-2005-02-05 pigi ( pigi@frumar.it)
- * Version update to 0.99.140
- * Fixed the bug in opkg_conf for a wrong pointer.
-
-2005-02-05 pigi ( pigi@frumar.it)
- * Version update to 0.99.139
- * Fixed the "replaces" problem reported by pb_. Now opkg is able to resolve a "replace/conflict" reference
- * Added the possibility to keep the lists file in a different location. Fullfill enh #1276
-
-2005-02-02 pigi ( pigi@frumar.it)
- * Fixed the problem for SW_DEINSTALL in remove. Fix #1274
- * Fixed the problem issued from florian. This also fix the bug #520 HardLink are now supported
-
-2005-01-18 pigi ( pigi@frumar.it)
- * Version update to 0.99.138
- * libbb.h: patch for the uclib
-
-2005-01-14 pigi ( pigi@frumar.it)
- * opkg_install.c: applied patch from rjt@cambridgebroadband.com to remove some c99ism
-
-2005-01-14 jamey ( jamey@handhelds.org )
- * pkg_hash.c: applied patch from Jean Tourrilhes to allow default
- arch to be different than host arch
-
-2005-01-10 pigi ( pigi@frumar.it)
- * Version update to 0.99.137
- * fixed a little, but annoying bug when writing the status file.
-
-2005-01-10 pigi ( pigi@frumar.it)
- * Version update to 0.99.136
- * Lot of memory leak fixes from Benjamin Pineau <ben@zouh.org>
- * Fix for the Provides, that weren't able to "protect" their dependants while removing.
- Now the remove should be safer.
- * removed the replace.h stuff from automake .ac/.in files. This should align to oe
-
-2005-01-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.135
- * Various fix for dependencies in control files
-
-2005-01-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.134-1 for fixing a problem with cvs tag on previous version
-
-2005-01-06 pigi ( pigi@frumar.it)
- * Version update to 0.99.134
- * Added a new option for listing only the installed packages. Asked by pb_ but really important
- * Little modification to autoconfigure.sh
- * removed fileutils dependencies that has disappeared from 0.8 in control-cl.in control-unstripped.in libopkg-control.in
-
-2004-11-18 pigi ( pigi@frumar.it)
- * Version update to 0.99.133
- * Fix for preserve date and time when extracting a package. Thanks to <trevor.pering@intel.com>
-
-2004-10-07 pigi ( pigi@frumar.it)
- * Version update to 0.99.132
- * Little fix on available blocks calculation. Thanks to seved.torstendahl@netinsight.se for founding it.
- * this fix #1259
-
-2004-09-20 pigi ( pigi@frumar.it)
- * Version update to 0.99.131
- * Added a lot of debug info in DEBUG2
- * Added a check in opkg_install.c to permit replacing of existing file when installing a package
- * from a file ( not an upgrade ) when opkg find a file clash but the owner of the package is the
- * same. That should fix the #1246
-
-2004-09-02 pigi ( pigi@frumar.it)
- * Version update to 0.99.130
- * Added patch from pb_ for bug #1251. A lot of thanks to Phil
-
-2004-09-02 pigi ( pigi@frumar.it)
- * Some changes on output messages to be a little bit clear
-
-2004-09-01 pigi ( pigi@frumar.it)
- * Applied patches from pb_ (bug #1244)
- * Added EXTRADIST = opkg.c and others in Makefile.am as in opkg.0.99.xxx.tar.gz the opkg.c was missing. (
- reported by odvard12@yahoo.com )
- * Version update to 0.99.129
-
-2004-08-19 Florian <florian.boor@kernelconcepts.de>
- * Version update to 0.99.128
- * libopkg.c, opkg_cmd.c: Fixed return value zero if installation
- failed. Changed text because failing to install a package
- is not necessarily a bug :-)
- * Makefile.in, libbb/Makefile.in: Removed autogenerated files.
-
-2004-08-18 Florian <florian.boor@kernelconcepts.de>
- * Two more fixed memory leaks. Contributed by Nils Faerber.
-
-2004-08-17 Florian <florian.boor@kernelconcepts.de>
- * Fix to avoid major memory leak due to multiple initialising
- of hash tables. Contributed by Nils Faerber.
-
-2004-07-20 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.127
- * Applied patch from tmbinc@elitedvb.net (Felix Domke) to fix some problems when in use on platforms
- * different from arm. Fixes big #1234
-2004-06-15 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.126
-2004-06-12 florian <florian.boor@kernelconcepts.de>
- * Makefile.am: Added some missing headers to the list.
- * libopkg.pc.in: Fixed hardcoded prefix... tsts
-2004-06-12 pigi ( pigi@frumar.it)
- * pb_ patch for setuid bit in unarchive
-2004-06-05 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.125
- * modified almost all reference to xregexec in fnmatch ( as adviced by zap).
- This should fix every problem with strange character in package name when using regex in functions
- ( as per info_status_cmd or remove ). #1220
-2004-05-21 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.124
- * import the kergoth patch for Makefile.am to fix the linking problems on arch <> arm
- * added the opkg remove <regexp> feature.
- * fixed the opkg usage message, 'cause in "ifdef LIBOPKG" we don't have the opkg info field version.
- * added the message "No package removed" if no package has been removed. This to avoid misunderstanding
- with the successfully done message at the exit of execution.
-2004-05-16 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.122-3
- * Anothere little fix. Added the version number in control.in. This should fix definitelly the problem with dependencies
-2004-05-16 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.122-2
- * New subrelease released to correct the problem for dependencies (libopkg >= 0.99.122-1) in opkg control file
-2004-05-14 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.122-1
- * needed for a recompilation with the libtool updated. This could fix the #1209 created by my old libtool version
- * cleaned the cvs dir by removing the really unneeded busybox directory
-2004-05-10 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.122
- * pb_, cworth and I discussed a bit on opkg output to users. We agreed on removing some confusing
- * messages, moving them to a debug level of verbosity.
- * I do added also some message to user indicating the phase opkg is in, and a global ending message
- * informing the user for the status of operation.
- * This fixes the #1206, and hopefully does not introduce others ;-)
-2004-05-03 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.121
- * reenoo__ found a problem with depend lines > 1023, and pb fixed it. Thanks to both,
- * This should fix #1204.
-2004-04-08 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.120
- * pb found another one. The configure cmd now will set the correct values in status file
- * #1196 fixed
-2004-04-07 pigi ( pigi@frumar.it)
- * configure.ac: updated to 0.99.119
- * pb found another one. Commiting his patch, elegant as usual :)
-2004-03-29 jamey ( jamey@handhelds.org)
- * configure.ac: updated to 0.99.118
-2004-03-29 pigi ( pigi@frumar.it)
- * pb_ asked me to have a command to change the status of a package betwenn installed and unpacked.
- and I did it.
- * I' ve also included the fix for the empty lists as for bug # 1136 reported and suggested by k.vangelder@chello.nl
-2004-03-17 pigi ( pigi@frumar.it)
- * Added the implement for Essential in status file. This is needed to avoid the unintentional remove
- of essential packages. In effect the command "opkg remove opkg" worked without problems, but then
- it was difficult to reinstall. This fix the bug # 867
-2004-03-15 jamey <jamey@handhelds.org>
- * configure.ac: updated to 0.99.117
-2004-03-10 pigi ( pigi@frumar.it)
- * Added the check for *alloc in every source. I needed to modify some function ehre and there
- to check the return values from function allocating memory, but hopefully it should be all right now.
- * Added the check for at least a package for remove ( it was removing everithing if no pkgname followed the
- remove option.
-2004-03-09 pigi ( pigi@frumar.it)
- * Added a flag to disble the checking of directories when the command does not need to
- read anything from there. Fix bug #1096
-2004-03-09 pigi ( pigi@frumar.it)
- * Changes to correct the behaviour of verbosity. Now the "0" works, and the "1" is again
- the default.
- This fixes the bug #1099
-2004-03-07 pigi ( pigi@frumar.it)
- * Minimal changes for a clean compile in libopkg.c ( so we can close the bug# 1119 )
-2004-03-03 pigi ( pigi@frumar.it)
- * Missing \n in Size and Source Fields.
-2004-03-03 pigi ( pigi@frumar.it)
- * Florian noticed a free missiing in opkg_cmd.c ( should sleep more at night )
- it was in an (almost) unsed part of the code ( old code ) but, just in case...
- * Changed a comment in pkg.c ( it was in italian ) and added a bit of explain in
- pkg_formatted_field
-2004-03-02 jamey <jamey@handhelds.org>
- * configure.ac: updated to 0.99.116
- * pkg.h: from Pigi: pkg_formatted_info and pkg_formatted_field now allocate the strings they fill in
- * pkg.c, opkg_cmd.c: from Pigi: updated to the new pkg.h interface
-2004-02-29 florian <florian.boor@kernelconcepts.de>
- pkg.c: Pigi and me poked around a little bit and located the cause of
- latest segfault. strncat is not used correctly in pkg_formatted_info
- and pkg_formatted_field. I added a fix to the only section that
- triggered the bug and increased a buffer size.
- BUT: There are many similar bugs remaining!
-2004-02-24 jamey <jamey@handhelds.org>
- * configure.ac: updated to 0.99.115
- * opkg_cmd.c: segv caught by pigi: buffer freed in loop but used on next iterations. bug squashed.
- * user.c: realloc question buffer if it is too short so that messages are not truncated.
-2004-02-20 jamey <jamey@handhelds.org>
- * configure.ac: updated to 0.99.114
- * libbb/unarchive.c: patch from pigi@frumar.it: fix erroneous invalid header checksum message
-2004-02-19 jamey <jamey.hicks@hp.com>
- * configure.ac: update to 0.99.113
- * libopkg.c: patch from drw to fix opkg list
-2004-02-19 florian <florian.boor@kernelconcepts.de>
- * Some minor changes to make code compile on more compilers.
-2004-02-14 jamey <jamey.hicks@hp.com>
- * configure.ac: updated to 0.99.112
- * libbb/unarchive.c: copied in oldgnu tar compatibility mode from latest busybox.
-2004-02-13 jamey <jamey.hicks@hp.com>
- * configure.ac: updated to 0.99.111
- * pkg.c: wim delvaux's patch for status file in other destinations
-2004-01-23 florian <florian.boor@kernelconcepts.de>
- * Applied Dan's patch that adds a package download command to
- libopkg.
-2004-01-20 florian <florian.boor@kernelconcepts.de>
- * Applied Dan's changes to work incuded from a C++ app.
-2004-01-15 jamey
- * configure.ac: updated to 0.99.110
- * libopkg.c: added default callbacks for output
- * opkg_conf.c: default verbosity to 1
-2004-01-12 jamey
- * configure.ac: updated to 0.99.109
- * opkg_install.c: fix potential segv sprintf_alloc with fewer args than required by format string (yay valgrind)
- * sprintf_alloc.c: add null pointer checking
-2004-01-12 jamey
- * configure.ac: updated to 0.99.108
- * Makefile.am, familiar/: use opkg-cl as default executable, install as opkg via update-alternatives
-2004-01-12 jamey
- * configure.ac: updated to 0.99.107
- * void_list.c: check for null data
- * pkg.c: check for null pointers
-2003-12-23 florian <florian.boor@kernelconcepts.de>
- * Added void* parameter to some callbacks.
-
-2003-12-02 florian <florian.boor@kernelconcepts.de>
- * Added familiar/opkg-cl.control.in, which is a prototype of
- control file for opkg-cl package creation.
-2003-12-01 florian <florian.boor@kernelconcepts.de>
- * added opkg command line tool using libopkg, binary is known as opkg-cl
- * opkg-frontend.c: source for this tool
- * libbb/Makefile.am: Removed changing of CFLAGS, this avoids a nasty warning.
- * Makefile.am: Same fix and addition of new target creating opkg-cl.
- * removed ltmain.sh, libtool which seem to be created by autostuff
-
-2003-12-01 jamey
- * configure.ac: updated to 0.99.106
- * pkg.c, opkg_conf.c: check for null pointers (null pkg->dest in particular)
-2003-11-11 jamey
- * configure.ac: updated to 0.99.105
- * opkg_conf.c: added verbosity option to conf file
-2003-11-11 jamey
- * configure.ac: updated to 0.99.104
- * opkg_install.c: removed spurious calls to fflush, remove obsolete maintainer scripts on upgrade
- * opkg_remove.c: remove unused function: remove_conffiles
-2003-11-11 jamey
- * configure.ac: updated to 0.99.103
- * libopkg.pc.in, configure.ac: pkgconfig for libopkg
- * opkg_conf.c, pkg.c: check for error on fopen
- * pkg_hash.c: reduced verbosity
- * libtool: arm-linux-strip does not support --strip-debug on .a files
-2003-11-10 jamey
- * configure.ac: updated to 0.99.102
- * opkg_cmd.c: compute architecture_priority of packages in database before doing download command
- * conffile.c file_util.[ch] opkg_install.c: better separation of installation root filenames and actual filenames
- * pkg.h: added prototype for pkg_free_installed_files
-2003-11-10 jamey
- * configure.ac: updated to 0.99.101
- * libopkg changes
- * generate .list files from file_hash
-2003-11-05 jamey
- * configure.ac: updated to 0.99.100
- * opkg_install.c: fix segv: was passing conflictee->parent instead of conflictee
-2003-10-08 jamey
- * configure.ac: updated to 0.99.99
- * opkg_install.c: use the root_dir after stripping off offline_root prefix
-2003-10-08 jamey
- * configure.ac: updated to 0.99.98
- * pkg_hash.c: fixed segv if replaced_by->len was 0
- * opkg_cmd.c: opkg remove with no arguments will remove non-user leaf packages
- * opkg_remove.[ch]: export pkg_has_installed_dependents
- * pkg_depends.c: add pkg->parent to pkg->provides
- * opkg_install.c: strip offline_root prefix off of conffile name so comparing the md5sums should work
- * pkg.c: missing comma added
-2003-10-01 jamey
- * configure.ac: updated to 0.99.97
- * opkg_cmd.c: added whatdependsrec command to show what recursively depends on a package or packages
- * pkg_vec.[ch]: added pkg_vec_clear_marks and pkg_vec_mark_if_matches
- * args.c: usage string updated
-2003-09-28 jamey
- * configure.ac: updated to 0.99.96
- * opkg_conf.c: adjusted verbosity
- * opkg_install.c: only remove replacee if it is also conflicted, per debian standard
- * pkg_depends.c: only add to replaced_by if it also conflicts, per debian standard
- added pkg_provides, pkg_replaces, pkg_conflicts
- * pkg_hash.c: adjusted verbosity
-2003-09-28 jamey
- * configure.ac: updated to 0.99.95
- * args.[ch], opkg_cmd.c, opkg_conf.[ch], opkg_download.c, opkg_install.c, opkg_remove.c, pkg.[ch]:
- Implemented -test mode for opkg.
-2003-09-28 jamey
- * configure.ac: updated to 0.99.94
- * pkg_hash.c: fix pkg_hash_fetch_best_installation_candidate so
- that one can install another provider of an installed package name
-2003-09-26 jamey
- * configure.ac: updated to 0.99.93
- * opkg_install.c: corrected message level depending on conf->force_depend
- * opkg_conf.c: check for duplicate src entries
- * nv_pair_list.[ch]: added nv_pair_list_find
-2003-09-16 jamey
- * configure.ac: updated to 0.99.92
- * pkg_depends.c: some paranoia to try to avoid segv
- * void_list.c: silenced message about elt not being found
-2003-09-11 jamey
- * configure.ac: updated to 0.99.91
- * pkg_depends.c: added pkg_depend_str to fetch right kind of dependence string based on dependence index
- Use this in add_unresolved_dep.
- * pkg_depends.h: declaration of pkg_depend_str
-2003-08-22 11:02 jamey
- * configure.ac: updated to 0.99.90
- * str_list.[ch]: added str_list_alloc(), added str_list_remove_elt()
- * void_list.[ch]: added void_list_remove_elt()
- * pkg_parse.c: added parsing of Source field
- * pkg_hash.c: updated old_pkg->installed_files list when setting file owner if it was previously owned by old_pkg
- * pkg_extract.c: use installed_file list if it exists in pkg_extract_data_file_names_to_file
- * pkg.[ch]: added pkg_write_filelist() and pkg_write_changed_filelists()
- * opkg_remove.c: do not call opkg_conf_write_status_files from opkg_remove
- * opkg_install.c: use opkg_write_filelist()
- * ipgk_cmd.c: after writing status file, write any changed pkg filelists
-2003-08-20 11:02 jamey
- * configure.ac: updated to 0.99.89
- * pkg.c: print Source field in pkg_print_info
-2003-08-06 18:34 jamey
- * configure.ac: updated to 0.99.88
- * pkg_hash: bug 942, declare internal induction variable
- * opkg_cmd.c, opkg_conf.[ch], pkg_src.[ch], pkg_src_list.[ch]: bug 604, support Packages.gz
-2003-08-06 18:34 jamey
- * configure.ac: updated to 0.99.87
- * pkg.c: remove extra printing of Suggests field
- * pkg_vec.c: merge Status field only from current database, rest of Package info from Packages files
- * pkg_depends.c: print info about recommendations as Notice instead of DEBUG
-2003-07-11 18:34 jamey
- * configure.ac: updated to 0.99.86
- * opkg.h, opkg_cmd.c, opkg_configure.c, opkg_install.c, opkg_remove.c: only write status file if something changed.
-2003-07-11 18:34 jamey
- * configure.ac: updated to 0.99.85
- * pkg.c, pkg.h, pkg_depends.c, pkg_depends.h, pkg_parse.c: bug 885:
- add recommends and suggests
- * args.c, opkg_cmd.c, opkg_cmd.h: add opkg configure command
- * pkg_vec.c: apply patch for bug 883
-2003-05-11 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.84
- * pkg.c, opkg-compare-versions.c: fix problem where . and - were not treated as separators in version comparison
-2003-04-11 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.83
- * opkg_install.c: use pkg->installed_size instead of pkg->size
- * opkg_cmd.c, opkg_conf.c: put lists under offline_root if specified
-2003-04-11 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.82
- * pkg_hash.c: ignore Replaces directive when a package replaces itself
-2003-04-10 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.81
- * pkg.c: clear state_want and state_flags for any uninstallable package
-2003-04-10 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.80
- * pkg.c: pkg_merge was intermingling depends and predepends from
- old and new pkg, and was ignoring conflicts and replaces
- * pkg_depends.c: cleaned up interface to parseDepends
-2003-04-07 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.79
- * pkg_hash.c: default architecture to host_cpu if unspecified
- * opkg_install.c, opkg_download.c: refuse to install package with no architecture
-2003-04-07 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.78
- * args.[ch], opkg_conf.[ch]: added query_all (-A)
- * opkg_cmd.c: finished implementing whatdepends, whatrequires, whatprovides, and whatconflicts
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.77
- * opkg_cmd.c: implemented whatdepends
- * opkg_conf.c: fixed typo
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.76
- * args.c: was zeroing args structure too late
- * opkg_conf.c: test for existence of /etc/opkg.conf before trying to load it
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.75
- * familiar/rules: update postinst only to generate ipaqarch.conf if none exists
- * args.[ch]: added -t or --tmp-dir option to specify tmp-dir
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.74
- * opkg_cmd.c: avoid segv by only calling xregfree after xregcomp was called
- * pkg_hash.c: prefer pkgs that are marked hold/prefer, next
- abstract pkgs that are installed, next latest pkg if one provider,
- give up if multiple providers are acceptable -- let user decide
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.73
- * pkg_hash.c: remove latest_installed heuristic because it prevents upgrades.
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.72
- * pkg_hash.c: check for unresolved packages (apkg->provided_by->len == 0), better messages.
-2003-04-03 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.71
- * pkg.c: Added pkg_name_version_and_architecture_compare and abstract_pkg_name_compare
- * opkg_cmd.c: allow multiple fields for info and status command.
- Allow posix regexp's for package name in status, info, and list
- commands.
- * pkg_remove.c: fixed type error
- * xregex.h: added xregfree
- * pkg_hash.c: Provides functionality seems to be working again
-2003-04-02 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.70
- * args.c, args.h, opkg_conf.c, opkg_conf.h, opkg_install.c: implemented nodeps option
- * pkg_vec.[ch]: added [abstract_]pkg_vec_{contains,sort}
- * pkg.c: print which script not being run in offline root mode
-2003-04-02 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.69
- * pkg_vec.c: compare architecture to architecture, not to name
- * opkg_utils.c: do not exit, instead return NULL
- * opkg_install.c: do not exit, instead return -EINVAL
- * opkg_download.c: make sure to set pkg dest
- * opkg_cmd.c: notice instead of info for writing status file message
-2003-04-02 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.68
- * pkg_vec.c, pkg_depends.c: pkg_t's are the same if they have same name, version, and architecture
-2003-04-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.67
- * opkg_install.c: one last check for supported architecture in opkg_install_pkg
- * pkg.c: make pkg_print_field less fragile by using strcasecmp,
- added support to print Conflicts
- * pkg_hash.c: if multiple candidates with right architecture
- satisfy constraint_fcn, return latest version
- * opkg_cmd.c: when verbosity > 1, show if conffiles have been
- modified in info command
- * hash_table.c, hash_table.h: count number of elements in hash
- tables
- * file_util.c: explicitly use unsigned char
- * conffile.c: more debugging info
-2003-04-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.66
- * pkg_depends.c: fixed what seemed to be glaring deficiency in version_constraints_satisfied
- * pkg_hash.c: more debug info
- * pkg_parse.c, pkg.c: added Installed-Time as field saved to status file
-2003-04-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.65
- * opkg_cmd.c, opkg_conf.c: applied opkg dest installation patch from Ben Lau <benlau@linux.org.hk>
- * opkg_cmd.c: fixed probably segv when using offline_root, fixed problem installing from local file.
- * opkg_conf.c:
- - Do not add default architectures if opkg configuration files include architecture definitions.
- - Look for /etc/opkg/*.conf under offline root if using offline root mode
- * void_list.h: added void_list_empty()
- * nv_pair_list.h: added nv_pair_list_empty()
-2003-03-28 14:30 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: 0.99.64
- * pkg_hash.c: change fprintf stderr to opkg_message
- * pkg.h: added SF_MARKED and abstract_pkg_t state_flag field
- * pkg.c: include Provides, Replaces, and Architecture in status
- file
- * opkg_remove.c: make sure to print each dependent package only
- once
- * opkg_message.h: added OPKG_DEBUG2
- * opkg_install.c: modify message and level depending on
- force_depends
- * opkg_cmd.c: call pkg_info_preinstall_check before any
- install/upgrade/remove action
- * ChangeLog, autoconfigure.sh, includes.h,
- opkg_conf.c, opkg_remove.c, pkg.c, pkg.h, update-alternatives,
- xregex.h: applied kergoth's update-alternatives patch
- * opkg_cmd.c, opkg_remove.c: remove maybe_broken_removal... which
- was an expensive no-op; before removing package, make sure that
- nothing is installed that depends on the apkgs **provided** by a
- package
- * pkg.h: mark for future cleanup
- * ChangeLog: 0.99.62, adds architecture priority, better handling
- of file obsolescence and package replacements in progress
-2003-03-27 18:26 jamey
- * autoconfigure.sh: accidentally committed /usr/local/bin calls
- * opkg_conf.c: needed a strdup, set default verbosity back to 0
- * familiar/postinst: default architecture priorities
- * Makefile.in, autoconfigure.sh, opkg_cmd.c, opkg_conf.c, pkg.c:
- both name and value in nv_pair_list must be actual strings
- * pkg_hash.c: do not try to invoke NULL constraint_fcn
- * opkg_install.c: added file_hash_{set,get}_file_owner, created
- check_downgrade
- * opkg_conf.c, opkg_conf.h, opkg_remove.c, pkg.c, pkg_hash.c,
- pkg_hash.h: added file_hash_{set,get}_file_owner
- * hash_table.c: check for key already being present in
- hash_table_insert
- * configure.ac: update to 0.99.63
- * opkg_hash_test.c: update due to new prototypes
- * opkg_conf.c: missed a conversion from str_list to nv_pair_list
- * opkg_install.c: minor tweaks
- * pkg.c, pkg.h: added pkg_info_preinstall_check to update
- pkg->arch_priority
- * pkg_depends.c, pkg_depends.h: use constrained
- pkg_hash_fetch_best_installation_candidate in
- pkg_hash_fetch_unsatisfied_dependencies
- * pkg_hash.c, pkg_hash.h, opkg_cmd.c, opkg_upgrade.c: split
- pkg_hash_fetch_best_installation_candidate into a by name and a
- constrained version
- * opkg_install.c: block SIGINT while doing core of package
- installation (single package)
- * opkg_conf.c, opkg_conf.h: support for architecture priority
- * pkg_depends.c: cleanup, reindent
- * pkg.c, pkg.h: support for architecture_priority
- * opkg_cmd.c: installed SIGINT handler when upgrading or removing,
- support for architecture_priority
- * pkg_hash.c: added support for architecture priority, reindented
- * pkg_vec.c: minor cleanup
-2003-03-24 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.61
- * familiar/postinst: mkdir -p /etc/opkg
-2003-03-24 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.61
- * opkg_conf.c: read configuration from all *.conf files in /etc/opkg/
- * familiar/postinst: create /etc/opkg/*.conf according to platform opkg is installed on
-2003-03-20 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.60
- * various: added support for package architectures
- * configure.ac: do not test for malloc
-2003-03-17 Aman Gupta <opkg@themastermind1.net>
- * configure.ac: updated to 0.99.59
- * args.c: show all verbosity levels in usage info
- * args.h: changed default verbosity level to 1
- * opkg_cmd.c: opkg_multiple_files_scan() was useless, switch to using
- opkg_prepare_url_for_install()
- * opkg_install.c: fix --force-reinstall
- * opkg_remove.c: stop removing of modified conffiles
-2003-03-04 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.56
- * opkg_message.c: show error messages by default
- * opkg_message.h: protect against multiple inclusion
- * conffile.[ch]: switch to opkg_message, added conf argument to conffile_has_been_modified
- * opkg.h: move EXTENSION macros here
- * pkg_depends.c: minor cleanup
- * pkg.h: added prefer and obsolete flags
- * pkg.c: parse and unparse SF_PREFER and SF_OBSOLETE
- * opkg_install.[ch]:
- - added {pkg,name}_mark_dependencies_for_installation,
- - added conf argument to conffile_has_been_modified
- - missing ifdef OPKG_DEBUG_NO_TMP_CLEANUP
- * opkg_remove.c: added conf argument to conffile_has_been_modified
- * opkg_download.c: added opkg_prepare_for_install
-2003-03-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.55
- * opkg.h: wrap #if 0 around definition of of OPKG_DEBUG_NO_TMP_CLEANUP
-2003-03-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.54
- * opkg_install.c: make old package SW_DEINSTALL during opkg installation
- * opkg_cmd.[ch]: added some code to install packages marked SW_INSTALL, but have not enabled this code yet.
-2003-03-01 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: updated to 0.99.53
- * pkg_depends.c: let SW_INSTALL satisfy dependences (instead of SS_INSTALL)
-2003-03-01 Daniele Nicolodi <daniele@grinta.net>
- * opkg_install.c: indentation fixes and finish switch to message
- facility
- * opkg_cmd.c: indentation fixes, switch to message facility and
- some code cleanup
- * opkg_message.c (opkg_message): check for a NULL *conf parameter
- * opkg_message.h: renamed OPKG_ERR in OPKG_ERROR
-2003-02-28 Jamey Hicks <jamey@handhelds.org> (patch from Daniele Nicolodi <daniele@grinta.net>)
- * configure.ac: incremented version to 0.99.5
- * opkg_message.[ch]: added message facility
- * args.[ch]: verbosity control
- * opkg_conf.[ch]: verbosity control
- * opkg_install.c: switch to using message factility
-2003-02-28 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version to 0.99.51
- * opkg_cmd.c: added opkg_statisfy_all_dependences, called after
- install/upgrade of packages to handle packages that were split and
- no longer provide all the resources they used to provide.
-2003-02-27 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version to 0.99.50
- * opkg_cmd.c: write out status after doing an upgrade
-2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
- * configure.ac: incremented version to 0.99.49
- * pkg_parse.c, pkg.c: do not treat deb revision specially
-2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
- * configure.ac: incremented version number to 0.99.48
- * args.c: added help for opkg flags sub-command
- * opkg_cmd.c: added opkg_flag_cmd, do not upgrade package marked hold
- * opkg_install.c: do not remove obsolesced files if old_pkg is flagged noprune
- * opkg_remove.c: pkg->state_flag is a bitvector now
- * pkg.c: pkg->state_flag is a bitvector now
- * pkg.h: pkg->state_flag is a bitvector now
-2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
- * configure.ac: incremented version number to 0.99.47
- * pkg.c: refix "uninstalled package has NULL tmp_unpack_dir"
- * pkg_hash.c:
-2003-02-27 Aman Gupta <oz@themastermind1.net> (another patch from pb_)
- * configure.ac: incremented version number to 0.99.46
- * pkg.c: fix "uninstalled package has NULL tmp_unpack_dir"
-2003-02-24 Jamey Hicks <jamey@handhelds.org> (per patch from Philip Blundell <pb@handhelds.org>)
- * configure.ac: incremented version to 0.99.45
- * file_util.c: include space for null in line_size
- * opkg_cmd.c: sigint handler while configuring packages
- * opkg_install.c: state_status != SS_INSTALLED and != SS_UNPACKED
- * opkg_remove.c: missing i++
- * pkg.c: do not run scripts in offline_root mode
- * pkg_depends.c: every package provides itself
- * pkg_hash.c: better handling of packges provided by multiple providers
-2003-02-24 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version number to 0.99.44
- * args.c: added doc for -force-overwrite
-2002-11-26 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version number to 0.99.43
- * opkg_install.c: completely skip the space check when -force_space asserted
-2002-11-23 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version number to 0.99.42
- * args.c: missed one spot checking for -force_space or -force-space
-2002-11-23 Jamey Hicks <jamey@handhelds.org>
- * configure.ac: incremented version number to 0.99.41
- * opkg_install.c: added -force_space option to override out of space check
-2002-11-23 Aman Gupta <oz@themastermind1.net>
- * configure.ac: incremented version number to 0.99.40
- * opkg_configure.c: updated to match new text output format
- * opkg_install.c: updated to new text output format
- fixed problems where ipks installed from file or
- http were being installed over newer ipks of the
- same name
- * opkg_remove.c: updated to new text output format
- made opkg remove do what opkg purge originally did,
- by having it remove conffiles, and status entries for
- ipks that are removed. opkg_purge now calls
- opkg_remove
-2002-11-22 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.39
- * applied patches from Aman Gupta for better handling of dests
-2002-11-?? Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.38
-2002-11-07 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.37
- * hash_table.[ch]: moved internals of hash_tables out of pkg_hash.c
- * pkg_hash.c: moved internals of hash_tables out of pkg_hash.c
-2002-10-29 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.37
- * opkg_cmd.c: opkg_upgrade_cmd now installs uninstalled packages
- instead of getting a segv
-2002-10-29 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.36
- * changed verbose_get to verbose_wget as documented
-2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.34
- * opkg_cmd.c: fixed problem stringifying HOST_CPU
- * Makefile.am: helped fix problem stringifying HOST_CPU
-2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.33
- * opkg_cmd.c, args.c: added print-architecture and print-installation-architecture commands
- * Makefile.am: added defines for HOST_CPU and BUILD_CPU to CFLAGS and package: target
-2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.32
- * pkg.c: removed chroot breakage
-2002-08-07 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.31
- * other: applied multiple providers patch from philip blundell
- * opkg_cmd.c: implemented compare_versions cmd
-2002-07-25 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.30
- * opkg_conf.c: added offline_root_pre_script_cmd and offline_root_post_script_cmd
- * pkg.c: execute scripts in chroot'ed environment running
- pre_script_cmd and post_script_cmd before and after the pkg script.
-2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.29
- * pkg.c: fixed a segv when printing Replaces field
-2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.28
- * opkg_cmd.c: merged functionality from opkg_install_cmd into
- opkg_upgrade_cmd with an eye towards unifying these two commands.
- * opkg_install.c: installing a package that replaces other
- packages removes them first. (Upgrade does not do replacements automatically).
- * opkg_remove.c: opkg_remove_pkg will remove a package with
- installed dependents if state_flag == SF_REPLACE.
-2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.27
-2002-07-23 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.26
- * renamed pkg_vec_init/pkg_vec_deinit to pkg_vec_alloc/pkg_vec_free
- * started implementation of Replaces
-2002-07-22 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.25
- * many cleanups trying to regain stability
-2002-07-22 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.24
- * various files: trying to stomp a segv in conflicts checking.
-2002-07-17 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.23
- * opkg_remove.c: do not do recursive removal if force-depends is
- specified
- * other-files: other cleanups to reduce code clutter
-2002-07-16 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.22
- * user.[ch]: moved user interaction procedure here
- * args.[ch], opkg_conf.[ch]: added force_removal_of_dependent_packages
- * pkg.h: added state_status to abstract_pkg_t
- * opkg_remove.c: If package has installed dependents, then only
- remove if force_removal_of_dependent_packages is asserted in
- opkg.conf or on command line. Will add user interaction option later.
-2002-07-16 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.21 after
- applying dependent removal and conflicts patch.
-
-2002-07-14 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.20
- * opkg_download.c: removed useless -N flag from wget
- * update-alternatives: 'head -1' -> 'head -n 1', no sort -k 2 for busybox
-
-2002-07-15 Karthikeyan K <karthik@innvo.com>
-
- * opkg_remove.c (opkg_remove_dependant_pkgs): removed setting the
- dependencies_checked variable in the while loop b4 actually checking
- the dependencies of that package.
- * opkg_cmd.c (opkg_multiple_files_scan): added check for ".ipk" and
- ".deb" extension, so that no caching is attempted on arguments that
- are not local files
- * pkg_depends.c (pkg_hash_fetch_conflicts): while returning NULL,
- casted to (pkg_vec_t *) to compile without warnings
-
-2002-07-12 Abhaya Shenoy <abhaya@innvo.com>
-
- * pkg_depends.c (pkg_hash_fetch_conflicts): use new abstract_pkg_vec
- structure in checking provided_by
-
-2002-07-07 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.18
- * fixed a segv due to type error in provides support
-
-2002-07-07 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.17
- * updated provides support so that installed provider is preferred to
- uninstalled provider
-
-2002-07-05 Abhaya Shenoy <abhaya@innvo.com>
-
- * pkg_depends.c (pkg_hash_fetch_conflicts): check for conflicts
- found before returning
-
-2002-07-04 Abhaya Shenoy <abhaya@innvo.com>
- * opkg_install.c (check_conflicts_for): new function to call
- pkg_hash_fetch_conflicts and print offending packages
- (opkg_install_pkg): added call to check_conflicts_for
- * pkg.c (pkg_merge): provides from oldpkg should be given
- priority
- (pkg_init): init of conflicts, conflicts_count fields
- * pkg.h (struct pkg): added fields conflicts_str, conflicts,
- conflicts_count
- * pkg_depends.c (pkg_hash_fetch_conflicts): new function to check
- for conflicts
- (buildConflicts): new function to set up the conflicts in the pkg
- struct
- * pkg_depends.h: added new type CONFLICTS to depend_type enum
- * pkg_hash.c (hash_insert_pkg): added call to buildConflicts
- * pkg_parse.c (pkg_parse_raw): added parsing of Conflicts
-
-2002-07-04 Karthikeyan K <karthik@innvo.com>
-
- * opkg_cmd.c (opkg_multiple_files_scan): new function to handle installation
- of already downloaded files
- (opkg_install_cmd): added call to opkg_multiple_files_scan
- (opkg_remove_cmd): added call to possible_broken_removal_of_packages
- * opkg_install.c (opkg_install_pkg): added check to remove redundant upgrade
- when a package to be installed is already installed as a dependancy of
- another
- * opkg_remove.c (possible_broken_removal_of_packages): new fnuction
- to check that all packages can be removed, before actually starting to
- remove them
- (opkg_remove_dependant_pkgs): new function to remove dependant packages
- (opkg_remove_pkg): added call to opkg_remove_dependant_pkgs
- * pkg.c (abstract_pkg_init): initialized dependencies_checked
- * pkg_hash.c (pkg_hash_dump): added more information to hash dump
-
-2002-07-03 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.16
- * opkg_install.c: defensive programming in case pkg contains no Size: clause
-
-2002-07-02 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.15
- * pkg_depends.c: check for provided_by when fetching unsatisfied dependencies
-
-2002-07-02 Jamey Hicks <jamey.hicks@hp.com>
- * configure.ac: incremented version number to 0.99.14
- * pkg_hash.c: if abstract pkg is provided_by, then return pkg vec
- of first package that provides it.
-
-2002-06-17 Jamey Hicks <jamey.hicks@hp.com>
-
- * configure.ac: incremented version number to 0.99.12
- * args.h, opkg_conf.h, opkg_install.c: Added force_overwrite
- option. When this is asserted, opkg will overwrite files that
- have no owner or that belong to other packages.
- * opkg_conf.c, opkg_dest.c: Update status file atomically, keeping
- old copy of status file if cannot update new status file. Applied
- patch from Jukka Santala for this fix.
-
-2002-03-16 Carl Worth <cworth@east.isi.edu>
-
- * configure.ac: Incremented version number to 0.99.9-1.
-
- * RELEASE_NOTES: Added release notes for 0.99.9-1.
-
-2002-03-15 Carl Worth <cworth@east.isi.edu>
-
- * configure.ac: Incremented version number to 0.99.9.
-
- * RELEASE_NOTES: Added release notes for 0.99.9.
-
- * Makefile.am (bin_PROGRAMS): Install update-alternatives as well.
-
- * familiar/rules (binary-arch): Mv all of /bin to /usr/bin
-
- * configure.ac: Incremented version number to 0.99.8.
-
- * RELEASE_NOTES: Added release notes for 0.99.8.
-
- * familiar/rules (binary-arch): Fixed to use "make install-strip"
- rather than "make install" and a strip command.
-
- * opkg_cmd.c (opkg_install_cmd): Moved an error message up from
- opkg_install_by_name, (eventually all error messages should come
- up out of what will become libopkg, (pkg.c, opkg_install.c, etc.)
- and into opkg_cmd.c and friends).
- (opkg_upgrade_pkg): Pushed downgrade check down into
- opkg_install_by_name so that "opkg install foo" will do the
- downgrade check.
-
- * opkg.h: Rename some opkg_error_t error codes to be more
- consistent.
-
- * opkg_install.c (resolve_conffiles): Added missing removal of
- backed-up modified conffiles, (which led to bizarre, bogus
- conffile prompting the next time the package was upgraded).
- (user_prefers_old_conffile): Fixed reversed arguments to diff in
- interactive conffiles prompting.
- (opkg_install_by_name): Fixed "opkg install foo" to never
- downgrade foo, (just like "opkg upgrade foo").
-
- * familiar/rules: Added installation of
- /usr/share/doc/opkg/copyright file. Fixed so that opkg.conf goes
- to /etc, not /usr/etc, (but still keep binary in /usr/bin not
- /bin). Changed name of installed binary from opkg-unstable to
- opkg.
-
- * familiar/control.in (Package): Changed package name from
- opkg-unstable to opkg.
-
- * pkg_parse.c (parseVersion): Fixed to ignore whitespace at
- beginning of version string.
- (pkg_parse_raw): Fixed segfault if a package record list ends with
- a package paragraph without a final blank line.
-
- * opkg_install.c (check_data_file_clashes): Improved wording of
- file clash error message.
-
- * opkg_download.c (opkg_download_pkg): Fixed segfault if package
- has no src, (occurs if package had benn installed locally, then
- was removed (but not purged), then tried to reinstall eithout it
- existing in any /usr/lib/opkg/lists/* file).
-
- * etc/opkg.conf: Added a default opkg.conf to the distribution.
-
-2002-03-13 Carl Worth <cworth@east.isi.edu>
-
- * configure.ac: Incremented version to 0.99.7.
-
- * RELEASE_NOTES: Added release notes for 0.99.7.
-
- * pkg.c (pkg_run_script): Added support to export
- OPKG_OFFLINE_ROOT. This is really a nasty hack as it means scripts
- need to be modified to check OPKG_OFFLINE_ROOT. I'd really prefer
- coming up with a good, reliable chroot system. But for now this
- will let update-alternatives work, (which already does examine
- OPKG_OFFLINE_ROOT).
- (pkg_run_script): Added missing brace.
-
- * opkg_conf.c (opkg_conf_init): Reworked significantly to properly
- set up the pkg_dest_list stuff to account for offline_root.
-
- * args.c (args_parse): Added support for -force_defaults in
- addition to -force-defaults, etc. as I kept mistyping these
- somehow.
-
-2002-03-12 Carl Worth <cworth@east.isi.edu>
-
- * configure.ac: Incremented version to 0.99.6.
-
- * RELEASE_NOTES: Added release notes for 0.99.6.
-
- * opkg_download.c (opkg_download): Fixed bug in handling of
- "file://" URLs.
-
- * opkg.c (main): Fixed to abort if opkg_conf_init fails.
-
- * opkg_conf.c (opkg_conf_init): Fixed to complain if given an
- unknown dest.
-
- * pkg.c (pkg_print_field): Fixed several fields to not print if
- NULL, (Architecture. Maintainer, Size, Filename, Description)
-
- * args.c (args_parse): Fixed bug that was always setting
- force_removal_of_essentail_packages (yikes!).
-
- * configure.ac: Incremented version to 0.99.5.
-
- * RELEASE_NOTES: Added release notes for 0.99.5.
-
- * familiar/rules (binary-arch): Added strip back in in preparation
- of non-unstable release of opkg.
-
- * str_util.c (str_starts_with): Added convenience function.
-
- * pkg_extract.c (pkg_extract_data_file_names_to_file): Fixed
- filenames in *.list files to be compatible with dpkg and the old
- opkg, (no prefix of "." for example).
-
- * pkg.c (pkg_run_script): Added export of PKG_ROOT for the benefit
- of maintainer scripts.
-
- * opkg_remove.c (opkg_remove_pkg): Complain and abort if user
- attempts to remove an essential package, (also inform them of the
- force option if they insist).
-
- * opkg_install.c (opkg_install_pkg): Added message about whether
- installing or upgrading.
-
- * opkg_download.c (opkg_download): Added support for "file://"
- URLs, (untested).
- (opkg_download): Added support for wget proxy options.
-
- * opkg_conf.c (opkg_conf_init): Added proxy support to opkg_conf,
- (http_proxy, ftp_proxy, no_proxy, proxy_user, and proxy_passwd).
-
- * opkg_cmd.c (opkg_upgrade_pkg): Moved Upgrading message from
- opkg_upgrade_cmd to opkg_install_pkg.
-
- * args.c (args_parse): Added new option
- -force-removal-of-essential-packages, (which is intentionally
- painful to type and not listed in usage. It should not be used
- often).
-
-2002-03-11 Carl Worth <cworth@east.isi.edu>
-
- * configure.ac: Incremented version to 0.99.3.
-
- * RELEASE_NOTES: Added release notes for 0.99.3.
-
- * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Fixed
- to avoid infinite loop in the case of a circular dependency.
-
- * configure.ac: Incremented version to 0.99.2.
-
- * RELEASE_NOTES: Added release notes for 0.99.2.
-
- * familiar/rules: Commented out strip, (temporary until this beast
- is deemed more stable).
-
- * xsystem.c (xsystem): Cleaned up error message, (missing
- newline).
-
- * pkg.c (pkg_merge): Made pkg_merge a NOP if oldpkg == newpkg.
- (pkg_print_field): Don't print MD5sum field if NULL.
-
- * opkg_install.c (satisfy_dependencies_for): Now returns error
- status if one or more of the dependencies fail to install cleanly.
- (unpack_pkg_control_files): Fixed to not tack on a bunch of
- NULL-valued conffiles entries if non-NULL conffiles already
- exist. This fixed the errant prompting for unmodified conffiles
- during -force-reinstall.
- (unpack_pkg_control_files): Cleaned up conffile filenames to not
- have ugly things like "///" inside them.
-
- * opkg_download.c (opkg_download): Cleaned up error message.
- (opkg_download): Now uses new file_move function.
- (opkg_download_pkg): Created new function, (from old code in opkg_install).
-
- * opkg_cmd.c (opkg_download_cmd): Added new "opkg download"
- command.
-
- * file_util.c (file_move): Created file_move, (from code that had
- been in opkg_download).
- (file_copy): Added error message on failure.
-
- * conffile.c (conffile_has_been_modified): Eliminated crash if
- conffile_has_been_modified is called with conffile->value == NULL.
-
-2002-03-09 Carl Worth <cworth@east.isi.edu>
-
- * RELEASE_NOTES: Added release notes for 0.99.1
-
- * configure.ac: Incremented version to 0.99.1
-
- * pkg_hash.c (pkg_hash_pkg_owning_file): Fixed to actually return
- NULL if no package owns a file.
-
- * pkg.c (pkg_get_installed_files): Added installed_files_ref_cnt
- to pkg_t to prevent pkg->installed_files from being freed from an
- inner loop while still being used by an outer loop, (which was
- happening).
-
- * pkg_hash.c (pkg_hash_pkg_owning_file): Moved this function in
- from pkg_dest.c. Also, updated it to use pkg_get_installed rather
- than mucking around inside /usr/lib/opkg and globbing for *.list
- files.
- (pkg_hash_fetch_best_installation_candidate): Fixed to only return
- a package that actually could be installed, (ie. it must have
- either a local_filename or a non-NULL src from which it could be
- downloaded). This prevents a segfault during "opkg upgrade".
-
- * pkg.c (pkg_get_installed_files): Fixed to not do strange things
- to filenames such as: "//./bin/sh"
-
- * opkg_cmd.c (opkg_files_cmd): Added pkg_free_installed_files to
- conserve a bit of memory.
- (opkg_search_cmd): Updated to use pkg_get_installed rather than
- mucking around inside /usr/lib/opkg and globbing for *.list files.
-
- * pkg.c (pkg_free_installed_files): Added this function to free up
- memory from pkg_get_installed_files.
-
- * opkg_conf.c (opkg_conf_set_option): Added force_reinstall option
- to allow reinstallation of an installed package.
-
- * args.c (args_parse): Added -force-reinstall option to enable
- reinstallation of an installed package.
-
- * busybox-0.60.2/ar.c (ar_main): Updated unarchive call to track
- prototype change.
-
- * busybox-0.60.2/libbb/unarchive.c (free_header_ar): Added
- function to plug memory leak.
-
- * opkg_install.c (check_data_file_clashes): Fixed crash if no
- package can be found owning the pre-existing file.
-
- * pkg_dest.c (pkg_dest_deinit): Fixed bug that pkg_dest was
- holding on to freed data rather than making a local copy.
-
- * pkg_depends.c (freeDepends): Fixed crash when pkg->depends is NULL.
-
- * RELEASE_NOTES: Added release notes for 0.98.0 and 0.99.0.
-
- * busybox-0.60.2/libbb/unarchive.c (extract_archive): Fixed
- bug. Always alloc memory for full_name so we don't free data that
- we shouldn't.
- (unarchive): Updated to accept a free_headers function pointer as
- a counterpart to get_headers, to eliminate memory leaks.
- (free_header_tar): Implemented cleanup function as counterpart to
- get_header_tar, to eliminate memory leaks.
- (deb_extract): Added several calls to free_header_tar to eliminate
- memory leaks.
-
- * str_util.c (str_dup_safe): Added convenience function. Like
- strdup, but safe to use on a NULL pointer.
-
- * pkg_vec.c (pkg_vec_insert): Updated to use new pkg.c:pkg_merge
- rather than marry_two_packages. With this change the free(pkg) is
- now here rather than one level deeper. Eventually, I want to get
- this free(pkg) up and out of pkg_hash_insert.
-
- * pkg_parse.c (parseDependsString): Fixed bug walking off the end
- of the raw buffer looking for a character that isspace().
- (parseConffiles): Fixed big bug parsing Conffiles field where all
- conffiles appear on the same line.
-
- * pkg_hash.c (pkg_hash_add_from_file): Plugged memory leak of data
- allocated deep down in read_raw_pkgs_from_file.
-
- * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Plugged
- memory leak, (missing pkg_vec_deinit).
- (freeDepends): Added this function as the counterpart to
- buildDepends. Getting closer to chasing down all memory leaks.
- (depend_deinit): Added this function as the counterpart to
- depend_init. Getting closer to chasing down all memory leaks.
- (parseDepends): plugged memory leak of pkg_name.
-
- * pkg.c (pkg_deinit): Added pkg_deinit to take care of freeing any
- memory owned by a pkg_t.
- (pkg_init_from_file): This function was 100% broken, (missing
- rewind).
- (pkg_merge): Moved pkg_merge here from
- pkg_vec.c:marry_two_packages. Started work to make it
- non-destructive, (not finished).
- (pkg_print_info): Added Status and Essential fields to
- pkg_print_info.
- (pkg_print_status): Fixed pkg_print_status to work whether or not
- the package is installed.
-
- * opkg_utils.c (read_raw_pkgs_from_file): Moved fclose out of
- read_raw_pkgs_from_stream and into this function where it belongs,
- (since the fopen occurs here).
- (trim_alloc): Fixed trim to not free data passed in. Changed the
- name to make it obvious that it is allocating memory.
-
- * opkg_install.c (opkg_install_from_file): Fixed to be more robust
- to the fact that hash_insert_pkg sometimes frees the data that I
- pass into it (!).
- (satisfy_dependencies_for): Cosmetic change to messages.
- (satisfy_dependencies_for): Now sets the dest on to-be-installed
- packages, so that the state_want flag can be written to a status
- file if necessary.
- (satisfy_dependencies_for): Added pkg_vec_deinit to plug memory
- leak.
- (opkg_install_pkg): Added "run opkg update?" hint to error
- message.
- (backup_modified_conffiles): Made more robust to the case that a
- conffile has disappeared.
- (install_maintainer_scripts): Fixed bug that was installing
- maintainer scripts as libFoopostinst rather than
- libFoo.postinst. This was preventing postinst scripts from being
- executed.
- (cleanup_temporary_files): Added missing closedir to plug a memory
- leak.
-
- * opkg_download.c (opkg_download): Cosmetic change to error
- messages.
-
- * opkg_conf.c (opkg_conf_parse_file): Plugged some small memory
- leaks.
- (opkg_conf_set_option): Changed configuration options from
- force-depends, force-defaults to force_depdends, force_defaults to
- be compatible with old opkg.conf files.
- (opkg_conf_set_option): Fixed bug in parsing options.
- (opkg_conf_write_status_files): Fixed to list all interesting
- packages, (any with non-default state), in status file rather than
- just installed files.
- (opkg_conf_write_status_files): Plugged a memory leak.
-
- * opkg_cmd.c (opkg_status_cmd): Changed "opkg status" to use
- pkg_print_info so it is much more verbose, (includes fields such
- as Maintainer, etc. that are merged in from the lists files).
-
- * opkg.h (OPKG_DEBUG_NO_TMP_CLEANUP): Added compile-time option to
- preserve temporary files for easier debugging.
-
- * file_util.c (file_md5sum_alloc): cosmetic changes to variable
- names.
-
- * opkg_conf.c (opkg_conf_init): Added support for offline_root
- configuration file option.
-
- * args.c (args_init): Added support for -o, -offline,
- -offline-root command-line arguments. (Although they don't really
- have any effect yet).
-
- * opkg_install.c (opkg_install_pkg): Changed back to marking
- package as installed before postinst, (the pkg_run_script wanted
- to find the scripts in /usr/lib/opkg/info). Actually, it could
- probably find the script in either place at this point so maybe it
- doesn't really matter.
-
-2002-03-07 Carl Worth <cworth@east.isi.edu>
-
- * opkg_install.c (opkg_install_pkg): Changed to only mark package
- as installed after running opkg_configure, (to run the postinst
- script).
-
- * RELEASED opkg-unstable 0.99.0
-
- * Updated all instances of "XXX" in the code to indicate one of
- the following categories:
- XXX: BUG: This is a bug that needs to be fixed.
- XXX: QUESTION: Implementation approach is uncertain here.
- XXX: CLEANUP: Suggestion on how the code could be cleaned up.
- XXX: FEATURE: Comment describes a useful feature request.
-
- * pkg.c (pkg_print_status): Added the Depends field to package
- paragraphs in the status file, ("opkg remove" will need this).
-
- * opkg_install.c (satisfy_dependencies_for): Fixed "opkg install"
- to not complain several times about "Package foo already
- installed" when doing large recursive installs.
- (opkg_install_pkg): "opkg install foo" for an installed package
- will now check and install any missing dependencies before exiting
- with "Package foo is alrady installed."
-
-2002-03-06 Carl Worth <cworth@east.isi.edu>
-
- * pkg_dest.c (pkg_dest_pkg_owning_file_alloc): Moved this function
- here from opkg_install.c. Also plugged a memory leak in it with
- globfree.
-
- * pkg.c (pkg_remove_installed_files_list): Fixed bug that
- prevented package.list file from ever being removed during "opkg
- remove".
-
- * opkg_remove.c (remove_data_files_and_list): Fixed noisy and
- spurious warnings about non-empty directories. "opkg remove"
- should now only say anything if a directory that was solely
- provided by that package is non-empty.
-
- * opkg_cmd.c (opkg_install_pending_cmd): Plugged memory leak with
- globfree.
-
- * opkg_install.c: *Many* fixes to enable "opkg upgrade" to more or
- less work. Primarily fixing file clash identification and conffile
- handling/resolution. "opkg upgrade" has now worked correctly on
- several test cases!
-
- * opkg_install.c (unpack_pkg_control_files): Now initializes
- conffiles list from the contents of conffiles control file,
- (leaves md5sum calculation until the actual conffiles are
- extracted later).
- (opkg_install_pkg): Separated backup_modified_conffiles and
- check_data_file_clashes into separate functions.
- (preinst_configure): Simplified this function pushing its old
- logic into pkg.c:pkg_run_script.
- (backup_modified_conffiles): Added backup of any conffiles that
- are new as of this upgrade.
- (check_data_file_clashes): First real implementation of
- check_data_file_clashes.
- (resolve_conffiles): First real implementation of
- resolve_conffiles.
- (backup_make_backup): Added this and a few other functions to
- abstract backup creation/removal.
- (find_pkg_owning_file): Added this function.
-
- * pkg_extract.c (pkg_extract_data_files_to_dir): Fixed args to
- deb_extract so that existing files will be overwritten, (and any
- other error messages will no longer be suppressed).
-
- * pkg.c (pkg_print_status): Added Conffiles field to
- pkg_print_status.
- (pkg_print_field): Fixed crash when printing NULL Conffiles
- values.
- (pkg_get_conffile): Fixed crash if pkg_get_conffile called with a
- NULL pkg.
- (pkg_run_script): Made pkg_run_script smart enough to run scripts
- for uninstalled packages, (from
- <pkg_tmp_unpack_dir>/<script_name>), as well as for isntalled
- packages, (from <dest_info_dir>/<pkg_name>.<script_name>
-
- * str_util.c (str_tolower): Added convenience function.
- (str_toupper): Added convenience function.
-
- * nv_pair.c (nv_pair_init): Fixed crash from calling nv_pair_init
- with NULL value.
-
- * pkg.c (pkg_init_from_file): Fixed bug -- forgot to close file.
-
- * file_util.c (file_md5sum_alloc): Convenience wrapper around
- md5_stream as ripped out of busybox. This function takes care of
- file open/close and does the bin2hex conversion of the md5sum.
-
- * conffile.c (conffile_has_been_modified): Implemented this
- function for real now that we have md5sum capability.
-
- * md5.c (md5_stream): Sucked in md5sum calculation code from
- busybox, (it wasn't part of libbb, so I just copied the files
- straight in and ripped out uninteresting functions such as
- md5sum_main, etc.)
-
-2002-03-05 Carl Worth <cworth@east.isi.edu>
-
- * pkg.c (pkg_print_field): Added support for printing Conffiles
- field.
-
- * opkg_install.c (remove_obsolesced_files): With the fixed
- pkg_get_installed_files_list from below, this function now seems
- to work!
- (opkg_install_pkg): Fixed to mark old package as uninstalled after
- upgrading.
-
- * pkg.c (pkg_get_installed_files_list): Fixed so that it's
- possible to get an "installed_files" list even from an uninstalled
- package, (it pulls the list of data files straight out of the
- package).
-
- * opkg_cmd.c (opkg_upgrade_cmd): Fixed opkg_upgrade to not choke
- if asked to upgrade an un-installed package.
- (opkg_upgrade_pkg): Fixed printing of version numbers.
-
- * file_util.c (file_mkdir_hier): Abstracted call to libbb
- make_directory into new file_mkdir_hier. At this point, the only
- calls into libbb are isolated in file_util and pkg_extract. This
- will make it easier if we ever decide to directly incorporate that
- code or rewrite it.
-
- * pkg_extract.c (pkg_extract_data_files_to_dir): Abstracted all
- calls to deb_extract in several new pkg_extract functions.
-
-2002-03-04 Carl Worth <cworth@east.isi.edu>
-
- * opkg_conf.c (opkg_conf_init): Added support to opkg_conf to
- pickup command-line arguments for "force-defaults" and
- "force-depends". Things set on the command-line should take
- precedence over things found in the configuration file.
-
- * opkg_cmd.c (opkg_search_cmd): Fixed formatting of "opkg search"
- output.
-
- * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies):
- Re-added fix to set *unresolved to NULL if depends is NULL.
-
- * xregex.c (xregexec): Removed useless error messages from NOMATCH
- calls to regexec.
-
- * opkg_install.c (satisfy_dependencies_for): Added support for new
- "unresolved" argument in
- pkg_hash_fetch_unsatisfied_dependencies. Cleaned up warning/error
- messages.
-
- * opkg_cmd.c (opkg_search_cmd): Implemented first-cut of "opkg search".
-
- * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Fixed
- to set *unresolved to NULL if depends is NULL.
-
-2002-03-01 Carl Worth <cworth@east.isi.edu>
-
- * RELEASED opkg-unstable 0.98.0
-
- * opkg_configure.c (opkg_configure): Added flushing of stdout,
- (here and in a few other modules).
-
- * file_util.c (file_copy): Implemented this function here as one
- step toward isolating the calls into libbb functions. Updated old
- copy_file calls to file_copy in both opkg_download.c and
- opkg_install.c.
-
- * opkg_install.c, opkg_remove.c: Demoted several "XXX" comments to
- DPKG_INCOMPATIBILITY as I really don't intend on addressing them
- any time soon, (if ever).
-
- * opkg_cmd.c (opkg_files_cmd): Fixed "opkg files" from crashing on
- uninstalled packages.
-
- * familiar/rules: Added support for easy building of an
- opkg.ipk. The version number and the architecture are
- automatically sucked in correctly from autoconf magic, (even when
- cross-compiling). Maybe autoconf will start paying off with
- benefits rather than pain, (finally!).
-
- * configure.ac: Removed MEMCMP and STAT checks which were breaking
- cross-compilation.
-
- * opkg_cmd.c (opkg_upgrade_pkg): BIG bugfix: Package version
- comparison was sign-reversed, (hence it would never upgrade).
-
-2002-02-28 Carl Worth <cworth@east.isi.edu>
-
- * opkg_download.c (opkg_download): Changed from
- system("/bin/cp",...) to copy_file(...)
-
- * replace/strndup.c: Implemented an (untested) replacement for
- strndup.
-
- * configure.ac: Added AC_CANONICAL_HOST to automatically set the
- correct architecture type in the opkg control file.
-
- * configure.ac: Changed version number to 0.98.0 in preparation
- for alpha release.
-
- * familiar/rules: Added support for easy building of an opkg.ipk.
-
-2002-02-27 Carl Worth <cworth@east.isi.edu>
-
- * opkg_install.c (opkg_install_pkg): Fixed to abort on failed
- download.
-
- * pkg.c (pkg_run_script): Fixed bug that was preventing any
- package maintainer scripts from running, (hence, they run now so
- running non-native offline no longer works until I figure out the
- chroot plans).
-
- * TODO: Added rough outline of remaining features with a release
- schedule.
-
- * pkg_parse.c (pkg_parse_raw): Added parsing of "MD5Sum" in
- addition to "MD5sum" to accomodate bug in old opkg.
-
- * void_list.c (void_list_remove): Added new remove function, (also
- adjusts a forward iterator). Required new list->pre_head member
- which was added to all sub-list types.
-
- * pkg.c (pkg_init): Changed pkg->conffiles to be of the new
- conffile_list_t datatype.
- (pkg_remove_installed_files_list): Pulled this function into
- pkg.c, (from opkg_remove.c), so the mallocs and frees would be in
- the same C file.
- (pkg_get_conffile): Added this convenience function.
-
- * opkg_remove.c: Fixed several bugs. opkg_remove now actually
- works for simple packages!
-
- * opkg_install.c (opkg_install_pkg): Don't re-install if a package
- is already installed.
- (opkg_install_pkg): Fixed major bug that all of opkg_install's
- work was always being unwound even when successful.
-
- * opkg_cmd.c (opkg_files_cmd): Fixed to use
- pkg_get_installed_files_list rather than a private implementation
- that sifted through the file lists on disk.
-
- * str_util.c (str_ends_with): Added this convenient function.
- (str_chomp): Another convenience.
-
- * opkg_conf.c: Moved chomp to str_util.c (str_chomp), since
- someone else wanted it too.
-
-2002-02-26 Carl Worth <cworth@east.isi.edu>
-
- * pkg_parse.c (pkg_parse_raw): Added XXX requesting parsing of
- Conffiles: field along with a hint about how to store the data.
-
- * conffile_list.c: Added a little wrapper around nv_pair_list
-
- * conffile.c: Added a little wrapper around nv_pair
-
- * str_util.c (str_ends_with): New convenience function.
-
- * str_list.c (str_list_remove): Plugged in remove function.
-
- * void_list.c (void_list_remove): Added remove function, (handles
- updating of forward iterator).
-
- * pkg.c (pkg_run_script): Changed to return return value of
- script.
-
- * opkg_remove.c: Fleshed out initial version of all opkg_remove.c
- functions.
-
- * opkg_configure.c (opkg_configure): Added check on return value
- of pkg_run script. Added comments about dpkg compliance.
-
- * opkg_cmd.c (opkg_purge_cmd): Added opkg_purge_cmd
-
-2002-02-20 Carl Worth <cworth@east.isi.edu>
-
- * Added USC copyright statements, (and Compaq stubs as necessary)
-
- * opkg_install.c: At this point "opkg install" on a simple
- package, (no scripts and no dependencies), works just fine. It
- might even do some of the script and dependency handling correctly
- too, but I haven't tested that yet. "opkg install libc6" is a nice
- little test that should complete without any errors or
- warnings. Follow that up with "opkg status" to see that it worked.
-
- * pkg.c (pkg_run_script): Added convenience method for running
- package scripts.
-
- * opkg_install.c: Fixed several bugs:
- (unpack_pkg_control_files): control files now extract to the
- correct temporary directory.
- (opkg_install_pkg): pkg->state_want is now properly set to SW_INSTALL
- (opkg_install_pkg): status file now gets written after installation
- (cleanup_temporary_files): All temporary files are cleaned up.
-
- * opkg_configure.c (opkg_configure): Fleshed out a very simple
- opkg_configure, (simply runs "postinst configure"). Maybe it will
- need to be smarter at some point. Moved unwritten conffiles stuff
- back to opkg_install.c.
-
- * opkg_conf.c (opkg_conf_write_status_files): Moved this function
- from opkg_utils to opkg_conf since it needs access to the
- pkg_dest_list.
-
- * pkg_vec.c (marry_two_packages): Added several missing fields,
- (state_want, state_flag, filename, local_filename, tmp_unpack_dir,
- md5sum, size, installed_size, priority, source, conffiles,
- isntalled_files, essential)
-
-2002-02-19 Carl Worth <cworth@east.isi.edu>
-
- * opkg_install.c: several little bug fixes. "opkg install" will
- now actually install files from a package! There are still some
- bugs, (eg. postinst scripts are not called -- probably other
- things as well). But, it's coming together now.
-
- * pkg_dest.c (pkg_dest_init): now creates all necessary directories
-
- * opkg_download.c (opkg_download): Fixed misleading parameter name.
-
- * opkg_conf.c (opkg_conf_deinit): Now cleans up tmd_dir on deinit
- opkg.c: now calls opkg_conf_deinit before exiting.
- (opkg_conf_add_nv): Fixed to set default_dest when parsing first
- dest in opkg.conf
-
- * opkg_cmd.c (opkg_list_cmd): Fixed ugly bug in opkg_list that led
- to infinite loops, segfaults, string corruption, and other bizarre
- behavior.
-
- * Added many files as we are approaching the first functional opkg
- implementation in C:
- file_util.c: convenience for testing if file_exists, reading files, etc.
- opkg_configure.c: mostly just a stub so far
- opkg_download.c: convenient function to download a file
- nv_pair.c: data structure to hold a name-value pair
- nv_pair_list.c: data structure to hold a list of nv_pair_t
- pkg_dest.c: data structure for everything a pkg destination wants
- pkg_dest_list.c: data structure to hold a list of pkg_dest_t
- pkg_extract.c: convenience functions for package extraction,
- (these function should encapsulate any libbb borrowings we perform
- -- although some slipped into other files already)
- pkg_src.c: everything you might need for a pkg src.
- pkg_src_list.c: data structure to hold a list of pkg_src_t
- str_list.c: data structure to hold a list of char *
- void_list.c: generic linked-list data structure and functions
- xsystem.c: wrapper around system() with error checking
-
- * opkg_remove.c: Just added some stubs. Nothing really works at
- all yet.
-
- * opkg_install.c: Large rework of opkg_install. It's now close to
- actually being usable, (but it's not quite there yet). Revamped to
- match dpkg install order more closely, (with all the stubs in case
- we ever want to call all the scripts that dpkg does). Also updated
- to use a more recent deb_extract from libbb.
-
- * opkg_extract_test.c (main): Added support for a third arg, (the
- filename to extract to the buffer).
-
- * opkg_conf.c (opkg_conf_init): Added several fields to
- opkg_conf_t: pkg_src_list, pkg_dest_list ,
- restrict_to_default_dest, default_dest, tmp_dir, lists_dir,
- pending_dir, force_depends, and pkg_hash. There's still a bit of
- tension between options stored in the config file, (opkg_conf_t),
- and command-line arguments, (args_t).
-
- * opkg_cmd.c: First version that is approaching usability. The
- following commands are more-or-less in place: "opkg update", "opkg
- list", "opkg info", "opkg status". While the rest are in various
- states of being partiallyy written or written but untested.
- (opkg_upgrade_cmd): Added support for restricting to a dest. Many
- other changes, largely involving plugging into the pkg_hash for
- real for the first time, and adding multiple dest support.
-
- * opkg.c: Added support for setting the dest on the command-line.
-
- * args.c: Added support for OPKG_CONF_DIR environment variable and
- -f, -conf, and -conf-file options.
-
- * configure.ac: Added lots of little bits suggested by autoscan.
-
-2002-02-18 Carl Worth <cworth@east.isi.edu>
-
- * pkg_parse.c (pkg_parse_raw): Added parsing, (kinda ugly), for
- essential field.
- * pkg.c (pkg_print_field): Added the essential flag.
-
- * pkg_vec.c (pkg_vec_insert): Fixed to use pkg_compare_versions to
- determine matching versions instead of a strcmp on the version
- string.
-
-2002-02-15 Carl Worth <cworth@east.isi.edu>
-
- * pkg_parse.c (pkg_parse_raw): Updated to accept a pkg_src_t
-
- * pkg.c (pkg_init): Added field to pkg_t: "pkg_src_t *src"
-
- * pkg_hash.c (pkg_hash_add_from_file): Updated to accept a pkg_src_t
-
- * pkg_parse.c (parseStatus): Modified to accept a pkg_t *
- (parseVersion): Added this function
- (pkg_parse_raw): Updated to accept a pkg_dest_t
- (pkg_parse_raw): Reworked the parsing to use a pkg_t rather than a
- slew of local variables.
- (pkg_parse_raw): Added support for about a dozen new pkg_t fields
-
- * pkg.h: Updated for all pkg.c changes.
-
- * pkg.c (pkg_new): Added pkg_new for convenient alloc'ing of a pkg_t.
- (pkg_init): Added several fields to pkg_t: dest, section,
- suggests, filename, local_filename, tmp_unpack_dir, md5sum, size,
- installed_size, priority, source, and conffiles.
- (): Moved buildPkg this function to pkg_parse
- (pkg_init_from_file): Added convenience function for filling a
- pkg_t from an actual package file.
- (pkg_print_info): Split print_pkg into both pkg_print_info and
- pkg_print_status.
- (pkg_print_field): Added pkg_print_field, (extremely ugly)
- (): Moved parseversion to pkg_parse where it belongs
- (pkg_version_str_alloc): Added, (complement of parse_version)
-
- * pkg_depends.h: Added GPL blurb
- (PKG_DEPENDS_H): Added multiple include protection
-
- * pkg_depends.c: Moved non-static prototypes to header file.
- Changed several locl-only functions to be static.
- Added function prototypes for static functions.
- (buildDepends): Removed unecessary cast of malloc return value.
-
- * pkg_hash.h: Moved hash-related struct declarations to this file
- Rename pkg_fetch* to have consistent pkg_hash_fetch prefix.
- Added missing prototype for pkg_vec_fetch_by_name
-
- * pkg_hash.c: (pkg_hash_add_from_file): Added support for setting
- the pkg_dest
- (pkg_hash_add_from_file): Moved buildDepends call to
- hash_insert_pkg
- (pkg_hash_fetch_installed_by_name_dest): Added this function to
- support pkg_dest
-
- * opkg_utils.h: Added GPL blurb
- (OPKG_UTILS_H): Added multiple include protection
-
- * opkg_utils.c:
- (read_raw_pkgs_from_file): broke read_raw_pkgs into
- read_raw_pkgs_from_file and read_raw-pkgs_from_stream
- (opkg_write_status_file): Fixed return value
- (print_pkg_status): Moved this function to pkg.c:pkg_print_status
- (line_is_blank): Fixed const char handling
-
-2002-02-08 Carl Worth <cworth@east.isi.edu>
-
- * pkg_parse.c: Fixed a bug in parsing the 3 state fields.
-
-2002-02-06 Carl Worth <cworth@east.isi.edu>
-
- * pkg.c: Expanded pkg_status field to the full 3 fields: state_want,
- state_flag, and state_status.
-
-2001-12-11 Carl Worth <cworth@east.isi.edu>
-
- * opkg_conf.c: Now parses /etc/opkg.conf, (and doesn't do anything
- with it).
-
- * opkg.c: Started work on opkg main, (not much here yet).
-
- * opkg_cmd.h: Added a tiny thing to abstract top-level opkg
- commands, (not finished).
-
- * Set up autoconf and friends
diff --git a/ChangeLog.ipkg b/ChangeLog.ipkg
new file mode 100644
index 0000000..d13b3fb
--- /dev/null
+++ b/ChangeLog.ipkg
@@ -0,0 +1,1761 @@
+2006-05-30 pigi ( pigi@frumar.it)
+ * Version update to 0.99.163
+ * Fixed a bug in GNU_TAR_EXTENSION of unarchive.c. This fix #1666
+
+2006-05-04 pigi ( pigi@frumar.it)
+ * Fixed a little bug in makefile that inhibit the compilation from .tar.gz ( missing intercept dir )
+
+2006-04-20 pigi ( pigi@frumar.it)
+ * Version update to 0.99.162
+ * Fixed a bad bug introduced in .160 that was blocking the install of a package
+
+2006-04-18 pigi ( pigi@frumar.it)
+ * Version update to 0.99.161
+
+2006-04-18 pigi ( pigi@frumar.it)
+ * Another little fix for the upgrade part.Now alse the prerm and postrm scripts gets deleted before upgrading.
+ wishing this fix the last troubles in upgrade part.
+ * Fix for #1585 after the bug introduced with the modify for offline root. ( Again )
+
+2006-03-30 pigi ( pigi@frumar.it)
+ * Activated the patch from Gunter@ohrner.net for the md5 check of package
+ * Another change in the upgrade part, to handle the ghosts files from an upgraded package
+
+2006-03-30 pigi ( pigi@frumar.it)
+ * Version update to 0.99.160
+ * Fix for #1585 after the bug introduced with the modify for offline root.
+ * Patch from Gunter@ohrner.net that fix a memory leak
+ * Not yet activated, but inserted a patch from Gunter@ohrner.net for the md5 check of package
+
+2006-02-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.159
+ * Another change in the upgrade part, to handle the ghosts files from an upgraded package
+ * Now it should be ok. Thanks to pb_ for pointing out where to look at.
+
+2006-02-02 pigi ( pigi@frumar.it)
+ * Version update to 0.99.158
+ * Modified the way upgrade handle the removing of a package, to be sure that opkg doesn't break busybox upgrade
+ * this should fix #1503
+
+2006-01-30 pigi ( pigi@frumar.it)
+ * applied patch from pb_ for speed up things in boot ( to avoid multiple configure execution )
+ * applied patch from <r.schwebel@pengutronix.de> for 100+ filenames in tar file ( again )!
+ * applied patch from <r.schwebel@pengutronix.de> to avoid trouble in offlineroot installations.
+
+2006-01-22 pigi ( pigi@frumar.it)
+ * Version update to 0.99.157
+
+2006-01-17 pigi ( pigi@frumar.it)
+ * Added a check to avoid reading feed files with several options. This should fix #1458 and speed up a lot of executions.
+
+2006-01-12 pigi ( pigi@frumar.it)
+ * Version update to 0.99.156
+ * Fixed a length problem for strncpy when "Installing" option added. This fix bug #1456. Thanks to hrw for signaling
+
+2005-12-15 pigi ( pigi@frumar.it)
+ * Version update to 0.99.155
+ * Added a function to remove the package that is being upgraded.
+ * Fixed a problem when installing by hand. Now opkg knows that a package has been selected by hand,
+ * and, if every check returns ok, it install the wanted package, instead of selecting one from feed.
+ * Moreover, now downgrade should works again.
+ * Fixed the "Replaces" bug. Now opkg is able to replace a package also if it doesn't conflict.
+ * Other minor changes in debug options
+
+2005-09-15 pigi ( pigi@frumar.it)
+ * Version update to 0.99.154
+ * Corrected a problem when removing a package, caused by an off by one alignement with the "Provides:" String
+ * Patched for the "depends:" bug introduced after the "Provides:" fix. This fix #1393
+ * Added a little fix for an off-by-one error in checking for depends.
+
+2005-07-29 pigi ( pigi@frumar.it)
+ * Applied a patch for the GNU tar compatibility . Now opkg can handle filenames > 100 char.
+
+2005-07-29 pigi ( pigi@frumar.it)
+ * Version update to 0.99.153
+ * Fixed a problem with Provides:. Now opkg is able to install foo when foo is provided by bar, and is able to determine the best candidate based on
+ * package name. This also fix #1328
+
+2005-07-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.152
+ * Fixed a length problem for strncpy after "Downgrading" option added. This fix bug #1373. Thanks to steven.scholz@imc-berlin.de for signaling
+
+2005-06-16 pigi ( pigi@frumar.it)
+ * Version update to 0.99.151
+ * Fixed a missing check for null pointers . This fix bug #1358
+
+2005-06-05 pigi ( pigi@frumar.it)
+ * Version update to 0.99.150
+ * Added the -force-downgrade option to allow the downgrade of a package
+
+2005-05-11 pigi ( pigi@frumar.it)
+ * Version update to 0.99.149
+ * Added the possibility to choice the opkglibdir from configure ( --with-libopkgdir )
+
+2005-04-10 pigi ( pigi@frumar.it)
+ * Version update to 0.99.148
+
+2005-04-09 pigi ( pigi@frumar.it)
+ * Found a bug in output from error_list. Now every error is printed, also if the functions don't return an error.
+ * Added a patch to Makefile from Robert Schwebel <r.schwebel@pengutronix.de>, cleaning things a bit. Thanks to Schwebel
+
+2005-03-30 pigi ( pigi@frumar.it)
+ * Version update to 0.99.147
+ * Found a bug in opkg_install when freeing a cursor
+
+2005-03-28 pigi ( pigi@frumar.it)
+ * Version update to 0.99.146
+ * Modified the opkg_error messaging to collect all the messages at the end of the program
+
+2005-03-26 pigi ( pigi@frumar.it)
+ * Little bug in message when "depends broken"
+
+2005-03-14 pigi ( pigi@frumar.it)
+ * Version update to 0.99.145
+ * Found a bug in opkg remove when a package was depending in itself and opkg where asked to "-recursive"
+ This fix bug # 1301
+ * A very little beautify in args.c
+
+2005-03-07 pigi ( pigi@frumar.it)
+ * Added the check for md5 in resolv_conf_file. Now opkg ask for confirmation only it the files differ
+
+2005-02-22 pigi ( pigi@frumar.it)
+ * Version update to 0.99.144
+ * A little fix suggested by drw in opkg_conf.c
+ * Changed the opkg.h to be build in automake for oe mechanism . This will enhance the building phase
+ by honouring the lib hierarchy choose by users
+ * Changes in automake to honour the new building mechanism
+
+2005-02-20 pigi ( pigi@frumar.it)
+ * Version update to 0.99.143
+ * libopkg.h: reverting the previous modify
+ * opkg_conf.c: fixing a probable bug in list_dir that fix problems with opie-packagemanager ( tanks to drw for signaling)
+
+2005-02-20 pigi ( pigi@frumar.it)
+ * libopkg.h: added some define to fix the broken external interface after 0.99.139 and lists_dir
+
+2005-02-17 pigi ( pigi@frumar.it)
+ * pkg_depends.c: applied patch from rjt@cambridgebroadband.com to remove some c99ism
+
+2005-02-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.142
+ * Fixed the definition of full_write and full_read as per bug #1280
+
+2005-02-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.141
+ * Added space in opkg_message to give more readible messages
+ * Corrected a problem when creating the directories in pkg_dest_init
+
+2005-02-05 pigi ( pigi@frumar.it)
+ * Version update to 0.99.140
+ * Fixed the bug in opkg_conf for a wrong pointer.
+
+2005-02-05 pigi ( pigi@frumar.it)
+ * Version update to 0.99.139
+ * Fixed the "replaces" problem reported by pb_. Now opkg is able to resolve a "replace/conflict" reference
+ * Added the possibility to keep the lists file in a different location. Fullfill enh #1276
+
+2005-02-02 pigi ( pigi@frumar.it)
+ * Fixed the problem for SW_DEINSTALL in remove. Fix #1274
+ * Fixed the problem issued from florian. This also fix the bug #520 HardLink are now supported
+
+2005-01-18 pigi ( pigi@frumar.it)
+ * Version update to 0.99.138
+ * libbb.h: patch for the uclib
+
+2005-01-14 pigi ( pigi@frumar.it)
+ * opkg_install.c: applied patch from rjt@cambridgebroadband.com to remove some c99ism
+
+2005-01-14 jamey ( jamey@handhelds.org )
+ * pkg_hash.c: applied patch from Jean Tourrilhes to allow default
+ arch to be different than host arch
+
+2005-01-10 pigi ( pigi@frumar.it)
+ * Version update to 0.99.137
+ * fixed a little, but annoying bug when writing the status file.
+
+2005-01-10 pigi ( pigi@frumar.it)
+ * Version update to 0.99.136
+ * Lot of memory leak fixes from Benjamin Pineau <ben@zouh.org>
+ * Fix for the Provides, that weren't able to "protect" their dependants while removing.
+ Now the remove should be safer.
+ * removed the replace.h stuff from automake .ac/.in files. This should align to oe
+
+2005-01-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.135
+ * Various fix for dependencies in control files
+
+2005-01-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.134-1 for fixing a problem with cvs tag on previous version
+
+2005-01-06 pigi ( pigi@frumar.it)
+ * Version update to 0.99.134
+ * Added a new option for listing only the installed packages. Asked by pb_ but really important
+ * Little modification to autoconfigure.sh
+ * removed fileutils dependencies that has disappeared from 0.8 in control-cl.in control-unstripped.in libopkg-control.in
+
+2004-11-18 pigi ( pigi@frumar.it)
+ * Version update to 0.99.133
+ * Fix for preserve date and time when extracting a package. Thanks to <trevor.pering@intel.com>
+
+2004-10-07 pigi ( pigi@frumar.it)
+ * Version update to 0.99.132
+ * Little fix on available blocks calculation. Thanks to seved.torstendahl@netinsight.se for founding it.
+ * this fix #1259
+
+2004-09-20 pigi ( pigi@frumar.it)
+ * Version update to 0.99.131
+ * Added a lot of debug info in DEBUG2
+ * Added a check in opkg_install.c to permit replacing of existing file when installing a package
+ * from a file ( not an upgrade ) when opkg find a file clash but the owner of the package is the
+ * same. That should fix the #1246
+
+2004-09-02 pigi ( pigi@frumar.it)
+ * Version update to 0.99.130
+ * Added patch from pb_ for bug #1251. A lot of thanks to Phil
+
+2004-09-02 pigi ( pigi@frumar.it)
+ * Some changes on output messages to be a little bit clear
+
+2004-09-01 pigi ( pigi@frumar.it)
+ * Applied patches from pb_ (bug #1244)
+ * Added EXTRADIST = opkg.c and others in Makefile.am as in opkg.0.99.xxx.tar.gz the opkg.c was missing. (
+ reported by odvard12@yahoo.com )
+ * Version update to 0.99.129
+
+2004-08-19 Florian <florian.boor@kernelconcepts.de>
+ * Version update to 0.99.128
+ * libopkg.c, opkg_cmd.c: Fixed return value zero if installation
+ failed. Changed text because failing to install a package
+ is not necessarily a bug :-)
+ * Makefile.in, libbb/Makefile.in: Removed autogenerated files.
+
+2004-08-18 Florian <florian.boor@kernelconcepts.de>
+ * Two more fixed memory leaks. Contributed by Nils Faerber.
+
+2004-08-17 Florian <florian.boor@kernelconcepts.de>
+ * Fix to avoid major memory leak due to multiple initialising
+ of hash tables. Contributed by Nils Faerber.
+
+2004-07-20 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.127
+ * Applied patch from tmbinc@elitedvb.net (Felix Domke) to fix some problems when in use on platforms
+ * different from arm. Fixes big #1234
+2004-06-15 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.126
+2004-06-12 florian <florian.boor@kernelconcepts.de>
+ * Makefile.am: Added some missing headers to the list.
+ * libopkg.pc.in: Fixed hardcoded prefix... tsts
+2004-06-12 pigi ( pigi@frumar.it)
+ * pb_ patch for setuid bit in unarchive
+2004-06-05 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.125
+ * modified almost all reference to xregexec in fnmatch ( as adviced by zap).
+ This should fix every problem with strange character in package name when using regex in functions
+ ( as per info_status_cmd or remove ). #1220
+2004-05-21 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.124
+ * import the kergoth patch for Makefile.am to fix the linking problems on arch <> arm
+ * added the opkg remove <regexp> feature.
+ * fixed the opkg usage message, 'cause in "ifdef LIBOPKG" we don't have the opkg info field version.
+ * added the message "No package removed" if no package has been removed. This to avoid misunderstanding
+ with the successfully done message at the exit of execution.
+2004-05-16 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.122-3
+ * Anothere little fix. Added the version number in control.in. This should fix definitelly the problem with dependencies
+2004-05-16 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.122-2
+ * New subrelease released to correct the problem for dependencies (libopkg >= 0.99.122-1) in opkg control file
+2004-05-14 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.122-1
+ * needed for a recompilation with the libtool updated. This could fix the #1209 created by my old libtool version
+ * cleaned the cvs dir by removing the really unneeded busybox directory
+2004-05-10 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.122
+ * pb_, cworth and I discussed a bit on opkg output to users. We agreed on removing some confusing
+ * messages, moving them to a debug level of verbosity.
+ * I do added also some message to user indicating the phase opkg is in, and a global ending message
+ * informing the user for the status of operation.
+ * This fixes the #1206, and hopefully does not introduce others ;-)
+2004-05-03 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.121
+ * reenoo__ found a problem with depend lines > 1023, and pb fixed it. Thanks to both,
+ * This should fix #1204.
+2004-04-08 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.120
+ * pb found another one. The configure cmd now will set the correct values in status file
+ * #1196 fixed
+2004-04-07 pigi ( pigi@frumar.it)
+ * configure.ac: updated to 0.99.119
+ * pb found another one. Commiting his patch, elegant as usual :)
+2004-03-29 jamey ( jamey@handhelds.org)
+ * configure.ac: updated to 0.99.118
+2004-03-29 pigi ( pigi@frumar.it)
+ * pb_ asked me to have a command to change the status of a package betwenn installed and unpacked.
+ and I did it.
+ * I' ve also included the fix for the empty lists as for bug # 1136 reported and suggested by k.vangelder@chello.nl
+2004-03-17 pigi ( pigi@frumar.it)
+ * Added the implement for Essential in status file. This is needed to avoid the unintentional remove
+ of essential packages. In effect the command "opkg remove opkg" worked without problems, but then
+ it was difficult to reinstall. This fix the bug # 867
+2004-03-15 jamey <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.117
+2004-03-10 pigi ( pigi@frumar.it)
+ * Added the check for *alloc in every source. I needed to modify some function ehre and there
+ to check the return values from function allocating memory, but hopefully it should be all right now.
+ * Added the check for at least a package for remove ( it was removing everithing if no pkgname followed the
+ remove option.
+2004-03-09 pigi ( pigi@frumar.it)
+ * Added a flag to disble the checking of directories when the command does not need to
+ read anything from there. Fix bug #1096
+2004-03-09 pigi ( pigi@frumar.it)
+ * Changes to correct the behaviour of verbosity. Now the "0" works, and the "1" is again
+ the default.
+ This fixes the bug #1099
+2004-03-07 pigi ( pigi@frumar.it)
+ * Minimal changes for a clean compile in libopkg.c ( so we can close the bug# 1119 )
+2004-03-03 pigi ( pigi@frumar.it)
+ * Missing \n in Size and Source Fields.
+2004-03-03 pigi ( pigi@frumar.it)
+ * Florian noticed a free missiing in opkg_cmd.c ( should sleep more at night )
+ it was in an (almost) unsed part of the code ( old code ) but, just in case...
+ * Changed a comment in pkg.c ( it was in italian ) and added a bit of explain in
+ pkg_formatted_field
+2004-03-02 jamey <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.116
+ * pkg.h: from Pigi: pkg_formatted_info and pkg_formatted_field now allocate the strings they fill in
+ * pkg.c, opkg_cmd.c: from Pigi: updated to the new pkg.h interface
+2004-02-29 florian <florian.boor@kernelconcepts.de>
+ pkg.c: Pigi and me poked around a little bit and located the cause of
+ latest segfault. strncat is not used correctly in pkg_formatted_info
+ and pkg_formatted_field. I added a fix to the only section that
+ triggered the bug and increased a buffer size.
+ BUT: There are many similar bugs remaining!
+2004-02-24 jamey <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.115
+ * opkg_cmd.c: segv caught by pigi: buffer freed in loop but used on next iterations. bug squashed.
+ * user.c: realloc question buffer if it is too short so that messages are not truncated.
+2004-02-20 jamey <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.114
+ * libbb/unarchive.c: patch from pigi@frumar.it: fix erroneous invalid header checksum message
+2004-02-19 jamey <jamey.hicks@hp.com>
+ * configure.ac: update to 0.99.113
+ * libopkg.c: patch from drw to fix opkg list
+2004-02-19 florian <florian.boor@kernelconcepts.de>
+ * Some minor changes to make code compile on more compilers.
+2004-02-14 jamey <jamey.hicks@hp.com>
+ * configure.ac: updated to 0.99.112
+ * libbb/unarchive.c: copied in oldgnu tar compatibility mode from latest busybox.
+2004-02-13 jamey <jamey.hicks@hp.com>
+ * configure.ac: updated to 0.99.111
+ * pkg.c: wim delvaux's patch for status file in other destinations
+2004-01-23 florian <florian.boor@kernelconcepts.de>
+ * Applied Dan's patch that adds a package download command to
+ libopkg.
+2004-01-20 florian <florian.boor@kernelconcepts.de>
+ * Applied Dan's changes to work incuded from a C++ app.
+2004-01-15 jamey
+ * configure.ac: updated to 0.99.110
+ * libopkg.c: added default callbacks for output
+ * opkg_conf.c: default verbosity to 1
+2004-01-12 jamey
+ * configure.ac: updated to 0.99.109
+ * opkg_install.c: fix potential segv sprintf_alloc with fewer args than required by format string (yay valgrind)
+ * sprintf_alloc.c: add null pointer checking
+2004-01-12 jamey
+ * configure.ac: updated to 0.99.108
+ * Makefile.am, familiar/: use opkg-cl as default executable, install as opkg via update-alternatives
+2004-01-12 jamey
+ * configure.ac: updated to 0.99.107
+ * void_list.c: check for null data
+ * pkg.c: check for null pointers
+2003-12-23 florian <florian.boor@kernelconcepts.de>
+ * Added void* parameter to some callbacks.
+
+2003-12-02 florian <florian.boor@kernelconcepts.de>
+ * Added familiar/opkg-cl.control.in, which is a prototype of
+ control file for opkg-cl package creation.
+2003-12-01 florian <florian.boor@kernelconcepts.de>
+ * added opkg command line tool using libopkg, binary is known as opkg-cl
+ * opkg-frontend.c: source for this tool
+ * libbb/Makefile.am: Removed changing of CFLAGS, this avoids a nasty warning.
+ * Makefile.am: Same fix and addition of new target creating opkg-cl.
+ * removed ltmain.sh, libtool which seem to be created by autostuff
+
+2003-12-01 jamey
+ * configure.ac: updated to 0.99.106
+ * pkg.c, opkg_conf.c: check for null pointers (null pkg->dest in particular)
+2003-11-11 jamey
+ * configure.ac: updated to 0.99.105
+ * opkg_conf.c: added verbosity option to conf file
+2003-11-11 jamey
+ * configure.ac: updated to 0.99.104
+ * opkg_install.c: removed spurious calls to fflush, remove obsolete maintainer scripts on upgrade
+ * opkg_remove.c: remove unused function: remove_conffiles
+2003-11-11 jamey
+ * configure.ac: updated to 0.99.103
+ * libopkg.pc.in, configure.ac: pkgconfig for libopkg
+ * opkg_conf.c, pkg.c: check for error on fopen
+ * pkg_hash.c: reduced verbosity
+ * libtool: arm-linux-strip does not support --strip-debug on .a files
+2003-11-10 jamey
+ * configure.ac: updated to 0.99.102
+ * opkg_cmd.c: compute architecture_priority of packages in database before doing download command
+ * conffile.c file_util.[ch] opkg_install.c: better separation of installation root filenames and actual filenames
+ * pkg.h: added prototype for pkg_free_installed_files
+2003-11-10 jamey
+ * configure.ac: updated to 0.99.101
+ * libopkg changes
+ * generate .list files from file_hash
+2003-11-05 jamey
+ * configure.ac: updated to 0.99.100
+ * opkg_install.c: fix segv: was passing conflictee->parent instead of conflictee
+2003-10-08 jamey
+ * configure.ac: updated to 0.99.99
+ * opkg_install.c: use the root_dir after stripping off offline_root prefix
+2003-10-08 jamey
+ * configure.ac: updated to 0.99.98
+ * pkg_hash.c: fixed segv if replaced_by->len was 0
+ * opkg_cmd.c: opkg remove with no arguments will remove non-user leaf packages
+ * opkg_remove.[ch]: export pkg_has_installed_dependents
+ * pkg_depends.c: add pkg->parent to pkg->provides
+ * opkg_install.c: strip offline_root prefix off of conffile name so comparing the md5sums should work
+ * pkg.c: missing comma added
+2003-10-01 jamey
+ * configure.ac: updated to 0.99.97
+ * opkg_cmd.c: added whatdependsrec command to show what recursively depends on a package or packages
+ * pkg_vec.[ch]: added pkg_vec_clear_marks and pkg_vec_mark_if_matches
+ * args.c: usage string updated
+2003-09-28 jamey
+ * configure.ac: updated to 0.99.96
+ * opkg_conf.c: adjusted verbosity
+ * opkg_install.c: only remove replacee if it is also conflicted, per debian standard
+ * pkg_depends.c: only add to replaced_by if it also conflicts, per debian standard
+ added pkg_provides, pkg_replaces, pkg_conflicts
+ * pkg_hash.c: adjusted verbosity
+2003-09-28 jamey
+ * configure.ac: updated to 0.99.95
+ * args.[ch], opkg_cmd.c, opkg_conf.[ch], opkg_download.c, opkg_install.c, opkg_remove.c, pkg.[ch]:
+ Implemented -test mode for opkg.
+2003-09-28 jamey
+ * configure.ac: updated to 0.99.94
+ * pkg_hash.c: fix pkg_hash_fetch_best_installation_candidate so
+ that one can install another provider of an installed package name
+2003-09-26 jamey
+ * configure.ac: updated to 0.99.93
+ * opkg_install.c: corrected message level depending on conf->force_depend
+ * opkg_conf.c: check for duplicate src entries
+ * nv_pair_list.[ch]: added nv_pair_list_find
+2003-09-16 jamey
+ * configure.ac: updated to 0.99.92
+ * pkg_depends.c: some paranoia to try to avoid segv
+ * void_list.c: silenced message about elt not being found
+2003-09-11 jamey
+ * configure.ac: updated to 0.99.91
+ * pkg_depends.c: added pkg_depend_str to fetch right kind of dependence string based on dependence index
+ Use this in add_unresolved_dep.
+ * pkg_depends.h: declaration of pkg_depend_str
+2003-08-22 11:02 jamey
+ * configure.ac: updated to 0.99.90
+ * str_list.[ch]: added str_list_alloc(), added str_list_remove_elt()
+ * void_list.[ch]: added void_list_remove_elt()
+ * pkg_parse.c: added parsing of Source field
+ * pkg_hash.c: updated old_pkg->installed_files list when setting file owner if it was previously owned by old_pkg
+ * pkg_extract.c: use installed_file list if it exists in pkg_extract_data_file_names_to_file
+ * pkg.[ch]: added pkg_write_filelist() and pkg_write_changed_filelists()
+ * opkg_remove.c: do not call opkg_conf_write_status_files from opkg_remove
+ * opkg_install.c: use opkg_write_filelist()
+ * ipgk_cmd.c: after writing status file, write any changed pkg filelists
+2003-08-20 11:02 jamey
+ * configure.ac: updated to 0.99.89
+ * pkg.c: print Source field in pkg_print_info
+2003-08-06 18:34 jamey
+ * configure.ac: updated to 0.99.88
+ * pkg_hash: bug 942, declare internal induction variable
+ * opkg_cmd.c, opkg_conf.[ch], pkg_src.[ch], pkg_src_list.[ch]: bug 604, support Packages.gz
+2003-08-06 18:34 jamey
+ * configure.ac: updated to 0.99.87
+ * pkg.c: remove extra printing of Suggests field
+ * pkg_vec.c: merge Status field only from current database, rest of Package info from Packages files
+ * pkg_depends.c: print info about recommendations as Notice instead of DEBUG
+2003-07-11 18:34 jamey
+ * configure.ac: updated to 0.99.86
+ * opkg.h, opkg_cmd.c, opkg_configure.c, opkg_install.c, opkg_remove.c: only write status file if something changed.
+2003-07-11 18:34 jamey
+ * configure.ac: updated to 0.99.85
+ * pkg.c, pkg.h, pkg_depends.c, pkg_depends.h, pkg_parse.c: bug 885:
+ add recommends and suggests
+ * args.c, opkg_cmd.c, opkg_cmd.h: add opkg configure command
+ * pkg_vec.c: apply patch for bug 883
+2003-05-11 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.84
+ * pkg.c, opkg-compare-versions.c: fix problem where . and - were not treated as separators in version comparison
+2003-04-11 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.83
+ * opkg_install.c: use pkg->installed_size instead of pkg->size
+ * opkg_cmd.c, opkg_conf.c: put lists under offline_root if specified
+2003-04-11 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.82
+ * pkg_hash.c: ignore Replaces directive when a package replaces itself
+2003-04-10 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.81
+ * pkg.c: clear state_want and state_flags for any uninstallable package
+2003-04-10 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.80
+ * pkg.c: pkg_merge was intermingling depends and predepends from
+ old and new pkg, and was ignoring conflicts and replaces
+ * pkg_depends.c: cleaned up interface to parseDepends
+2003-04-07 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.79
+ * pkg_hash.c: default architecture to host_cpu if unspecified
+ * opkg_install.c, opkg_download.c: refuse to install package with no architecture
+2003-04-07 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.78
+ * args.[ch], opkg_conf.[ch]: added query_all (-A)
+ * opkg_cmd.c: finished implementing whatdepends, whatrequires, whatprovides, and whatconflicts
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.77
+ * opkg_cmd.c: implemented whatdepends
+ * opkg_conf.c: fixed typo
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.76
+ * args.c: was zeroing args structure too late
+ * opkg_conf.c: test for existence of /etc/opkg.conf before trying to load it
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.75
+ * familiar/rules: update postinst only to generate ipaqarch.conf if none exists
+ * args.[ch]: added -t or --tmp-dir option to specify tmp-dir
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.74
+ * opkg_cmd.c: avoid segv by only calling xregfree after xregcomp was called
+ * pkg_hash.c: prefer pkgs that are marked hold/prefer, next
+ abstract pkgs that are installed, next latest pkg if one provider,
+ give up if multiple providers are acceptable -- let user decide
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.73
+ * pkg_hash.c: remove latest_installed heuristic because it prevents upgrades.
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.72
+ * pkg_hash.c: check for unresolved packages (apkg->provided_by->len == 0), better messages.
+2003-04-03 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.71
+ * pkg.c: Added pkg_name_version_and_architecture_compare and abstract_pkg_name_compare
+ * opkg_cmd.c: allow multiple fields for info and status command.
+ Allow posix regexp's for package name in status, info, and list
+ commands.
+ * pkg_remove.c: fixed type error
+ * xregex.h: added xregfree
+ * pkg_hash.c: Provides functionality seems to be working again
+2003-04-02 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.70
+ * args.c, args.h, opkg_conf.c, opkg_conf.h, opkg_install.c: implemented nodeps option
+ * pkg_vec.[ch]: added [abstract_]pkg_vec_{contains,sort}
+ * pkg.c: print which script not being run in offline root mode
+2003-04-02 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.69
+ * pkg_vec.c: compare architecture to architecture, not to name
+ * opkg_utils.c: do not exit, instead return NULL
+ * opkg_install.c: do not exit, instead return -EINVAL
+ * opkg_download.c: make sure to set pkg dest
+ * opkg_cmd.c: notice instead of info for writing status file message
+2003-04-02 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.68
+ * pkg_vec.c, pkg_depends.c: pkg_t's are the same if they have same name, version, and architecture
+2003-04-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.67
+ * opkg_install.c: one last check for supported architecture in opkg_install_pkg
+ * pkg.c: make pkg_print_field less fragile by using strcasecmp,
+ added support to print Conflicts
+ * pkg_hash.c: if multiple candidates with right architecture
+ satisfy constraint_fcn, return latest version
+ * opkg_cmd.c: when verbosity > 1, show if conffiles have been
+ modified in info command
+ * hash_table.c, hash_table.h: count number of elements in hash
+ tables
+ * file_util.c: explicitly use unsigned char
+ * conffile.c: more debugging info
+2003-04-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.66
+ * pkg_depends.c: fixed what seemed to be glaring deficiency in version_constraints_satisfied
+ * pkg_hash.c: more debug info
+ * pkg_parse.c, pkg.c: added Installed-Time as field saved to status file
+2003-04-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.65
+ * opkg_cmd.c, opkg_conf.c: applied opkg dest installation patch from Ben Lau <benlau@linux.org.hk>
+ * opkg_cmd.c: fixed probably segv when using offline_root, fixed problem installing from local file.
+ * opkg_conf.c:
+ - Do not add default architectures if opkg configuration files include architecture definitions.
+ - Look for /etc/opkg/*.conf under offline root if using offline root mode
+ * void_list.h: added void_list_empty()
+ * nv_pair_list.h: added nv_pair_list_empty()
+2003-03-28 14:30 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: 0.99.64
+ * pkg_hash.c: change fprintf stderr to opkg_message
+ * pkg.h: added SF_MARKED and abstract_pkg_t state_flag field
+ * pkg.c: include Provides, Replaces, and Architecture in status
+ file
+ * opkg_remove.c: make sure to print each dependent package only
+ once
+ * opkg_message.h: added OPKG_DEBUG2
+ * opkg_install.c: modify message and level depending on
+ force_depends
+ * opkg_cmd.c: call pkg_info_preinstall_check before any
+ install/upgrade/remove action
+ * ChangeLog, autoconfigure.sh, includes.h,
+ opkg_conf.c, opkg_remove.c, pkg.c, pkg.h, update-alternatives,
+ xregex.h: applied kergoth's update-alternatives patch
+ * opkg_cmd.c, opkg_remove.c: remove maybe_broken_removal... which
+ was an expensive no-op; before removing package, make sure that
+ nothing is installed that depends on the apkgs **provided** by a
+ package
+ * pkg.h: mark for future cleanup
+ * ChangeLog: 0.99.62, adds architecture priority, better handling
+ of file obsolescence and package replacements in progress
+2003-03-27 18:26 jamey
+ * autoconfigure.sh: accidentally committed /usr/local/bin calls
+ * opkg_conf.c: needed a strdup, set default verbosity back to 0
+ * familiar/postinst: default architecture priorities
+ * Makefile.in, autoconfigure.sh, opkg_cmd.c, opkg_conf.c, pkg.c:
+ both name and value in nv_pair_list must be actual strings
+ * pkg_hash.c: do not try to invoke NULL constraint_fcn
+ * opkg_install.c: added file_hash_{set,get}_file_owner, created
+ check_downgrade
+ * opkg_conf.c, opkg_conf.h, opkg_remove.c, pkg.c, pkg_hash.c,
+ pkg_hash.h: added file_hash_{set,get}_file_owner
+ * hash_table.c: check for key already being present in
+ hash_table_insert
+ * configure.ac: update to 0.99.63
+ * opkg_hash_test.c: update due to new prototypes
+ * opkg_conf.c: missed a conversion from str_list to nv_pair_list
+ * opkg_install.c: minor tweaks
+ * pkg.c, pkg.h: added pkg_info_preinstall_check to update
+ pkg->arch_priority
+ * pkg_depends.c, pkg_depends.h: use constrained
+ pkg_hash_fetch_best_installation_candidate in
+ pkg_hash_fetch_unsatisfied_dependencies
+ * pkg_hash.c, pkg_hash.h, opkg_cmd.c, opkg_upgrade.c: split
+ pkg_hash_fetch_best_installation_candidate into a by name and a
+ constrained version
+ * opkg_install.c: block SIGINT while doing core of package
+ installation (single package)
+ * opkg_conf.c, opkg_conf.h: support for architecture priority
+ * pkg_depends.c: cleanup, reindent
+ * pkg.c, pkg.h: support for architecture_priority
+ * opkg_cmd.c: installed SIGINT handler when upgrading or removing,
+ support for architecture_priority
+ * pkg_hash.c: added support for architecture priority, reindented
+ * pkg_vec.c: minor cleanup
+2003-03-24 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.61
+ * familiar/postinst: mkdir -p /etc/opkg
+2003-03-24 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.61
+ * opkg_conf.c: read configuration from all *.conf files in /etc/opkg/
+ * familiar/postinst: create /etc/opkg/*.conf according to platform opkg is installed on
+2003-03-20 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.60
+ * various: added support for package architectures
+ * configure.ac: do not test for malloc
+2003-03-17 Aman Gupta <opkg@themastermind1.net>
+ * configure.ac: updated to 0.99.59
+ * args.c: show all verbosity levels in usage info
+ * args.h: changed default verbosity level to 1
+ * opkg_cmd.c: opkg_multiple_files_scan() was useless, switch to using
+ opkg_prepare_url_for_install()
+ * opkg_install.c: fix --force-reinstall
+ * opkg_remove.c: stop removing of modified conffiles
+2003-03-04 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.56
+ * opkg_message.c: show error messages by default
+ * opkg_message.h: protect against multiple inclusion
+ * conffile.[ch]: switch to opkg_message, added conf argument to conffile_has_been_modified
+ * opkg.h: move EXTENSION macros here
+ * pkg_depends.c: minor cleanup
+ * pkg.h: added prefer and obsolete flags
+ * pkg.c: parse and unparse SF_PREFER and SF_OBSOLETE
+ * opkg_install.[ch]:
+ - added {pkg,name}_mark_dependencies_for_installation,
+ - added conf argument to conffile_has_been_modified
+ - missing ifdef OPKG_DEBUG_NO_TMP_CLEANUP
+ * opkg_remove.c: added conf argument to conffile_has_been_modified
+ * opkg_download.c: added opkg_prepare_for_install
+2003-03-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.55
+ * opkg.h: wrap #if 0 around definition of of OPKG_DEBUG_NO_TMP_CLEANUP
+2003-03-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.54
+ * opkg_install.c: make old package SW_DEINSTALL during opkg installation
+ * opkg_cmd.[ch]: added some code to install packages marked SW_INSTALL, but have not enabled this code yet.
+2003-03-01 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: updated to 0.99.53
+ * pkg_depends.c: let SW_INSTALL satisfy dependences (instead of SS_INSTALL)
+2003-03-01 Daniele Nicolodi <daniele@grinta.net>
+ * opkg_install.c: indentation fixes and finish switch to message
+ facility
+ * opkg_cmd.c: indentation fixes, switch to message facility and
+ some code cleanup
+ * opkg_message.c (opkg_message): check for a NULL *conf parameter
+ * opkg_message.h: renamed OPKG_ERR in OPKG_ERROR
+2003-02-28 Jamey Hicks <jamey@handhelds.org> (patch from Daniele Nicolodi <daniele@grinta.net>)
+ * configure.ac: incremented version to 0.99.5
+ * opkg_message.[ch]: added message facility
+ * args.[ch]: verbosity control
+ * opkg_conf.[ch]: verbosity control
+ * opkg_install.c: switch to using message factility
+2003-02-28 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version to 0.99.51
+ * opkg_cmd.c: added opkg_statisfy_all_dependences, called after
+ install/upgrade of packages to handle packages that were split and
+ no longer provide all the resources they used to provide.
+2003-02-27 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version to 0.99.50
+ * opkg_cmd.c: write out status after doing an upgrade
+2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
+ * configure.ac: incremented version to 0.99.49
+ * pkg_parse.c, pkg.c: do not treat deb revision specially
+2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
+ * configure.ac: incremented version number to 0.99.48
+ * args.c: added help for opkg flags sub-command
+ * opkg_cmd.c: added opkg_flag_cmd, do not upgrade package marked hold
+ * opkg_install.c: do not remove obsolesced files if old_pkg is flagged noprune
+ * opkg_remove.c: pkg->state_flag is a bitvector now
+ * pkg.c: pkg->state_flag is a bitvector now
+ * pkg.h: pkg->state_flag is a bitvector now
+2003-02-27 Jamey Hicks <jamey@handhelds.org> (another patch from pb)
+ * configure.ac: incremented version number to 0.99.47
+ * pkg.c: refix "uninstalled package has NULL tmp_unpack_dir"
+ * pkg_hash.c:
+2003-02-27 Aman Gupta <oz@themastermind1.net> (another patch from pb_)
+ * configure.ac: incremented version number to 0.99.46
+ * pkg.c: fix "uninstalled package has NULL tmp_unpack_dir"
+2003-02-24 Jamey Hicks <jamey@handhelds.org> (per patch from Philip Blundell <pb@handhelds.org>)
+ * configure.ac: incremented version to 0.99.45
+ * file_util.c: include space for null in line_size
+ * opkg_cmd.c: sigint handler while configuring packages
+ * opkg_install.c: state_status != SS_INSTALLED and != SS_UNPACKED
+ * opkg_remove.c: missing i++
+ * pkg.c: do not run scripts in offline_root mode
+ * pkg_depends.c: every package provides itself
+ * pkg_hash.c: better handling of packges provided by multiple providers
+2003-02-24 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version number to 0.99.44
+ * args.c: added doc for -force-overwrite
+2002-11-26 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version number to 0.99.43
+ * opkg_install.c: completely skip the space check when -force_space asserted
+2002-11-23 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version number to 0.99.42
+ * args.c: missed one spot checking for -force_space or -force-space
+2002-11-23 Jamey Hicks <jamey@handhelds.org>
+ * configure.ac: incremented version number to 0.99.41
+ * opkg_install.c: added -force_space option to override out of space check
+2002-11-23 Aman Gupta <oz@themastermind1.net>
+ * configure.ac: incremented version number to 0.99.40
+ * opkg_configure.c: updated to match new text output format
+ * opkg_install.c: updated to new text output format
+ fixed problems where ipks installed from file or
+ http were being installed over newer ipks of the
+ same name
+ * opkg_remove.c: updated to new text output format
+ made opkg remove do what opkg purge originally did,
+ by having it remove conffiles, and status entries for
+ ipks that are removed. opkg_purge now calls
+ opkg_remove
+2002-11-22 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.39
+ * applied patches from Aman Gupta for better handling of dests
+2002-11-?? Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.38
+2002-11-07 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.37
+ * hash_table.[ch]: moved internals of hash_tables out of pkg_hash.c
+ * pkg_hash.c: moved internals of hash_tables out of pkg_hash.c
+2002-10-29 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.37
+ * opkg_cmd.c: opkg_upgrade_cmd now installs uninstalled packages
+ instead of getting a segv
+2002-10-29 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.36
+ * changed verbose_get to verbose_wget as documented
+2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.34
+ * opkg_cmd.c: fixed problem stringifying HOST_CPU
+ * Makefile.am: helped fix problem stringifying HOST_CPU
+2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.33
+ * opkg_cmd.c, args.c: added print-architecture and print-installation-architecture commands
+ * Makefile.am: added defines for HOST_CPU and BUILD_CPU to CFLAGS and package: target
+2002-08-08 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.32
+ * pkg.c: removed chroot breakage
+2002-08-07 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.31
+ * other: applied multiple providers patch from philip blundell
+ * opkg_cmd.c: implemented compare_versions cmd
+2002-07-25 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.30
+ * opkg_conf.c: added offline_root_pre_script_cmd and offline_root_post_script_cmd
+ * pkg.c: execute scripts in chroot'ed environment running
+ pre_script_cmd and post_script_cmd before and after the pkg script.
+2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.29
+ * pkg.c: fixed a segv when printing Replaces field
+2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.28
+ * opkg_cmd.c: merged functionality from opkg_install_cmd into
+ opkg_upgrade_cmd with an eye towards unifying these two commands.
+ * opkg_install.c: installing a package that replaces other
+ packages removes them first. (Upgrade does not do replacements automatically).
+ * opkg_remove.c: opkg_remove_pkg will remove a package with
+ installed dependents if state_flag == SF_REPLACE.
+2002-07-24 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.27
+2002-07-23 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.26
+ * renamed pkg_vec_init/pkg_vec_deinit to pkg_vec_alloc/pkg_vec_free
+ * started implementation of Replaces
+2002-07-22 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.25
+ * many cleanups trying to regain stability
+2002-07-22 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.24
+ * various files: trying to stomp a segv in conflicts checking.
+2002-07-17 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.23
+ * opkg_remove.c: do not do recursive removal if force-depends is
+ specified
+ * other-files: other cleanups to reduce code clutter
+2002-07-16 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.22
+ * user.[ch]: moved user interaction procedure here
+ * args.[ch], opkg_conf.[ch]: added force_removal_of_dependent_packages
+ * pkg.h: added state_status to abstract_pkg_t
+ * opkg_remove.c: If package has installed dependents, then only
+ remove if force_removal_of_dependent_packages is asserted in
+ opkg.conf or on command line. Will add user interaction option later.
+2002-07-16 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.21 after
+ applying dependent removal and conflicts patch.
+
+2002-07-14 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.20
+ * opkg_download.c: removed useless -N flag from wget
+ * update-alternatives: 'head -1' -> 'head -n 1', no sort -k 2 for busybox
+
+2002-07-15 Karthikeyan K <karthik@innvo.com>
+
+ * opkg_remove.c (opkg_remove_dependant_pkgs): removed setting the
+ dependencies_checked variable in the while loop b4 actually checking
+ the dependencies of that package.
+ * opkg_cmd.c (opkg_multiple_files_scan): added check for ".ipk" and
+ ".deb" extension, so that no caching is attempted on arguments that
+ are not local files
+ * pkg_depends.c (pkg_hash_fetch_conflicts): while returning NULL,
+ casted to (pkg_vec_t *) to compile without warnings
+
+2002-07-12 Abhaya Shenoy <abhaya@innvo.com>
+
+ * pkg_depends.c (pkg_hash_fetch_conflicts): use new abstract_pkg_vec
+ structure in checking provided_by
+
+2002-07-07 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.18
+ * fixed a segv due to type error in provides support
+
+2002-07-07 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.17
+ * updated provides support so that installed provider is preferred to
+ uninstalled provider
+
+2002-07-05 Abhaya Shenoy <abhaya@innvo.com>
+
+ * pkg_depends.c (pkg_hash_fetch_conflicts): check for conflicts
+ found before returning
+
+2002-07-04 Abhaya Shenoy <abhaya@innvo.com>
+ * opkg_install.c (check_conflicts_for): new function to call
+ pkg_hash_fetch_conflicts and print offending packages
+ (opkg_install_pkg): added call to check_conflicts_for
+ * pkg.c (pkg_merge): provides from oldpkg should be given
+ priority
+ (pkg_init): init of conflicts, conflicts_count fields
+ * pkg.h (struct pkg): added fields conflicts_str, conflicts,
+ conflicts_count
+ * pkg_depends.c (pkg_hash_fetch_conflicts): new function to check
+ for conflicts
+ (buildConflicts): new function to set up the conflicts in the pkg
+ struct
+ * pkg_depends.h: added new type CONFLICTS to depend_type enum
+ * pkg_hash.c (hash_insert_pkg): added call to buildConflicts
+ * pkg_parse.c (pkg_parse_raw): added parsing of Conflicts
+
+2002-07-04 Karthikeyan K <karthik@innvo.com>
+
+ * opkg_cmd.c (opkg_multiple_files_scan): new function to handle installation
+ of already downloaded files
+ (opkg_install_cmd): added call to opkg_multiple_files_scan
+ (opkg_remove_cmd): added call to possible_broken_removal_of_packages
+ * opkg_install.c (opkg_install_pkg): added check to remove redundant upgrade
+ when a package to be installed is already installed as a dependancy of
+ another
+ * opkg_remove.c (possible_broken_removal_of_packages): new fnuction
+ to check that all packages can be removed, before actually starting to
+ remove them
+ (opkg_remove_dependant_pkgs): new function to remove dependant packages
+ (opkg_remove_pkg): added call to opkg_remove_dependant_pkgs
+ * pkg.c (abstract_pkg_init): initialized dependencies_checked
+ * pkg_hash.c (pkg_hash_dump): added more information to hash dump
+
+2002-07-03 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.16
+ * opkg_install.c: defensive programming in case pkg contains no Size: clause
+
+2002-07-02 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.15
+ * pkg_depends.c: check for provided_by when fetching unsatisfied dependencies
+
+2002-07-02 Jamey Hicks <jamey.hicks@hp.com>
+ * configure.ac: incremented version number to 0.99.14
+ * pkg_hash.c: if abstract pkg is provided_by, then return pkg vec
+ of first package that provides it.
+
+2002-06-17 Jamey Hicks <jamey.hicks@hp.com>
+
+ * configure.ac: incremented version number to 0.99.12
+ * args.h, opkg_conf.h, opkg_install.c: Added force_overwrite
+ option. When this is asserted, opkg will overwrite files that
+ have no owner or that belong to other packages.
+ * opkg_conf.c, opkg_dest.c: Update status file atomically, keeping
+ old copy of status file if cannot update new status file. Applied
+ patch from Jukka Santala for this fix.
+
+2002-03-16 Carl Worth <cworth@east.isi.edu>
+
+ * configure.ac: Incremented version number to 0.99.9-1.
+
+ * RELEASE_NOTES: Added release notes for 0.99.9-1.
+
+2002-03-15 Carl Worth <cworth@east.isi.edu>
+
+ * configure.ac: Incremented version number to 0.99.9.
+
+ * RELEASE_NOTES: Added release notes for 0.99.9.
+
+ * Makefile.am (bin_PROGRAMS): Install update-alternatives as well.
+
+ * familiar/rules (binary-arch): Mv all of /bin to /usr/bin
+
+ * configure.ac: Incremented version number to 0.99.8.
+
+ * RELEASE_NOTES: Added release notes for 0.99.8.
+
+ * familiar/rules (binary-arch): Fixed to use "make install-strip"
+ rather than "make install" and a strip command.
+
+ * opkg_cmd.c (opkg_install_cmd): Moved an error message up from
+ opkg_install_by_name, (eventually all error messages should come
+ up out of what will become libopkg, (pkg.c, opkg_install.c, etc.)
+ and into opkg_cmd.c and friends).
+ (opkg_upgrade_pkg): Pushed downgrade check down into
+ opkg_install_by_name so that "opkg install foo" will do the
+ downgrade check.
+
+ * opkg.h: Rename some opkg_error_t error codes to be more
+ consistent.
+
+ * opkg_install.c (resolve_conffiles): Added missing removal of
+ backed-up modified conffiles, (which led to bizarre, bogus
+ conffile prompting the next time the package was upgraded).
+ (user_prefers_old_conffile): Fixed reversed arguments to diff in
+ interactive conffiles prompting.
+ (opkg_install_by_name): Fixed "opkg install foo" to never
+ downgrade foo, (just like "opkg upgrade foo").
+
+ * familiar/rules: Added installation of
+ /usr/share/doc/opkg/copyright file. Fixed so that opkg.conf goes
+ to /etc, not /usr/etc, (but still keep binary in /usr/bin not
+ /bin). Changed name of installed binary from opkg-unstable to
+ opkg.
+
+ * familiar/control.in (Package): Changed package name from
+ opkg-unstable to opkg.
+
+ * pkg_parse.c (parseVersion): Fixed to ignore whitespace at
+ beginning of version string.
+ (pkg_parse_raw): Fixed segfault if a package record list ends with
+ a package paragraph without a final blank line.
+
+ * opkg_install.c (check_data_file_clashes): Improved wording of
+ file clash error message.
+
+ * opkg_download.c (opkg_download_pkg): Fixed segfault if package
+ has no src, (occurs if package had benn installed locally, then
+ was removed (but not purged), then tried to reinstall eithout it
+ existing in any /usr/lib/opkg/lists/* file).
+
+ * etc/opkg.conf: Added a default opkg.conf to the distribution.
+
+2002-03-13 Carl Worth <cworth@east.isi.edu>
+
+ * configure.ac: Incremented version to 0.99.7.
+
+ * RELEASE_NOTES: Added release notes for 0.99.7.
+
+ * pkg.c (pkg_run_script): Added support to export
+ OPKG_OFFLINE_ROOT. This is really a nasty hack as it means scripts
+ need to be modified to check OPKG_OFFLINE_ROOT. I'd really prefer
+ coming up with a good, reliable chroot system. But for now this
+ will let update-alternatives work, (which already does examine
+ OPKG_OFFLINE_ROOT).
+ (pkg_run_script): Added missing brace.
+
+ * opkg_conf.c (opkg_conf_init): Reworked significantly to properly
+ set up the pkg_dest_list stuff to account for offline_root.
+
+ * args.c (args_parse): Added support for -force_defaults in
+ addition to -force-defaults, etc. as I kept mistyping these
+ somehow.
+
+2002-03-12 Carl Worth <cworth@east.isi.edu>
+
+ * configure.ac: Incremented version to 0.99.6.
+
+ * RELEASE_NOTES: Added release notes for 0.99.6.
+
+ * opkg_download.c (opkg_download): Fixed bug in handling of
+ "file://" URLs.
+
+ * opkg.c (main): Fixed to abort if opkg_conf_init fails.
+
+ * opkg_conf.c (opkg_conf_init): Fixed to complain if given an
+ unknown dest.
+
+ * pkg.c (pkg_print_field): Fixed several fields to not print if
+ NULL, (Architecture. Maintainer, Size, Filename, Description)
+
+ * args.c (args_parse): Fixed bug that was always setting
+ force_removal_of_essentail_packages (yikes!).
+
+ * configure.ac: Incremented version to 0.99.5.
+
+ * RELEASE_NOTES: Added release notes for 0.99.5.
+
+ * familiar/rules (binary-arch): Added strip back in in preparation
+ of non-unstable release of opkg.
+
+ * str_util.c (str_starts_with): Added convenience function.
+
+ * pkg_extract.c (pkg_extract_data_file_names_to_file): Fixed
+ filenames in *.list files to be compatible with dpkg and the old
+ opkg, (no prefix of "." for example).
+
+ * pkg.c (pkg_run_script): Added export of PKG_ROOT for the benefit
+ of maintainer scripts.
+
+ * opkg_remove.c (opkg_remove_pkg): Complain and abort if user
+ attempts to remove an essential package, (also inform them of the
+ force option if they insist).
+
+ * opkg_install.c (opkg_install_pkg): Added message about whether
+ installing or upgrading.
+
+ * opkg_download.c (opkg_download): Added support for "file://"
+ URLs, (untested).
+ (opkg_download): Added support for wget proxy options.
+
+ * opkg_conf.c (opkg_conf_init): Added proxy support to opkg_conf,
+ (http_proxy, ftp_proxy, no_proxy, proxy_user, and proxy_passwd).
+
+ * opkg_cmd.c (opkg_upgrade_pkg): Moved Upgrading message from
+ opkg_upgrade_cmd to opkg_install_pkg.
+
+ * args.c (args_parse): Added new option
+ -force-removal-of-essential-packages, (which is intentionally
+ painful to type and not listed in usage. It should not be used
+ often).
+
+2002-03-11 Carl Worth <cworth@east.isi.edu>
+
+ * configure.ac: Incremented version to 0.99.3.
+
+ * RELEASE_NOTES: Added release notes for 0.99.3.
+
+ * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Fixed
+ to avoid infinite loop in the case of a circular dependency.
+
+ * configure.ac: Incremented version to 0.99.2.
+
+ * RELEASE_NOTES: Added release notes for 0.99.2.
+
+ * familiar/rules: Commented out strip, (temporary until this beast
+ is deemed more stable).
+
+ * xsystem.c (xsystem): Cleaned up error message, (missing
+ newline).
+
+ * pkg.c (pkg_merge): Made pkg_merge a NOP if oldpkg == newpkg.
+ (pkg_print_field): Don't print MD5sum field if NULL.
+
+ * opkg_install.c (satisfy_dependencies_for): Now returns error
+ status if one or more of the dependencies fail to install cleanly.
+ (unpack_pkg_control_files): Fixed to not tack on a bunch of
+ NULL-valued conffiles entries if non-NULL conffiles already
+ exist. This fixed the errant prompting for unmodified conffiles
+ during -force-reinstall.
+ (unpack_pkg_control_files): Cleaned up conffile filenames to not
+ have ugly things like "///" inside them.
+
+ * opkg_download.c (opkg_download): Cleaned up error message.
+ (opkg_download): Now uses new file_move function.
+ (opkg_download_pkg): Created new function, (from old code in opkg_install).
+
+ * opkg_cmd.c (opkg_download_cmd): Added new "opkg download"
+ command.
+
+ * file_util.c (file_move): Created file_move, (from code that had
+ been in opkg_download).
+ (file_copy): Added error message on failure.
+
+ * conffile.c (conffile_has_been_modified): Eliminated crash if
+ conffile_has_been_modified is called with conffile->value == NULL.
+
+2002-03-09 Carl Worth <cworth@east.isi.edu>
+
+ * RELEASE_NOTES: Added release notes for 0.99.1
+
+ * configure.ac: Incremented version to 0.99.1
+
+ * pkg_hash.c (pkg_hash_pkg_owning_file): Fixed to actually return
+ NULL if no package owns a file.
+
+ * pkg.c (pkg_get_installed_files): Added installed_files_ref_cnt
+ to pkg_t to prevent pkg->installed_files from being freed from an
+ inner loop while still being used by an outer loop, (which was
+ happening).
+
+ * pkg_hash.c (pkg_hash_pkg_owning_file): Moved this function in
+ from pkg_dest.c. Also, updated it to use pkg_get_installed rather
+ than mucking around inside /usr/lib/opkg and globbing for *.list
+ files.
+ (pkg_hash_fetch_best_installation_candidate): Fixed to only return
+ a package that actually could be installed, (ie. it must have
+ either a local_filename or a non-NULL src from which it could be
+ downloaded). This prevents a segfault during "opkg upgrade".
+
+ * pkg.c (pkg_get_installed_files): Fixed to not do strange things
+ to filenames such as: "//./bin/sh"
+
+ * opkg_cmd.c (opkg_files_cmd): Added pkg_free_installed_files to
+ conserve a bit of memory.
+ (opkg_search_cmd): Updated to use pkg_get_installed rather than
+ mucking around inside /usr/lib/opkg and globbing for *.list files.
+
+ * pkg.c (pkg_free_installed_files): Added this function to free up
+ memory from pkg_get_installed_files.
+
+ * opkg_conf.c (opkg_conf_set_option): Added force_reinstall option
+ to allow reinstallation of an installed package.
+
+ * args.c (args_parse): Added -force-reinstall option to enable
+ reinstallation of an installed package.
+
+ * busybox-0.60.2/ar.c (ar_main): Updated unarchive call to track
+ prototype change.
+
+ * busybox-0.60.2/libbb/unarchive.c (free_header_ar): Added
+ function to plug memory leak.
+
+ * opkg_install.c (check_data_file_clashes): Fixed crash if no
+ package can be found owning the pre-existing file.
+
+ * pkg_dest.c (pkg_dest_deinit): Fixed bug that pkg_dest was
+ holding on to freed data rather than making a local copy.
+
+ * pkg_depends.c (freeDepends): Fixed crash when pkg->depends is NULL.
+
+ * RELEASE_NOTES: Added release notes for 0.98.0 and 0.99.0.
+
+ * busybox-0.60.2/libbb/unarchive.c (extract_archive): Fixed
+ bug. Always alloc memory for full_name so we don't free data that
+ we shouldn't.
+ (unarchive): Updated to accept a free_headers function pointer as
+ a counterpart to get_headers, to eliminate memory leaks.
+ (free_header_tar): Implemented cleanup function as counterpart to
+ get_header_tar, to eliminate memory leaks.
+ (deb_extract): Added several calls to free_header_tar to eliminate
+ memory leaks.
+
+ * str_util.c (str_dup_safe): Added convenience function. Like
+ strdup, but safe to use on a NULL pointer.
+
+ * pkg_vec.c (pkg_vec_insert): Updated to use new pkg.c:pkg_merge
+ rather than marry_two_packages. With this change the free(pkg) is
+ now here rather than one level deeper. Eventually, I want to get
+ this free(pkg) up and out of pkg_hash_insert.
+
+ * pkg_parse.c (parseDependsString): Fixed bug walking off the end
+ of the raw buffer looking for a character that isspace().
+ (parseConffiles): Fixed big bug parsing Conffiles field where all
+ conffiles appear on the same line.
+
+ * pkg_hash.c (pkg_hash_add_from_file): Plugged memory leak of data
+ allocated deep down in read_raw_pkgs_from_file.
+
+ * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Plugged
+ memory leak, (missing pkg_vec_deinit).
+ (freeDepends): Added this function as the counterpart to
+ buildDepends. Getting closer to chasing down all memory leaks.
+ (depend_deinit): Added this function as the counterpart to
+ depend_init. Getting closer to chasing down all memory leaks.
+ (parseDepends): plugged memory leak of pkg_name.
+
+ * pkg.c (pkg_deinit): Added pkg_deinit to take care of freeing any
+ memory owned by a pkg_t.
+ (pkg_init_from_file): This function was 100% broken, (missing
+ rewind).
+ (pkg_merge): Moved pkg_merge here from
+ pkg_vec.c:marry_two_packages. Started work to make it
+ non-destructive, (not finished).
+ (pkg_print_info): Added Status and Essential fields to
+ pkg_print_info.
+ (pkg_print_status): Fixed pkg_print_status to work whether or not
+ the package is installed.
+
+ * opkg_utils.c (read_raw_pkgs_from_file): Moved fclose out of
+ read_raw_pkgs_from_stream and into this function where it belongs,
+ (since the fopen occurs here).
+ (trim_alloc): Fixed trim to not free data passed in. Changed the
+ name to make it obvious that it is allocating memory.
+
+ * opkg_install.c (opkg_install_from_file): Fixed to be more robust
+ to the fact that hash_insert_pkg sometimes frees the data that I
+ pass into it (!).
+ (satisfy_dependencies_for): Cosmetic change to messages.
+ (satisfy_dependencies_for): Now sets the dest on to-be-installed
+ packages, so that the state_want flag can be written to a status
+ file if necessary.
+ (satisfy_dependencies_for): Added pkg_vec_deinit to plug memory
+ leak.
+ (opkg_install_pkg): Added "run opkg update?" hint to error
+ message.
+ (backup_modified_conffiles): Made more robust to the case that a
+ conffile has disappeared.
+ (install_maintainer_scripts): Fixed bug that was installing
+ maintainer scripts as libFoopostinst rather than
+ libFoo.postinst. This was preventing postinst scripts from being
+ executed.
+ (cleanup_temporary_files): Added missing closedir to plug a memory
+ leak.
+
+ * opkg_download.c (opkg_download): Cosmetic change to error
+ messages.
+
+ * opkg_conf.c (opkg_conf_parse_file): Plugged some small memory
+ leaks.
+ (opkg_conf_set_option): Changed configuration options from
+ force-depends, force-defaults to force_depdends, force_defaults to
+ be compatible with old opkg.conf files.
+ (opkg_conf_set_option): Fixed bug in parsing options.
+ (opkg_conf_write_status_files): Fixed to list all interesting
+ packages, (any with non-default state), in status file rather than
+ just installed files.
+ (opkg_conf_write_status_files): Plugged a memory leak.
+
+ * opkg_cmd.c (opkg_status_cmd): Changed "opkg status" to use
+ pkg_print_info so it is much more verbose, (includes fields such
+ as Maintainer, etc. that are merged in from the lists files).
+
+ * opkg.h (OPKG_DEBUG_NO_TMP_CLEANUP): Added compile-time option to
+ preserve temporary files for easier debugging.
+
+ * file_util.c (file_md5sum_alloc): cosmetic changes to variable
+ names.
+
+ * opkg_conf.c (opkg_conf_init): Added support for offline_root
+ configuration file option.
+
+ * args.c (args_init): Added support for -o, -offline,
+ -offline-root command-line arguments. (Although they don't really
+ have any effect yet).
+
+ * opkg_install.c (opkg_install_pkg): Changed back to marking
+ package as installed before postinst, (the pkg_run_script wanted
+ to find the scripts in /usr/lib/opkg/info). Actually, it could
+ probably find the script in either place at this point so maybe it
+ doesn't really matter.
+
+2002-03-07 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_install.c (opkg_install_pkg): Changed to only mark package
+ as installed after running opkg_configure, (to run the postinst
+ script).
+
+ * RELEASED opkg-unstable 0.99.0
+
+ * Updated all instances of "XXX" in the code to indicate one of
+ the following categories:
+ XXX: BUG: This is a bug that needs to be fixed.
+ XXX: QUESTION: Implementation approach is uncertain here.
+ XXX: CLEANUP: Suggestion on how the code could be cleaned up.
+ XXX: FEATURE: Comment describes a useful feature request.
+
+ * pkg.c (pkg_print_status): Added the Depends field to package
+ paragraphs in the status file, ("opkg remove" will need this).
+
+ * opkg_install.c (satisfy_dependencies_for): Fixed "opkg install"
+ to not complain several times about "Package foo already
+ installed" when doing large recursive installs.
+ (opkg_install_pkg): "opkg install foo" for an installed package
+ will now check and install any missing dependencies before exiting
+ with "Package foo is alrady installed."
+
+2002-03-06 Carl Worth <cworth@east.isi.edu>
+
+ * pkg_dest.c (pkg_dest_pkg_owning_file_alloc): Moved this function
+ here from opkg_install.c. Also plugged a memory leak in it with
+ globfree.
+
+ * pkg.c (pkg_remove_installed_files_list): Fixed bug that
+ prevented package.list file from ever being removed during "opkg
+ remove".
+
+ * opkg_remove.c (remove_data_files_and_list): Fixed noisy and
+ spurious warnings about non-empty directories. "opkg remove"
+ should now only say anything if a directory that was solely
+ provided by that package is non-empty.
+
+ * opkg_cmd.c (opkg_install_pending_cmd): Plugged memory leak with
+ globfree.
+
+ * opkg_install.c: *Many* fixes to enable "opkg upgrade" to more or
+ less work. Primarily fixing file clash identification and conffile
+ handling/resolution. "opkg upgrade" has now worked correctly on
+ several test cases!
+
+ * opkg_install.c (unpack_pkg_control_files): Now initializes
+ conffiles list from the contents of conffiles control file,
+ (leaves md5sum calculation until the actual conffiles are
+ extracted later).
+ (opkg_install_pkg): Separated backup_modified_conffiles and
+ check_data_file_clashes into separate functions.
+ (preinst_configure): Simplified this function pushing its old
+ logic into pkg.c:pkg_run_script.
+ (backup_modified_conffiles): Added backup of any conffiles that
+ are new as of this upgrade.
+ (check_data_file_clashes): First real implementation of
+ check_data_file_clashes.
+ (resolve_conffiles): First real implementation of
+ resolve_conffiles.
+ (backup_make_backup): Added this and a few other functions to
+ abstract backup creation/removal.
+ (find_pkg_owning_file): Added this function.
+
+ * pkg_extract.c (pkg_extract_data_files_to_dir): Fixed args to
+ deb_extract so that existing files will be overwritten, (and any
+ other error messages will no longer be suppressed).
+
+ * pkg.c (pkg_print_status): Added Conffiles field to
+ pkg_print_status.
+ (pkg_print_field): Fixed crash when printing NULL Conffiles
+ values.
+ (pkg_get_conffile): Fixed crash if pkg_get_conffile called with a
+ NULL pkg.
+ (pkg_run_script): Made pkg_run_script smart enough to run scripts
+ for uninstalled packages, (from
+ <pkg_tmp_unpack_dir>/<script_name>), as well as for isntalled
+ packages, (from <dest_info_dir>/<pkg_name>.<script_name>
+
+ * str_util.c (str_tolower): Added convenience function.
+ (str_toupper): Added convenience function.
+
+ * nv_pair.c (nv_pair_init): Fixed crash from calling nv_pair_init
+ with NULL value.
+
+ * pkg.c (pkg_init_from_file): Fixed bug -- forgot to close file.
+
+ * file_util.c (file_md5sum_alloc): Convenience wrapper around
+ md5_stream as ripped out of busybox. This function takes care of
+ file open/close and does the bin2hex conversion of the md5sum.
+
+ * conffile.c (conffile_has_been_modified): Implemented this
+ function for real now that we have md5sum capability.
+
+ * md5.c (md5_stream): Sucked in md5sum calculation code from
+ busybox, (it wasn't part of libbb, so I just copied the files
+ straight in and ripped out uninteresting functions such as
+ md5sum_main, etc.)
+
+2002-03-05 Carl Worth <cworth@east.isi.edu>
+
+ * pkg.c (pkg_print_field): Added support for printing Conffiles
+ field.
+
+ * opkg_install.c (remove_obsolesced_files): With the fixed
+ pkg_get_installed_files_list from below, this function now seems
+ to work!
+ (opkg_install_pkg): Fixed to mark old package as uninstalled after
+ upgrading.
+
+ * pkg.c (pkg_get_installed_files_list): Fixed so that it's
+ possible to get an "installed_files" list even from an uninstalled
+ package, (it pulls the list of data files straight out of the
+ package).
+
+ * opkg_cmd.c (opkg_upgrade_cmd): Fixed opkg_upgrade to not choke
+ if asked to upgrade an un-installed package.
+ (opkg_upgrade_pkg): Fixed printing of version numbers.
+
+ * file_util.c (file_mkdir_hier): Abstracted call to libbb
+ make_directory into new file_mkdir_hier. At this point, the only
+ calls into libbb are isolated in file_util and pkg_extract. This
+ will make it easier if we ever decide to directly incorporate that
+ code or rewrite it.
+
+ * pkg_extract.c (pkg_extract_data_files_to_dir): Abstracted all
+ calls to deb_extract in several new pkg_extract functions.
+
+2002-03-04 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_conf.c (opkg_conf_init): Added support to opkg_conf to
+ pickup command-line arguments for "force-defaults" and
+ "force-depends". Things set on the command-line should take
+ precedence over things found in the configuration file.
+
+ * opkg_cmd.c (opkg_search_cmd): Fixed formatting of "opkg search"
+ output.
+
+ * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies):
+ Re-added fix to set *unresolved to NULL if depends is NULL.
+
+ * xregex.c (xregexec): Removed useless error messages from NOMATCH
+ calls to regexec.
+
+ * opkg_install.c (satisfy_dependencies_for): Added support for new
+ "unresolved" argument in
+ pkg_hash_fetch_unsatisfied_dependencies. Cleaned up warning/error
+ messages.
+
+ * opkg_cmd.c (opkg_search_cmd): Implemented first-cut of "opkg search".
+
+ * pkg_depends.c (pkg_hash_fetch_unsatisfied_dependencies): Fixed
+ to set *unresolved to NULL if depends is NULL.
+
+2002-03-01 Carl Worth <cworth@east.isi.edu>
+
+ * RELEASED opkg-unstable 0.98.0
+
+ * opkg_configure.c (opkg_configure): Added flushing of stdout,
+ (here and in a few other modules).
+
+ * file_util.c (file_copy): Implemented this function here as one
+ step toward isolating the calls into libbb functions. Updated old
+ copy_file calls to file_copy in both opkg_download.c and
+ opkg_install.c.
+
+ * opkg_install.c, opkg_remove.c: Demoted several "XXX" comments to
+ DPKG_INCOMPATIBILITY as I really don't intend on addressing them
+ any time soon, (if ever).
+
+ * opkg_cmd.c (opkg_files_cmd): Fixed "opkg files" from crashing on
+ uninstalled packages.
+
+ * familiar/rules: Added support for easy building of an
+ opkg.ipk. The version number and the architecture are
+ automatically sucked in correctly from autoconf magic, (even when
+ cross-compiling). Maybe autoconf will start paying off with
+ benefits rather than pain, (finally!).
+
+ * configure.ac: Removed MEMCMP and STAT checks which were breaking
+ cross-compilation.
+
+ * opkg_cmd.c (opkg_upgrade_pkg): BIG bugfix: Package version
+ comparison was sign-reversed, (hence it would never upgrade).
+
+2002-02-28 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_download.c (opkg_download): Changed from
+ system("/bin/cp",...) to copy_file(...)
+
+ * replace/strndup.c: Implemented an (untested) replacement for
+ strndup.
+
+ * configure.ac: Added AC_CANONICAL_HOST to automatically set the
+ correct architecture type in the opkg control file.
+
+ * configure.ac: Changed version number to 0.98.0 in preparation
+ for alpha release.
+
+ * familiar/rules: Added support for easy building of an opkg.ipk.
+
+2002-02-27 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_install.c (opkg_install_pkg): Fixed to abort on failed
+ download.
+
+ * pkg.c (pkg_run_script): Fixed bug that was preventing any
+ package maintainer scripts from running, (hence, they run now so
+ running non-native offline no longer works until I figure out the
+ chroot plans).
+
+ * TODO: Added rough outline of remaining features with a release
+ schedule.
+
+ * pkg_parse.c (pkg_parse_raw): Added parsing of "MD5Sum" in
+ addition to "MD5sum" to accomodate bug in old opkg.
+
+ * void_list.c (void_list_remove): Added new remove function, (also
+ adjusts a forward iterator). Required new list->pre_head member
+ which was added to all sub-list types.
+
+ * pkg.c (pkg_init): Changed pkg->conffiles to be of the new
+ conffile_list_t datatype.
+ (pkg_remove_installed_files_list): Pulled this function into
+ pkg.c, (from opkg_remove.c), so the mallocs and frees would be in
+ the same C file.
+ (pkg_get_conffile): Added this convenience function.
+
+ * opkg_remove.c: Fixed several bugs. opkg_remove now actually
+ works for simple packages!
+
+ * opkg_install.c (opkg_install_pkg): Don't re-install if a package
+ is already installed.
+ (opkg_install_pkg): Fixed major bug that all of opkg_install's
+ work was always being unwound even when successful.
+
+ * opkg_cmd.c (opkg_files_cmd): Fixed to use
+ pkg_get_installed_files_list rather than a private implementation
+ that sifted through the file lists on disk.
+
+ * str_util.c (str_ends_with): Added this convenient function.
+ (str_chomp): Another convenience.
+
+ * opkg_conf.c: Moved chomp to str_util.c (str_chomp), since
+ someone else wanted it too.
+
+2002-02-26 Carl Worth <cworth@east.isi.edu>
+
+ * pkg_parse.c (pkg_parse_raw): Added XXX requesting parsing of
+ Conffiles: field along with a hint about how to store the data.
+
+ * conffile_list.c: Added a little wrapper around nv_pair_list
+
+ * conffile.c: Added a little wrapper around nv_pair
+
+ * str_util.c (str_ends_with): New convenience function.
+
+ * str_list.c (str_list_remove): Plugged in remove function.
+
+ * void_list.c (void_list_remove): Added remove function, (handles
+ updating of forward iterator).
+
+ * pkg.c (pkg_run_script): Changed to return return value of
+ script.
+
+ * opkg_remove.c: Fleshed out initial version of all opkg_remove.c
+ functions.
+
+ * opkg_configure.c (opkg_configure): Added check on return value
+ of pkg_run script. Added comments about dpkg compliance.
+
+ * opkg_cmd.c (opkg_purge_cmd): Added opkg_purge_cmd
+
+2002-02-20 Carl Worth <cworth@east.isi.edu>
+
+ * Added USC copyright statements, (and Compaq stubs as necessary)
+
+ * opkg_install.c: At this point "opkg install" on a simple
+ package, (no scripts and no dependencies), works just fine. It
+ might even do some of the script and dependency handling correctly
+ too, but I haven't tested that yet. "opkg install libc6" is a nice
+ little test that should complete without any errors or
+ warnings. Follow that up with "opkg status" to see that it worked.
+
+ * pkg.c (pkg_run_script): Added convenience method for running
+ package scripts.
+
+ * opkg_install.c: Fixed several bugs:
+ (unpack_pkg_control_files): control files now extract to the
+ correct temporary directory.
+ (opkg_install_pkg): pkg->state_want is now properly set to SW_INSTALL
+ (opkg_install_pkg): status file now gets written after installation
+ (cleanup_temporary_files): All temporary files are cleaned up.
+
+ * opkg_configure.c (opkg_configure): Fleshed out a very simple
+ opkg_configure, (simply runs "postinst configure"). Maybe it will
+ need to be smarter at some point. Moved unwritten conffiles stuff
+ back to opkg_install.c.
+
+ * opkg_conf.c (opkg_conf_write_status_files): Moved this function
+ from opkg_utils to opkg_conf since it needs access to the
+ pkg_dest_list.
+
+ * pkg_vec.c (marry_two_packages): Added several missing fields,
+ (state_want, state_flag, filename, local_filename, tmp_unpack_dir,
+ md5sum, size, installed_size, priority, source, conffiles,
+ isntalled_files, essential)
+
+2002-02-19 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_install.c: several little bug fixes. "opkg install" will
+ now actually install files from a package! There are still some
+ bugs, (eg. postinst scripts are not called -- probably other
+ things as well). But, it's coming together now.
+
+ * pkg_dest.c (pkg_dest_init): now creates all necessary directories
+
+ * opkg_download.c (opkg_download): Fixed misleading parameter name.
+
+ * opkg_conf.c (opkg_conf_deinit): Now cleans up tmd_dir on deinit
+ opkg.c: now calls opkg_conf_deinit before exiting.
+ (opkg_conf_add_nv): Fixed to set default_dest when parsing first
+ dest in opkg.conf
+
+ * opkg_cmd.c (opkg_list_cmd): Fixed ugly bug in opkg_list that led
+ to infinite loops, segfaults, string corruption, and other bizarre
+ behavior.
+
+ * Added many files as we are approaching the first functional opkg
+ implementation in C:
+ file_util.c: convenience for testing if file_exists, reading files, etc.
+ opkg_configure.c: mostly just a stub so far
+ opkg_download.c: convenient function to download a file
+ nv_pair.c: data structure to hold a name-value pair
+ nv_pair_list.c: data structure to hold a list of nv_pair_t
+ pkg_dest.c: data structure for everything a pkg destination wants
+ pkg_dest_list.c: data structure to hold a list of pkg_dest_t
+ pkg_extract.c: convenience functions for package extraction,
+ (these function should encapsulate any libbb borrowings we perform
+ -- although some slipped into other files already)
+ pkg_src.c: everything you might need for a pkg src.
+ pkg_src_list.c: data structure to hold a list of pkg_src_t
+ str_list.c: data structure to hold a list of char *
+ void_list.c: generic linked-list data structure and functions
+ xsystem.c: wrapper around system() with error checking
+
+ * opkg_remove.c: Just added some stubs. Nothing really works at
+ all yet.
+
+ * opkg_install.c: Large rework of opkg_install. It's now close to
+ actually being usable, (but it's not quite there yet). Revamped to
+ match dpkg install order more closely, (with all the stubs in case
+ we ever want to call all the scripts that dpkg does). Also updated
+ to use a more recent deb_extract from libbb.
+
+ * opkg_extract_test.c (main): Added support for a third arg, (the
+ filename to extract to the buffer).
+
+ * opkg_conf.c (opkg_conf_init): Added several fields to
+ opkg_conf_t: pkg_src_list, pkg_dest_list ,
+ restrict_to_default_dest, default_dest, tmp_dir, lists_dir,
+ pending_dir, force_depends, and pkg_hash. There's still a bit of
+ tension between options stored in the config file, (opkg_conf_t),
+ and command-line arguments, (args_t).
+
+ * opkg_cmd.c: First version that is approaching usability. The
+ following commands are more-or-less in place: "opkg update", "opkg
+ list", "opkg info", "opkg status". While the rest are in various
+ states of being partiallyy written or written but untested.
+ (opkg_upgrade_cmd): Added support for restricting to a dest. Many
+ other changes, largely involving plugging into the pkg_hash for
+ real for the first time, and adding multiple dest support.
+
+ * opkg.c: Added support for setting the dest on the command-line.
+
+ * args.c: Added support for OPKG_CONF_DIR environment variable and
+ -f, -conf, and -conf-file options.
+
+ * configure.ac: Added lots of little bits suggested by autoscan.
+
+2002-02-18 Carl Worth <cworth@east.isi.edu>
+
+ * pkg_parse.c (pkg_parse_raw): Added parsing, (kinda ugly), for
+ essential field.
+ * pkg.c (pkg_print_field): Added the essential flag.
+
+ * pkg_vec.c (pkg_vec_insert): Fixed to use pkg_compare_versions to
+ determine matching versions instead of a strcmp on the version
+ string.
+
+2002-02-15 Carl Worth <cworth@east.isi.edu>
+
+ * pkg_parse.c (pkg_parse_raw): Updated to accept a pkg_src_t
+
+ * pkg.c (pkg_init): Added field to pkg_t: "pkg_src_t *src"
+
+ * pkg_hash.c (pkg_hash_add_from_file): Updated to accept a pkg_src_t
+
+ * pkg_parse.c (parseStatus): Modified to accept a pkg_t *
+ (parseVersion): Added this function
+ (pkg_parse_raw): Updated to accept a pkg_dest_t
+ (pkg_parse_raw): Reworked the parsing to use a pkg_t rather than a
+ slew of local variables.
+ (pkg_parse_raw): Added support for about a dozen new pkg_t fields
+
+ * pkg.h: Updated for all pkg.c changes.
+
+ * pkg.c (pkg_new): Added pkg_new for convenient alloc'ing of a pkg_t.
+ (pkg_init): Added several fields to pkg_t: dest, section,
+ suggests, filename, local_filename, tmp_unpack_dir, md5sum, size,
+ installed_size, priority, source, and conffiles.
+ (): Moved buildPkg this function to pkg_parse
+ (pkg_init_from_file): Added convenience function for filling a
+ pkg_t from an actual package file.
+ (pkg_print_info): Split print_pkg into both pkg_print_info and
+ pkg_print_status.
+ (pkg_print_field): Added pkg_print_field, (extremely ugly)
+ (): Moved parseversion to pkg_parse where it belongs
+ (pkg_version_str_alloc): Added, (complement of parse_version)
+
+ * pkg_depends.h: Added GPL blurb
+ (PKG_DEPENDS_H): Added multiple include protection
+
+ * pkg_depends.c: Moved non-static prototypes to header file.
+ Changed several locl-only functions to be static.
+ Added function prototypes for static functions.
+ (buildDepends): Removed unecessary cast of malloc return value.
+
+ * pkg_hash.h: Moved hash-related struct declarations to this file
+ Rename pkg_fetch* to have consistent pkg_hash_fetch prefix.
+ Added missing prototype for pkg_vec_fetch_by_name
+
+ * pkg_hash.c: (pkg_hash_add_from_file): Added support for setting
+ the pkg_dest
+ (pkg_hash_add_from_file): Moved buildDepends call to
+ hash_insert_pkg
+ (pkg_hash_fetch_installed_by_name_dest): Added this function to
+ support pkg_dest
+
+ * opkg_utils.h: Added GPL blurb
+ (OPKG_UTILS_H): Added multiple include protection
+
+ * opkg_utils.c:
+ (read_raw_pkgs_from_file): broke read_raw_pkgs into
+ read_raw_pkgs_from_file and read_raw-pkgs_from_stream
+ (opkg_write_status_file): Fixed return value
+ (print_pkg_status): Moved this function to pkg.c:pkg_print_status
+ (line_is_blank): Fixed const char handling
+
+2002-02-08 Carl Worth <cworth@east.isi.edu>
+
+ * pkg_parse.c: Fixed a bug in parsing the 3 state fields.
+
+2002-02-06 Carl Worth <cworth@east.isi.edu>
+
+ * pkg.c: Expanded pkg_status field to the full 3 fields: state_want,
+ state_flag, and state_status.
+
+2001-12-11 Carl Worth <cworth@east.isi.edu>
+
+ * opkg_conf.c: Now parses /etc/opkg.conf, (and doesn't do anything
+ with it).
+
+ * opkg.c: Started work on opkg main, (not much here yet).
+
+ * opkg_cmd.h: Added a tiny thing to abstract top-level opkg
+ commands, (not finished).
+
+ * Set up autoconf and friends
diff --git a/autogen.sh b/autogen.sh
new file mode 100755
index 0000000..73b2179
--- /dev/null
+++ b/autogen.sh
@@ -0,0 +1,5 @@
+#! /bin/sh
+autoreconf -v --install || exit 1
+glib-gettextize --force --copy || exit 1
+./configure --enable-maintainer-mode "$@"
+
diff --git a/compile b/compile
deleted file mode 100755
index 3d21703..0000000
--- a/compile
+++ /dev/null
@@ -1,142 +0,0 @@
-#! /bin/sh
-# Wrapper for compilers which do not understand `-c -o'.
-
-scriptversion=2004-10-12.08
-
-# Copyright (C) 1999, 2000, 2003, 2004 Free Software Foundation, Inc.
-# Written by Tom Tromey <tromey@cygnus.com>.
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# This file is maintained in Automake, please report
-# bugs to <bug-automake@gnu.org> or send patches to
-# <automake-patches@gnu.org>.
-
-case $1 in
- '')
- echo "$0: No command. Try \`$0 --help' for more information." 1>&2
- exit 1;
- ;;
- -h | --h*)
- cat <<\EOF
-Usage: compile [--help] [--version] PROGRAM [ARGS]
-
-Wrapper for compilers which do not understand `-c -o'.
-Remove `-o dest.o' from ARGS, run PROGRAM with the remaining
-arguments, and rename the output as expected.
-
-If you are trying to build a whole package this is not the
-right script to run: please start by reading the file `INSTALL'.
-
-Report bugs to <bug-automake@gnu.org>.
-EOF
- exit 0
- ;;
- -v | --v*)
- echo "compile $scriptversion"
- exit 0
- ;;
-esac
-
-ofile=
-cfile=
-eat=
-
-for arg
-do
- if test -n "$eat"; then
- eat=
- else
- case $1 in
- -o)
- # configure might choose to run compile as `compile cc -o foo foo.c'.
- # So we strip `-o arg' only if arg is an object.
- eat=1
- case $2 in
- *.o | *.obj)
- ofile=$2
- ;;
- *)
- set x "$@" -o "$2"
- shift
- ;;
- esac
- ;;
- *.c)
- cfile=$1
- set x "$@" "$1"
- shift
- ;;
- *)
- set x "$@" "$1"
- shift
- ;;
- esac
- fi
- shift
-done
-
-if test -z "$ofile" || test -z "$cfile"; then
- # If no `-o' option was seen then we might have been invoked from a
- # pattern rule where we don't need one. That is ok -- this is a
- # normal compilation that the losing compiler can handle. If no
- # `.c' file was seen then we are probably linking. That is also
- # ok.
- exec "$@"
-fi
-
-# Name of file we expect compiler to create.
-cofile=`echo "$cfile" | sed -e 's|^.*/||' -e 's/\.c$/.o/'`
-
-# Create the lock directory.
-# Note: use `[/.-]' here to ensure that we don't use the same name
-# that we are using for the .o file. Also, base the name on the expected
-# object file name, since that is what matters with a parallel build.
-lockdir=`echo "$cofile" | sed -e 's|[/.-]|_|g'`.d
-while true; do
- if mkdir "$lockdir" >/dev/null 2>&1; then
- break
- fi
- sleep 1
-done
-# FIXME: race condition here if user kills between mkdir and trap.
-trap "rmdir '$lockdir'; exit 1" 1 2 15
-
-# Run the compile.
-"$@"
-ret=$?
-
-if test -f "$cofile"; then
- mv "$cofile" "$ofile"
-elif test -f "${cofile}bj"; then
- mv "${cofile}bj" "$ofile"
-fi
-
-rmdir "$lockdir"
-exit $ret
-
-# Local Variables:
-# mode: shell-script
-# sh-indentation: 2
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "scriptversion="
-# time-stamp-format: "%:y-%02m-%02d.%02H"
-# time-stamp-end: "$"
-# End:
diff --git a/config.guess b/config.guess
deleted file mode 100755
index ad5281e..0000000
--- a/config.guess
+++ /dev/null
@@ -1,1466 +0,0 @@
-#! /bin/sh
-# Attempt to guess a canonical system name.
-# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
-# 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
-
-timestamp='2005-08-03'
-
-# This file is free software; you can redistribute it and/or modify it
-# under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-# General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
-# 02110-1301, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-
-# Originally written by Per Bothner <per@bothner.com>.
-# Please send patches to <config-patches@gnu.org>. Submit a context
-# diff and a properly formatted ChangeLog entry.
-#
-# This script attempts to guess a canonical system name similar to
-# config.sub. If it succeeds, it prints the system name on stdout, and
-# exits with 0. Otherwise, it exits with 1.
-#
-# The plan is that this can be called by configure scripts if you
-# don't specify an explicit build system type.
-
-me=`echo "$0" | sed -e 's,.*/,,'`
-
-usage="\
-Usage: $0 [OPTION]
-
-Output the configuration name of the system \`$me' is run on.
-
-Operation modes:
- -h, --help print this help, then exit
- -t, --time-stamp print date of last modification, then exit
- -v, --version print version number, then exit
-
-Report bugs and patches to <config-patches@gnu.org>."
-
-version="\
-GNU config.guess ($timestamp)
-
-Originally written by Per Bothner.
-Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
-Free Software Foundation, Inc.
-
-This is free software; see the source for copying conditions. There is NO
-warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
-
-help="
-Try \`$me --help' for more information."
-
-# Parse command line
-while test $# -gt 0 ; do
- case $1 in
- --time-stamp | --time* | -t )
- echo "$timestamp" ; exit ;;
- --version | -v )
- echo "$version" ; exit ;;
- --help | --h* | -h )
- echo "$usage"; exit ;;
- -- ) # Stop option processing
- shift; break ;;
- - ) # Use stdin as input.
- break ;;
- -* )
- echo "$me: invalid option $1$help" >&2
- exit 1 ;;
- * )
- break ;;
- esac
-done
-
-if test $# != 0; then
- echo "$me: too many arguments$help" >&2
- exit 1
-fi
-
-trap 'exit 1' 1 2 15
-
-# CC_FOR_BUILD -- compiler used by this script. Note that the use of a
-# compiler to aid in system detection is discouraged as it requires
-# temporary files to be created and, as you can see below, it is a
-# headache to deal with in a portable fashion.
-
-# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still
-# use `HOST_CC' if defined, but it is deprecated.
-
-# Portable tmp directory creation inspired by the Autoconf team.
-
-set_cc_for_build='
-trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ;
-trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ;
-: ${TMPDIR=/tmp} ;
- { tmp=`(umask 077 && mktemp -d -q "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } ||
- { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } ||
- { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } ||
- { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ;
-dummy=$tmp/dummy ;
-tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
-case $CC_FOR_BUILD,$HOST_CC,$CC in
- ,,) echo "int x;" > $dummy.c ;
- for c in cc gcc c89 c99 ; do
- if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
- CC_FOR_BUILD="$c"; break ;
- fi ;
- done ;
- if test x"$CC_FOR_BUILD" = x ; then
- CC_FOR_BUILD=no_compiler_found ;
- fi
- ;;
- ,,*) CC_FOR_BUILD=$CC ;;
- ,*,*) CC_FOR_BUILD=$HOST_CC ;;
-esac ; set_cc_for_build= ;'
-
-# This is needed to find uname on a Pyramid OSx when run in the BSD universe.
-# (ghazi@noc.rutgers.edu 1994-08-24)
-if (test -f /.attbin/uname) >/dev/null 2>&1 ; then
- PATH=$PATH:/.attbin ; export PATH
-fi
-
-UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown
-UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
-UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
-UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
-
-# Note: order is significant - the case branches are not exclusive.
-
-case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
- *:NetBSD:*:*)
- # NetBSD (nbsd) targets should (where applicable) match one or
- # more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*,
- # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently
- # switched to ELF, *-*-netbsd* would select the old
- # object file format. This provides both forward
- # compatibility and a consistent mechanism for selecting the
- # object file format.
- #
- # Note: NetBSD doesn't particularly care about the vendor
- # portion of the name. We always set it to "unknown".
- sysctl="sysctl -n hw.machine_arch"
- UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \
- /usr/sbin/$sysctl 2>/dev/null || echo unknown)`
- case "${UNAME_MACHINE_ARCH}" in
- armeb) machine=armeb-unknown ;;
- arm*) machine=arm-unknown ;;
- sh3el) machine=shl-unknown ;;
- sh3eb) machine=sh-unknown ;;
- *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
- esac
- # The Operating System including object format, if it has switched
- # to ELF recently, or will in the future.
- case "${UNAME_MACHINE_ARCH}" in
- arm*|i386|m68k|ns32k|sh3*|sparc|vax)
- eval $set_cc_for_build
- if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
- | grep __ELF__ >/dev/null
- then
- # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout).
- # Return netbsd for either. FIX?
- os=netbsd
- else
- os=netbsdelf
- fi
- ;;
- *)
- os=netbsd
- ;;
- esac
- # The OS release
- # Debian GNU/NetBSD machines have a different userland, and
- # thus, need a distinct triplet. However, they do not need
- # kernel version information, so it can be replaced with a
- # suitable tag, in the style of linux-gnu.
- case "${UNAME_VERSION}" in
- Debian*)
- release='-gnu'
- ;;
- *)
- release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
- ;;
- esac
- # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
- # contains redundant information, the shorter form:
- # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
- echo "${machine}-${os}${release}"
- exit ;;
- *:OpenBSD:*:*)
- UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE}
- exit ;;
- *:ekkoBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
- exit ;;
- macppc:MirBSD:*:*)
- echo powerppc-unknown-mirbsd${UNAME_RELEASE}
- exit ;;
- *:MirBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
- exit ;;
- alpha:OSF1:*:*)
- case $UNAME_RELEASE in
- *4.0)
- UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'`
- ;;
- *5.*)
- UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'`
- ;;
- esac
- # According to Compaq, /usr/sbin/psrinfo has been available on
- # OSF/1 and Tru64 systems produced since 1995. I hope that
- # covers most systems running today. This code pipes the CPU
- # types through head -n 1, so we only detect the type of CPU 0.
- ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1`
- case "$ALPHA_CPU_TYPE" in
- "EV4 (21064)")
- UNAME_MACHINE="alpha" ;;
- "EV4.5 (21064)")
- UNAME_MACHINE="alpha" ;;
- "LCA4 (21066/21068)")
- UNAME_MACHINE="alpha" ;;
- "EV5 (21164)")
- UNAME_MACHINE="alphaev5" ;;
- "EV5.6 (21164A)")
- UNAME_MACHINE="alphaev56" ;;
- "EV5.6 (21164PC)")
- UNAME_MACHINE="alphapca56" ;;
- "EV5.7 (21164PC)")
- UNAME_MACHINE="alphapca57" ;;
- "EV6 (21264)")
- UNAME_MACHINE="alphaev6" ;;
- "EV6.7 (21264A)")
- UNAME_MACHINE="alphaev67" ;;
- "EV6.8CB (21264C)")
- UNAME_MACHINE="alphaev68" ;;
- "EV6.8AL (21264B)")
- UNAME_MACHINE="alphaev68" ;;
- "EV6.8CX (21264D)")
- UNAME_MACHINE="alphaev68" ;;
- "EV6.9A (21264/EV69A)")
- UNAME_MACHINE="alphaev69" ;;
- "EV7 (21364)")
- UNAME_MACHINE="alphaev7" ;;
- "EV7.9 (21364A)")
- UNAME_MACHINE="alphaev79" ;;
- esac
- # A Pn.n version is a patched version.
- # A Vn.n version is a released version.
- # A Tn.n version is a released field test version.
- # A Xn.n version is an unreleased experimental baselevel.
- # 1.2 uses "1.2" for uname -r.
- echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
- exit ;;
- Alpha\ *:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # Should we change UNAME_MACHINE based on the output of uname instead
- # of the specific Alpha model?
- echo alpha-pc-interix
- exit ;;
- 21064:Windows_NT:50:3)
- echo alpha-dec-winnt3.5
- exit ;;
- Amiga*:UNIX_System_V:4.0:*)
- echo m68k-unknown-sysv4
- exit ;;
- *:[Aa]miga[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-amigaos
- exit ;;
- *:[Mm]orph[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-morphos
- exit ;;
- *:OS/390:*:*)
- echo i370-ibm-openedition
- exit ;;
- *:z/VM:*:*)
- echo s390-ibm-zvmoe
- exit ;;
- *:OS400:*:*)
- echo powerpc-ibm-os400
- exit ;;
- arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
- echo arm-acorn-riscix${UNAME_RELEASE}
- exit ;;
- arm:riscos:*:*|arm:RISCOS:*:*)
- echo arm-unknown-riscos
- exit ;;
- SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
- echo hppa1.1-hitachi-hiuxmpp
- exit ;;
- Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*)
- # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE.
- if test "`(/bin/universe) 2>/dev/null`" = att ; then
- echo pyramid-pyramid-sysv3
- else
- echo pyramid-pyramid-bsd
- fi
- exit ;;
- NILE*:*:*:dcosx)
- echo pyramid-pyramid-svr4
- exit ;;
- DRS?6000:unix:4.0:6*)
- echo sparc-icl-nx6
- exit ;;
- DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*)
- case `/usr/bin/uname -p` in
- sparc) echo sparc-icl-nx7; exit ;;
- esac ;;
- sun4H:SunOS:5.*:*)
- echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
- exit ;;
- sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
- echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
- exit ;;
- i86pc:SunOS:5.*:*)
- echo i386-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
- exit ;;
- sun4*:SunOS:6*:*)
- # According to config.sub, this is the proper way to canonicalize
- # SunOS6. Hard to guess exactly what SunOS6 will be like, but
- # it's likely to be more like Solaris than SunOS4.
- echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
- exit ;;
- sun4*:SunOS:*:*)
- case "`/usr/bin/arch -k`" in
- Series*|S4*)
- UNAME_RELEASE=`uname -v`
- ;;
- esac
- # Japanese Language versions have a version number like `4.1.3-JL'.
- echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
- exit ;;
- sun3*:SunOS:*:*)
- echo m68k-sun-sunos${UNAME_RELEASE}
- exit ;;
- sun*:*:4.2BSD:*)
- UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
- test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3
- case "`/bin/arch`" in
- sun3)
- echo m68k-sun-sunos${UNAME_RELEASE}
- ;;
- sun4)
- echo sparc-sun-sunos${UNAME_RELEASE}
- ;;
- esac
- exit ;;
- aushp:SunOS:*:*)
- echo sparc-auspex-sunos${UNAME_RELEASE}
- exit ;;
- # The situation for MiNT is a little confusing. The machine name
- # can be virtually everything (everything which is not
- # "atarist" or "atariste" at least should have a processor
- # > m68000). The system name ranges from "MiNT" over "FreeMiNT"
- # to the lowercase version "mint" (or "freemint"). Finally
- # the system name "TOS" denotes a system which is actually not
- # MiNT. But MiNT is downward compatible to TOS, so this should
- # be no problem.
- atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
- exit ;;
- atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
- exit ;;
- *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
- exit ;;
- milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
- echo m68k-milan-mint${UNAME_RELEASE}
- exit ;;
- hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
- echo m68k-hades-mint${UNAME_RELEASE}
- exit ;;
- *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
- echo m68k-unknown-mint${UNAME_RELEASE}
- exit ;;
- m68k:machten:*:*)
- echo m68k-apple-machten${UNAME_RELEASE}
- exit ;;
- powerpc:machten:*:*)
- echo powerpc-apple-machten${UNAME_RELEASE}
- exit ;;
- RISC*:Mach:*:*)
- echo mips-dec-mach_bsd4.3
- exit ;;
- RISC*:ULTRIX:*:*)
- echo mips-dec-ultrix${UNAME_RELEASE}
- exit ;;
- VAX*:ULTRIX*:*:*)
- echo vax-dec-ultrix${UNAME_RELEASE}
- exit ;;
- 2020:CLIX:*:* | 2430:CLIX:*:*)
- echo clipper-intergraph-clix${UNAME_RELEASE}
- exit ;;
- mips:*:*:UMIPS | mips:*:*:RISCos)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
-#ifdef __cplusplus
-#include <stdio.h> /* for printf() prototype */
- int main (int argc, char *argv[]) {
-#else
- int main (argc, argv) int argc; char *argv[]; {
-#endif
- #if defined (host_mips) && defined (MIPSEB)
- #if defined (SYSTYPE_SYSV)
- printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
- #endif
- #if defined (SYSTYPE_SVR4)
- printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
- #endif
- #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
- printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
- #endif
- #endif
- exit (-1);
- }
-EOF
- $CC_FOR_BUILD -o $dummy $dummy.c &&
- dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` &&
- SYSTEM_NAME=`$dummy $dummyarg` &&
- { echo "$SYSTEM_NAME"; exit; }
- echo mips-mips-riscos${UNAME_RELEASE}
- exit ;;
- Motorola:PowerMAX_OS:*:*)
- echo powerpc-motorola-powermax
- exit ;;
- Motorola:*:4.3:PL8-*)
- echo powerpc-harris-powermax
- exit ;;
- Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*)
- echo powerpc-harris-powermax
- exit ;;
- Night_Hawk:Power_UNIX:*:*)
- echo powerpc-harris-powerunix
- exit ;;
- m88k:CX/UX:7*:*)
- echo m88k-harris-cxux7
- exit ;;
- m88k:*:4*:R4*)
- echo m88k-motorola-sysv4
- exit ;;
- m88k:*:3*:R3*)
- echo m88k-motorola-sysv3
- exit ;;
- AViiON:dgux:*:*)
- # DG/UX returns AViiON for all architectures
- UNAME_PROCESSOR=`/usr/bin/uname -p`
- if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
- then
- if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
- [ ${TARGET_BINARY_INTERFACE}x = x ]
- then
- echo m88k-dg-dgux${UNAME_RELEASE}
- else
- echo m88k-dg-dguxbcs${UNAME_RELEASE}
- fi
- else
- echo i586-dg-dgux${UNAME_RELEASE}
- fi
- exit ;;
- M88*:DolphinOS:*:*) # DolphinOS (SVR3)
- echo m88k-dolphin-sysv3
- exit ;;
- M88*:*:R3*:*)
- # Delta 88k system running SVR3
- echo m88k-motorola-sysv3
- exit ;;
- XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3)
- echo m88k-tektronix-sysv3
- exit ;;
- Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD)
- echo m68k-tektronix-bsd
- exit ;;
- *:IRIX*:*:*)
- echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
- exit ;;
- ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
- echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
- exit ;; # Note that: echo "'`uname -s`'" gives 'AIX '
- i*86:AIX:*:*)
- echo i386-ibm-aix
- exit ;;
- ia64:AIX:*:*)
- if [ -x /usr/bin/oslevel ] ; then
- IBM_REV=`/usr/bin/oslevel`
- else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
- fi
- echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
- exit ;;
- *:AIX:2:3)
- if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
- #include <sys/systemcfg.h>
-
- main()
- {
- if (!__power_pc())
- exit(1);
- puts("powerpc-ibm-aix3.2.5");
- exit(0);
- }
-EOF
- if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy`
- then
- echo "$SYSTEM_NAME"
- else
- echo rs6000-ibm-aix3.2.5
- fi
- elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then
- echo rs6000-ibm-aix3.2.4
- else
- echo rs6000-ibm-aix3.2
- fi
- exit ;;
- *:AIX:*:[45])
- IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
- if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
- IBM_ARCH=rs6000
- else
- IBM_ARCH=powerpc
- fi
- if [ -x /usr/bin/oslevel ] ; then
- IBM_REV=`/usr/bin/oslevel`
- else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
- fi
- echo ${IBM_ARCH}-ibm-aix${IBM_REV}
- exit ;;
- *:AIX:*:*)
- echo rs6000-ibm-aix
- exit ;;
- ibmrt:4.4BSD:*|romp-ibm:BSD:*)
- echo romp-ibm-bsd4.4
- exit ;;
- ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and
- echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
- exit ;; # report: romp-ibm BSD 4.3
- *:BOSX:*:*)
- echo rs6000-bull-bosx
- exit ;;
- DPX/2?00:B.O.S.:*:*)
- echo m68k-bull-sysv3
- exit ;;
- 9000/[34]??:4.3bsd:1.*:*)
- echo m68k-hp-bsd
- exit ;;
- hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*)
- echo m68k-hp-bsd4.4
- exit ;;
- 9000/[34678]??:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- case "${UNAME_MACHINE}" in
- 9000/31? ) HP_ARCH=m68000 ;;
- 9000/[34]?? ) HP_ARCH=m68k ;;
- 9000/[678][0-9][0-9])
- if [ -x /usr/bin/getconf ]; then
- sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
- sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
- case "${sc_cpu_version}" in
- 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
- 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
- 532) # CPU_PA_RISC2_0
- case "${sc_kernel_bits}" in
- 32) HP_ARCH="hppa2.0n" ;;
- 64) HP_ARCH="hppa2.0w" ;;
- '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20
- esac ;;
- esac
- fi
- if [ "${HP_ARCH}" = "" ]; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
-
- #define _HPUX_SOURCE
- #include <stdlib.h>
- #include <unistd.h>
-
- int main ()
- {
- #if defined(_SC_KERNEL_BITS)
- long bits = sysconf(_SC_KERNEL_BITS);
- #endif
- long cpu = sysconf (_SC_CPU_VERSION);
-
- switch (cpu)
- {
- case CPU_PA_RISC1_0: puts ("hppa1.0"); break;
- case CPU_PA_RISC1_1: puts ("hppa1.1"); break;
- case CPU_PA_RISC2_0:
- #if defined(_SC_KERNEL_BITS)
- switch (bits)
- {
- case 64: puts ("hppa2.0w"); break;
- case 32: puts ("hppa2.0n"); break;
- default: puts ("hppa2.0"); break;
- } break;
- #else /* !defined(_SC_KERNEL_BITS) */
- puts ("hppa2.0"); break;
- #endif
- default: puts ("hppa1.0"); break;
- }
- exit (0);
- }
-EOF
- (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy`
- test -z "$HP_ARCH" && HP_ARCH=hppa
- fi ;;
- esac
- if [ ${HP_ARCH} = "hppa2.0w" ]
- then
- eval $set_cc_for_build
-
- # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating
- # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler
- # generating 64-bit code. GNU and HP use different nomenclature:
- #
- # $ CC_FOR_BUILD=cc ./config.guess
- # => hppa2.0w-hp-hpux11.23
- # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess
- # => hppa64-hp-hpux11.23
-
- if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) |
- grep __LP64__ >/dev/null
- then
- HP_ARCH="hppa2.0w"
- else
- HP_ARCH="hppa64"
- fi
- fi
- echo ${HP_ARCH}-hp-hpux${HPUX_REV}
- exit ;;
- ia64:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- echo ia64-hp-hpux${HPUX_REV}
- exit ;;
- 3050*:HI-UX:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
- #include <unistd.h>
- int
- main ()
- {
- long cpu = sysconf (_SC_CPU_VERSION);
- /* The order matters, because CPU_IS_HP_MC68K erroneously returns
- true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct
- results, however. */
- if (CPU_IS_PA_RISC (cpu))
- {
- switch (cpu)
- {
- case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break;
- case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break;
- case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break;
- default: puts ("hppa-hitachi-hiuxwe2"); break;
- }
- }
- else if (CPU_IS_HP_MC68K (cpu))
- puts ("m68k-hitachi-hiuxwe2");
- else puts ("unknown-hitachi-hiuxwe2");
- exit (0);
- }
-EOF
- $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` &&
- { echo "$SYSTEM_NAME"; exit; }
- echo unknown-hitachi-hiuxwe2
- exit ;;
- 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
- echo hppa1.1-hp-bsd
- exit ;;
- 9000/8??:4.3bsd:*:*)
- echo hppa1.0-hp-bsd
- exit ;;
- *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
- echo hppa1.0-hp-mpeix
- exit ;;
- hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
- echo hppa1.1-hp-osf
- exit ;;
- hp8??:OSF1:*:*)
- echo hppa1.0-hp-osf
- exit ;;
- i*86:OSF1:*:*)
- if [ -x /usr/sbin/sysversion ] ; then
- echo ${UNAME_MACHINE}-unknown-osf1mk
- else
- echo ${UNAME_MACHINE}-unknown-osf1
- fi
- exit ;;
- parisc*:Lites*:*:*)
- echo hppa1.1-hp-lites
- exit ;;
- C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*)
- echo c1-convex-bsd
- exit ;;
- C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*)
- if getsysinfo -f scalar_acc
- then echo c32-convex-bsd
- else echo c2-convex-bsd
- fi
- exit ;;
- C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*)
- echo c34-convex-bsd
- exit ;;
- C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*)
- echo c38-convex-bsd
- exit ;;
- C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*)
- echo c4-convex-bsd
- exit ;;
- CRAY*Y-MP:*:*:*)
- echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
- exit ;;
- CRAY*[A-Z]90:*:*:*)
- echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
- | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
- -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
- -e 's/\.[^.]*$/.X/'
- exit ;;
- CRAY*TS:*:*:*)
- echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
- exit ;;
- CRAY*T3E:*:*:*)
- echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
- exit ;;
- CRAY*SV1:*:*:*)
- echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
- exit ;;
- *:UNICOS/mp:*:*)
- echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
- exit ;;
- F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
- FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
- FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
- echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
- exit ;;
- 5000:UNIX_System_V:4.*:*)
- FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'`
- echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
- exit ;;
- i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
- echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
- exit ;;
- sparc*:BSD/OS:*:*)
- echo sparc-unknown-bsdi${UNAME_RELEASE}
- exit ;;
- *:BSD/OS:*:*)
- echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
- exit ;;
- *:FreeBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
- exit ;;
- i*:CYGWIN*:*)
- echo ${UNAME_MACHINE}-pc-cygwin
- exit ;;
- i*:MINGW*:*)
- echo ${UNAME_MACHINE}-pc-mingw32
- exit ;;
- i*:windows32*:*)
- # uname -m includes "-pc" on this system.
- echo ${UNAME_MACHINE}-mingw32
- exit ;;
- i*:PW*:*)
- echo ${UNAME_MACHINE}-pc-pw32
- exit ;;
- x86:Interix*:[34]*)
- echo i586-pc-interix${UNAME_RELEASE}|sed -e 's/\..*//'
- exit ;;
- [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
- echo i${UNAME_MACHINE}-pc-mks
- exit ;;
- i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
- # UNAME_MACHINE based on the output of uname instead of i386?
- echo i586-pc-interix
- exit ;;
- i*:UWIN*:*)
- echo ${UNAME_MACHINE}-pc-uwin
- exit ;;
- amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*)
- echo x86_64-unknown-cygwin
- exit ;;
- p*:CYGWIN*:*)
- echo powerpcle-unknown-cygwin
- exit ;;
- prep*:SunOS:5.*:*)
- echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
- exit ;;
- *:GNU:*:*)
- # the GNU system
- echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
- exit ;;
- *:GNU/*:*:*)
- # other systems with GNU libc and userland
- echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu
- exit ;;
- i*86:Minix:*:*)
- echo ${UNAME_MACHINE}-pc-minix
- exit ;;
- arm*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- cris:Linux:*:*)
- echo cris-axis-linux-gnu
- exit ;;
- crisv32:Linux:*:*)
- echo crisv32-axis-linux-gnu
- exit ;;
- frv:Linux:*:*)
- echo frv-unknown-linux-gnu
- exit ;;
- ia64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- m32r*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- m68*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- mips:Linux:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
- #undef CPU
- #undef mips
- #undef mipsel
- #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
- CPU=mipsel
- #else
- #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
- CPU=mips
- #else
- CPU=
- #endif
- #endif
-EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
- test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; }
- ;;
- mips64:Linux:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
- #undef CPU
- #undef mips64
- #undef mips64el
- #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL)
- CPU=mips64el
- #else
- #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB)
- CPU=mips64
- #else
- CPU=
- #endif
- #endif
-EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^CPU=`
- test x"${CPU}" != x && { echo "${CPU}-unknown-linux-gnu"; exit; }
- ;;
- or32:Linux:*:*)
- echo or32-unknown-linux-gnu
- exit ;;
- ppc:Linux:*:*)
- echo powerpc-unknown-linux-gnu
- exit ;;
- ppc64:Linux:*:*)
- echo powerpc64-unknown-linux-gnu
- exit ;;
- alpha:Linux:*:*)
- case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
- EV5) UNAME_MACHINE=alphaev5 ;;
- EV56) UNAME_MACHINE=alphaev56 ;;
- PCA56) UNAME_MACHINE=alphapca56 ;;
- PCA57) UNAME_MACHINE=alphapca56 ;;
- EV6) UNAME_MACHINE=alphaev6 ;;
- EV67) UNAME_MACHINE=alphaev67 ;;
- EV68*) UNAME_MACHINE=alphaev68 ;;
- esac
- objdump --private-headers /bin/sh | grep ld.so.1 >/dev/null
- if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
- echo ${UNAME_MACHINE}-unknown-linux-gnu${LIBC}
- exit ;;
- parisc:Linux:*:* | hppa:Linux:*:*)
- # Look for CPU level
- case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
- PA7*) echo hppa1.1-unknown-linux-gnu ;;
- PA8*) echo hppa2.0-unknown-linux-gnu ;;
- *) echo hppa-unknown-linux-gnu ;;
- esac
- exit ;;
- parisc64:Linux:*:* | hppa64:Linux:*:*)
- echo hppa64-unknown-linux-gnu
- exit ;;
- s390:Linux:*:* | s390x:Linux:*:*)
- echo ${UNAME_MACHINE}-ibm-linux
- exit ;;
- sh64*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- sh*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- sparc:Linux:*:* | sparc64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-gnu
- exit ;;
- x86_64:Linux:*:*)
- echo x86_64-unknown-linux-gnu
- exit ;;
- i*86:Linux:*:*)
- # The BFD linker knows what the default object file format is, so
- # first see if it will tell us. cd to the root directory to prevent
- # problems with other programs or directories called `ld' in the path.
- # Set LC_ALL=C to ensure ld outputs messages in English.
- ld_supported_targets=`cd /; LC_ALL=C ld --help 2>&1 \
- | sed -ne '/supported targets:/!d
- s/[ ][ ]*/ /g
- s/.*supported targets: *//
- s/ .*//
- p'`
- case "$ld_supported_targets" in
- elf32-i386)
- TENTATIVE="${UNAME_MACHINE}-pc-linux-gnu"
- ;;
- a.out-i386-linux)
- echo "${UNAME_MACHINE}-pc-linux-gnuaout"
- exit ;;
- coff-i386)
- echo "${UNAME_MACHINE}-pc-linux-gnucoff"
- exit ;;
- "")
- # Either a pre-BFD a.out linker (linux-gnuoldld) or
- # one that does not give us useful --help.
- echo "${UNAME_MACHINE}-pc-linux-gnuoldld"
- exit ;;
- esac
- # Determine whether the default compiler is a.out or elf
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
- #include <features.h>
- #ifdef __ELF__
- # ifdef __GLIBC__
- # if __GLIBC__ >= 2
- LIBC=gnu
- # else
- LIBC=gnulibc1
- # endif
- # else
- LIBC=gnulibc1
- # endif
- #else
- #ifdef __INTEL_COMPILER
- LIBC=gnu
- #else
- LIBC=gnuaout
- #endif
- #endif
- #ifdef __dietlibc__
- LIBC=dietlibc
- #endif
-EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep ^LIBC=`
- test x"${LIBC}" != x && {
- echo "${UNAME_MACHINE}-pc-linux-${LIBC}"
- exit
- }
- test x"${TENTATIVE}" != x && { echo "${TENTATIVE}"; exit; }
- ;;
- i*86:DYNIX/ptx:4*:*)
- # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
- # earlier versions are messed up and put the nodename in both
- # sysname and nodename.
- echo i386-sequent-sysv4
- exit ;;
- i*86:UNIX_SV:4.2MP:2.*)
- # Unixware is an offshoot of SVR4, but it has its own version
- # number series starting with 2...
- # I am not positive that other SVR4 systems won't match this,
- # I just have to hope. -- rms.
- # Use sysv4.2uw... so that sysv4* matches it.
- echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
- exit ;;
- i*86:OS/2:*:*)
- # If we were able to find `uname', then EMX Unix compatibility
- # is probably installed.
- echo ${UNAME_MACHINE}-pc-os2-emx
- exit ;;
- i*86:XTS-300:*:STOP)
- echo ${UNAME_MACHINE}-unknown-stop
- exit ;;
- i*86:atheos:*:*)
- echo ${UNAME_MACHINE}-unknown-atheos
- exit ;;
- i*86:syllable:*:*)
- echo ${UNAME_MACHINE}-pc-syllable
- exit ;;
- i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.0*:*)
- echo i386-unknown-lynxos${UNAME_RELEASE}
- exit ;;
- i*86:*DOS:*:*)
- echo ${UNAME_MACHINE}-pc-msdosdjgpp
- exit ;;
- i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
- UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
- if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
- echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
- else
- echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
- fi
- exit ;;
- i*86:*:5:[678]*)
- # UnixWare 7.x, OpenUNIX and OpenServer 6.
- case `/bin/uname -X | grep "^Machine"` in
- *486*) UNAME_MACHINE=i486 ;;
- *Pentium) UNAME_MACHINE=i586 ;;
- *Pent*|*Celeron) UNAME_MACHINE=i686 ;;
- esac
- echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
- exit ;;
- i*86:*:3.2:*)
- if test -f /usr/options/cb.name; then
- UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
- echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
- elif /bin/uname -X 2>/dev/null >/dev/null ; then
- UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
- (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
- (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \
- && UNAME_MACHINE=i586
- (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \
- && UNAME_MACHINE=i686
- (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
- && UNAME_MACHINE=i686
- echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
- else
- echo ${UNAME_MACHINE}-pc-sysv32
- fi
- exit ;;
- pc:*:*:*)
- # Left here for compatibility:
- # uname -m prints for DJGPP always 'pc', but it prints nothing about
- # the processor, so we play safe by assuming i386.
- echo i386-pc-msdosdjgpp
- exit ;;
- Intel:Mach:3*:*)
- echo i386-pc-mach3
- exit ;;
- paragon:*:*:*)
- echo i860-intel-osf1
- exit ;;
- i860:*:4.*:*) # i860-SVR4
- if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
- echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
- else # Add other i860-SVR4 vendors below as they are discovered.
- echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4
- fi
- exit ;;
- mini*:CTIX:SYS*5:*)
- # "miniframe"
- echo m68010-convergent-sysv
- exit ;;
- mc68k:UNIX:SYSTEM5:3.51m)
- echo m68k-convergent-sysv
- exit ;;
- M680?0:D-NIX:5.3:*)
- echo m68k-diab-dnix
- exit ;;
- M68*:*:R3V[5678]*:*)
- test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;;
- 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0)
- OS_REL=''
- test -r /etc/.relid \
- && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
- /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
- /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
- 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
- /bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4; exit; } ;;
- m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
- echo m68k-unknown-lynxos${UNAME_RELEASE}
- exit ;;
- mc68030:UNIX_System_V:4.*:*)
- echo m68k-atari-sysv4
- exit ;;
- TSUNAMI:LynxOS:2.*:*)
- echo sparc-unknown-lynxos${UNAME_RELEASE}
- exit ;;
- rs6000:LynxOS:2.*:*)
- echo rs6000-unknown-lynxos${UNAME_RELEASE}
- exit ;;
- PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.0*:*)
- echo powerpc-unknown-lynxos${UNAME_RELEASE}
- exit ;;
- SM[BE]S:UNIX_SV:*:*)
- echo mips-dde-sysv${UNAME_RELEASE}
- exit ;;
- RM*:ReliantUNIX-*:*:*)
- echo mips-sni-sysv4
- exit ;;
- RM*:SINIX-*:*:*)
- echo mips-sni-sysv4
- exit ;;
- *:SINIX-*:*:*)
- if uname -p 2>/dev/null >/dev/null ; then
- UNAME_MACHINE=`(uname -p) 2>/dev/null`
- echo ${UNAME_MACHINE}-sni-sysv4
- else
- echo ns32k-sni-sysv
- fi
- exit ;;
- PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort
- # says <Richard.M.Bartel@ccMail.Census.GOV>
- echo i586-unisys-sysv4
- exit ;;
- *:UNIX_System_V:4*:FTX*)
- # From Gerald Hewes <hewes@openmarket.com>.
- # How about differentiating between stratus architectures? -djm
- echo hppa1.1-stratus-sysv4
- exit ;;
- *:*:*:FTX*)
- # From seanf@swdc.stratus.com.
- echo i860-stratus-sysv4
- exit ;;
- i*86:VOS:*:*)
- # From Paul.Green@stratus.com.
- echo ${UNAME_MACHINE}-stratus-vos
- exit ;;
- *:VOS:*:*)
- # From Paul.Green@stratus.com.
- echo hppa1.1-stratus-vos
- exit ;;
- mc68*:A/UX:*:*)
- echo m68k-apple-aux${UNAME_RELEASE}
- exit ;;
- news*:NEWS-OS:6*:*)
- echo mips-sony-newsos6
- exit ;;
- R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
- if [ -d /usr/nec ]; then
- echo mips-nec-sysv${UNAME_RELEASE}
- else
- echo mips-unknown-sysv${UNAME_RELEASE}
- fi
- exit ;;
- BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only.
- echo powerpc-be-beos
- exit ;;
- BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only.
- echo powerpc-apple-beos
- exit ;;
- BePC:BeOS:*:*) # BeOS running on Intel PC compatible.
- echo i586-pc-beos
- exit ;;
- SX-4:SUPER-UX:*:*)
- echo sx4-nec-superux${UNAME_RELEASE}
- exit ;;
- SX-5:SUPER-UX:*:*)
- echo sx5-nec-superux${UNAME_RELEASE}
- exit ;;
- SX-6:SUPER-UX:*:*)
- echo sx6-nec-superux${UNAME_RELEASE}
- exit ;;
- Power*:Rhapsody:*:*)
- echo powerpc-apple-rhapsody${UNAME_RELEASE}
- exit ;;
- *:Rhapsody:*:*)
- echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
- exit ;;
- *:Darwin:*:*)
- UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
- case $UNAME_PROCESSOR in
- *86) UNAME_PROCESSOR=i686 ;;
- unknown) UNAME_PROCESSOR=powerpc ;;
- esac
- echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
- exit ;;
- *:procnto*:*:* | *:QNX:[0123456789]*:*)
- UNAME_PROCESSOR=`uname -p`
- if test "$UNAME_PROCESSOR" = "x86"; then
- UNAME_PROCESSOR=i386
- UNAME_MACHINE=pc
- fi
- echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
- exit ;;
- *:QNX:*:4*)
- echo i386-pc-qnx
- exit ;;
- NSE-?:NONSTOP_KERNEL:*:*)
- echo nse-tandem-nsk${UNAME_RELEASE}
- exit ;;
- NSR-?:NONSTOP_KERNEL:*:*)
- echo nsr-tandem-nsk${UNAME_RELEASE}
- exit ;;
- *:NonStop-UX:*:*)
- echo mips-compaq-nonstopux
- exit ;;
- BS2000:POSIX*:*:*)
- echo bs2000-siemens-sysv
- exit ;;
- DS/*:UNIX_System_V:*:*)
- echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
- exit ;;
- *:Plan9:*:*)
- # "uname -m" is not consistent, so use $cputype instead. 386
- # is converted to i386 for consistency with other x86
- # operating systems.
- if test "$cputype" = "386"; then
- UNAME_MACHINE=i386
- else
- UNAME_MACHINE="$cputype"
- fi
- echo ${UNAME_MACHINE}-unknown-plan9
- exit ;;
- *:TOPS-10:*:*)
- echo pdp10-unknown-tops10
- exit ;;
- *:TENEX:*:*)
- echo pdp10-unknown-tenex
- exit ;;
- KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*)
- echo pdp10-dec-tops20
- exit ;;
- XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*)
- echo pdp10-xkl-tops20
- exit ;;
- *:TOPS-20:*:*)
- echo pdp10-unknown-tops20
- exit ;;
- *:ITS:*:*)
- echo pdp10-unknown-its
- exit ;;
- SEI:*:*:SEIUX)
- echo mips-sei-seiux${UNAME_RELEASE}
- exit ;;
- *:DragonFly:*:*)
- echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
- exit ;;
- *:*VMS:*:*)
- UNAME_MACHINE=`(uname -p) 2>/dev/null`
- case "${UNAME_MACHINE}" in
- A*) echo alpha-dec-vms ; exit ;;
- I*) echo ia64-dec-vms ; exit ;;
- V*) echo vax-dec-vms ; exit ;;
- esac ;;
- *:XENIX:*:SysV)
- echo i386-pc-xenix
- exit ;;
- i*86:skyos:*:*)
- echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//'
- exit ;;
-esac
-
-#echo '(No uname command or uname output not recognized.)' 1>&2
-#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
-
-eval $set_cc_for_build
-cat >$dummy.c <<EOF
-#ifdef _SEQUENT_
-# include <sys/types.h>
-# include <sys/utsname.h>
-#endif
-main ()
-{
-#if defined (sony)
-#if defined (MIPSEB)
- /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed,
- I don't know.... */
- printf ("mips-sony-bsd\n"); exit (0);
-#else
-#include <sys/param.h>
- printf ("m68k-sony-newsos%s\n",
-#ifdef NEWSOS4
- "4"
-#else
- ""
-#endif
- ); exit (0);
-#endif
-#endif
-
-#if defined (__arm) && defined (__acorn) && defined (__unix)
- printf ("arm-acorn-riscix\n"); exit (0);
-#endif
-
-#if defined (hp300) && !defined (hpux)
- printf ("m68k-hp-bsd\n"); exit (0);
-#endif
-
-#if defined (NeXT)
-#if !defined (__ARCHITECTURE__)
-#define __ARCHITECTURE__ "m68k"
-#endif
- int version;
- version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`;
- if (version < 4)
- printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version);
- else
- printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version);
- exit (0);
-#endif
-
-#if defined (MULTIMAX) || defined (n16)
-#if defined (UMAXV)
- printf ("ns32k-encore-sysv\n"); exit (0);
-#else
-#if defined (CMU)
- printf ("ns32k-encore-mach\n"); exit (0);
-#else
- printf ("ns32k-encore-bsd\n"); exit (0);
-#endif
-#endif
-#endif
-
-#if defined (__386BSD__)
- printf ("i386-pc-bsd\n"); exit (0);
-#endif
-
-#if defined (sequent)
-#if defined (i386)
- printf ("i386-sequent-dynix\n"); exit (0);
-#endif
-#if defined (ns32000)
- printf ("ns32k-sequent-dynix\n"); exit (0);
-#endif
-#endif
-
-#if defined (_SEQUENT_)
- struct utsname un;
-
- uname(&un);
-
- if (strncmp(un.version, "V2", 2) == 0) {
- printf ("i386-sequent-ptx2\n"); exit (0);
- }
- if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */
- printf ("i386-sequent-ptx1\n"); exit (0);
- }
- printf ("i386-sequent-ptx\n"); exit (0);
-
-#endif
-
-#if defined (vax)
-# if !defined (ultrix)
-# include <sys/param.h>
-# if defined (BSD)
-# if BSD == 43
- printf ("vax-dec-bsd4.3\n"); exit (0);
-# else
-# if BSD == 199006
- printf ("vax-dec-bsd4.3reno\n"); exit (0);
-# else
- printf ("vax-dec-bsd\n"); exit (0);
-# endif
-# endif
-# else
- printf ("vax-dec-bsd\n"); exit (0);
-# endif
-# else
- printf ("vax-dec-ultrix\n"); exit (0);
-# endif
-#endif
-
-#if defined (alliant) && defined (i860)
- printf ("i860-alliant-bsd\n"); exit (0);
-#endif
-
- exit (1);
-}
-EOF
-
-$CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null && SYSTEM_NAME=`$dummy` &&
- { echo "$SYSTEM_NAME"; exit; }
-
-# Apollos put the system type in the environment.
-
-test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit; }
-
-# Convex versions that predate uname can use getsysinfo(1)
-
-if [ -x /usr/convex/getsysinfo ]
-then
- case `getsysinfo -f cpu_type` in
- c1*)
- echo c1-convex-bsd
- exit ;;
- c2*)
- if getsysinfo -f scalar_acc
- then echo c32-convex-bsd
- else echo c2-convex-bsd
- fi
- exit ;;
- c34*)
- echo c34-convex-bsd
- exit ;;
- c38*)
- echo c38-convex-bsd
- exit ;;
- c4*)
- echo c4-convex-bsd
- exit ;;
- esac
-fi
-
-cat >&2 <<EOF
-$0: unable to guess system type
-
-This script, last modified $timestamp, has failed to recognize
-the operating system you are using. It is advised that you
-download the most up to date version of the config scripts from
-
- http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.guess
-and
- http://savannah.gnu.org/cgi-bin/viewcvs/*checkout*/config/config/config.sub
-
-If the version you run ($0) is already up to date, please
-send the following data and any information you think might be
-pertinent to <config-patches@gnu.org> in order to provide the needed
-information to handle your system.
-
-config.guess timestamp = $timestamp
-
-uname -m = `(uname -m) 2>/dev/null || echo unknown`
-uname -r = `(uname -r) 2>/dev/null || echo unknown`
-uname -s = `(uname -s) 2>/dev/null || echo unknown`
-uname -v = `(uname -v) 2>/dev/null || echo unknown`
-
-/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null`
-/bin/uname -X = `(/bin/uname -X) 2>/dev/null`
-
-hostinfo = `(hostinfo) 2>/dev/null`
-/bin/universe = `(/bin/universe) 2>/dev/null`
-/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null`
-/bin/arch = `(/bin/arch) 2>/dev/null`
-/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
-/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
-
-UNAME_MACHINE = ${UNAME_MACHINE}
-UNAME_RELEASE = ${UNAME_RELEASE}
-UNAME_SYSTEM = ${UNAME_SYSTEM}
-UNAME_VERSION = ${UNAME_VERSION}
-EOF
-
-exit 1
-
-# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "timestamp='"
-# time-stamp-format: "%:y-%02m-%02d"
-# time-stamp-end: "'"
-# End:
diff --git a/config.sub b/config.sub
deleted file mode 100755
index 1c366df..0000000
--- a/config.sub
+++ /dev/null
@@ -1,1579 +0,0 @@
-#! /bin/sh
-# Configuration validation subroutine script.
-# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
-# 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
-
-timestamp='2005-07-08'
-
-# This file is (in principle) common to ALL GNU software.
-# The presence of a machine in this file suggests that SOME GNU software
-# can handle that machine. It does not imply ALL GNU software can.
-#
-# This file is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
-# 02110-1301, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-
-# Please send patches to <config-patches@gnu.org>. Submit a context
-# diff and a properly formatted ChangeLog entry.
-#
-# Configuration subroutine to validate and canonicalize a configuration type.
-# Supply the specified configuration type as an argument.
-# If it is invalid, we print an error message on stderr and exit with code 1.
-# Otherwise, we print the canonical config type on stdout and succeed.
-
-# This file is supposed to be the same for all GNU packages
-# and recognize all the CPU types, system types and aliases
-# that are meaningful with *any* GNU software.
-# Each package is responsible for reporting which valid configurations
-# it does not support. The user should be able to distinguish
-# a failure to support a valid configuration from a meaningless
-# configuration.
-
-# The goal of this file is to map all the various variations of a given
-# machine specification into a single specification in the form:
-# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM
-# or in some cases, the newer four-part form:
-# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM
-# It is wrong to echo any other type of specification.
-
-me=`echo "$0" | sed -e 's,.*/,,'`
-
-usage="\
-Usage: $0 [OPTION] CPU-MFR-OPSYS
- $0 [OPTION] ALIAS
-
-Canonicalize a configuration name.
-
-Operation modes:
- -h, --help print this help, then exit
- -t, --time-stamp print date of last modification, then exit
- -v, --version print version number, then exit
-
-Report bugs and patches to <config-patches@gnu.org>."
-
-version="\
-GNU config.sub ($timestamp)
-
-Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
-Free Software Foundation, Inc.
-
-This is free software; see the source for copying conditions. There is NO
-warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
-
-help="
-Try \`$me --help' for more information."
-
-# Parse command line
-while test $# -gt 0 ; do
- case $1 in
- --time-stamp | --time* | -t )
- echo "$timestamp" ; exit ;;
- --version | -v )
- echo "$version" ; exit ;;
- --help | --h* | -h )
- echo "$usage"; exit ;;
- -- ) # Stop option processing
- shift; break ;;
- - ) # Use stdin as input.
- break ;;
- -* )
- echo "$me: invalid option $1$help"
- exit 1 ;;
-
- *local*)
- # First pass through any local machine types.
- echo $1
- exit ;;
-
- * )
- break ;;
- esac
-done
-
-case $# in
- 0) echo "$me: missing argument$help" >&2
- exit 1;;
- 1) ;;
- *) echo "$me: too many arguments$help" >&2
- exit 1;;
-esac
-
-# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
-# Here we must recognize all the valid KERNEL-OS combinations.
-maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
-case $maybe_os in
- nto-qnx* | linux-gnu* | linux-dietlibc | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | \
- kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | storm-chaos* | os2-emx* | rtmk-nova*)
- os=-$maybe_os
- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
- ;;
- *)
- basic_machine=`echo $1 | sed 's/-[^-]*$//'`
- if [ $basic_machine != $1 ]
- then os=`echo $1 | sed 's/.*-/-/'`
- else os=; fi
- ;;
-esac
-
-### Let's recognize common machines as not being operating systems so
-### that things like config.sub decstation-3100 work. We also
-### recognize some manufacturers as not being operating systems, so we
-### can provide default operating systems below.
-case $os in
- -sun*os*)
- # Prevent following clause from handling this invalid input.
- ;;
- -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \
- -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \
- -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \
- -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
- -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
- -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
- -apple | -axis | -knuth | -cray)
- os=
- basic_machine=$1
- ;;
- -sim | -cisco | -oki | -wec | -winbond)
- os=
- basic_machine=$1
- ;;
- -scout)
- ;;
- -wrs)
- os=-vxworks
- basic_machine=$1
- ;;
- -chorusos*)
- os=-chorusos
- basic_machine=$1
- ;;
- -chorusrdb)
- os=-chorusrdb
- basic_machine=$1
- ;;
- -hiux*)
- os=-hiuxwe2
- ;;
- -sco5)
- os=-sco3.2v5
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -sco4)
- os=-sco3.2v4
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -sco3.2.[4-9]*)
- os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -sco3.2v[4-9]*)
- # Don't forget version if it is 3.2v4 or newer.
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -sco*)
- os=-sco3.2v2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -udk*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -isc)
- os=-isc2.2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -clix*)
- basic_machine=clipper-intergraph
- ;;
- -isc*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
- ;;
- -lynx*)
- os=-lynxos
- ;;
- -ptx*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
- ;;
- -windowsnt*)
- os=`echo $os | sed -e 's/windowsnt/winnt/'`
- ;;
- -psos*)
- os=-psos
- ;;
- -mint | -mint[0-9]*)
- basic_machine=m68k-atari
- os=-mint
- ;;
-esac
-
-# Decode aliases for certain CPU-COMPANY combinations.
-case $basic_machine in
- # Recognize the basic CPU types without company name.
- # Some are omitted here because they have special meanings below.
- 1750a | 580 \
- | a29k \
- | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
- | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
- | am33_2.0 \
- | arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr \
- | bfin \
- | c4x | clipper \
- | d10v | d30v | dlx | dsp16xx \
- | fr30 | frv \
- | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
- | i370 | i860 | i960 | ia64 \
- | ip2k | iq2000 \
- | m32r | m32rle | m68000 | m68k | m88k | maxq | mcore \
- | mips | mipsbe | mipseb | mipsel | mipsle \
- | mips16 \
- | mips64 | mips64el \
- | mips64vr | mips64vrel \
- | mips64orion | mips64orionel \
- | mips64vr4100 | mips64vr4100el \
- | mips64vr4300 | mips64vr4300el \
- | mips64vr5000 | mips64vr5000el \
- | mips64vr5900 | mips64vr5900el \
- | mipsisa32 | mipsisa32el \
- | mipsisa32r2 | mipsisa32r2el \
- | mipsisa64 | mipsisa64el \
- | mipsisa64r2 | mipsisa64r2el \
- | mipsisa64sb1 | mipsisa64sb1el \
- | mipsisa64sr71k | mipsisa64sr71kel \
- | mipstx39 | mipstx39el \
- | mn10200 | mn10300 \
- | ms1 \
- | msp430 \
- | ns16k | ns32k \
- | or32 \
- | pdp10 | pdp11 | pj | pjl \
- | powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \
- | pyramid \
- | sh | sh[1234] | sh[24]a | sh[23]e | sh[34]eb | shbe | shle | sh[1234]le | sh3ele \
- | sh64 | sh64le \
- | sparc | sparc64 | sparc64b | sparc86x | sparclet | sparclite \
- | sparcv8 | sparcv9 | sparcv9b \
- | strongarm \
- | tahoe | thumb | tic4x | tic80 | tron \
- | v850 | v850e \
- | we32k \
- | x86 | xscale | xscalee[bl] | xstormy16 | xtensa \
- | z8k)
- basic_machine=$basic_machine-unknown
- ;;
- m32c)
- basic_machine=$basic_machine-unknown
- ;;
- m6811 | m68hc11 | m6812 | m68hc12)
- # Motorola 68HC11/12.
- basic_machine=$basic_machine-unknown
- os=-none
- ;;
- m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
- ;;
-
- # We use `pc' rather than `unknown'
- # because (1) that's what they normally are, and
- # (2) the word "unknown" tends to confuse beginning users.
- i*86 | x86_64)
- basic_machine=$basic_machine-pc
- ;;
- # Object if more than one company name word.
- *-*-*)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
- exit 1
- ;;
- # Recognize the basic CPU types with company name.
- 580-* \
- | a29k-* \
- | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
- | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
- | alphapca5[67]-* | alpha64pca5[67]-* | arc-* \
- | arm-* | armbe-* | armle-* | armeb-* | armv*-* \
- | avr-* \
- | bfin-* | bs2000-* \
- | c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \
- | clipper-* | craynv-* | cydra-* \
- | d10v-* | d30v-* | dlx-* \
- | elxsi-* \
- | f30[01]-* | f700-* | fr30-* | frv-* | fx80-* \
- | h8300-* | h8500-* \
- | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
- | i*86-* | i860-* | i960-* | ia64-* \
- | ip2k-* | iq2000-* \
- | m32r-* | m32rle-* \
- | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
- | m88110-* | m88k-* | maxq-* | mcore-* \
- | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
- | mips16-* \
- | mips64-* | mips64el-* \
- | mips64vr-* | mips64vrel-* \
- | mips64orion-* | mips64orionel-* \
- | mips64vr4100-* | mips64vr4100el-* \
- | mips64vr4300-* | mips64vr4300el-* \
- | mips64vr5000-* | mips64vr5000el-* \
- | mips64vr5900-* | mips64vr5900el-* \
- | mipsisa32-* | mipsisa32el-* \
- | mipsisa32r2-* | mipsisa32r2el-* \
- | mipsisa64-* | mipsisa64el-* \
- | mipsisa64r2-* | mipsisa64r2el-* \
- | mipsisa64sb1-* | mipsisa64sb1el-* \
- | mipsisa64sr71k-* | mipsisa64sr71kel-* \
- | mipstx39-* | mipstx39el-* \
- | mmix-* \
- | ms1-* \
- | msp430-* \
- | none-* | np1-* | ns16k-* | ns32k-* \
- | orion-* \
- | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
- | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \
- | pyramid-* \
- | romp-* | rs6000-* \
- | sh-* | sh[1234]-* | sh[24]a-* | sh[23]e-* | sh[34]eb-* | shbe-* \
- | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
- | sparc-* | sparc64-* | sparc64b-* | sparc86x-* | sparclet-* \
- | sparclite-* \
- | sparcv8-* | sparcv9-* | sparcv9b-* | strongarm-* | sv1-* | sx?-* \
- | tahoe-* | thumb-* \
- | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
- | tron-* \
- | v850-* | v850e-* | vax-* \
- | we32k-* \
- | x86-* | x86_64-* | xps100-* | xscale-* | xscalee[bl]-* \
- | xstormy16-* | xtensa-* \
- | ymp-* \
- | z8k-*)
- ;;
- m32c-*)
- ;;
- # Recognize the various machine names and aliases which stand
- # for a CPU type and a company and sometimes even an OS.
- 386bsd)
- basic_machine=i386-unknown
- os=-bsd
- ;;
- 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
- basic_machine=m68000-att
- ;;
- 3b*)
- basic_machine=we32k-att
- ;;
- a29khif)
- basic_machine=a29k-amd
- os=-udi
- ;;
- abacus)
- basic_machine=abacus-unknown
- ;;
- adobe68k)
- basic_machine=m68010-adobe
- os=-scout
- ;;
- alliant | fx80)
- basic_machine=fx80-alliant
- ;;
- altos | altos3068)
- basic_machine=m68k-altos
- ;;
- am29k)
- basic_machine=a29k-none
- os=-bsd
- ;;
- amd64)
- basic_machine=x86_64-pc
- ;;
- amd64-*)
- basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- amdahl)
- basic_machine=580-amdahl
- os=-sysv
- ;;
- amiga | amiga-*)
- basic_machine=m68k-unknown
- ;;
- amigaos | amigados)
- basic_machine=m68k-unknown
- os=-amigaos
- ;;
- amigaunix | amix)
- basic_machine=m68k-unknown
- os=-sysv4
- ;;
- apollo68)
- basic_machine=m68k-apollo
- os=-sysv
- ;;
- apollo68bsd)
- basic_machine=m68k-apollo
- os=-bsd
- ;;
- aux)
- basic_machine=m68k-apple
- os=-aux
- ;;
- balance)
- basic_machine=ns32k-sequent
- os=-dynix
- ;;
- c90)
- basic_machine=c90-cray
- os=-unicos
- ;;
- convex-c1)
- basic_machine=c1-convex
- os=-bsd
- ;;
- convex-c2)
- basic_machine=c2-convex
- os=-bsd
- ;;
- convex-c32)
- basic_machine=c32-convex
- os=-bsd
- ;;
- convex-c34)
- basic_machine=c34-convex
- os=-bsd
- ;;
- convex-c38)
- basic_machine=c38-convex
- os=-bsd
- ;;
- cray | j90)
- basic_machine=j90-cray
- os=-unicos
- ;;
- craynv)
- basic_machine=craynv-cray
- os=-unicosmp
- ;;
- cr16c)
- basic_machine=cr16c-unknown
- os=-elf
- ;;
- crds | unos)
- basic_machine=m68k-crds
- ;;
- crisv32 | crisv32-* | etraxfs*)
- basic_machine=crisv32-axis
- ;;
- cris | cris-* | etrax*)
- basic_machine=cris-axis
- ;;
- crx)
- basic_machine=crx-unknown
- os=-elf
- ;;
- da30 | da30-*)
- basic_machine=m68k-da30
- ;;
- decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn)
- basic_machine=mips-dec
- ;;
- decsystem10* | dec10*)
- basic_machine=pdp10-dec
- os=-tops10
- ;;
- decsystem20* | dec20*)
- basic_machine=pdp10-dec
- os=-tops20
- ;;
- delta | 3300 | motorola-3300 | motorola-delta \
- | 3300-motorola | delta-motorola)
- basic_machine=m68k-motorola
- ;;
- delta88)
- basic_machine=m88k-motorola
- os=-sysv3
- ;;
- djgpp)
- basic_machine=i586-pc
- os=-msdosdjgpp
- ;;
- dpx20 | dpx20-*)
- basic_machine=rs6000-bull
- os=-bosx
- ;;
- dpx2* | dpx2*-bull)
- basic_machine=m68k-bull
- os=-sysv3
- ;;
- ebmon29k)
- basic_machine=a29k-amd
- os=-ebmon
- ;;
- elxsi)
- basic_machine=elxsi-elxsi
- os=-bsd
- ;;
- encore | umax | mmax)
- basic_machine=ns32k-encore
- ;;
- es1800 | OSE68k | ose68k | ose | OSE)
- basic_machine=m68k-ericsson
- os=-ose
- ;;
- fx2800)
- basic_machine=i860-alliant
- ;;
- genix)
- basic_machine=ns32k-ns
- ;;
- gmicro)
- basic_machine=tron-gmicro
- os=-sysv
- ;;
- go32)
- basic_machine=i386-pc
- os=-go32
- ;;
- h3050r* | hiux*)
- basic_machine=hppa1.1-hitachi
- os=-hiuxwe2
- ;;
- h8300hms)
- basic_machine=h8300-hitachi
- os=-hms
- ;;
- h8300xray)
- basic_machine=h8300-hitachi
- os=-xray
- ;;
- h8500hms)
- basic_machine=h8500-hitachi
- os=-hms
- ;;
- harris)
- basic_machine=m88k-harris
- os=-sysv3
- ;;
- hp300-*)
- basic_machine=m68k-hp
- ;;
- hp300bsd)
- basic_machine=m68k-hp
- os=-bsd
- ;;
- hp300hpux)
- basic_machine=m68k-hp
- os=-hpux
- ;;
- hp3k9[0-9][0-9] | hp9[0-9][0-9])
- basic_machine=hppa1.0-hp
- ;;
- hp9k2[0-9][0-9] | hp9k31[0-9])
- basic_machine=m68000-hp
- ;;
- hp9k3[2-9][0-9])
- basic_machine=m68k-hp
- ;;
- hp9k6[0-9][0-9] | hp6[0-9][0-9])
- basic_machine=hppa1.0-hp
- ;;
- hp9k7[0-79][0-9] | hp7[0-79][0-9])
- basic_machine=hppa1.1-hp
- ;;
- hp9k78[0-9] | hp78[0-9])
- # FIXME: really hppa2.0-hp
- basic_machine=hppa1.1-hp
- ;;
- hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893)
- # FIXME: really hppa2.0-hp
- basic_machine=hppa1.1-hp
- ;;
- hp9k8[0-9][13679] | hp8[0-9][13679])
- basic_machine=hppa1.1-hp
- ;;
- hp9k8[0-9][0-9] | hp8[0-9][0-9])
- basic_machine=hppa1.0-hp
- ;;
- hppa-next)
- os=-nextstep3
- ;;
- hppaosf)
- basic_machine=hppa1.1-hp
- os=-osf
- ;;
- hppro)
- basic_machine=hppa1.1-hp
- os=-proelf
- ;;
- i370-ibm* | ibm*)
- basic_machine=i370-ibm
- ;;
-# I'm not sure what "Sysv32" means. Should this be sysv3.2?
- i*86v32)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
- os=-sysv32
- ;;
- i*86v4*)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
- os=-sysv4
- ;;
- i*86v)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
- os=-sysv
- ;;
- i*86sol2)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
- os=-solaris2
- ;;
- i386mach)
- basic_machine=i386-mach
- os=-mach
- ;;
- i386-vsta | vsta)
- basic_machine=i386-unknown
- os=-vsta
- ;;
- iris | iris4d)
- basic_machine=mips-sgi
- case $os in
- -irix*)
- ;;
- *)
- os=-irix4
- ;;
- esac
- ;;
- isi68 | isi)
- basic_machine=m68k-isi
- os=-sysv
- ;;
- m88k-omron*)
- basic_machine=m88k-omron
- ;;
- magnum | m3230)
- basic_machine=mips-mips
- os=-sysv
- ;;
- merlin)
- basic_machine=ns32k-utek
- os=-sysv
- ;;
- mingw32)
- basic_machine=i386-pc
- os=-mingw32
- ;;
- miniframe)
- basic_machine=m68000-convergent
- ;;
- *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*)
- basic_machine=m68k-atari
- os=-mint
- ;;
- mips3*-*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
- ;;
- mips3*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
- ;;
- monitor)
- basic_machine=m68k-rom68k
- os=-coff
- ;;
- morphos)
- basic_machine=powerpc-unknown
- os=-morphos
- ;;
- msdos)
- basic_machine=i386-pc
- os=-msdos
- ;;
- mvs)
- basic_machine=i370-ibm
- os=-mvs
- ;;
- ncr3000)
- basic_machine=i486-ncr
- os=-sysv4
- ;;
- netbsd386)
- basic_machine=i386-unknown
- os=-netbsd
- ;;
- netwinder)
- basic_machine=armv4l-rebel
- os=-linux
- ;;
- news | news700 | news800 | news900)
- basic_machine=m68k-sony
- os=-newsos
- ;;
- news1000)
- basic_machine=m68030-sony
- os=-newsos
- ;;
- news-3600 | risc-news)
- basic_machine=mips-sony
- os=-newsos
- ;;
- necv70)
- basic_machine=v70-nec
- os=-sysv
- ;;
- next | m*-next )
- basic_machine=m68k-next
- case $os in
- -nextstep* )
- ;;
- -ns2*)
- os=-nextstep2
- ;;
- *)
- os=-nextstep3
- ;;
- esac
- ;;
- nh3000)
- basic_machine=m68k-harris
- os=-cxux
- ;;
- nh[45]000)
- basic_machine=m88k-harris
- os=-cxux
- ;;
- nindy960)
- basic_machine=i960-intel
- os=-nindy
- ;;
- mon960)
- basic_machine=i960-intel
- os=-mon960
- ;;
- nonstopux)
- basic_machine=mips-compaq
- os=-nonstopux
- ;;
- np1)
- basic_machine=np1-gould
- ;;
- nsr-tandem)
- basic_machine=nsr-tandem
- ;;
- op50n-* | op60c-*)
- basic_machine=hppa1.1-oki
- os=-proelf
- ;;
- openrisc | openrisc-*)
- basic_machine=or32-unknown
- ;;
- os400)
- basic_machine=powerpc-ibm
- os=-os400
- ;;
- OSE68000 | ose68000)
- basic_machine=m68000-ericsson
- os=-ose
- ;;
- os68k)
- basic_machine=m68k-none
- os=-os68k
- ;;
- pa-hitachi)
- basic_machine=hppa1.1-hitachi
- os=-hiuxwe2
- ;;
- paragon)
- basic_machine=i860-intel
- os=-osf
- ;;
- pbd)
- basic_machine=sparc-tti
- ;;
- pbb)
- basic_machine=m68k-tti
- ;;
- pc532 | pc532-*)
- basic_machine=ns32k-pc532
- ;;
- pentium | p5 | k5 | k6 | nexgen | viac3)
- basic_machine=i586-pc
- ;;
- pentiumpro | p6 | 6x86 | athlon | athlon_*)
- basic_machine=i686-pc
- ;;
- pentiumii | pentium2 | pentiumiii | pentium3)
- basic_machine=i686-pc
- ;;
- pentium4)
- basic_machine=i786-pc
- ;;
- pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
- basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- pentiumpro-* | p6-* | 6x86-* | athlon-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- pentium4-*)
- basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- pn)
- basic_machine=pn-gould
- ;;
- power) basic_machine=power-ibm
- ;;
- ppc) basic_machine=powerpc-unknown
- ;;
- ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- ppcle | powerpclittle | ppc-le | powerpc-little)
- basic_machine=powerpcle-unknown
- ;;
- ppcle-* | powerpclittle-*)
- basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- ppc64) basic_machine=powerpc64-unknown
- ;;
- ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- ppc64le | powerpc64little | ppc64-le | powerpc64-little)
- basic_machine=powerpc64le-unknown
- ;;
- ppc64le-* | powerpc64little-*)
- basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
- ;;
- ps2)
- basic_machine=i386-ibm
- ;;
- pw32)
- basic_machine=i586-unknown
- os=-pw32
- ;;
- rom68k)
- basic_machine=m68k-rom68k
- os=-coff
- ;;
- rm[46]00)
- basic_machine=mips-siemens
- ;;
- rtpc | rtpc-*)
- basic_machine=romp-ibm
- ;;
- s390 | s390-*)
- basic_machine=s390-ibm
- ;;
- s390x | s390x-*)
- basic_machine=s390x-ibm
- ;;
- sa29200)
- basic_machine=a29k-amd
- os=-udi
- ;;
- sb1)
- basic_machine=mipsisa64sb1-unknown
- ;;
- sb1el)
- basic_machine=mipsisa64sb1el-unknown
- ;;
- sei)
- basic_machine=mips-sei
- os=-seiux
- ;;
- sequent)
- basic_machine=i386-sequent
- ;;
- sh)
- basic_machine=sh-hitachi
- os=-hms
- ;;
- sh64)
- basic_machine=sh64-unknown
- ;;
- sparclite-wrs | simso-wrs)
- basic_machine=sparclite-wrs
- os=-vxworks
- ;;
- sps7)
- basic_machine=m68k-bull
- os=-sysv2
- ;;
- spur)
- basic_machine=spur-unknown
- ;;
- st2000)
- basic_machine=m68k-tandem
- ;;
- stratus)
- basic_machine=i860-stratus
- os=-sysv4
- ;;
- sun2)
- basic_machine=m68000-sun
- ;;
- sun2os3)
- basic_machine=m68000-sun
- os=-sunos3
- ;;
- sun2os4)
- basic_machine=m68000-sun
- os=-sunos4
- ;;
- sun3os3)
- basic_machine=m68k-sun
- os=-sunos3
- ;;
- sun3os4)
- basic_machine=m68k-sun
- os=-sunos4
- ;;
- sun4os3)
- basic_machine=sparc-sun
- os=-sunos3
- ;;
- sun4os4)
- basic_machine=sparc-sun
- os=-sunos4
- ;;
- sun4sol2)
- basic_machine=sparc-sun
- os=-solaris2
- ;;
- sun3 | sun3-*)
- basic_machine=m68k-sun
- ;;
- sun4)
- basic_machine=sparc-sun
- ;;
- sun386 | sun386i | roadrunner)
- basic_machine=i386-sun
- ;;
- sv1)
- basic_machine=sv1-cray
- os=-unicos
- ;;
- symmetry)
- basic_machine=i386-sequent
- os=-dynix
- ;;
- t3e)
- basic_machine=alphaev5-cray
- os=-unicos
- ;;
- t90)
- basic_machine=t90-cray
- os=-unicos
- ;;
- tic54x | c54x*)
- basic_machine=tic54x-unknown
- os=-coff
- ;;
- tic55x | c55x*)
- basic_machine=tic55x-unknown
- os=-coff
- ;;
- tic6x | c6x*)
- basic_machine=tic6x-unknown
- os=-coff
- ;;
- tx39)
- basic_machine=mipstx39-unknown
- ;;
- tx39el)
- basic_machine=mipstx39el-unknown
- ;;
- toad1)
- basic_machine=pdp10-xkl
- os=-tops20
- ;;
- tower | tower-32)
- basic_machine=m68k-ncr
- ;;
- tpf)
- basic_machine=s390x-ibm
- os=-tpf
- ;;
- udi29k)
- basic_machine=a29k-amd
- os=-udi
- ;;
- ultra3)
- basic_machine=a29k-nyu
- os=-sym1
- ;;
- v810 | necv810)
- basic_machine=v810-nec
- os=-none
- ;;
- vaxv)
- basic_machine=vax-dec
- os=-sysv
- ;;
- vms)
- basic_machine=vax-dec
- os=-vms
- ;;
- vpp*|vx|vx-*)
- basic_machine=f301-fujitsu
- ;;
- vxworks960)
- basic_machine=i960-wrs
- os=-vxworks
- ;;
- vxworks68)
- basic_machine=m68k-wrs
- os=-vxworks
- ;;
- vxworks29k)
- basic_machine=a29k-wrs
- os=-vxworks
- ;;
- w65*)
- basic_machine=w65-wdc
- os=-none
- ;;
- w89k-*)
- basic_machine=hppa1.1-winbond
- os=-proelf
- ;;
- xbox)
- basic_machine=i686-pc
- os=-mingw32
- ;;
- xps | xps100)
- basic_machine=xps100-honeywell
- ;;
- ymp)
- basic_machine=ymp-cray
- os=-unicos
- ;;
- z8k-*-coff)
- basic_machine=z8k-unknown
- os=-sim
- ;;
- none)
- basic_machine=none-none
- os=-none
- ;;
-
-# Here we handle the default manufacturer of certain CPU types. It is in
-# some cases the only manufacturer, in others, it is the most popular.
- w89k)
- basic_machine=hppa1.1-winbond
- ;;
- op50n)
- basic_machine=hppa1.1-oki
- ;;
- op60c)
- basic_machine=hppa1.1-oki
- ;;
- romp)
- basic_machine=romp-ibm
- ;;
- mmix)
- basic_machine=mmix-knuth
- ;;
- rs6000)
- basic_machine=rs6000-ibm
- ;;
- vax)
- basic_machine=vax-dec
- ;;
- pdp10)
- # there are many clones, so DEC is not a safe bet
- basic_machine=pdp10-unknown
- ;;
- pdp11)
- basic_machine=pdp11-dec
- ;;
- we32k)
- basic_machine=we32k-att
- ;;
- sh[1234] | sh[24]a | sh[34]eb | sh[1234]le | sh[23]ele)
- basic_machine=sh-unknown
- ;;
- sparc | sparcv8 | sparcv9 | sparcv9b)
- basic_machine=sparc-sun
- ;;
- cydra)
- basic_machine=cydra-cydrome
- ;;
- orion)
- basic_machine=orion-highlevel
- ;;
- orion105)
- basic_machine=clipper-highlevel
- ;;
- mac | mpw | mac-mpw)
- basic_machine=m68k-apple
- ;;
- pmac | pmac-mpw)
- basic_machine=powerpc-apple
- ;;
- *-unknown)
- # Make sure to match an already-canonicalized machine name.
- ;;
- *)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
- exit 1
- ;;
-esac
-
-# Here we canonicalize certain aliases for manufacturers.
-case $basic_machine in
- *-digital*)
- basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
- ;;
- *-commodore*)
- basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
- ;;
- *)
- ;;
-esac
-
-# Decode manufacturer-specific aliases for certain operating systems.
-
-if [ x"$os" != x"" ]
-then
-case $os in
- # First match some system type aliases
- # that might get confused with valid system types.
- # -solaris* is a basic system type, with this one exception.
- -solaris1 | -solaris1.*)
- os=`echo $os | sed -e 's|solaris1|sunos4|'`
- ;;
- -solaris)
- os=-solaris2
- ;;
- -svr4*)
- os=-sysv4
- ;;
- -unixware*)
- os=-sysv4.2uw
- ;;
- -gnu/linux*)
- os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'`
- ;;
- # First accept the basic system types.
- # The portable systems comes first.
- # Each alternative MUST END IN A *, to match a version number.
- # -sysv* is not here because it comes later, after sysvr4.
- -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
- | -*vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[34]*\
- | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \
- | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
- | -aos* \
- | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
- | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
- | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* | -openbsd* \
- | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
- | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
- | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
- | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
- | -chorusos* | -chorusrdb* \
- | -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
- | -mingw32* | -linux-gnu* | -linux-uclibc* | -uxpv* | -beos* | -mpeix* | -udk* \
- | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
- | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
- | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
- | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
- | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
- | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \
- | -skyos* | -haiku*)
- # Remember, each alternative MUST END IN *, to match a version number.
- ;;
- -qnx*)
- case $basic_machine in
- x86-* | i*86-*)
- ;;
- *)
- os=-nto$os
- ;;
- esac
- ;;
- -nto-qnx*)
- ;;
- -nto*)
- os=`echo $os | sed -e 's|nto|nto-qnx|'`
- ;;
- -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \
- | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \
- | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*)
- ;;
- -mac*)
- os=`echo $os | sed -e 's|mac|macos|'`
- ;;
- -linux-dietlibc)
- os=-linux-dietlibc
- ;;
- -linux*)
- os=`echo $os | sed -e 's|linux|linux-gnu|'`
- ;;
- -sunos5*)
- os=`echo $os | sed -e 's|sunos5|solaris2|'`
- ;;
- -sunos6*)
- os=`echo $os | sed -e 's|sunos6|solaris3|'`
- ;;
- -opened*)
- os=-openedition
- ;;
- -os400*)
- os=-os400
- ;;
- -wince*)
- os=-wince
- ;;
- -osfrose*)
- os=-osfrose
- ;;
- -osf*)
- os=-osf
- ;;
- -utek*)
- os=-bsd
- ;;
- -dynix*)
- os=-bsd
- ;;
- -acis*)
- os=-aos
- ;;
- -atheos*)
- os=-atheos
- ;;
- -syllable*)
- os=-syllable
- ;;
- -386bsd)
- os=-bsd
- ;;
- -ctix* | -uts*)
- os=-sysv
- ;;
- -nova*)
- os=-rtmk-nova
- ;;
- -ns2 )
- os=-nextstep2
- ;;
- -nsk*)
- os=-nsk
- ;;
- # Preserve the version number of sinix5.
- -sinix5.*)
- os=`echo $os | sed -e 's|sinix|sysv|'`
- ;;
- -sinix*)
- os=-sysv4
- ;;
- -tpf*)
- os=-tpf
- ;;
- -triton*)
- os=-sysv3
- ;;
- -oss*)
- os=-sysv3
- ;;
- -svr4)
- os=-sysv4
- ;;
- -svr3)
- os=-sysv3
- ;;
- -sysvr4)
- os=-sysv4
- ;;
- # This must come after -sysvr4.
- -sysv*)
- ;;
- -ose*)
- os=-ose
- ;;
- -es1800*)
- os=-ose
- ;;
- -xenix)
- os=-xenix
- ;;
- -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
- os=-mint
- ;;
- -aros*)
- os=-aros
- ;;
- -kaos*)
- os=-kaos
- ;;
- -zvmoe)
- os=-zvmoe
- ;;
- -none)
- ;;
- *)
- # Get rid of the `-' at the beginning of $os.
- os=`echo $os | sed 's/[^-]*-//'`
- echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2
- exit 1
- ;;
-esac
-else
-
-# Here we handle the default operating systems that come with various machines.
-# The value should be what the vendor currently ships out the door with their
-# machine or put another way, the most popular os provided with the machine.
-
-# Note that if you're going to try to match "-MANUFACTURER" here (say,
-# "-sun"), then you have to tell the case statement up towards the top
-# that MANUFACTURER isn't an operating system. Otherwise, code above
-# will signal an error saying that MANUFACTURER isn't an operating
-# system, and we'll never get to this point.
-
-case $basic_machine in
- *-acorn)
- os=-riscix1.2
- ;;
- arm*-rebel)
- os=-linux
- ;;
- arm*-semi)
- os=-aout
- ;;
- c4x-* | tic4x-*)
- os=-coff
- ;;
- # This must come before the *-dec entry.
- pdp10-*)
- os=-tops20
- ;;
- pdp11-*)
- os=-none
- ;;
- *-dec | vax-*)
- os=-ultrix4.2
- ;;
- m68*-apollo)
- os=-domain
- ;;
- i386-sun)
- os=-sunos4.0.2
- ;;
- m68000-sun)
- os=-sunos3
- # This also exists in the configure program, but was not the
- # default.
- # os=-sunos4
- ;;
- m68*-cisco)
- os=-aout
- ;;
- mips*-cisco)
- os=-elf
- ;;
- mips*-*)
- os=-elf
- ;;
- or32-*)
- os=-coff
- ;;
- *-tti) # must be before sparc entry or we get the wrong os.
- os=-sysv3
- ;;
- sparc-* | *-sun)
- os=-sunos4.1.1
- ;;
- *-be)
- os=-beos
- ;;
- *-haiku)
- os=-haiku
- ;;
- *-ibm)
- os=-aix
- ;;
- *-knuth)
- os=-mmixware
- ;;
- *-wec)
- os=-proelf
- ;;
- *-winbond)
- os=-proelf
- ;;
- *-oki)
- os=-proelf
- ;;
- *-hp)
- os=-hpux
- ;;
- *-hitachi)
- os=-hiux
- ;;
- i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent)
- os=-sysv
- ;;
- *-cbm)
- os=-amigaos
- ;;
- *-dg)
- os=-dgux
- ;;
- *-dolphin)
- os=-sysv3
- ;;
- m68k-ccur)
- os=-rtu
- ;;
- m88k-omron*)
- os=-luna
- ;;
- *-next )
- os=-nextstep
- ;;
- *-sequent)
- os=-ptx
- ;;
- *-crds)
- os=-unos
- ;;
- *-ns)
- os=-genix
- ;;
- i370-*)
- os=-mvs
- ;;
- *-next)
- os=-nextstep3
- ;;
- *-gould)
- os=-sysv
- ;;
- *-highlevel)
- os=-bsd
- ;;
- *-encore)
- os=-bsd
- ;;
- *-sgi)
- os=-irix
- ;;
- *-siemens)
- os=-sysv4
- ;;
- *-masscomp)
- os=-rtu
- ;;
- f30[01]-fujitsu | f700-fujitsu)
- os=-uxpv
- ;;
- *-rom68k)
- os=-coff
- ;;
- *-*bug)
- os=-coff
- ;;
- *-apple)
- os=-macos
- ;;
- *-atari*)
- os=-mint
- ;;
- *)
- os=-none
- ;;
-esac
-fi
-
-# Here we handle the case where we know the os, and the CPU type, but not the
-# manufacturer. We pick the logical manufacturer.
-vendor=unknown
-case $basic_machine in
- *-unknown)
- case $os in
- -riscix*)
- vendor=acorn
- ;;
- -sunos*)
- vendor=sun
- ;;
- -aix*)
- vendor=ibm
- ;;
- -beos*)
- vendor=be
- ;;
- -hpux*)
- vendor=hp
- ;;
- -mpeix*)
- vendor=hp
- ;;
- -hiux*)
- vendor=hitachi
- ;;
- -unos*)
- vendor=crds
- ;;
- -dgux*)
- vendor=dg
- ;;
- -luna*)
- vendor=omron
- ;;
- -genix*)
- vendor=ns
- ;;
- -mvs* | -opened*)
- vendor=ibm
- ;;
- -os400*)
- vendor=ibm
- ;;
- -ptx*)
- vendor=sequent
- ;;
- -tpf*)
- vendor=ibm
- ;;
- -vxsim* | -vxworks* | -windiss*)
- vendor=wrs
- ;;
- -aux*)
- vendor=apple
- ;;
- -hms*)
- vendor=hitachi
- ;;
- -mpw* | -macos*)
- vendor=apple
- ;;
- -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
- vendor=atari
- ;;
- -vos*)
- vendor=stratus
- ;;
- esac
- basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
- ;;
-esac
-
-echo $basic_machine$os
-exit
-
-# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "timestamp='"
-# time-stamp-format: "%:y-%02m-%02d"
-# time-stamp-end: "'"
-# End:
diff --git a/depcomp b/depcomp
deleted file mode 100755
index 11e2d3b..0000000
--- a/depcomp
+++ /dev/null
@@ -1,522 +0,0 @@
-#! /bin/sh
-# depcomp - compile a program generating dependencies as side-effects
-
-scriptversion=2004-05-31.23
-
-# Copyright (C) 1999, 2000, 2003, 2004 Free Software Foundation, Inc.
-
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-# 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
-
-case $1 in
- '')
- echo "$0: No command. Try \`$0 --help' for more information." 1>&2
- exit 1;
- ;;
- -h | --h*)
- cat <<\EOF
-Usage: depcomp [--help] [--version] PROGRAM [ARGS]
-
-Run PROGRAMS ARGS to compile a file, generating dependencies
-as side-effects.
-
-Environment variables:
- depmode Dependency tracking mode.
- source Source file read by `PROGRAMS ARGS'.
- object Object file output by `PROGRAMS ARGS'.
- DEPDIR directory where to store dependencies.
- depfile Dependency file to output.
- tmpdepfile Temporary file to use when outputing dependencies.
- libtool Whether libtool is used (yes/no).
-
-Report bugs to <bug-automake@gnu.org>.
-EOF
- exit 0
- ;;
- -v | --v*)
- echo "depcomp $scriptversion"
- exit 0
- ;;
-esac
-
-if test -z "$depmode" || test -z "$source" || test -z "$object"; then
- echo "depcomp: Variables source, object and depmode must be set" 1>&2
- exit 1
-fi
-
-# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
-depfile=${depfile-`echo "$object" |
- sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
-tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
-
-rm -f "$tmpdepfile"
-
-# Some modes work just like other modes, but use different flags. We
-# parameterize here, but still list the modes in the big case below,
-# to make depend.m4 easier to write. Note that we *cannot* use a case
-# here, because this file can only contain one case statement.
-if test "$depmode" = hp; then
- # HP compiler uses -M and no extra arg.
- gccflag=-M
- depmode=gcc
-fi
-
-if test "$depmode" = dashXmstdout; then
- # This is just like dashmstdout with a different argument.
- dashmflag=-xM
- depmode=dashmstdout
-fi
-
-case "$depmode" in
-gcc3)
-## gcc 3 implements dependency tracking that does exactly what
-## we want. Yay! Note: for some reason libtool 1.4 doesn't like
-## it if -MD -MP comes after the -MF stuff. Hmm.
- "$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
- stat=$?
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile"
- exit $stat
- fi
- mv "$tmpdepfile" "$depfile"
- ;;
-
-gcc)
-## There are various ways to get dependency output from gcc. Here's
-## why we pick this rather obscure method:
-## - Don't want to use -MD because we'd like the dependencies to end
-## up in a subdir. Having to rename by hand is ugly.
-## (We might end up doing this anyway to support other compilers.)
-## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
-## -MM, not -M (despite what the docs say).
-## - Using -M directly means running the compiler twice (even worse
-## than renaming).
- if test -z "$gccflag"; then
- gccflag=-MD,
- fi
- "$@" -Wp,"$gccflag$tmpdepfile"
- stat=$?
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile"
- exit $stat
- fi
- rm -f "$depfile"
- echo "$object : \\" > "$depfile"
- alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
-## The second -e expression handles DOS-style file names with drive letters.
- sed -e 's/^[^:]*: / /' \
- -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
-## This next piece of magic avoids the `deleted header file' problem.
-## The problem is that when a header file which appears in a .P file
-## is deleted, the dependency causes make to die (because there is
-## typically no way to rebuild the header). We avoid this by adding
-## dummy dependencies for each header file. Too bad gcc doesn't do
-## this for us directly.
- tr ' ' '
-' < "$tmpdepfile" |
-## Some versions of gcc put a space before the `:'. On the theory
-## that the space means something, we add a space to the output as
-## well.
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly. Breaking it into two sed invocations is a workaround.
- sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- rm -f "$tmpdepfile"
- ;;
-
-hp)
- # This case exists only to let depend.m4 do its work. It works by
- # looking at the text of this script. This case will never be run,
- # since it is checked for above.
- exit 1
- ;;
-
-sgi)
- if test "$libtool" = yes; then
- "$@" "-Wp,-MDupdate,$tmpdepfile"
- else
- "$@" -MDupdate "$tmpdepfile"
- fi
- stat=$?
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile"
- exit $stat
- fi
- rm -f "$depfile"
-
- if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
- echo "$object : \\" > "$depfile"
-
- # Clip off the initial element (the dependent). Don't try to be
- # clever and replace this with sed code, as IRIX sed won't handle
- # lines with more than a fixed number of characters (4096 in
- # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
- # the IRIX cc adds comments like `#:fec' to the end of the
- # dependency line.
- tr ' ' '
-' < "$tmpdepfile" \
- | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
- tr '
-' ' ' >> $depfile
- echo >> $depfile
-
- # The second pass generates a dummy entry for each header file.
- tr ' ' '
-' < "$tmpdepfile" \
- | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
- >> $depfile
- else
- # The sourcefile does not contain any dependencies, so just
- # store a dummy comment line, to avoid errors with the Makefile
- # "include basename.Plo" scheme.
- echo "#dummy" > "$depfile"
- fi
- rm -f "$tmpdepfile"
- ;;
-
-aix)
- # The C for AIX Compiler uses -M and outputs the dependencies
- # in a .u file. In older versions, this file always lives in the
- # current directory. Also, the AIX compiler puts `$object:' at the
- # start of each line; $object doesn't have directory information.
- # Version 6 uses the directory in both cases.
- stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'`
- tmpdepfile="$stripped.u"
- if test "$libtool" = yes; then
- "$@" -Wc,-M
- else
- "$@" -M
- fi
- stat=$?
-
- if test -f "$tmpdepfile"; then :
- else
- stripped=`echo "$stripped" | sed 's,^.*/,,'`
- tmpdepfile="$stripped.u"
- fi
-
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile"
- exit $stat
- fi
-
- if test -f "$tmpdepfile"; then
- outname="$stripped.o"
- # Each line is of the form `foo.o: dependent.h'.
- # Do two passes, one to just change these to
- # `$object: dependent.h' and one to simply `dependent.h:'.
- sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
- sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
- else
- # The sourcefile does not contain any dependencies, so just
- # store a dummy comment line, to avoid errors with the Makefile
- # "include basename.Plo" scheme.
- echo "#dummy" > "$depfile"
- fi
- rm -f "$tmpdepfile"
- ;;
-
-icc)
- # Intel's C compiler understands `-MD -MF file'. However on
- # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
- # ICC 7.0 will fill foo.d with something like
- # foo.o: sub/foo.c
- # foo.o: sub/foo.h
- # which is wrong. We want:
- # sub/foo.o: sub/foo.c
- # sub/foo.o: sub/foo.h
- # sub/foo.c:
- # sub/foo.h:
- # ICC 7.1 will output
- # foo.o: sub/foo.c sub/foo.h
- # and will wrap long lines using \ :
- # foo.o: sub/foo.c ... \
- # sub/foo.h ... \
- # ...
-
- "$@" -MD -MF "$tmpdepfile"
- stat=$?
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile"
- exit $stat
- fi
- rm -f "$depfile"
- # Each line is of the form `foo.o: dependent.h',
- # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
- # Do two passes, one to just change these to
- # `$object: dependent.h' and one to simply `dependent.h:'.
- sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
- # Some versions of the HPUX 10.20 sed can't process this invocation
- # correctly. Breaking it into two sed invocations is a workaround.
- sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
- sed -e 's/$/ :/' >> "$depfile"
- rm -f "$tmpdepfile"
- ;;
-
-tru64)
- # The Tru64 compiler uses -MD to generate dependencies as a side
- # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
- # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
- # dependencies in `foo.d' instead, so we check for that too.
- # Subdirectories are respected.
- dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
- test "x$dir" = "x$object" && dir=
- base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
-
- if test "$libtool" = yes; then
- # Dependencies are output in .lo.d with libtool 1.4.
- # With libtool 1.5 they are output both in $dir.libs/$base.o.d
- # and in $dir.libs/$base.o.d and $dir$base.o.d. We process the
- # latter, because the former will be cleaned when $dir.libs is
- # erased.
- tmpdepfile1="$dir.libs/$base.lo.d"
- tmpdepfile2="$dir$base.o.d"
- tmpdepfile3="$dir.libs/$base.d"
- "$@" -Wc,-MD
- else
- tmpdepfile1="$dir$base.o.d"
- tmpdepfile2="$dir$base.d"
- tmpdepfile3="$dir$base.d"
- "$@" -MD
- fi
-
- stat=$?
- if test $stat -eq 0; then :
- else
- rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
- exit $stat
- fi
-
- if test -f "$tmpdepfile1"; then
- tmpdepfile="$tmpdepfile1"
- elif test -f "$tmpdepfile2"; then
- tmpdepfile="$tmpdepfile2"
- else
- tmpdepfile="$tmpdepfile3"
- fi
- if test -f "$tmpdepfile"; then
- sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
- # That's a tab and a space in the [].
- sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
- else
- echo "#dummy" > "$depfile"
- fi
- rm -f "$tmpdepfile"
- ;;
-
-#nosideeffect)
- # This comment above is used by automake to tell side-effect
- # dependency tracking mechanisms from slower ones.
-
-dashmstdout)
- # Important note: in order to support this mode, a compiler *must*
- # always write the preprocessed file to stdout, regardless of -o.
- "$@" || exit $?
-
- # Remove the call to Libtool.
- if test "$libtool" = yes; then
- while test $1 != '--mode=compile'; do
- shift
- done
- shift
- fi
-
- # Remove `-o $object'.
- IFS=" "
- for arg
- do
- case $arg in
- -o)
- shift
- ;;
- $object)
- shift
- ;;
- *)
- set fnord "$@" "$arg"
- shift # fnord
- shift # $arg
- ;;
- esac
- done
-
- test -z "$dashmflag" && dashmflag=-M
- # Require at least two characters before searching for `:'
- # in the target name. This is to cope with DOS-style filenames:
- # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
- "$@" $dashmflag |
- sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
- rm -f "$depfile"
- cat < "$tmpdepfile" > "$depfile"
- tr ' ' '
-' < "$tmpdepfile" | \
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly. Breaking it into two sed invocations is a workaround.
- sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- rm -f "$tmpdepfile"
- ;;
-
-dashXmstdout)
- # This case only exists to satisfy depend.m4. It is never actually
- # run, as this mode is specially recognized in the preamble.
- exit 1
- ;;
-
-makedepend)
- "$@" || exit $?
- # Remove any Libtool call
- if test "$libtool" = yes; then
- while test $1 != '--mode=compile'; do
- shift
- done
- shift
- fi
- # X makedepend
- shift
- cleared=no
- for arg in "$@"; do
- case $cleared in
- no)
- set ""; shift
- cleared=yes ;;
- esac
- case "$arg" in
- -D*|-I*)
- set fnord "$@" "$arg"; shift ;;
- # Strip any option that makedepend may not understand. Remove
- # the object too, otherwise makedepend will parse it as a source file.
- -*|$object)
- ;;
- *)
- set fnord "$@" "$arg"; shift ;;
- esac
- done
- obj_suffix="`echo $object | sed 's/^.*\././'`"
- touch "$tmpdepfile"
- ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
- rm -f "$depfile"
- cat < "$tmpdepfile" > "$depfile"
- sed '1,2d' "$tmpdepfile" | tr ' ' '
-' | \
-## Some versions of the HPUX 10.20 sed can't process this invocation
-## correctly. Breaking it into two sed invocations is a workaround.
- sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- rm -f "$tmpdepfile" "$tmpdepfile".bak
- ;;
-
-cpp)
- # Important note: in order to support this mode, a compiler *must*
- # always write the preprocessed file to stdout.
- "$@" || exit $?
-
- # Remove the call to Libtool.
- if test "$libtool" = yes; then
- while test $1 != '--mode=compile'; do
- shift
- done
- shift
- fi
-
- # Remove `-o $object'.
- IFS=" "
- for arg
- do
- case $arg in
- -o)
- shift
- ;;
- $object)
- shift
- ;;
- *)
- set fnord "$@" "$arg"
- shift # fnord
- shift # $arg
- ;;
- esac
- done
-
- "$@" -E |
- sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
- sed '$ s: \\$::' > "$tmpdepfile"
- rm -f "$depfile"
- echo "$object : \\" > "$depfile"
- cat < "$tmpdepfile" >> "$depfile"
- sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
- rm -f "$tmpdepfile"
- ;;
-
-msvisualcpp)
- # Important note: in order to support this mode, a compiler *must*
- # always write the preprocessed file to stdout, regardless of -o,
- # because we must use -o when running libtool.
- "$@" || exit $?
- IFS=" "
- for arg
- do
- case "$arg" in
- "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
- set fnord "$@"
- shift
- shift
- ;;
- *)
- set fnord "$@" "$arg"
- shift
- shift
- ;;
- esac
- done
- "$@" -E |
- sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
- rm -f "$depfile"
- echo "$object : \\" > "$depfile"
- . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
- echo " " >> "$depfile"
- . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
- rm -f "$tmpdepfile"
- ;;
-
-none)
- exec "$@"
- ;;
-
-*)
- echo "Unknown depmode $depmode" 1>&2
- exit 1
- ;;
-esac
-
-exit 0
-
-# Local Variables:
-# mode: shell-script
-# sh-indentation: 2
-# eval: (add-hook 'write-file-hooks 'time-stamp)
-# time-stamp-start: "scriptversion="
-# time-stamp-format: "%:y-%02m-%02d.%02H"
-# time-stamp-end: "$"
-# End:
diff --git a/familiar/Makefile.am b/familiar/Makefile.am
deleted file mode 100644
index 8b13789..0000000
--- a/familiar/Makefile.am
+++ /dev/null
@@ -1 +0,0 @@
-
diff --git a/familiar/control-unstripped.in b/familiar/control-unstripped.in
deleted file mode 100644
index bccea05..0000000
--- a/familiar/control-unstripped.in
+++ /dev/null
@@ -1,22 +0,0 @@
-Package: opkg-unstripped
-Replaces: opkg
-Version: @VERSION@
-Section: base
-Priority: required
-Essential: yes
-Architecture: @host_cpu@
-Maintainer: Jamey Hicks <jamey@handhelds.org>
-Source: http://www.handhelds.org/packages/opkg/opkg-@VERSION@.tar.gz
-Depends: libc6, busybox
-Description: lightweight package management system
- opkg is the Itsy Package Management System, for handling
- installation and removal of packages on a system. It can
- recursively follow dependencies and download all packages
- necessary to install a particular package.
- .
- opkg knows how to install both .ipk and .deb packages.
- .
- opkg is intended to serve the same functions (and more) for
- Familiar that dpkg and apt serve for Debian, (while taking
- up much less space).
-
diff --git a/familiar/control.in b/familiar/control.in
deleted file mode 100644
index d1532cf..0000000
--- a/familiar/control.in
+++ /dev/null
@@ -1,21 +0,0 @@
-Package: opkg
-Version: @VERSION@
-Section: base
-Priority: required
-Essential: yes
-Architecture: @host_cpu@
-Maintainer: Pierluigi Frullani <pigi@frumar.it>
-Source: http://www.handhelds.org/packages/opkg/opkg-@VERSION@.tar.gz
-Depends: libc6, libopkg (>= @VERSION@)
-Description: lightweight package management system
- opkg is the Itsy Package Management System, for handling
- installation and removal of packages on a system. It can
- recursively follow dependencies and download all packages
- necessary to install a particular package.
- .
- opkg knows how to install both .ipk and .deb packages.
- .
- opkg is intended to serve the same functions (and more) for
- Familiar that dpkg and apt serve for Debian, (while taking
- up much less space).
-
diff --git a/familiar/libopkg-control.in b/familiar/libopkg-control.in
deleted file mode 100644
index b1b672d..0000000
--- a/familiar/libopkg-control.in
+++ /dev/null
@@ -1,21 +0,0 @@
-Package: libopkg
-Version: @VERSION@
-Section: base
-Priority: optional
-Essential: yes
-Architecture: @host_cpu@
-Maintainer: Jamey Hicks <jamey@handhelds.org>
-Source: http://www.handhelds.org/packages/opkg/opkg-@VERSION@.tar.gz
-Depends: libc6, busybox
-Description: lightweight package management system
- opkg is the Itsy Package Management System, for handling
- installation and removal of packages on a system. It can
- recursively follow dependencies and download all packages
- necessary to install a particular package.
- .
- opkg knows how to install both .ipk and .deb packages.
- .
- opkg is intended to serve the same functions (and more) for
- Familiar that dpkg and apt serve for Debian, (while taking
- up much less space).
-
diff --git a/familiar/libopkg-dev-control.in b/familiar/libopkg-dev-control.in
deleted file mode 100644
index a11caab..0000000
--- a/familiar/libopkg-dev-control.in
+++ /dev/null
@@ -1,21 +0,0 @@
-Package: libopkg-dev
-Version: @VERSION@
-Section: base
-Priority: optional
-Essential: yes
-Architecture: @host_cpu@
-Maintainer: Jamey Hicks <jamey@handhelds.org>
-Source: http://www.handhelds.org/packages/opkg/opkg-@VERSION@.tar.gz
-Depends: libopkg
-Description: lightweight package management system
- opkg is the Itsy Package Management System, for handling
- installation and removal of packages on a system. It can
- recursively follow dependencies and download all packages
- necessary to install a particular package.
- .
- opkg knows how to install both .ipk and .deb packages.
- .
- opkg is intended to serve the same functions (and more) for
- Familiar that dpkg and apt serve for Debian, (while taking
- up much less space).
-
diff --git a/install-sh b/install-sh
deleted file mode 100755
index a9386e9..0000000
--- a/install-sh
+++ /dev/null
@@ -1,294 +0,0 @@
-#!/bin/sh
-#
-# install - install a program, script, or datafile
-#
-# This originates from X11R5 (mit/util/scripts/install.sh), which was
-# later released in X11R6 (xc/config/util/install.sh) with the
-# following copyright and license.
-#
-# Copyright (C) 1994 X Consortium
-#
-# Permission is hereby granted, free of charge, to any person obtaining a copy
-# of this software and associated documentation files (the "Software"), to
-# deal in the Software without restriction, including without limitation the
-# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
-# sell copies of the Software, and to permit persons to whom the Software is
-# furnished to do so, subject to the following conditions:
-#
-# The above copyright notice and this permission notice shall be included in
-# all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
-# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
-# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-#
-# Except as contained in this notice, the name of the X Consortium shall not
-# be used in advertising or otherwise to promote the sale, use or other deal-
-# ings in this Software without prior written authorization from the X Consor-
-# tium.
-#
-#
-# FSF changes to this file are in the public domain.
-#
-# Calling this script install-sh is preferred over install.sh, to prevent
-# `make' implicit rules from creating a file called install from it
-# when there is no Makefile.
-#
-# This script is compatible with the BSD install script, but was written
-# from scratch. It can only install one file at a time, a restriction
-# shared with many OS's install programs.
-
-
-# set DOITPROG to echo to test this script
-
-# Don't use :- since 4.3BSD and earlier shells don't like it.
-doit="${DOITPROG-}"
-
-
-# put in absolute paths if you don't have them in your path; or use env. vars.
-
-mvprog="${MVPROG-mv}"
-cpprog="${CPPROG-cp}"
-chmodprog="${CHMODPROG-chmod}"
-chownprog="${CHOWNPROG-chown}"
-chgrpprog="${CHGRPPROG-chgrp}"
-stripprog="${STRIPPROG-strip}"
-rmprog="${RMPROG-rm}"
-mkdirprog="${MKDIRPROG-mkdir}"
-
-transformbasename=""
-transform_arg=""
-instcmd="$mvprog"
-chmodcmd="$chmodprog 0755"
-chowncmd=""
-chgrpcmd=""
-stripcmd=""
-rmcmd="$rmprog -f"
-mvcmd="$mvprog"
-src=""
-dst=""
-dir_arg=""
-
-while [ x"$1" != x ]; do
- case $1 in
- -c) instcmd=$cpprog
- shift
- continue;;
-
- -d) dir_arg=true
- shift
- continue;;
-
- -m) chmodcmd="$chmodprog $2"
- shift
- shift
- continue;;
-
- -o) chowncmd="$chownprog $2"
- shift
- shift
- continue;;
-
- -g) chgrpcmd="$chgrpprog $2"
- shift
- shift
- continue;;
-
- -s) stripcmd=$stripprog
- shift
- continue;;
-
- -t=*) transformarg=`echo $1 | sed 's/-t=//'`
- shift
- continue;;
-
- -b=*) transformbasename=`echo $1 | sed 's/-b=//'`
- shift
- continue;;
-
- *) if [ x"$src" = x ]
- then
- src=$1
- else
- # this colon is to work around a 386BSD /bin/sh bug
- :
- dst=$1
- fi
- shift
- continue;;
- esac
-done
-
-if [ x"$src" = x ]
-then
- echo "$0: no input file specified" >&2
- exit 1
-else
- :
-fi
-
-if [ x"$dir_arg" != x ]; then
- dst=$src
- src=""
-
- if [ -d "$dst" ]; then
- instcmd=:
- chmodcmd=""
- else
- instcmd=$mkdirprog
- fi
-else
-
-# Waiting for this to be detected by the "$instcmd $src $dsttmp" command
-# might cause directories to be created, which would be especially bad
-# if $src (and thus $dsttmp) contains '*'.
-
- if [ -f "$src" ] || [ -d "$src" ]
- then
- :
- else
- echo "$0: $src does not exist" >&2
- exit 1
- fi
-
- if [ x"$dst" = x ]
- then
- echo "$0: no destination specified" >&2
- exit 1
- else
- :
- fi
-
-# If destination is a directory, append the input filename; if your system
-# does not like double slashes in filenames, you may need to add some logic
-
- if [ -d "$dst" ]
- then
- dst=$dst/`basename "$src"`
- else
- :
- fi
-fi
-
-## this sed command emulates the dirname command
-dstdir=`echo "$dst" | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
-
-# Make sure that the destination directory exists.
-# this part is taken from Noah Friedman's mkinstalldirs script
-
-# Skip lots of stat calls in the usual case.
-if [ ! -d "$dstdir" ]; then
-defaultIFS='
- '
-IFS="${IFS-$defaultIFS}"
-
-oIFS=$IFS
-# Some sh's can't handle IFS=/ for some reason.
-IFS='%'
-set - `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'`
-IFS=$oIFS
-
-pathcomp=''
-
-while [ $# -ne 0 ] ; do
- pathcomp=$pathcomp$1
- shift
-
- if [ ! -d "$pathcomp" ] ;
- then
- $mkdirprog "$pathcomp"
- else
- :
- fi
-
- pathcomp=$pathcomp/
-done
-fi
-
-if [ x"$dir_arg" != x ]
-then
- $doit $instcmd "$dst" &&
-
- if [ x"$chowncmd" != x ]; then $doit $chowncmd "$dst"; else : ; fi &&
- if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd "$dst"; else : ; fi &&
- if [ x"$stripcmd" != x ]; then $doit $stripcmd "$dst"; else : ; fi &&
- if [ x"$chmodcmd" != x ]; then $doit $chmodcmd "$dst"; else : ; fi
-else
-
-# If we're going to rename the final executable, determine the name now.
-
- if [ x"$transformarg" = x ]
- then
- dstfile=`basename "$dst"`
- else
- dstfile=`basename "$dst" $transformbasename |
- sed $transformarg`$transformbasename
- fi
-
-# don't allow the sed command to completely eliminate the filename
-
- if [ x"$dstfile" = x ]
- then
- dstfile=`basename "$dst"`
- else
- :
- fi
-
-# Make a couple of temp file names in the proper directory.
-
- dsttmp=$dstdir/_inst.$$_
- rmtmp=$dstdir/_rm.$$_
-
-# Trap to clean up temp files at exit.
-
- trap 'status=$?; rm -f "$dsttmp" "$rmtmp" && exit $status' 0
- trap '(exit $?); exit' 1 2 13 15
-
-# Move or copy the file name to the temp name
-
- $doit $instcmd "$src" "$dsttmp" &&
-
-# and set any options; do chmod last to preserve setuid bits
-
-# If any of these fail, we abort the whole thing. If we want to
-# ignore errors from any of these, just make sure not to ignore
-# errors from the above "$doit $instcmd $src $dsttmp" command.
-
- if [ x"$chowncmd" != x ]; then $doit $chowncmd "$dsttmp"; else :;fi &&
- if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd "$dsttmp"; else :;fi &&
- if [ x"$stripcmd" != x ]; then $doit $stripcmd "$dsttmp"; else :;fi &&
- if [ x"$chmodcmd" != x ]; then $doit $chmodcmd "$dsttmp"; else :;fi &&
-
-# Now remove or move aside any old file at destination location. We try this
-# two ways since rm can't unlink itself on some systems and the destination
-# file might be busy for other reasons. In this case, the final cleanup
-# might fail but the new file should still install successfully.
-
-{
- if [ -f "$dstdir/$dstfile" ]
- then
- $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null ||
- $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null ||
- {
- echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2
- (exit 1); exit
- }
- else
- :
- fi
-} &&
-
-# Now rename the file to the real destination.
-
- $doit $mvcmd "$dsttmp" "$dstdir/$dstfile"
-
-fi &&
-
-# The final little trick to "correctly" pass the exit status to the exit trap.
-
-{
- (exit 0); exit
-}
diff --git a/ltmain.sh b/ltmain.sh
deleted file mode 100644
index 9e71d27..0000000
--- a/ltmain.sh
+++ /dev/null
@@ -1,6530 +0,0 @@
-# ltmain.sh - Provide generalized library-building support services.
-# NOTE: Changing this file will not affect anything until you rerun configure.
-#
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005
-# Free Software Foundation, Inc.
-# Originally by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-# General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-#
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-basename="s,^.*/,,g"
-
-# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
-# is ksh but when the shell is invoked as "sh" and the current value of
-# the _XPG environment variable is not equal to 1 (one), the special
-# positional parameter $0, within a function call, is the name of the
-# function.
-progpath="$0"
-
-# The name of this program:
-progname=`echo "$progpath" | $SED $basename`
-modename="$progname"
-
-# Global variables:
-EXIT_SUCCESS=0
-EXIT_FAILURE=1
-
-PROGRAM=ltmain.sh
-PACKAGE=libtool
-VERSION=1.5.20
-TIMESTAMP=" (1.1220.2.287 2005/08/31 18:54:15)"
-
-# See if we are running on zsh, and set the options which allow our
-# commands through without removal of \ escapes.
-if test -n "${ZSH_VERSION+set}" ; then
- setopt NO_GLOB_SUBST
-fi
-
-# Check that we have a working $echo.
-if test "X$1" = X--no-reexec; then
- # Discard the --no-reexec flag, and continue.
- shift
-elif test "X$1" = X--fallback-echo; then
- # Avoid inline document here, it may be left over
- :
-elif test "X`($echo '\t') 2>/dev/null`" = 'X\t'; then
- # Yippee, $echo works!
- :
-else
- # Restart under the correct shell, and then maybe $echo will work.
- exec $SHELL "$progpath" --no-reexec ${1+"$@"}
-fi
-
-if test "X$1" = X--fallback-echo; then
- # used as fallback echo
- shift
- cat <<EOF
-$*
-EOF
- exit $EXIT_SUCCESS
-fi
-
-default_mode=
-help="Try \`$progname --help' for more information."
-magic="%%%MAGIC variable%%%"
-mkdir="mkdir"
-mv="mv -f"
-rm="rm -f"
-
-# Sed substitution that helps us do robust quoting. It backslashifies
-# metacharacters that are still active within double-quoted strings.
-Xsed="${SED}"' -e 1s/^X//'
-sed_quote_subst='s/\([\\`\\"$\\\\]\)/\\\1/g'
-# test EBCDIC or ASCII
-case `echo X|tr X '\101'` in
- A) # ASCII based system
- # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr
- SP2NL='tr \040 \012'
- NL2SP='tr \015\012 \040\040'
- ;;
- *) # EBCDIC based system
- SP2NL='tr \100 \n'
- NL2SP='tr \r\n \100\100'
- ;;
-esac
-
-# NLS nuisances.
-# Only set LANG and LC_ALL to C if already set.
-# These must not be set unconditionally because not all systems understand
-# e.g. LANG=C (notably SCO).
-# We save the old values to restore during execute mode.
-if test "${LC_ALL+set}" = set; then
- save_LC_ALL="$LC_ALL"; LC_ALL=C; export LC_ALL
-fi
-if test "${LANG+set}" = set; then
- save_LANG="$LANG"; LANG=C; export LANG
-fi
-
-# Make sure IFS has a sensible default
-lt_nl='
-'
-IFS=" $lt_nl"
-
-if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
- $echo "$modename: not configured to build any kind of library" 1>&2
- $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
- exit $EXIT_FAILURE
-fi
-
-# Global variables.
-mode=$default_mode
-nonopt=
-prev=
-prevopt=
-run=
-show="$echo"
-show_help=
-execute_dlfiles=
-lo2o="s/\\.lo\$/.${objext}/"
-o2lo="s/\\.${objext}\$/.lo/"
-
-#####################################
-# Shell function definitions:
-# This seems to be the best place for them
-
-# func_win32_libid arg
-# return the library type of file 'arg'
-#
-# Need a lot of goo to handle *both* DLLs and import libs
-# Has to be a shell function in order to 'eat' the argument
-# that is supplied when $file_magic_command is called.
-func_win32_libid ()
-{
- win32_libid_type="unknown"
- win32_fileres=`file -L $1 2>/dev/null`
- case $win32_fileres in
- *ar\ archive\ import\ library*) # definitely import
- win32_libid_type="x86 archive import"
- ;;
- *ar\ archive*) # could be an import, or static
- if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | \
- $EGREP -e 'file format pe-i386(.*architecture: i386)?' >/dev/null ; then
- win32_nmres=`eval $NM -f posix -A $1 | \
- sed -n -e '1,100{/ I /{x;/import/!{s/^/import/;h;p;};x;};}'`
- if test "X$win32_nmres" = "Ximport" ; then
- win32_libid_type="x86 archive import"
- else
- win32_libid_type="x86 archive static"
- fi
- fi
- ;;
- *DLL*)
- win32_libid_type="x86 DLL"
- ;;
- *executable*) # but shell scripts are "executable" too...
- case $win32_fileres in
- *MS\ Windows\ PE\ Intel*)
- win32_libid_type="x86 DLL"
- ;;
- esac
- ;;
- esac
- $echo $win32_libid_type
-}
-
-
-# func_infer_tag arg
-# Infer tagged configuration to use if any are available and
-# if one wasn't chosen via the "--tag" command line option.
-# Only attempt this if the compiler in the base compile
-# command doesn't match the default compiler.
-# arg is usually of the form 'gcc ...'
-func_infer_tag ()
-{
- if test -n "$available_tags" && test -z "$tagname"; then
- CC_quoted=
- for arg in $CC; do
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- CC_quoted="$CC_quoted $arg"
- done
- case $@ in
- # Blanks in the command may have been stripped by the calling shell,
- # but not from the CC environment variable when configure was run.
- " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*) ;;
- # Blanks at the start of $base_compile will cause this to fail
- # if we don't check for them as well.
- *)
- for z in $available_tags; do
- if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
- # Evaluate the configuration.
- eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
- CC_quoted=
- for arg in $CC; do
- # Double-quote args containing other shell metacharacters.
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- CC_quoted="$CC_quoted $arg"
- done
- case "$@ " in
- " $CC "* | "$CC "* | " `$echo $CC` "* | "`$echo $CC` "* | " $CC_quoted"* | "$CC_quoted "* | " `$echo $CC_quoted` "* | "`$echo $CC_quoted` "*)
- # The compiler in the base compile command matches
- # the one in the tagged configuration.
- # Assume this is the tagged configuration we want.
- tagname=$z
- break
- ;;
- esac
- fi
- done
- # If $tagname still isn't set, then no tagged configuration
- # was found and let the user know that the "--tag" command
- # line option must be used.
- if test -z "$tagname"; then
- $echo "$modename: unable to infer tagged configuration"
- $echo "$modename: specify a tag with \`--tag'" 1>&2
- exit $EXIT_FAILURE
-# else
-# $echo "$modename: using $tagname tagged configuration"
- fi
- ;;
- esac
- fi
-}
-
-
-# func_extract_an_archive dir oldlib
-func_extract_an_archive ()
-{
- f_ex_an_ar_dir="$1"; shift
- f_ex_an_ar_oldlib="$1"
-
- $show "(cd $f_ex_an_ar_dir && $AR x $f_ex_an_ar_oldlib)"
- $run eval "(cd \$f_ex_an_ar_dir && $AR x \$f_ex_an_ar_oldlib)" || exit $?
- if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
- :
- else
- $echo "$modename: ERROR: object name conflicts: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" 1>&2
- exit $EXIT_FAILURE
- fi
-}
-
-# func_extract_archives gentop oldlib ...
-func_extract_archives ()
-{
- my_gentop="$1"; shift
- my_oldlibs=${1+"$@"}
- my_oldobjs=""
- my_xlib=""
- my_xabs=""
- my_xdir=""
- my_status=""
-
- $show "${rm}r $my_gentop"
- $run ${rm}r "$my_gentop"
- $show "$mkdir $my_gentop"
- $run $mkdir "$my_gentop"
- my_status=$?
- if test "$my_status" -ne 0 && test ! -d "$my_gentop"; then
- exit $my_status
- fi
-
- for my_xlib in $my_oldlibs; do
- # Extract the objects.
- case $my_xlib in
- [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;;
- *) my_xabs=`pwd`"/$my_xlib" ;;
- esac
- my_xlib=`$echo "X$my_xlib" | $Xsed -e 's%^.*/%%'`
- my_xdir="$my_gentop/$my_xlib"
-
- $show "${rm}r $my_xdir"
- $run ${rm}r "$my_xdir"
- $show "$mkdir $my_xdir"
- $run $mkdir "$my_xdir"
- status=$?
- if test "$status" -ne 0 && test ! -d "$my_xdir"; then
- exit $status
- fi
- case $host in
- *-darwin*)
- $show "Extracting $my_xabs"
- # Do not bother doing anything if just a dry run
- if test -z "$run"; then
- darwin_orig_dir=`pwd`
- cd $my_xdir || exit $?
- darwin_archive=$my_xabs
- darwin_curdir=`pwd`
- darwin_base_archive=`$echo "X$darwin_archive" | $Xsed -e 's%^.*/%%'`
- darwin_arches=`lipo -info "$darwin_archive" 2>/dev/null | $EGREP Architectures 2>/dev/null`
- if test -n "$darwin_arches"; then
- darwin_arches=`echo "$darwin_arches" | $SED -e 's/.*are://'`
- darwin_arch=
- $show "$darwin_base_archive has multiple architectures $darwin_arches"
- for darwin_arch in $darwin_arches ; do
- mkdir -p "unfat-$$/${darwin_base_archive}-${darwin_arch}"
- lipo -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}"
- cd "unfat-$$/${darwin_base_archive}-${darwin_arch}"
- func_extract_an_archive "`pwd`" "${darwin_base_archive}"
- cd "$darwin_curdir"
- $rm "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}"
- done # $darwin_arches
- ## Okay now we have a bunch of thin objects, gotta fatten them up :)
- darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print| xargs basename | sort -u | $NL2SP`
- darwin_file=
- darwin_files=
- for darwin_file in $darwin_filelist; do
- darwin_files=`find unfat-$$ -name $darwin_file -print | $NL2SP`
- lipo -create -output "$darwin_file" $darwin_files
- done # $darwin_filelist
- ${rm}r unfat-$$
- cd "$darwin_orig_dir"
- else
- cd "$darwin_orig_dir"
- func_extract_an_archive "$my_xdir" "$my_xabs"
- fi # $darwin_arches
- fi # $run
- ;;
- *)
- func_extract_an_archive "$my_xdir" "$my_xabs"
- ;;
- esac
- my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | $NL2SP`
- done
- func_extract_archives_result="$my_oldobjs"
-}
-# End of Shell function definitions
-#####################################
-
-# Darwin sucks
-eval std_shrext=\"$shrext_cmds\"
-
-# Parse our command line options once, thoroughly.
-while test "$#" -gt 0
-do
- arg="$1"
- shift
-
- case $arg in
- -*=*) optarg=`$echo "X$arg" | $Xsed -e 's/[-_a-zA-Z0-9]*=//'` ;;
- *) optarg= ;;
- esac
-
- # If the previous option needs an argument, assign it.
- if test -n "$prev"; then
- case $prev in
- execute_dlfiles)
- execute_dlfiles="$execute_dlfiles $arg"
- ;;
- tag)
- tagname="$arg"
- preserve_args="${preserve_args}=$arg"
-
- # Check whether tagname contains only valid characters
- case $tagname in
- *[!-_A-Za-z0-9,/]*)
- $echo "$progname: invalid tag name: $tagname" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- case $tagname in
- CC)
- # Don't test for the "default" C tag, as we know, it's there, but
- # not specially marked.
- ;;
- *)
- if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "$progpath" > /dev/null; then
- taglist="$taglist $tagname"
- # Evaluate the configuration.
- eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$tagname'$/,/^# ### END LIBTOOL TAG CONFIG: '$tagname'$/p' < $progpath`"
- else
- $echo "$progname: ignoring unknown tag $tagname" 1>&2
- fi
- ;;
- esac
- ;;
- *)
- eval "$prev=\$arg"
- ;;
- esac
-
- prev=
- prevopt=
- continue
- fi
-
- # Have we seen a non-optional argument yet?
- case $arg in
- --help)
- show_help=yes
- ;;
-
- --version)
- $echo "$PROGRAM (GNU $PACKAGE) $VERSION$TIMESTAMP"
- $echo
- $echo "Copyright (C) 2005 Free Software Foundation, Inc."
- $echo "This is free software; see the source for copying conditions. There is NO"
- $echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
- exit $?
- ;;
-
- --config)
- ${SED} -e '1,/^# ### BEGIN LIBTOOL CONFIG/d' -e '/^# ### END LIBTOOL CONFIG/,$d' $progpath
- # Now print the configurations for the tags.
- for tagname in $taglist; do
- ${SED} -n -e "/^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$/,/^# ### END LIBTOOL TAG CONFIG: $tagname$/p" < "$progpath"
- done
- exit $?
- ;;
-
- --debug)
- $echo "$progname: enabling shell trace mode"
- set -x
- preserve_args="$preserve_args $arg"
- ;;
-
- --dry-run | -n)
- run=:
- ;;
-
- --features)
- $echo "host: $host"
- if test "$build_libtool_libs" = yes; then
- $echo "enable shared libraries"
- else
- $echo "disable shared libraries"
- fi
- if test "$build_old_libs" = yes; then
- $echo "enable static libraries"
- else
- $echo "disable static libraries"
- fi
- exit $?
- ;;
-
- --finish) mode="finish" ;;
-
- --mode) prevopt="--mode" prev=mode ;;
- --mode=*) mode="$optarg" ;;
-
- --preserve-dup-deps) duplicate_deps="yes" ;;
-
- --quiet | --silent)
- show=:
- preserve_args="$preserve_args $arg"
- ;;
-
- --tag) prevopt="--tag" prev=tag ;;
- --tag=*)
- set tag "$optarg" ${1+"$@"}
- shift
- prev=tag
- preserve_args="$preserve_args --tag"
- ;;
-
- -dlopen)
- prevopt="-dlopen"
- prev=execute_dlfiles
- ;;
-
- -*)
- $echo "$modename: unrecognized option \`$arg'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- ;;
-
- *)
- nonopt="$arg"
- break
- ;;
- esac
-done
-
-if test -n "$prevopt"; then
- $echo "$modename: option \`$prevopt' requires an argument" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
-fi
-
-# If this variable is set in any of the actions, the command in it
-# will be execed at the end. This prevents here-documents from being
-# left over by shells.
-exec_cmd=
-
-if test -z "$show_help"; then
-
- # Infer the operation mode.
- if test -z "$mode"; then
- $echo "*** Warning: inferring the mode of operation is deprecated." 1>&2
- $echo "*** Future versions of Libtool will require --mode=MODE be specified." 1>&2
- case $nonopt in
- *cc | cc* | *++ | gcc* | *-gcc* | g++* | xlc*)
- mode=link
- for arg
- do
- case $arg in
- -c)
- mode=compile
- break
- ;;
- esac
- done
- ;;
- *db | *dbx | *strace | *truss)
- mode=execute
- ;;
- *install*|cp|mv)
- mode=install
- ;;
- *rm)
- mode=uninstall
- ;;
- *)
- # If we have no mode, but dlfiles were specified, then do execute mode.
- test -n "$execute_dlfiles" && mode=execute
-
- # Just use the default operation mode.
- if test -z "$mode"; then
- if test -n "$nonopt"; then
- $echo "$modename: warning: cannot infer operation mode from \`$nonopt'" 1>&2
- else
- $echo "$modename: warning: cannot infer operation mode without MODE-ARGS" 1>&2
- fi
- fi
- ;;
- esac
- fi
-
- # Only execute mode is allowed to have -dlopen flags.
- if test -n "$execute_dlfiles" && test "$mode" != execute; then
- $echo "$modename: unrecognized option \`-dlopen'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Change the help message to a mode-specific one.
- generic_help="$help"
- help="Try \`$modename --help --mode=$mode' for more information."
-
- # These modes are in order of execution frequency so that they run quickly.
- case $mode in
- # libtool compile mode
- compile)
- modename="$modename: compile"
- # Get the compilation command and the source file.
- base_compile=
- srcfile="$nonopt" # always keep a non-empty value in "srcfile"
- suppress_opt=yes
- suppress_output=
- arg_mode=normal
- libobj=
- later=
-
- for arg
- do
- case $arg_mode in
- arg )
- # do not "continue". Instead, add this to base_compile
- lastarg="$arg"
- arg_mode=normal
- ;;
-
- target )
- libobj="$arg"
- arg_mode=normal
- continue
- ;;
-
- normal )
- # Accept any command-line options.
- case $arg in
- -o)
- if test -n "$libobj" ; then
- $echo "$modename: you cannot specify \`-o' more than once" 1>&2
- exit $EXIT_FAILURE
- fi
- arg_mode=target
- continue
- ;;
-
- -static | -prefer-pic | -prefer-non-pic)
- later="$later $arg"
- continue
- ;;
-
- -no-suppress)
- suppress_opt=no
- continue
- ;;
-
- -Xcompiler)
- arg_mode=arg # the next one goes into the "base_compile" arg list
- continue # The current "srcfile" will either be retained or
- ;; # replaced later. I would guess that would be a bug.
-
- -Wc,*)
- args=`$echo "X$arg" | $Xsed -e "s/^-Wc,//"`
- lastarg=
- save_ifs="$IFS"; IFS=','
- for arg in $args; do
- IFS="$save_ifs"
-
- # Double-quote args containing other shell metacharacters.
- # Many Bourne shells cannot handle close brackets correctly
- # in scan sets, so we specify it separately.
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- lastarg="$lastarg $arg"
- done
- IFS="$save_ifs"
- lastarg=`$echo "X$lastarg" | $Xsed -e "s/^ //"`
-
- # Add the arguments to base_compile.
- base_compile="$base_compile $lastarg"
- continue
- ;;
-
- * )
- # Accept the current argument as the source file.
- # The previous "srcfile" becomes the current argument.
- #
- lastarg="$srcfile"
- srcfile="$arg"
- ;;
- esac # case $arg
- ;;
- esac # case $arg_mode
-
- # Aesthetically quote the previous argument.
- lastarg=`$echo "X$lastarg" | $Xsed -e "$sed_quote_subst"`
-
- case $lastarg in
- # Double-quote args containing other shell metacharacters.
- # Many Bourne shells cannot handle close brackets correctly
- # in scan sets, and some SunOS ksh mistreat backslash-escaping
- # in scan sets (worked around with variable expansion),
- # and furthermore cannot handle '|' '&' '(' ')' in scan sets
- # at all, so we specify them separately.
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- lastarg="\"$lastarg\""
- ;;
- esac
-
- base_compile="$base_compile $lastarg"
- done # for arg
-
- case $arg_mode in
- arg)
- $echo "$modename: you must specify an argument for -Xcompile"
- exit $EXIT_FAILURE
- ;;
- target)
- $echo "$modename: you must specify a target with \`-o'" 1>&2
- exit $EXIT_FAILURE
- ;;
- *)
- # Get the name of the library object.
- [ -z "$libobj" ] && libobj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%'`
- ;;
- esac
-
- # Recognize several different file suffixes.
- # If the user specifies -o file.o, it is replaced with file.lo
- xform='[cCFSifmso]'
- case $libobj in
- *.ada) xform=ada ;;
- *.adb) xform=adb ;;
- *.ads) xform=ads ;;
- *.asm) xform=asm ;;
- *.c++) xform=c++ ;;
- *.cc) xform=cc ;;
- *.ii) xform=ii ;;
- *.class) xform=class ;;
- *.cpp) xform=cpp ;;
- *.cxx) xform=cxx ;;
- *.f90) xform=f90 ;;
- *.for) xform=for ;;
- *.java) xform=java ;;
- esac
-
- libobj=`$echo "X$libobj" | $Xsed -e "s/\.$xform$/.lo/"`
-
- case $libobj in
- *.lo) obj=`$echo "X$libobj" | $Xsed -e "$lo2o"` ;;
- *)
- $echo "$modename: cannot determine name of library object from \`$libobj'" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- func_infer_tag $base_compile
-
- for arg in $later; do
- case $arg in
- -static)
- build_old_libs=yes
- continue
- ;;
-
- -prefer-pic)
- pic_mode=yes
- continue
- ;;
-
- -prefer-non-pic)
- pic_mode=no
- continue
- ;;
- esac
- done
-
- qlibobj=`$echo "X$libobj" | $Xsed -e "$sed_quote_subst"`
- case $qlibobj in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- qlibobj="\"$qlibobj\"" ;;
- esac
- test "X$libobj" != "X$qlibobj" \
- && $echo "X$libobj" | grep '[]~#^*{};<>?"'"'"' &()|`$[]' \
- && $echo "$modename: libobj name \`$libobj' may not contain shell special characters."
- objname=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
- xdir=`$echo "X$obj" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$xdir" = "X$obj"; then
- xdir=
- else
- xdir=$xdir/
- fi
- lobj=${xdir}$objdir/$objname
-
- if test -z "$base_compile"; then
- $echo "$modename: you must specify a compilation command" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Delete any leftover library objects.
- if test "$build_old_libs" = yes; then
- removelist="$obj $lobj $libobj ${libobj}T"
- else
- removelist="$lobj $libobj ${libobj}T"
- fi
-
- $run $rm $removelist
- trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
-
- # On Cygwin there's no "real" PIC flag so we must build both object types
- case $host_os in
- cygwin* | mingw* | pw32* | os2*)
- pic_mode=default
- ;;
- esac
- if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then
- # non-PIC code in shared libraries is not supported
- pic_mode=default
- fi
-
- # Calculate the filename of the output object if compiler does
- # not support -o with -c
- if test "$compiler_c_o" = no; then
- output_obj=`$echo "X$srcfile" | $Xsed -e 's%^.*/%%' -e 's%\.[^.]*$%%'`.${objext}
- lockfile="$output_obj.lock"
- removelist="$removelist $output_obj $lockfile"
- trap "$run $rm $removelist; exit $EXIT_FAILURE" 1 2 15
- else
- output_obj=
- need_locks=no
- lockfile=
- fi
-
- # Lock this critical section if it is needed
- # We use this script file to make the link, it avoids creating a new file
- if test "$need_locks" = yes; then
- until $run ln "$progpath" "$lockfile" 2>/dev/null; do
- $show "Waiting for $lockfile to be removed"
- sleep 2
- done
- elif test "$need_locks" = warn; then
- if test -f "$lockfile"; then
- $echo "\
-*** ERROR, $lockfile exists and contains:
-`cat $lockfile 2>/dev/null`
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
- $run $rm $removelist
- exit $EXIT_FAILURE
- fi
- $echo "$srcfile" > "$lockfile"
- fi
-
- if test -n "$fix_srcfile_path"; then
- eval srcfile=\"$fix_srcfile_path\"
- fi
- qsrcfile=`$echo "X$srcfile" | $Xsed -e "$sed_quote_subst"`
- case $qsrcfile in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- qsrcfile="\"$qsrcfile\"" ;;
- esac
-
- $run $rm "$libobj" "${libobj}T"
-
- # Create a libtool object file (analogous to a ".la" file),
- # but don't create it if we're doing a dry run.
- test -z "$run" && cat > ${libobj}T <<EOF
-# $libobj - a libtool object file
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# Please DO NOT delete this file!
-# It is necessary for linking the library.
-
-# Name of the PIC object.
-EOF
-
- # Only build a PIC object if we are building libtool libraries.
- if test "$build_libtool_libs" = yes; then
- # Without this assignment, base_compile gets emptied.
- fbsd_hideous_sh_bug=$base_compile
-
- if test "$pic_mode" != no; then
- command="$base_compile $qsrcfile $pic_flag"
- else
- # Don't build PIC code
- command="$base_compile $qsrcfile"
- fi
-
- if test ! -d "${xdir}$objdir"; then
- $show "$mkdir ${xdir}$objdir"
- $run $mkdir ${xdir}$objdir
- status=$?
- if test "$status" -ne 0 && test ! -d "${xdir}$objdir"; then
- exit $status
- fi
- fi
-
- if test -z "$output_obj"; then
- # Place PIC objects in $objdir
- command="$command -o $lobj"
- fi
-
- $run $rm "$lobj" "$output_obj"
-
- $show "$command"
- if $run eval "$command"; then :
- else
- test -n "$output_obj" && $run $rm $removelist
- exit $EXIT_FAILURE
- fi
-
- if test "$need_locks" = warn &&
- test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
- $echo "\
-*** ERROR, $lockfile contains:
-`cat $lockfile 2>/dev/null`
-
-but it should contain:
-$srcfile
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
- $run $rm $removelist
- exit $EXIT_FAILURE
- fi
-
- # Just move the object if needed, then go on to compile the next one
- if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then
- $show "$mv $output_obj $lobj"
- if $run $mv $output_obj $lobj; then :
- else
- error=$?
- $run $rm $removelist
- exit $error
- fi
- fi
-
- # Append the name of the PIC object to the libtool object file.
- test -z "$run" && cat >> ${libobj}T <<EOF
-pic_object='$objdir/$objname'
-
-EOF
-
- # Allow error messages only from the first compilation.
- if test "$suppress_opt" = yes; then
- suppress_output=' >/dev/null 2>&1'
- fi
- else
- # No PIC object so indicate it doesn't exist in the libtool
- # object file.
- test -z "$run" && cat >> ${libobj}T <<EOF
-pic_object=none
-
-EOF
- fi
-
- # Only build a position-dependent object if we build old libraries.
- if test "$build_old_libs" = yes; then
- if test "$pic_mode" != yes; then
- # Don't build PIC code
- command="$base_compile $qsrcfile"
- else
- command="$base_compile $qsrcfile $pic_flag"
- fi
- if test "$compiler_c_o" = yes; then
- command="$command -o $obj"
- fi
-
- # Suppress compiler output if we already did a PIC compilation.
- command="$command$suppress_output"
- $run $rm "$obj" "$output_obj"
- $show "$command"
- if $run eval "$command"; then :
- else
- $run $rm $removelist
- exit $EXIT_FAILURE
- fi
-
- if test "$need_locks" = warn &&
- test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
- $echo "\
-*** ERROR, $lockfile contains:
-`cat $lockfile 2>/dev/null`
-
-but it should contain:
-$srcfile
-
-This indicates that another process is trying to use the same
-temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
-repeat this compilation, it may succeed, by chance, but you had better
-avoid parallel builds (make -j) in this platform, or get a better
-compiler."
-
- $run $rm $removelist
- exit $EXIT_FAILURE
- fi
-
- # Just move the object if needed
- if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then
- $show "$mv $output_obj $obj"
- if $run $mv $output_obj $obj; then :
- else
- error=$?
- $run $rm $removelist
- exit $error
- fi
- fi
-
- # Append the name of the non-PIC object the libtool object file.
- # Only append if the libtool object file exists.
- test -z "$run" && cat >> ${libobj}T <<EOF
-# Name of the non-PIC object.
-non_pic_object='$objname'
-
-EOF
- else
- # Append the name of the non-PIC object the libtool object file.
- # Only append if the libtool object file exists.
- test -z "$run" && cat >> ${libobj}T <<EOF
-# Name of the non-PIC object.
-non_pic_object=none
-
-EOF
- fi
-
- $run $mv "${libobj}T" "${libobj}"
-
- # Unlock the critical section if it was locked
- if test "$need_locks" != no; then
- $run $rm "$lockfile"
- fi
-
- exit $EXIT_SUCCESS
- ;;
-
- # libtool link mode
- link | relink)
- modename="$modename: link"
- case $host in
- *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
- # It is impossible to link a dll without this setting, and
- # we shouldn't force the makefile maintainer to figure out
- # which system we are compiling for in order to pass an extra
- # flag for every libtool invocation.
- # allow_undefined=no
-
- # FIXME: Unfortunately, there are problems with the above when trying
- # to make a dll which has undefined symbols, in which case not
- # even a static library is built. For now, we need to specify
- # -no-undefined on the libtool link line when we can be certain
- # that all symbols are satisfied, otherwise we get a static library.
- allow_undefined=yes
- ;;
- *)
- allow_undefined=yes
- ;;
- esac
- libtool_args="$nonopt"
- base_compile="$nonopt $@"
- compile_command="$nonopt"
- finalize_command="$nonopt"
-
- compile_rpath=
- finalize_rpath=
- compile_shlibpath=
- finalize_shlibpath=
- convenience=
- old_convenience=
- deplibs=
- old_deplibs=
- compiler_flags=
- linker_flags=
- dllsearchpath=
- lib_search_path=`pwd`
- inst_prefix_dir=
-
- avoid_version=no
- dlfiles=
- dlprefiles=
- dlself=no
- export_dynamic=no
- export_symbols=
- export_symbols_regex=
- generated=
- libobjs=
- ltlibs=
- module=no
- no_install=no
- objs=
- non_pic_objects=
- precious_files_regex=
- prefer_static_libs=no
- preload=no
- prev=
- prevarg=
- release=
- rpath=
- xrpath=
- perm_rpath=
- temp_rpath=
- thread_safe=no
- vinfo=
- vinfo_number=no
-
- func_infer_tag $base_compile
-
- # We need to know -static, to get the right output filenames.
- for arg
- do
- case $arg in
- -all-static | -static)
- if test "X$arg" = "X-all-static"; then
- if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then
- $echo "$modename: warning: complete static linking is impossible in this configuration" 1>&2
- fi
- if test -n "$link_static_flag"; then
- dlopen_self=$dlopen_self_static
- fi
- else
- if test -z "$pic_flag" && test -n "$link_static_flag"; then
- dlopen_self=$dlopen_self_static
- fi
- fi
- build_libtool_libs=no
- build_old_libs=yes
- prefer_static_libs=yes
- break
- ;;
- esac
- done
-
- # See if our shared archives depend on static archives.
- test -n "$old_archive_from_new_cmds" && build_old_libs=yes
-
- # Go through the arguments, transforming them on the way.
- while test "$#" -gt 0; do
- arg="$1"
- shift
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- qarg=\"`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`\" ### testsuite: skip nested quoting test
- ;;
- *) qarg=$arg ;;
- esac
- libtool_args="$libtool_args $qarg"
-
- # If the previous option needs an argument, assign it.
- if test -n "$prev"; then
- case $prev in
- output)
- compile_command="$compile_command @OUTPUT@"
- finalize_command="$finalize_command @OUTPUT@"
- ;;
- esac
-
- case $prev in
- dlfiles|dlprefiles)
- if test "$preload" = no; then
- # Add the symbol object into the linking commands.
- compile_command="$compile_command @SYMFILE@"
- finalize_command="$finalize_command @SYMFILE@"
- preload=yes
- fi
- case $arg in
- *.la | *.lo) ;; # We handle these cases below.
- force)
- if test "$dlself" = no; then
- dlself=needless
- export_dynamic=yes
- fi
- prev=
- continue
- ;;
- self)
- if test "$prev" = dlprefiles; then
- dlself=yes
- elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then
- dlself=yes
- else
- dlself=needless
- export_dynamic=yes
- fi
- prev=
- continue
- ;;
- *)
- if test "$prev" = dlfiles; then
- dlfiles="$dlfiles $arg"
- else
- dlprefiles="$dlprefiles $arg"
- fi
- prev=
- continue
- ;;
- esac
- ;;
- expsyms)
- export_symbols="$arg"
- if test ! -f "$arg"; then
- $echo "$modename: symbol file \`$arg' does not exist"
- exit $EXIT_FAILURE
- fi
- prev=
- continue
- ;;
- expsyms_regex)
- export_symbols_regex="$arg"
- prev=
- continue
- ;;
- inst_prefix)
- inst_prefix_dir="$arg"
- prev=
- continue
- ;;
- precious_regex)
- precious_files_regex="$arg"
- prev=
- continue
- ;;
- release)
- release="-$arg"
- prev=
- continue
- ;;
- objectlist)
- if test -f "$arg"; then
- save_arg=$arg
- moreargs=
- for fil in `cat $save_arg`
- do
-# moreargs="$moreargs $fil"
- arg=$fil
- # A libtool-controlled object.
-
- # Check to see that this really is a libtool object.
- if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- pic_object=
- non_pic_object=
-
- # Read the .lo file
- # If there is no directory component, then add one.
- case $arg in
- */* | *\\*) . $arg ;;
- *) . ./$arg ;;
- esac
-
- if test -z "$pic_object" || \
- test -z "$non_pic_object" ||
- test "$pic_object" = none && \
- test "$non_pic_object" = none; then
- $echo "$modename: cannot find name of object for \`$arg'" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Extract subdirectory from the argument.
- xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$xdir" = "X$arg"; then
- xdir=
- else
- xdir="$xdir/"
- fi
-
- if test "$pic_object" != none; then
- # Prepend the subdirectory the object is found in.
- pic_object="$xdir$pic_object"
-
- if test "$prev" = dlfiles; then
- if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
- dlfiles="$dlfiles $pic_object"
- prev=
- continue
- else
- # If libtool objects are unsupported, then we need to preload.
- prev=dlprefiles
- fi
- fi
-
- # CHECK ME: I think I busted this. -Ossama
- if test "$prev" = dlprefiles; then
- # Preload the old-style object.
- dlprefiles="$dlprefiles $pic_object"
- prev=
- fi
-
- # A PIC object.
- libobjs="$libobjs $pic_object"
- arg="$pic_object"
- fi
-
- # Non-PIC object.
- if test "$non_pic_object" != none; then
- # Prepend the subdirectory the object is found in.
- non_pic_object="$xdir$non_pic_object"
-
- # A standard non-PIC object
- non_pic_objects="$non_pic_objects $non_pic_object"
- if test -z "$pic_object" || test "$pic_object" = none ; then
- arg="$non_pic_object"
- fi
- fi
- else
- # Only an error if not doing a dry-run.
- if test -z "$run"; then
- $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
- exit $EXIT_FAILURE
- else
- # Dry-run case.
-
- # Extract subdirectory from the argument.
- xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$xdir" = "X$arg"; then
- xdir=
- else
- xdir="$xdir/"
- fi
-
- pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
- non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
- libobjs="$libobjs $pic_object"
- non_pic_objects="$non_pic_objects $non_pic_object"
- fi
- fi
- done
- else
- $echo "$modename: link input file \`$save_arg' does not exist"
- exit $EXIT_FAILURE
- fi
- arg=$save_arg
- prev=
- continue
- ;;
- rpath | xrpath)
- # We need an absolute path.
- case $arg in
- [\\/]* | [A-Za-z]:[\\/]*) ;;
- *)
- $echo "$modename: only absolute run-paths are allowed" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
- if test "$prev" = rpath; then
- case "$rpath " in
- *" $arg "*) ;;
- *) rpath="$rpath $arg" ;;
- esac
- else
- case "$xrpath " in
- *" $arg "*) ;;
- *) xrpath="$xrpath $arg" ;;
- esac
- fi
- prev=
- continue
- ;;
- xcompiler)
- compiler_flags="$compiler_flags $qarg"
- prev=
- compile_command="$compile_command $qarg"
- finalize_command="$finalize_command $qarg"
- continue
- ;;
- xlinker)
- linker_flags="$linker_flags $qarg"
- compiler_flags="$compiler_flags $wl$qarg"
- prev=
- compile_command="$compile_command $wl$qarg"
- finalize_command="$finalize_command $wl$qarg"
- continue
- ;;
- xcclinker)
- linker_flags="$linker_flags $qarg"
- compiler_flags="$compiler_flags $qarg"
- prev=
- compile_command="$compile_command $qarg"
- finalize_command="$finalize_command $qarg"
- continue
- ;;
- shrext)
- shrext_cmds="$arg"
- prev=
- continue
- ;;
- darwin_framework)
- compiler_flags="$compiler_flags $arg"
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- prev=
- continue
- ;;
- *)
- eval "$prev=\"\$arg\""
- prev=
- continue
- ;;
- esac
- fi # test -n "$prev"
-
- prevarg="$arg"
-
- case $arg in
- -all-static)
- if test -n "$link_static_flag"; then
- compile_command="$compile_command $link_static_flag"
- finalize_command="$finalize_command $link_static_flag"
- fi
- continue
- ;;
-
- -allow-undefined)
- # FIXME: remove this flag sometime in the future.
- $echo "$modename: \`-allow-undefined' is deprecated because it is the default" 1>&2
- continue
- ;;
-
- -avoid-version)
- avoid_version=yes
- continue
- ;;
-
- -dlopen)
- prev=dlfiles
- continue
- ;;
-
- -dlpreopen)
- prev=dlprefiles
- continue
- ;;
-
- -export-dynamic)
- export_dynamic=yes
- continue
- ;;
-
- -export-symbols | -export-symbols-regex)
- if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
- $echo "$modename: more than one -exported-symbols argument is not allowed"
- exit $EXIT_FAILURE
- fi
- if test "X$arg" = "X-export-symbols"; then
- prev=expsyms
- else
- prev=expsyms_regex
- fi
- continue
- ;;
-
- -framework|-arch)
- prev=darwin_framework
- compiler_flags="$compiler_flags $arg"
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- continue
- ;;
-
- -inst-prefix-dir)
- prev=inst_prefix
- continue
- ;;
-
- # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:*
- # so, if we see these flags be careful not to treat them like -L
- -L[A-Z][A-Z]*:*)
- case $with_gcc/$host in
- no/*-*-irix* | /*-*-irix*)
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- ;;
- esac
- continue
- ;;
-
- -L*)
- dir=`$echo "X$arg" | $Xsed -e 's/^-L//'`
- # We need an absolute path.
- case $dir in
- [\\/]* | [A-Za-z]:[\\/]*) ;;
- *)
- absdir=`cd "$dir" && pwd`
- if test -z "$absdir"; then
- $echo "$modename: cannot determine absolute directory name of \`$dir'" 1>&2
- exit $EXIT_FAILURE
- fi
- dir="$absdir"
- ;;
- esac
- case "$deplibs " in
- *" -L$dir "*) ;;
- *)
- deplibs="$deplibs -L$dir"
- lib_search_path="$lib_search_path $dir"
- ;;
- esac
- case $host in
- *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
- case :$dllsearchpath: in
- *":$dir:"*) ;;
- *) dllsearchpath="$dllsearchpath:$dir";;
- esac
- ;;
- esac
- continue
- ;;
-
- -l*)
- if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
- case $host in
- *-*-cygwin* | *-*-pw32* | *-*-beos*)
- # These systems don't actually have a C or math library (as such)
- continue
- ;;
- *-*-mingw* | *-*-os2*)
- # These systems don't actually have a C library (as such)
- test "X$arg" = "X-lc" && continue
- ;;
- *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
- # Do not include libc due to us having libc/libc_r.
- test "X$arg" = "X-lc" && continue
- ;;
- *-*-rhapsody* | *-*-darwin1.[012])
- # Rhapsody C and math libraries are in the System framework
- deplibs="$deplibs -framework System"
- continue
- esac
- elif test "X$arg" = "X-lc_r"; then
- case $host in
- *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
- # Do not include libc_r directly, use -pthread flag.
- continue
- ;;
- esac
- fi
- deplibs="$deplibs $arg"
- continue
- ;;
-
- # Tru64 UNIX uses -model [arg] to determine the layout of C++
- # classes, name mangling, and exception handling.
- -model)
- compile_command="$compile_command $arg"
- compiler_flags="$compiler_flags $arg"
- finalize_command="$finalize_command $arg"
- prev=xcompiler
- continue
- ;;
-
- -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
- compiler_flags="$compiler_flags $arg"
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- continue
- ;;
-
- -module)
- module=yes
- continue
- ;;
-
- # -64, -mips[0-9] enable 64-bit mode on the SGI compiler
- # -r[0-9][0-9]* specifies the processor on the SGI compiler
- # -xarch=*, -xtarget=* enable 64-bit mode on the Sun compiler
- # +DA*, +DD* enable 64-bit mode on the HP compiler
- # -q* pass through compiler args for the IBM compiler
- # -m* pass through architecture-specific compiler args for GCC
- -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*)
-
- # Unknown arguments in both finalize_command and compile_command need
- # to be aesthetically quoted because they are evaled later.
- arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- if test "$with_gcc" = "yes" ; then
- compiler_flags="$compiler_flags $arg"
- fi
- continue
- ;;
-
- -shrext)
- prev=shrext
- continue
- ;;
-
- -no-fast-install)
- fast_install=no
- continue
- ;;
-
- -no-install)
- case $host in
- *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
- # The PATH hackery in wrapper scripts is required on Windows
- # in order for the loader to find any dlls it needs.
- $echo "$modename: warning: \`-no-install' is ignored for $host" 1>&2
- $echo "$modename: warning: assuming \`-no-fast-install' instead" 1>&2
- fast_install=no
- ;;
- *) no_install=yes ;;
- esac
- continue
- ;;
-
- -no-undefined)
- allow_undefined=no
- continue
- ;;
-
- -objectlist)
- prev=objectlist
- continue
- ;;
-
- -o) prev=output ;;
-
- -precious-files-regex)
- prev=precious_regex
- continue
- ;;
-
- -release)
- prev=release
- continue
- ;;
-
- -rpath)
- prev=rpath
- continue
- ;;
-
- -R)
- prev=xrpath
- continue
- ;;
-
- -R*)
- dir=`$echo "X$arg" | $Xsed -e 's/^-R//'`
- # We need an absolute path.
- case $dir in
- [\\/]* | [A-Za-z]:[\\/]*) ;;
- *)
- $echo "$modename: only absolute run-paths are allowed" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
- case "$xrpath " in
- *" $dir "*) ;;
- *) xrpath="$xrpath $dir" ;;
- esac
- continue
- ;;
-
- -static)
- # The effects of -static are defined in a previous loop.
- # We used to do the same as -all-static on platforms that
- # didn't have a PIC flag, but the assumption that the effects
- # would be equivalent was wrong. It would break on at least
- # Digital Unix and AIX.
- continue
- ;;
-
- -thread-safe)
- thread_safe=yes
- continue
- ;;
-
- -version-info)
- prev=vinfo
- continue
- ;;
- -version-number)
- prev=vinfo
- vinfo_number=yes
- continue
- ;;
-
- -Wc,*)
- args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wc,//'`
- arg=
- save_ifs="$IFS"; IFS=','
- for flag in $args; do
- IFS="$save_ifs"
- case $flag in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- flag="\"$flag\""
- ;;
- esac
- arg="$arg $wl$flag"
- compiler_flags="$compiler_flags $flag"
- done
- IFS="$save_ifs"
- arg=`$echo "X$arg" | $Xsed -e "s/^ //"`
- ;;
-
- -Wl,*)
- args=`$echo "X$arg" | $Xsed -e "$sed_quote_subst" -e 's/^-Wl,//'`
- arg=
- save_ifs="$IFS"; IFS=','
- for flag in $args; do
- IFS="$save_ifs"
- case $flag in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- flag="\"$flag\""
- ;;
- esac
- arg="$arg $wl$flag"
- compiler_flags="$compiler_flags $wl$flag"
- linker_flags="$linker_flags $flag"
- done
- IFS="$save_ifs"
- arg=`$echo "X$arg" | $Xsed -e "s/^ //"`
- ;;
-
- -Xcompiler)
- prev=xcompiler
- continue
- ;;
-
- -Xlinker)
- prev=xlinker
- continue
- ;;
-
- -XCClinker)
- prev=xcclinker
- continue
- ;;
-
- # Some other compiler flag.
- -* | +*)
- # Unknown arguments in both finalize_command and compile_command need
- # to be aesthetically quoted because they are evaled later.
- arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- ;;
-
- *.$objext)
- # A standard object.
- objs="$objs $arg"
- ;;
-
- *.lo)
- # A libtool-controlled object.
-
- # Check to see that this really is a libtool object.
- if (${SED} -e '2q' $arg | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- pic_object=
- non_pic_object=
-
- # Read the .lo file
- # If there is no directory component, then add one.
- case $arg in
- */* | *\\*) . $arg ;;
- *) . ./$arg ;;
- esac
-
- if test -z "$pic_object" || \
- test -z "$non_pic_object" ||
- test "$pic_object" = none && \
- test "$non_pic_object" = none; then
- $echo "$modename: cannot find name of object for \`$arg'" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Extract subdirectory from the argument.
- xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$xdir" = "X$arg"; then
- xdir=
- else
- xdir="$xdir/"
- fi
-
- if test "$pic_object" != none; then
- # Prepend the subdirectory the object is found in.
- pic_object="$xdir$pic_object"
-
- if test "$prev" = dlfiles; then
- if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
- dlfiles="$dlfiles $pic_object"
- prev=
- continue
- else
- # If libtool objects are unsupported, then we need to preload.
- prev=dlprefiles
- fi
- fi
-
- # CHECK ME: I think I busted this. -Ossama
- if test "$prev" = dlprefiles; then
- # Preload the old-style object.
- dlprefiles="$dlprefiles $pic_object"
- prev=
- fi
-
- # A PIC object.
- libobjs="$libobjs $pic_object"
- arg="$pic_object"
- fi
-
- # Non-PIC object.
- if test "$non_pic_object" != none; then
- # Prepend the subdirectory the object is found in.
- non_pic_object="$xdir$non_pic_object"
-
- # A standard non-PIC object
- non_pic_objects="$non_pic_objects $non_pic_object"
- if test -z "$pic_object" || test "$pic_object" = none ; then
- arg="$non_pic_object"
- fi
- fi
- else
- # Only an error if not doing a dry-run.
- if test -z "$run"; then
- $echo "$modename: \`$arg' is not a valid libtool object" 1>&2
- exit $EXIT_FAILURE
- else
- # Dry-run case.
-
- # Extract subdirectory from the argument.
- xdir=`$echo "X$arg" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$xdir" = "X$arg"; then
- xdir=
- else
- xdir="$xdir/"
- fi
-
- pic_object=`$echo "X${xdir}${objdir}/${arg}" | $Xsed -e "$lo2o"`
- non_pic_object=`$echo "X${xdir}${arg}" | $Xsed -e "$lo2o"`
- libobjs="$libobjs $pic_object"
- non_pic_objects="$non_pic_objects $non_pic_object"
- fi
- fi
- ;;
-
- *.$libext)
- # An archive.
- deplibs="$deplibs $arg"
- old_deplibs="$old_deplibs $arg"
- continue
- ;;
-
- *.la)
- # A libtool-controlled library.
-
- if test "$prev" = dlfiles; then
- # This library was specified with -dlopen.
- dlfiles="$dlfiles $arg"
- prev=
- elif test "$prev" = dlprefiles; then
- # The library was specified with -dlpreopen.
- dlprefiles="$dlprefiles $arg"
- prev=
- else
- deplibs="$deplibs $arg"
- fi
- continue
- ;;
-
- # Some other compiler argument.
- *)
- # Unknown arguments in both finalize_command and compile_command need
- # to be aesthetically quoted because they are evaled later.
- arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- ;;
- esac # arg
-
- # Now actually substitute the argument into the commands.
- if test -n "$arg"; then
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- fi
- done # argument parsing loop
-
- if test -n "$prev"; then
- $echo "$modename: the \`$prevarg' option requires an argument" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
- eval arg=\"$export_dynamic_flag_spec\"
- compile_command="$compile_command $arg"
- finalize_command="$finalize_command $arg"
- fi
-
- oldlibs=
- # calculate the name of the file, without its directory
- outputname=`$echo "X$output" | $Xsed -e 's%^.*/%%'`
- libobjs_save="$libobjs"
-
- if test -n "$shlibpath_var"; then
- # get the directories listed in $shlibpath_var
- eval shlib_search_path=\`\$echo \"X\${$shlibpath_var}\" \| \$Xsed -e \'s/:/ /g\'\`
- else
- shlib_search_path=
- fi
- eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
- eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
-
- output_objdir=`$echo "X$output" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$output_objdir" = "X$output"; then
- output_objdir="$objdir"
- else
- output_objdir="$output_objdir/$objdir"
- fi
- # Create the object directory.
- if test ! -d "$output_objdir"; then
- $show "$mkdir $output_objdir"
- $run $mkdir $output_objdir
- status=$?
- if test "$status" -ne 0 && test ! -d "$output_objdir"; then
- exit $status
- fi
- fi
-
- # Determine the type of output
- case $output in
- "")
- $echo "$modename: you must specify an output file" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- ;;
- *.$libext) linkmode=oldlib ;;
- *.lo | *.$objext) linkmode=obj ;;
- *.la) linkmode=lib ;;
- *) linkmode=prog ;; # Anything else should be a program.
- esac
-
- case $host in
- *cygwin* | *mingw* | *pw32*)
- # don't eliminate duplications in $postdeps and $predeps
- duplicate_compiler_generated_deps=yes
- ;;
- *)
- duplicate_compiler_generated_deps=$duplicate_deps
- ;;
- esac
- specialdeplibs=
-
- libs=
- # Find all interdependent deplibs by searching for libraries
- # that are linked more than once (e.g. -la -lb -la)
- for deplib in $deplibs; do
- if test "X$duplicate_deps" = "Xyes" ; then
- case "$libs " in
- *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
- esac
- fi
- libs="$libs $deplib"
- done
-
- if test "$linkmode" = lib; then
- libs="$predeps $libs $compiler_lib_search_path $postdeps"
-
- # Compute libraries that are listed more than once in $predeps
- # $postdeps and mark them as special (i.e., whose duplicates are
- # not to be eliminated).
- pre_post_deps=
- if test "X$duplicate_compiler_generated_deps" = "Xyes" ; then
- for pre_post_dep in $predeps $postdeps; do
- case "$pre_post_deps " in
- *" $pre_post_dep "*) specialdeplibs="$specialdeplibs $pre_post_deps" ;;
- esac
- pre_post_deps="$pre_post_deps $pre_post_dep"
- done
- fi
- pre_post_deps=
- fi
-
- deplibs=
- newdependency_libs=
- newlib_search_path=
- need_relink=no # whether we're linking any uninstalled libtool libraries
- notinst_deplibs= # not-installed libtool libraries
- notinst_path= # paths that contain not-installed libtool libraries
- case $linkmode in
- lib)
- passes="conv link"
- for file in $dlfiles $dlprefiles; do
- case $file in
- *.la) ;;
- *)
- $echo "$modename: libraries can \`-dlopen' only libtool libraries: $file" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
- done
- ;;
- prog)
- compile_deplibs=
- finalize_deplibs=
- alldeplibs=no
- newdlfiles=
- newdlprefiles=
- passes="conv scan dlopen dlpreopen link"
- ;;
- *) passes="conv"
- ;;
- esac
- for pass in $passes; do
- if test "$linkmode,$pass" = "lib,link" ||
- test "$linkmode,$pass" = "prog,scan"; then
- libs="$deplibs"
- deplibs=
- fi
- if test "$linkmode" = prog; then
- case $pass in
- dlopen) libs="$dlfiles" ;;
- dlpreopen) libs="$dlprefiles" ;;
- link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
- esac
- fi
- if test "$pass" = dlopen; then
- # Collect dlpreopened libraries
- save_deplibs="$deplibs"
- deplibs=
- fi
- for deplib in $libs; do
- lib=
- found=no
- case $deplib in
- -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe)
- if test "$linkmode,$pass" = "prog,link"; then
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- else
- compiler_flags="$compiler_flags $deplib"
- fi
- continue
- ;;
- -l*)
- if test "$linkmode" != lib && test "$linkmode" != prog; then
- $echo "$modename: warning: \`-l' is ignored for archives/objects" 1>&2
- continue
- fi
- name=`$echo "X$deplib" | $Xsed -e 's/^-l//'`
- for searchdir in $newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path; do
- for search_ext in .la $std_shrext .so .a; do
- # Search the libtool library
- lib="$searchdir/lib${name}${search_ext}"
- if test -f "$lib"; then
- if test "$search_ext" = ".la"; then
- found=yes
- else
- found=no
- fi
- break 2
- fi
- done
- done
- if test "$found" != yes; then
- # deplib doesn't seem to be a libtool library
- if test "$linkmode,$pass" = "prog,link"; then
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- else
- deplibs="$deplib $deplibs"
- test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
- fi
- continue
- else # deplib is a libtool library
- # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
- # We need to do some special things here, and not later.
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- case " $predeps $postdeps " in
- *" $deplib "*)
- if (${SED} -e '2q' $lib |
- grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- library_names=
- old_library=
- case $lib in
- */* | *\\*) . $lib ;;
- *) . ./$lib ;;
- esac
- for l in $old_library $library_names; do
- ll="$l"
- done
- if test "X$ll" = "X$old_library" ; then # only static version available
- found=no
- ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
- test "X$ladir" = "X$lib" && ladir="."
- lib=$ladir/$old_library
- if test "$linkmode,$pass" = "prog,link"; then
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- else
- deplibs="$deplib $deplibs"
- test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
- fi
- continue
- fi
- fi
- ;;
- *) ;;
- esac
- fi
- fi
- ;; # -l
- -L*)
- case $linkmode in
- lib)
- deplibs="$deplib $deplibs"
- test "$pass" = conv && continue
- newdependency_libs="$deplib $newdependency_libs"
- newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
- ;;
- prog)
- if test "$pass" = conv; then
- deplibs="$deplib $deplibs"
- continue
- fi
- if test "$pass" = scan; then
- deplibs="$deplib $deplibs"
- else
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- fi
- newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`
- ;;
- *)
- $echo "$modename: warning: \`-L' is ignored for archives/objects" 1>&2
- ;;
- esac # linkmode
- continue
- ;; # -L
- -R*)
- if test "$pass" = link; then
- dir=`$echo "X$deplib" | $Xsed -e 's/^-R//'`
- # Make sure the xrpath contains only unique directories.
- case "$xrpath " in
- *" $dir "*) ;;
- *) xrpath="$xrpath $dir" ;;
- esac
- fi
- deplibs="$deplib $deplibs"
- continue
- ;;
- *.la) lib="$deplib" ;;
- *.$libext)
- if test "$pass" = conv; then
- deplibs="$deplib $deplibs"
- continue
- fi
- case $linkmode in
- lib)
- valid_a_lib=no
- case $deplibs_check_method in
- match_pattern*)
- set dummy $deplibs_check_method
- match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
- if eval $echo \"$deplib\" 2>/dev/null \
- | $SED 10q \
- | $EGREP "$match_pattern_regex" > /dev/null; then
- valid_a_lib=yes
- fi
- ;;
- pass_all)
- valid_a_lib=yes
- ;;
- esac
- if test "$valid_a_lib" != yes; then
- $echo
- $echo "*** Warning: Trying to link with static lib archive $deplib."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which you do not appear to have"
- $echo "*** because the file extensions .$libext of this argument makes me believe"
- $echo "*** that it is just a static archive that I should not used here."
- else
- $echo
- $echo "*** Warning: Linking the shared library $output against the"
- $echo "*** static library $deplib is not portable!"
- deplibs="$deplib $deplibs"
- fi
- continue
- ;;
- prog)
- if test "$pass" != link; then
- deplibs="$deplib $deplibs"
- else
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- fi
- continue
- ;;
- esac # linkmode
- ;; # *.$libext
- *.lo | *.$objext)
- if test "$pass" = conv; then
- deplibs="$deplib $deplibs"
- elif test "$linkmode" = prog; then
- if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
- # If there is no dlopen support or we're linking statically,
- # we need to preload.
- newdlprefiles="$newdlprefiles $deplib"
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- else
- newdlfiles="$newdlfiles $deplib"
- fi
- fi
- continue
- ;;
- %DEPLIBS%)
- alldeplibs=yes
- continue
- ;;
- esac # case $deplib
- if test "$found" = yes || test -f "$lib"; then :
- else
- $echo "$modename: cannot find the library \`$lib'" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Check to see that this really is a libtool archive.
- if (${SED} -e '2q' $lib | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
- else
- $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
- exit $EXIT_FAILURE
- fi
-
- ladir=`$echo "X$lib" | $Xsed -e 's%/[^/]*$%%'`
- test "X$ladir" = "X$lib" && ladir="."
-
- dlname=
- dlopen=
- dlpreopen=
- libdir=
- library_names=
- old_library=
- # If the library was installed with an old release of libtool,
- # it will not redefine variables installed, or shouldnotlink
- installed=yes
- shouldnotlink=no
- avoidtemprpath=
-
-
- # Read the .la file
- case $lib in
- */* | *\\*) . $lib ;;
- *) . ./$lib ;;
- esac
-
- if test "$linkmode,$pass" = "lib,link" ||
- test "$linkmode,$pass" = "prog,scan" ||
- { test "$linkmode" != prog && test "$linkmode" != lib; }; then
- test -n "$dlopen" && dlfiles="$dlfiles $dlopen"
- test -n "$dlpreopen" && dlprefiles="$dlprefiles $dlpreopen"
- fi
-
- if test "$pass" = conv; then
- # Only check for convenience libraries
- deplibs="$lib $deplibs"
- if test -z "$libdir"; then
- if test -z "$old_library"; then
- $echo "$modename: cannot find name of link library for \`$lib'" 1>&2
- exit $EXIT_FAILURE
- fi
- # It is a libtool convenience library, so add in its objects.
- convenience="$convenience $ladir/$objdir/$old_library"
- old_convenience="$old_convenience $ladir/$objdir/$old_library"
- tmp_libs=
- for deplib in $dependency_libs; do
- deplibs="$deplib $deplibs"
- if test "X$duplicate_deps" = "Xyes" ; then
- case "$tmp_libs " in
- *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
- esac
- fi
- tmp_libs="$tmp_libs $deplib"
- done
- elif test "$linkmode" != prog && test "$linkmode" != lib; then
- $echo "$modename: \`$lib' is not a convenience library" 1>&2
- exit $EXIT_FAILURE
- fi
- continue
- fi # $pass = conv
-
-
- # Get the name of the library we link against.
- linklib=
- for l in $old_library $library_names; do
- linklib="$l"
- done
- if test -z "$linklib"; then
- $echo "$modename: cannot find name of link library for \`$lib'" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # This library was specified with -dlopen.
- if test "$pass" = dlopen; then
- if test -z "$libdir"; then
- $echo "$modename: cannot -dlopen a convenience library: \`$lib'" 1>&2
- exit $EXIT_FAILURE
- fi
- if test -z "$dlname" ||
- test "$dlopen_support" != yes ||
- test "$build_libtool_libs" = no; then
- # If there is no dlname, no dlopen support or we're linking
- # statically, we need to preload. We also need to preload any
- # dependent libraries so libltdl's deplib preloader doesn't
- # bomb out in the load deplibs phase.
- dlprefiles="$dlprefiles $lib $dependency_libs"
- else
- newdlfiles="$newdlfiles $lib"
- fi
- continue
- fi # $pass = dlopen
-
- # We need an absolute path.
- case $ladir in
- [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;;
- *)
- abs_ladir=`cd "$ladir" && pwd`
- if test -z "$abs_ladir"; then
- $echo "$modename: warning: cannot determine absolute directory name of \`$ladir'" 1>&2
- $echo "$modename: passing it literally to the linker, although it might fail" 1>&2
- abs_ladir="$ladir"
- fi
- ;;
- esac
- laname=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
-
- # Find the relevant object directory and library name.
- if test "X$installed" = Xyes; then
- if test ! -f "$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
- $echo "$modename: warning: library \`$lib' was moved." 1>&2
- dir="$ladir"
- absdir="$abs_ladir"
- libdir="$abs_ladir"
- else
- dir="$libdir"
- absdir="$libdir"
- fi
- test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
- else
- if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
- dir="$ladir"
- absdir="$abs_ladir"
- # Remove this search path later
- notinst_path="$notinst_path $abs_ladir"
- else
- dir="$ladir/$objdir"
- absdir="$abs_ladir/$objdir"
- # Remove this search path later
- notinst_path="$notinst_path $abs_ladir"
- fi
- fi # $installed = yes
- name=`$echo "X$laname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
-
- # This library was specified with -dlpreopen.
- if test "$pass" = dlpreopen; then
- if test -z "$libdir"; then
- $echo "$modename: cannot -dlpreopen a convenience library: \`$lib'" 1>&2
- exit $EXIT_FAILURE
- fi
- # Prefer using a static library (so that no silly _DYNAMIC symbols
- # are required to link).
- if test -n "$old_library"; then
- newdlprefiles="$newdlprefiles $dir/$old_library"
- # Otherwise, use the dlname, so that lt_dlopen finds it.
- elif test -n "$dlname"; then
- newdlprefiles="$newdlprefiles $dir/$dlname"
- else
- newdlprefiles="$newdlprefiles $dir/$linklib"
- fi
- fi # $pass = dlpreopen
-
- if test -z "$libdir"; then
- # Link the convenience library
- if test "$linkmode" = lib; then
- deplibs="$dir/$old_library $deplibs"
- elif test "$linkmode,$pass" = "prog,link"; then
- compile_deplibs="$dir/$old_library $compile_deplibs"
- finalize_deplibs="$dir/$old_library $finalize_deplibs"
- else
- deplibs="$lib $deplibs" # used for prog,scan pass
- fi
- continue
- fi
-
-
- if test "$linkmode" = prog && test "$pass" != link; then
- newlib_search_path="$newlib_search_path $ladir"
- deplibs="$lib $deplibs"
-
- linkalldeplibs=no
- if test "$link_all_deplibs" != no || test -z "$library_names" ||
- test "$build_libtool_libs" = no; then
- linkalldeplibs=yes
- fi
-
- tmp_libs=
- for deplib in $dependency_libs; do
- case $deplib in
- -L*) newlib_search_path="$newlib_search_path "`$echo "X$deplib" | $Xsed -e 's/^-L//'`;; ### testsuite: skip nested quoting test
- esac
- # Need to link against all dependency_libs?
- if test "$linkalldeplibs" = yes; then
- deplibs="$deplib $deplibs"
- else
- # Need to hardcode shared library paths
- # or/and link against static libraries
- newdependency_libs="$deplib $newdependency_libs"
- fi
- if test "X$duplicate_deps" = "Xyes" ; then
- case "$tmp_libs " in
- *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
- esac
- fi
- tmp_libs="$tmp_libs $deplib"
- done # for deplib
- continue
- fi # $linkmode = prog...
-
- if test "$linkmode,$pass" = "prog,link"; then
- if test -n "$library_names" &&
- { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
- # We need to hardcode the library path
- if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then
- # Make sure the rpath contains only unique directories.
- case "$temp_rpath " in
- *" $dir "*) ;;
- *" $absdir "*) ;;
- *) temp_rpath="$temp_rpath $absdir" ;;
- esac
- fi
-
- # Hardcode the library path.
- # Skip directories that are in the system default run-time
- # search path.
- case " $sys_lib_dlsearch_path " in
- *" $absdir "*) ;;
- *)
- case "$compile_rpath " in
- *" $absdir "*) ;;
- *) compile_rpath="$compile_rpath $absdir"
- esac
- ;;
- esac
- case " $sys_lib_dlsearch_path " in
- *" $libdir "*) ;;
- *)
- case "$finalize_rpath " in
- *" $libdir "*) ;;
- *) finalize_rpath="$finalize_rpath $libdir"
- esac
- ;;
- esac
- fi # $linkmode,$pass = prog,link...
-
- if test "$alldeplibs" = yes &&
- { test "$deplibs_check_method" = pass_all ||
- { test "$build_libtool_libs" = yes &&
- test -n "$library_names"; }; }; then
- # We only need to search for static libraries
- continue
- fi
- fi
-
- link_static=no # Whether the deplib will be linked statically
- if test -n "$library_names" &&
- { test "$prefer_static_libs" = no || test -z "$old_library"; }; then
- if test "$installed" = no; then
- notinst_deplibs="$notinst_deplibs $lib"
- need_relink=yes
- fi
- # This is a shared library
-
- # Warn about portability, can't link against -module's on
- # some systems (darwin)
- if test "$shouldnotlink" = yes && test "$pass" = link ; then
- $echo
- if test "$linkmode" = prog; then
- $echo "*** Warning: Linking the executable $output against the loadable module"
- else
- $echo "*** Warning: Linking the shared library $output against the loadable module"
- fi
- $echo "*** $linklib is not portable!"
- fi
- if test "$linkmode" = lib &&
- test "$hardcode_into_libs" = yes; then
- # Hardcode the library path.
- # Skip directories that are in the system default run-time
- # search path.
- case " $sys_lib_dlsearch_path " in
- *" $absdir "*) ;;
- *)
- case "$compile_rpath " in
- *" $absdir "*) ;;
- *) compile_rpath="$compile_rpath $absdir"
- esac
- ;;
- esac
- case " $sys_lib_dlsearch_path " in
- *" $libdir "*) ;;
- *)
- case "$finalize_rpath " in
- *" $libdir "*) ;;
- *) finalize_rpath="$finalize_rpath $libdir"
- esac
- ;;
- esac
- fi
-
- if test -n "$old_archive_from_expsyms_cmds"; then
- # figure out the soname
- set dummy $library_names
- realname="$2"
- shift; shift
- libname=`eval \\$echo \"$libname_spec\"`
- # use dlname if we got it. it's perfectly good, no?
- if test -n "$dlname"; then
- soname="$dlname"
- elif test -n "$soname_spec"; then
- # bleh windows
- case $host in
- *cygwin* | mingw*)
- major=`expr $current - $age`
- versuffix="-$major"
- ;;
- esac
- eval soname=\"$soname_spec\"
- else
- soname="$realname"
- fi
-
- # Make a new name for the extract_expsyms_cmds to use
- soroot="$soname"
- soname=`$echo $soroot | ${SED} -e 's/^.*\///'`
- newlib="libimp-`$echo $soname | ${SED} 's/^lib//;s/\.dll$//'`.a"
-
- # If the library has no export list, then create one now
- if test -f "$output_objdir/$soname-def"; then :
- else
- $show "extracting exported symbol list from \`$soname'"
- save_ifs="$IFS"; IFS='~'
- cmds=$extract_expsyms_cmds
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
- fi
-
- # Create $newlib
- if test -f "$output_objdir/$newlib"; then :; else
- $show "generating import library for \`$soname'"
- save_ifs="$IFS"; IFS='~'
- cmds=$old_archive_from_expsyms_cmds
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
- fi
- # make sure the library variables are pointing to the new library
- dir=$output_objdir
- linklib=$newlib
- fi # test -n "$old_archive_from_expsyms_cmds"
-
- if test "$linkmode" = prog || test "$mode" != relink; then
- add_shlibpath=
- add_dir=
- add=
- lib_linked=yes
- case $hardcode_action in
- immediate | unsupported)
- if test "$hardcode_direct" = no; then
- add="$dir/$linklib"
- case $host in
- *-*-sco3.2v5* ) add_dir="-L$dir" ;;
- *-*-darwin* )
- # if the lib is a module then we can not link against
- # it, someone is ignoring the new warnings I added
- if /usr/bin/file -L $add 2> /dev/null | $EGREP "bundle" >/dev/null ; then
- $echo "** Warning, lib $linklib is a module, not a shared library"
- if test -z "$old_library" ; then
- $echo
- $echo "** And there doesn't seem to be a static archive available"
- $echo "** The link will probably fail, sorry"
- else
- add="$dir/$old_library"
- fi
- fi
- esac
- elif test "$hardcode_minus_L" = no; then
- case $host in
- *-*-sunos*) add_shlibpath="$dir" ;;
- esac
- add_dir="-L$dir"
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = no; then
- add_shlibpath="$dir"
- add="-l$name"
- else
- lib_linked=no
- fi
- ;;
- relink)
- if test "$hardcode_direct" = yes; then
- add="$dir/$linklib"
- elif test "$hardcode_minus_L" = yes; then
- add_dir="-L$dir"
- # Try looking first in the location we're being installed to.
- if test -n "$inst_prefix_dir"; then
- case $libdir in
- [\\/]*)
- add_dir="$add_dir -L$inst_prefix_dir$libdir"
- ;;
- esac
- fi
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = yes; then
- add_shlibpath="$dir"
- add="-l$name"
- else
- lib_linked=no
- fi
- ;;
- *) lib_linked=no ;;
- esac
-
- if test "$lib_linked" != yes; then
- $echo "$modename: configuration error: unsupported hardcode properties"
- exit $EXIT_FAILURE
- fi
-
- if test -n "$add_shlibpath"; then
- case :$compile_shlibpath: in
- *":$add_shlibpath:"*) ;;
- *) compile_shlibpath="$compile_shlibpath$add_shlibpath:" ;;
- esac
- fi
- if test "$linkmode" = prog; then
- test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
- test -n "$add" && compile_deplibs="$add $compile_deplibs"
- else
- test -n "$add_dir" && deplibs="$add_dir $deplibs"
- test -n "$add" && deplibs="$add $deplibs"
- if test "$hardcode_direct" != yes && \
- test "$hardcode_minus_L" != yes && \
- test "$hardcode_shlibpath_var" = yes; then
- case :$finalize_shlibpath: in
- *":$libdir:"*) ;;
- *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
- esac
- fi
- fi
- fi
-
- if test "$linkmode" = prog || test "$mode" = relink; then
- add_shlibpath=
- add_dir=
- add=
- # Finalize command for both is simple: just hardcode it.
- if test "$hardcode_direct" = yes; then
- add="$libdir/$linklib"
- elif test "$hardcode_minus_L" = yes; then
- add_dir="-L$libdir"
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = yes; then
- case :$finalize_shlibpath: in
- *":$libdir:"*) ;;
- *) finalize_shlibpath="$finalize_shlibpath$libdir:" ;;
- esac
- add="-l$name"
- elif test "$hardcode_automatic" = yes; then
- if test -n "$inst_prefix_dir" &&
- test -f "$inst_prefix_dir$libdir/$linklib" ; then
- add="$inst_prefix_dir$libdir/$linklib"
- else
- add="$libdir/$linklib"
- fi
- else
- # We cannot seem to hardcode it, guess we'll fake it.
- add_dir="-L$libdir"
- # Try looking first in the location we're being installed to.
- if test -n "$inst_prefix_dir"; then
- case $libdir in
- [\\/]*)
- add_dir="$add_dir -L$inst_prefix_dir$libdir"
- ;;
- esac
- fi
- add="-l$name"
- fi
-
- if test "$linkmode" = prog; then
- test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
- test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
- else
- test -n "$add_dir" && deplibs="$add_dir $deplibs"
- test -n "$add" && deplibs="$add $deplibs"
- fi
- fi
- elif test "$linkmode" = prog; then
- # Here we assume that one of hardcode_direct or hardcode_minus_L
- # is not unsupported. This is valid on all known static and
- # shared platforms.
- if test "$hardcode_direct" != unsupported; then
- test -n "$old_library" && linklib="$old_library"
- compile_deplibs="$dir/$linklib $compile_deplibs"
- finalize_deplibs="$dir/$linklib $finalize_deplibs"
- else
- compile_deplibs="-l$name -L$dir $compile_deplibs"
- finalize_deplibs="-l$name -L$dir $finalize_deplibs"
- fi
- elif test "$build_libtool_libs" = yes; then
- # Not a shared library
- if test "$deplibs_check_method" != pass_all; then
- # We're trying link a shared library against a static one
- # but the system doesn't support it.
-
- # Just print a warning and add the library to dependency_libs so
- # that the program can be linked against the static library.
- $echo
- $echo "*** Warning: This system can not link to static lib archive $lib."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which you do not appear to have."
- if test "$module" = yes; then
- $echo "*** But as you try to build a module library, libtool will still create "
- $echo "*** a static module, that should work as long as the dlopening application"
- $echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
- if test -z "$global_symbol_pipe"; then
- $echo
- $echo "*** However, this would only work if libtool was able to extract symbol"
- $echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
- $echo "*** not find such a program. So, this module is probably useless."
- $echo "*** \`nm' from GNU binutils and a full rebuild may help."
- fi
- if test "$build_old_libs" = no; then
- build_libtool_libs=module
- build_old_libs=yes
- else
- build_libtool_libs=no
- fi
- fi
- else
- deplibs="$dir/$old_library $deplibs"
- link_static=yes
- fi
- fi # link shared/static library?
-
- if test "$linkmode" = lib; then
- if test -n "$dependency_libs" &&
- { test "$hardcode_into_libs" != yes ||
- test "$build_old_libs" = yes ||
- test "$link_static" = yes; }; then
- # Extract -R from dependency_libs
- temp_deplibs=
- for libdir in $dependency_libs; do
- case $libdir in
- -R*) temp_xrpath=`$echo "X$libdir" | $Xsed -e 's/^-R//'`
- case " $xrpath " in
- *" $temp_xrpath "*) ;;
- *) xrpath="$xrpath $temp_xrpath";;
- esac;;
- *) temp_deplibs="$temp_deplibs $libdir";;
- esac
- done
- dependency_libs="$temp_deplibs"
- fi
-
- newlib_search_path="$newlib_search_path $absdir"
- # Link against this library
- test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
- # ... and its dependency_libs
- tmp_libs=
- for deplib in $dependency_libs; do
- newdependency_libs="$deplib $newdependency_libs"
- if test "X$duplicate_deps" = "Xyes" ; then
- case "$tmp_libs " in
- *" $deplib "*) specialdeplibs="$specialdeplibs $deplib" ;;
- esac
- fi
- tmp_libs="$tmp_libs $deplib"
- done
-
- if test "$link_all_deplibs" != no; then
- # Add the search paths of all dependency libraries
- for deplib in $dependency_libs; do
- case $deplib in
- -L*) path="$deplib" ;;
- *.la)
- dir=`$echo "X$deplib" | $Xsed -e 's%/[^/]*$%%'`
- test "X$dir" = "X$deplib" && dir="."
- # We need an absolute path.
- case $dir in
- [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
- *)
- absdir=`cd "$dir" && pwd`
- if test -z "$absdir"; then
- $echo "$modename: warning: cannot determine absolute directory name of \`$dir'" 1>&2
- absdir="$dir"
- fi
- ;;
- esac
- if grep "^installed=no" $deplib > /dev/null; then
- path="$absdir/$objdir"
- else
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
- if test -z "$libdir"; then
- $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
- exit $EXIT_FAILURE
- fi
- if test "$absdir" != "$libdir"; then
- $echo "$modename: warning: \`$deplib' seems to be moved" 1>&2
- fi
- path="$absdir"
- fi
- depdepl=
- case $host in
- *-*-darwin*)
- # we do not want to link against static libs,
- # but need to link against shared
- eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
- if test -n "$deplibrary_names" ; then
- for tmp in $deplibrary_names ; do
- depdepl=$tmp
- done
- if test -f "$path/$depdepl" ; then
- depdepl="$path/$depdepl"
- fi
- # do not add paths which are already there
- case " $newlib_search_path " in
- *" $path "*) ;;
- *) newlib_search_path="$newlib_search_path $path";;
- esac
- fi
- path=""
- ;;
- *)
- path="-L$path"
- ;;
- esac
- ;;
- -l*)
- case $host in
- *-*-darwin*)
- # Again, we only want to link against shared libraries
- eval tmp_libs=`$echo "X$deplib" | $Xsed -e "s,^\-l,,"`
- for tmp in $newlib_search_path ; do
- if test -f "$tmp/lib$tmp_libs.dylib" ; then
- eval depdepl="$tmp/lib$tmp_libs.dylib"
- break
- fi
- done
- path=""
- ;;
- *) continue ;;
- esac
- ;;
- *) continue ;;
- esac
- case " $deplibs " in
- *" $path "*) ;;
- *) deplibs="$path $deplibs" ;;
- esac
- case " $deplibs " in
- *" $depdepl "*) ;;
- *) deplibs="$depdepl $deplibs" ;;
- esac
- done
- fi # link_all_deplibs != no
- fi # linkmode = lib
- done # for deplib in $libs
- dependency_libs="$newdependency_libs"
- if test "$pass" = dlpreopen; then
- # Link the dlpreopened libraries before other libraries
- for deplib in $save_deplibs; do
- deplibs="$deplib $deplibs"
- done
- fi
- if test "$pass" != dlopen; then
- if test "$pass" != conv; then
- # Make sure lib_search_path contains only unique directories.
- lib_search_path=
- for dir in $newlib_search_path; do
- case "$lib_search_path " in
- *" $dir "*) ;;
- *) lib_search_path="$lib_search_path $dir" ;;
- esac
- done
- newlib_search_path=
- fi
-
- if test "$linkmode,$pass" != "prog,link"; then
- vars="deplibs"
- else
- vars="compile_deplibs finalize_deplibs"
- fi
- for var in $vars dependency_libs; do
- # Add libraries to $var in reverse order
- eval tmp_libs=\"\$$var\"
- new_libs=
- for deplib in $tmp_libs; do
- # FIXME: Pedantically, this is the right thing to do, so
- # that some nasty dependency loop isn't accidentally
- # broken:
- #new_libs="$deplib $new_libs"
- # Pragmatically, this seems to cause very few problems in
- # practice:
- case $deplib in
- -L*) new_libs="$deplib $new_libs" ;;
- -R*) ;;
- *)
- # And here is the reason: when a library appears more
- # than once as an explicit dependence of a library, or
- # is implicitly linked in more than once by the
- # compiler, it is considered special, and multiple
- # occurrences thereof are not removed. Compare this
- # with having the same library being listed as a
- # dependency of multiple other libraries: in this case,
- # we know (pedantically, we assume) the library does not
- # need to be listed more than once, so we keep only the
- # last copy. This is not always right, but it is rare
- # enough that we require users that really mean to play
- # such unportable linking tricks to link the library
- # using -Wl,-lname, so that libtool does not consider it
- # for duplicate removal.
- case " $specialdeplibs " in
- *" $deplib "*) new_libs="$deplib $new_libs" ;;
- *)
- case " $new_libs " in
- *" $deplib "*) ;;
- *) new_libs="$deplib $new_libs" ;;
- esac
- ;;
- esac
- ;;
- esac
- done
- tmp_libs=
- for deplib in $new_libs; do
- case $deplib in
- -L*)
- case " $tmp_libs " in
- *" $deplib "*) ;;
- *) tmp_libs="$tmp_libs $deplib" ;;
- esac
- ;;
- *) tmp_libs="$tmp_libs $deplib" ;;
- esac
- done
- eval $var=\"$tmp_libs\"
- done # for var
- fi
- # Last step: remove runtime libs from dependency_libs
- # (they stay in deplibs)
- tmp_libs=
- for i in $dependency_libs ; do
- case " $predeps $postdeps $compiler_lib_search_path " in
- *" $i "*)
- i=""
- ;;
- esac
- if test -n "$i" ; then
- tmp_libs="$tmp_libs $i"
- fi
- done
- dependency_libs=$tmp_libs
- done # for pass
- if test "$linkmode" = prog; then
- dlfiles="$newdlfiles"
- dlprefiles="$newdlprefiles"
- fi
-
- case $linkmode in
- oldlib)
- if test -n "$deplibs"; then
- $echo "$modename: warning: \`-l' and \`-L' are ignored for archives" 1>&2
- fi
-
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
- $echo "$modename: warning: \`-dlopen' is ignored for archives" 1>&2
- fi
-
- if test -n "$rpath"; then
- $echo "$modename: warning: \`-rpath' is ignored for archives" 1>&2
- fi
-
- if test -n "$xrpath"; then
- $echo "$modename: warning: \`-R' is ignored for archives" 1>&2
- fi
-
- if test -n "$vinfo"; then
- $echo "$modename: warning: \`-version-info/-version-number' is ignored for archives" 1>&2
- fi
-
- if test -n "$release"; then
- $echo "$modename: warning: \`-release' is ignored for archives" 1>&2
- fi
-
- if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
- $echo "$modename: warning: \`-export-symbols' is ignored for archives" 1>&2
- fi
-
- # Now set the variables for building old libraries.
- build_libtool_libs=no
- oldlibs="$output"
- objs="$objs$old_deplibs"
- ;;
-
- lib)
- # Make sure we only generate libraries of the form `libNAME.la'.
- case $outputname in
- lib*)
- name=`$echo "X$outputname" | $Xsed -e 's/\.la$//' -e 's/^lib//'`
- eval shared_ext=\"$shrext_cmds\"
- eval libname=\"$libname_spec\"
- ;;
- *)
- if test "$module" = no; then
- $echo "$modename: libtool library \`$output' must begin with \`lib'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
- if test "$need_lib_prefix" != no; then
- # Add the "lib" prefix for modules if required
- name=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
- eval shared_ext=\"$shrext_cmds\"
- eval libname=\"$libname_spec\"
- else
- libname=`$echo "X$outputname" | $Xsed -e 's/\.la$//'`
- fi
- ;;
- esac
-
- if test -n "$objs"; then
- if test "$deplibs_check_method" != pass_all; then
- $echo "$modename: cannot build libtool library \`$output' from non-libtool objects on this host:$objs" 2>&1
- exit $EXIT_FAILURE
- else
- $echo
- $echo "*** Warning: Linking the shared library $output against the non-libtool"
- $echo "*** objects $objs is not portable!"
- libobjs="$libobjs $objs"
- fi
- fi
-
- if test "$dlself" != no; then
- $echo "$modename: warning: \`-dlopen self' is ignored for libtool libraries" 1>&2
- fi
-
- set dummy $rpath
- if test "$#" -gt 2; then
- $echo "$modename: warning: ignoring multiple \`-rpath's for a libtool library" 1>&2
- fi
- install_libdir="$2"
-
- oldlibs=
- if test -z "$rpath"; then
- if test "$build_libtool_libs" = yes; then
- # Building a libtool convenience library.
- # Some compilers have problems with a `.al' extension so
- # convenience libraries should have the same extension an
- # archive normally would.
- oldlibs="$output_objdir/$libname.$libext $oldlibs"
- build_libtool_libs=convenience
- build_old_libs=yes
- fi
-
- if test -n "$vinfo"; then
- $echo "$modename: warning: \`-version-info/-version-number' is ignored for convenience libraries" 1>&2
- fi
-
- if test -n "$release"; then
- $echo "$modename: warning: \`-release' is ignored for convenience libraries" 1>&2
- fi
- else
-
- # Parse the version information argument.
- save_ifs="$IFS"; IFS=':'
- set dummy $vinfo 0 0 0
- IFS="$save_ifs"
-
- if test -n "$8"; then
- $echo "$modename: too many parameters to \`-version-info'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # convert absolute version numbers to libtool ages
- # this retains compatibility with .la files and attempts
- # to make the code below a bit more comprehensible
-
- case $vinfo_number in
- yes)
- number_major="$2"
- number_minor="$3"
- number_revision="$4"
- #
- # There are really only two kinds -- those that
- # use the current revision as the major version
- # and those that subtract age and use age as
- # a minor version. But, then there is irix
- # which has an extra 1 added just for fun
- #
- case $version_type in
- darwin|linux|osf|windows)
- current=`expr $number_major + $number_minor`
- age="$number_minor"
- revision="$number_revision"
- ;;
- freebsd-aout|freebsd-elf|sunos)
- current="$number_major"
- revision="$number_minor"
- age="0"
- ;;
- irix|nonstopux)
- current=`expr $number_major + $number_minor - 1`
- age="$number_minor"
- revision="$number_minor"
- ;;
- esac
- ;;
- no)
- current="$2"
- revision="$3"
- age="$4"
- ;;
- esac
-
- # Check that each of the things are valid numbers.
- case $current in
- 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
- *)
- $echo "$modename: CURRENT \`$current' must be a nonnegative integer" 1>&2
- $echo "$modename: \`$vinfo' is not valid version information" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- case $revision in
- 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
- *)
- $echo "$modename: REVISION \`$revision' must be a nonnegative integer" 1>&2
- $echo "$modename: \`$vinfo' is not valid version information" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- case $age in
- 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
- *)
- $echo "$modename: AGE \`$age' must be a nonnegative integer" 1>&2
- $echo "$modename: \`$vinfo' is not valid version information" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- if test "$age" -gt "$current"; then
- $echo "$modename: AGE \`$age' is greater than the current interface number \`$current'" 1>&2
- $echo "$modename: \`$vinfo' is not valid version information" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Calculate the version variables.
- major=
- versuffix=
- verstring=
- case $version_type in
- none) ;;
-
- darwin)
- # Like Linux, but with the current version available in
- # verstring for coding it into the library header
- major=.`expr $current - $age`
- versuffix="$major.$age.$revision"
- # Darwin ld doesn't like 0 for these options...
- minor_current=`expr $current + 1`
- verstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision"
- ;;
-
- freebsd-aout)
- major=".$current"
- versuffix=".$current.$revision";
- ;;
-
- freebsd-elf)
- major=".$current"
- versuffix=".$current";
- ;;
-
- irix | nonstopux)
- major=`expr $current - $age + 1`
-
- case $version_type in
- nonstopux) verstring_prefix=nonstopux ;;
- *) verstring_prefix=sgi ;;
- esac
- verstring="$verstring_prefix$major.$revision"
-
- # Add in all the interfaces that we are compatible with.
- loop=$revision
- while test "$loop" -ne 0; do
- iface=`expr $revision - $loop`
- loop=`expr $loop - 1`
- verstring="$verstring_prefix$major.$iface:$verstring"
- done
-
- # Before this point, $major must not contain `.'.
- major=.$major
- versuffix="$major.$revision"
- ;;
-
- linux)
- major=.`expr $current - $age`
- versuffix="$major.$age.$revision"
- ;;
-
- osf)
- major=.`expr $current - $age`
- versuffix=".$current.$age.$revision"
- verstring="$current.$age.$revision"
-
- # Add in all the interfaces that we are compatible with.
- loop=$age
- while test "$loop" -ne 0; do
- iface=`expr $current - $loop`
- loop=`expr $loop - 1`
- verstring="$verstring:${iface}.0"
- done
-
- # Make executables depend on our current version.
- verstring="$verstring:${current}.0"
- ;;
-
- sunos)
- major=".$current"
- versuffix=".$current.$revision"
- ;;
-
- windows)
- # Use '-' rather than '.', since we only want one
- # extension on DOS 8.3 filesystems.
- major=`expr $current - $age`
- versuffix="-$major"
- ;;
-
- *)
- $echo "$modename: unknown library version type \`$version_type'" 1>&2
- $echo "Fatal configuration error. See the $PACKAGE docs for more information." 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- # Clear the version info if we defaulted, and they specified a release.
- if test -z "$vinfo" && test -n "$release"; then
- major=
- case $version_type in
- darwin)
- # we can't check for "0.0" in archive_cmds due to quoting
- # problems, so we reset it completely
- verstring=
- ;;
- *)
- verstring="0.0"
- ;;
- esac
- if test "$need_version" = no; then
- versuffix=
- else
- versuffix=".0.0"
- fi
- fi
-
- # Remove version info from name if versioning should be avoided
- if test "$avoid_version" = yes && test "$need_version" = no; then
- major=
- versuffix=
- verstring=""
- fi
-
- # Check to see if the archive will have undefined symbols.
- if test "$allow_undefined" = yes; then
- if test "$allow_undefined_flag" = unsupported; then
- $echo "$modename: warning: undefined symbols not allowed in $host shared libraries" 1>&2
- build_libtool_libs=no
- build_old_libs=yes
- fi
- else
- # Don't allow undefined symbols.
- allow_undefined_flag="$no_undefined_flag"
- fi
- fi
-
- if test "$mode" != relink; then
- # Remove our outputs, but don't remove object files since they
- # may have been created when compiling PIC objects.
- removelist=
- tempremovelist=`$echo "$output_objdir/*"`
- for p in $tempremovelist; do
- case $p in
- *.$objext)
- ;;
- $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
- if test "X$precious_files_regex" != "X"; then
- if echo $p | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
- then
- continue
- fi
- fi
- removelist="$removelist $p"
- ;;
- *) ;;
- esac
- done
- if test -n "$removelist"; then
- $show "${rm}r $removelist"
- $run ${rm}r $removelist
- fi
- fi
-
- # Now set the variables for building old libraries.
- if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
- oldlibs="$oldlibs $output_objdir/$libname.$libext"
-
- # Transform .lo files to .o files.
- oldobjs="$objs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}'$/d' -e "$lo2o" | $NL2SP`
- fi
-
- # Eliminate all temporary directories.
- for path in $notinst_path; do
- lib_search_path=`$echo "$lib_search_path " | ${SED} -e 's% $path % %g'`
- deplibs=`$echo "$deplibs " | ${SED} -e 's% -L$path % %g'`
- dependency_libs=`$echo "$dependency_libs " | ${SED} -e 's% -L$path % %g'`
- done
-
- if test -n "$xrpath"; then
- # If the user specified any rpath flags, then add them.
- temp_xrpath=
- for libdir in $xrpath; do
- temp_xrpath="$temp_xrpath -R$libdir"
- case "$finalize_rpath " in
- *" $libdir "*) ;;
- *) finalize_rpath="$finalize_rpath $libdir" ;;
- esac
- done
- if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
- dependency_libs="$temp_xrpath $dependency_libs"
- fi
- fi
-
- # Make sure dlfiles contains only unique files that won't be dlpreopened
- old_dlfiles="$dlfiles"
- dlfiles=
- for lib in $old_dlfiles; do
- case " $dlprefiles $dlfiles " in
- *" $lib "*) ;;
- *) dlfiles="$dlfiles $lib" ;;
- esac
- done
-
- # Make sure dlprefiles contains only unique files
- old_dlprefiles="$dlprefiles"
- dlprefiles=
- for lib in $old_dlprefiles; do
- case "$dlprefiles " in
- *" $lib "*) ;;
- *) dlprefiles="$dlprefiles $lib" ;;
- esac
- done
-
- if test "$build_libtool_libs" = yes; then
- if test -n "$rpath"; then
- case $host in
- *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos*)
- # these systems don't actually have a c library (as such)!
- ;;
- *-*-rhapsody* | *-*-darwin1.[012])
- # Rhapsody C library is in the System framework
- deplibs="$deplibs -framework System"
- ;;
- *-*-netbsd*)
- # Don't link with libc until the a.out ld.so is fixed.
- ;;
- *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
- # Do not include libc due to us having libc/libc_r.
- test "X$arg" = "X-lc" && continue
- ;;
- *)
- # Add libc to deplibs on all other systems if necessary.
- if test "$build_libtool_need_lc" = "yes"; then
- deplibs="$deplibs -lc"
- fi
- ;;
- esac
- fi
-
- # Transform deplibs into only deplibs that can be linked in shared.
- name_save=$name
- libname_save=$libname
- release_save=$release
- versuffix_save=$versuffix
- major_save=$major
- # I'm not sure if I'm treating the release correctly. I think
- # release should show up in the -l (ie -lgmp5) so we don't want to
- # add it in twice. Is that correct?
- release=""
- versuffix=""
- major=""
- newdeplibs=
- droppeddeps=no
- case $deplibs_check_method in
- pass_all)
- # Don't check for shared/static. Everything works.
- # This might be a little naive. We might want to check
- # whether the library exists or not. But this is on
- # osf3 & osf4 and I'm not really sure... Just
- # implementing what was already the behavior.
- newdeplibs=$deplibs
- ;;
- test_compile)
- # This code stresses the "libraries are programs" paradigm to its
- # limits. Maybe even breaks it. We compile a program, linking it
- # against the deplibs as a proxy for the library. Then we can check
- # whether they linked in statically or dynamically with ldd.
- $rm conftest.c
- cat > conftest.c <<EOF
- int main() { return 0; }
-EOF
- $rm conftest
- $LTCC -o conftest conftest.c $deplibs
- if test "$?" -eq 0 ; then
- ldd_output=`ldd conftest`
- for i in $deplibs; do
- name=`expr $i : '-l\(.*\)'`
- # If $name is empty we are operating on a -L argument.
- if test "$name" != "" && test "$name" -ne "0"; then
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- case " $predeps $postdeps " in
- *" $i "*)
- newdeplibs="$newdeplibs $i"
- i=""
- ;;
- esac
- fi
- if test -n "$i" ; then
- libname=`eval \\$echo \"$libname_spec\"`
- deplib_matches=`eval \\$echo \"$library_names_spec\"`
- set dummy $deplib_matches
- deplib_match=$2
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
- newdeplibs="$newdeplibs $i"
- else
- droppeddeps=yes
- $echo
- $echo "*** Warning: dynamic linker does not accept needed library $i."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which I believe you do not have"
- $echo "*** because a test_compile did reveal that the linker did not use it for"
- $echo "*** its dynamic dependency list that programs get resolved with at runtime."
- fi
- fi
- else
- newdeplibs="$newdeplibs $i"
- fi
- done
- else
- # Error occurred in the first compile. Let's try to salvage
- # the situation: Compile a separate program for each library.
- for i in $deplibs; do
- name=`expr $i : '-l\(.*\)'`
- # If $name is empty we are operating on a -L argument.
- if test "$name" != "" && test "$name" != "0"; then
- $rm conftest
- $LTCC -o conftest conftest.c $i
- # Did it work?
- if test "$?" -eq 0 ; then
- ldd_output=`ldd conftest`
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- case " $predeps $postdeps " in
- *" $i "*)
- newdeplibs="$newdeplibs $i"
- i=""
- ;;
- esac
- fi
- if test -n "$i" ; then
- libname=`eval \\$echo \"$libname_spec\"`
- deplib_matches=`eval \\$echo \"$library_names_spec\"`
- set dummy $deplib_matches
- deplib_match=$2
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
- newdeplibs="$newdeplibs $i"
- else
- droppeddeps=yes
- $echo
- $echo "*** Warning: dynamic linker does not accept needed library $i."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which you do not appear to have"
- $echo "*** because a test_compile did reveal that the linker did not use this one"
- $echo "*** as a dynamic dependency that programs can get resolved with at runtime."
- fi
- fi
- else
- droppeddeps=yes
- $echo
- $echo "*** Warning! Library $i is needed by this library but I was not able to"
- $echo "*** make it link in! You will probably need to install it or some"
- $echo "*** library that it depends on before this library will be fully"
- $echo "*** functional. Installing it before continuing would be even better."
- fi
- else
- newdeplibs="$newdeplibs $i"
- fi
- done
- fi
- ;;
- file_magic*)
- set dummy $deplibs_check_method
- file_magic_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
- for a_deplib in $deplibs; do
- name=`expr $a_deplib : '-l\(.*\)'`
- # If $name is empty we are operating on a -L argument.
- if test "$name" != "" && test "$name" != "0"; then
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- case " $predeps $postdeps " in
- *" $a_deplib "*)
- newdeplibs="$newdeplibs $a_deplib"
- a_deplib=""
- ;;
- esac
- fi
- if test -n "$a_deplib" ; then
- libname=`eval \\$echo \"$libname_spec\"`
- for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
- potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
- for potent_lib in $potential_libs; do
- # Follow soft links.
- if ls -lLd "$potent_lib" 2>/dev/null \
- | grep " -> " >/dev/null; then
- continue
- fi
- # The statement above tries to avoid entering an
- # endless loop below, in case of cyclic links.
- # We might still enter an endless loop, since a link
- # loop can be closed while we follow links,
- # but so what?
- potlib="$potent_lib"
- while test -h "$potlib" 2>/dev/null; do
- potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
- case $potliblink in
- [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
- *) potlib=`$echo "X$potlib" | $Xsed -e 's,[^/]*$,,'`"$potliblink";;
- esac
- done
- if eval $file_magic_cmd \"\$potlib\" 2>/dev/null \
- | ${SED} 10q \
- | $EGREP "$file_magic_regex" > /dev/null; then
- newdeplibs="$newdeplibs $a_deplib"
- a_deplib=""
- break 2
- fi
- done
- done
- fi
- if test -n "$a_deplib" ; then
- droppeddeps=yes
- $echo
- $echo "*** Warning: linker path does not have real file for library $a_deplib."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which you do not appear to have"
- $echo "*** because I did check the linker path looking for a file starting"
- if test -z "$potlib" ; then
- $echo "*** with $libname but no candidates were found. (...for file magic test)"
- else
- $echo "*** with $libname and none of the candidates passed a file format test"
- $echo "*** using a file magic. Last file checked: $potlib"
- fi
- fi
- else
- # Add a -L argument.
- newdeplibs="$newdeplibs $a_deplib"
- fi
- done # Gone through all deplibs.
- ;;
- match_pattern*)
- set dummy $deplibs_check_method
- match_pattern_regex=`expr "$deplibs_check_method" : "$2 \(.*\)"`
- for a_deplib in $deplibs; do
- name=`expr $a_deplib : '-l\(.*\)'`
- # If $name is empty we are operating on a -L argument.
- if test -n "$name" && test "$name" != "0"; then
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- case " $predeps $postdeps " in
- *" $a_deplib "*)
- newdeplibs="$newdeplibs $a_deplib"
- a_deplib=""
- ;;
- esac
- fi
- if test -n "$a_deplib" ; then
- libname=`eval \\$echo \"$libname_spec\"`
- for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
- potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
- for potent_lib in $potential_libs; do
- potlib="$potent_lib" # see symlink-check above in file_magic test
- if eval $echo \"$potent_lib\" 2>/dev/null \
- | ${SED} 10q \
- | $EGREP "$match_pattern_regex" > /dev/null; then
- newdeplibs="$newdeplibs $a_deplib"
- a_deplib=""
- break 2
- fi
- done
- done
- fi
- if test -n "$a_deplib" ; then
- droppeddeps=yes
- $echo
- $echo "*** Warning: linker path does not have real file for library $a_deplib."
- $echo "*** I have the capability to make that library automatically link in when"
- $echo "*** you link to this library. But I can only do this if you have a"
- $echo "*** shared version of the library, which you do not appear to have"
- $echo "*** because I did check the linker path looking for a file starting"
- if test -z "$potlib" ; then
- $echo "*** with $libname but no candidates were found. (...for regex pattern test)"
- else
- $echo "*** with $libname and none of the candidates passed a file format test"
- $echo "*** using a regex pattern. Last file checked: $potlib"
- fi
- fi
- else
- # Add a -L argument.
- newdeplibs="$newdeplibs $a_deplib"
- fi
- done # Gone through all deplibs.
- ;;
- none | unknown | *)
- newdeplibs=""
- tmp_deplibs=`$echo "X $deplibs" | $Xsed -e 's/ -lc$//' \
- -e 's/ -[LR][^ ]*//g'`
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- for i in $predeps $postdeps ; do
- # can't use Xsed below, because $i might contain '/'
- tmp_deplibs=`$echo "X $tmp_deplibs" | ${SED} -e "1s,^X,," -e "s,$i,,"`
- done
- fi
- if $echo "X $tmp_deplibs" | $Xsed -e 's/[ ]//g' \
- | grep . >/dev/null; then
- $echo
- if test "X$deplibs_check_method" = "Xnone"; then
- $echo "*** Warning: inter-library dependencies are not supported in this platform."
- else
- $echo "*** Warning: inter-library dependencies are not known to be supported."
- fi
- $echo "*** All declared inter-library dependencies are being dropped."
- droppeddeps=yes
- fi
- ;;
- esac
- versuffix=$versuffix_save
- major=$major_save
- release=$release_save
- libname=$libname_save
- name=$name_save
-
- case $host in
- *-*-rhapsody* | *-*-darwin1.[012])
- # On Rhapsody replace the C library is the System framework
- newdeplibs=`$echo "X $newdeplibs" | $Xsed -e 's/ -lc / -framework System /'`
- ;;
- esac
-
- if test "$droppeddeps" = yes; then
- if test "$module" = yes; then
- $echo
- $echo "*** Warning: libtool could not satisfy all declared inter-library"
- $echo "*** dependencies of module $libname. Therefore, libtool will create"
- $echo "*** a static module, that should work as long as the dlopening"
- $echo "*** application is linked with the -dlopen flag."
- if test -z "$global_symbol_pipe"; then
- $echo
- $echo "*** However, this would only work if libtool was able to extract symbol"
- $echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
- $echo "*** not find such a program. So, this module is probably useless."
- $echo "*** \`nm' from GNU binutils and a full rebuild may help."
- fi
- if test "$build_old_libs" = no; then
- oldlibs="$output_objdir/$libname.$libext"
- build_libtool_libs=module
- build_old_libs=yes
- else
- build_libtool_libs=no
- fi
- else
- $echo "*** The inter-library dependencies that have been dropped here will be"
- $echo "*** automatically added whenever a program is linked with this library"
- $echo "*** or is declared to -dlopen it."
-
- if test "$allow_undefined" = no; then
- $echo
- $echo "*** Since this library must not contain undefined symbols,"
- $echo "*** because either the platform does not support them or"
- $echo "*** it was explicitly requested with -no-undefined,"
- $echo "*** libtool will only create a static version of it."
- if test "$build_old_libs" = no; then
- oldlibs="$output_objdir/$libname.$libext"
- build_libtool_libs=module
- build_old_libs=yes
- else
- build_libtool_libs=no
- fi
- fi
- fi
- fi
- # Done checking deplibs!
- deplibs=$newdeplibs
- fi
-
- # All the library-specific variables (install_libdir is set above).
- library_names=
- old_library=
- dlname=
-
- # Test again, we may have decided not to build it any more
- if test "$build_libtool_libs" = yes; then
- if test "$hardcode_into_libs" = yes; then
- # Hardcode the library paths
- hardcode_libdirs=
- dep_rpath=
- rpath="$finalize_rpath"
- test "$mode" != relink && rpath="$compile_rpath$rpath"
- for libdir in $rpath; do
- if test -n "$hardcode_libdir_flag_spec"; then
- if test -n "$hardcode_libdir_separator"; then
- if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
- else
- # Just accumulate the unique libdirs.
- case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
- *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
- ;;
- *)
- hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
- ;;
- esac
- fi
- else
- eval flag=\"$hardcode_libdir_flag_spec\"
- dep_rpath="$dep_rpath $flag"
- fi
- elif test -n "$runpath_var"; then
- case "$perm_rpath " in
- *" $libdir "*) ;;
- *) perm_rpath="$perm_rpath $libdir" ;;
- esac
- fi
- done
- # Substitute the hardcoded libdirs into the rpath.
- if test -n "$hardcode_libdir_separator" &&
- test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
- if test -n "$hardcode_libdir_flag_spec_ld"; then
- eval dep_rpath=\"$hardcode_libdir_flag_spec_ld\"
- else
- eval dep_rpath=\"$hardcode_libdir_flag_spec\"
- fi
- fi
- if test -n "$runpath_var" && test -n "$perm_rpath"; then
- # We should set the runpath_var.
- rpath=
- for dir in $perm_rpath; do
- rpath="$rpath$dir:"
- done
- eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var"
- fi
- test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
- fi
-
- shlibpath="$finalize_shlibpath"
- test "$mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
- if test -n "$shlibpath"; then
- eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
- fi
-
- # Get the real and link names of the library.
- eval shared_ext=\"$shrext_cmds\"
- eval library_names=\"$library_names_spec\"
- set dummy $library_names
- realname="$2"
- shift; shift
-
- if test -n "$soname_spec"; then
- eval soname=\"$soname_spec\"
- else
- soname="$realname"
- fi
- if test -z "$dlname"; then
- dlname=$soname
- fi
-
- lib="$output_objdir/$realname"
- for link
- do
- linknames="$linknames $link"
- done
-
- # Use standard objects if they are pic
- test -z "$pic_flag" && libobjs=`$echo "X$libobjs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
-
- # Prepare the list of exported symbols
- if test -z "$export_symbols"; then
- if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then
- $show "generating symbol list for \`$libname.la'"
- export_symbols="$output_objdir/$libname.exp"
- $run $rm $export_symbols
- cmds=$export_symbols_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- if len=`expr "X$cmd" : ".*"` &&
- test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
- $show "$cmd"
- $run eval "$cmd" || exit $?
- skipped_export=false
- else
- # The command line is too long to execute in one step.
- $show "using reloadable object file for export list..."
- skipped_export=:
- # Break out early, otherwise skipped_export may be
- # set to false by a later but shorter cmd.
- break
- fi
- done
- IFS="$save_ifs"
- if test -n "$export_symbols_regex"; then
- $show "$EGREP -e \"$export_symbols_regex\" \"$export_symbols\" > \"${export_symbols}T\""
- $run eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
- $show "$mv \"${export_symbols}T\" \"$export_symbols\""
- $run eval '$mv "${export_symbols}T" "$export_symbols"'
- fi
- fi
- fi
-
- if test -n "$export_symbols" && test -n "$include_expsyms"; then
- $run eval '$echo "X$include_expsyms" | $SP2NL >> "$export_symbols"'
- fi
-
- tmp_deplibs=
- for test_deplib in $deplibs; do
- case " $convenience " in
- *" $test_deplib "*) ;;
- *)
- tmp_deplibs="$tmp_deplibs $test_deplib"
- ;;
- esac
- done
- deplibs="$tmp_deplibs"
-
- if test -n "$convenience"; then
- if test -n "$whole_archive_flag_spec"; then
- save_libobjs=$libobjs
- eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
- else
- gentop="$output_objdir/${outputname}x"
- generated="$generated $gentop"
-
- func_extract_archives $gentop $convenience
- libobjs="$libobjs $func_extract_archives_result"
- fi
- fi
-
- if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
- eval flag=\"$thread_safe_flag_spec\"
- linker_flags="$linker_flags $flag"
- fi
-
- # Make a backup of the uninstalled library when relinking
- if test "$mode" = relink; then
- $run eval '(cd $output_objdir && $rm ${realname}U && $mv $realname ${realname}U)' || exit $?
- fi
-
- # Do each of the archive commands.
- if test "$module" = yes && test -n "$module_cmds" ; then
- if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
- eval test_cmds=\"$module_expsym_cmds\"
- cmds=$module_expsym_cmds
- else
- eval test_cmds=\"$module_cmds\"
- cmds=$module_cmds
- fi
- else
- if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
- eval test_cmds=\"$archive_expsym_cmds\"
- cmds=$archive_expsym_cmds
- else
- eval test_cmds=\"$archive_cmds\"
- cmds=$archive_cmds
- fi
- fi
-
- if test "X$skipped_export" != "X:" &&
- len=`expr "X$test_cmds" : ".*" 2>/dev/null` &&
- test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
- :
- else
- # The command line is too long to link in one step, link piecewise.
- $echo "creating reloadable object files..."
-
- # Save the value of $output and $libobjs because we want to
- # use them later. If we have whole_archive_flag_spec, we
- # want to use save_libobjs as it was before
- # whole_archive_flag_spec was expanded, because we can't
- # assume the linker understands whole_archive_flag_spec.
- # This may have to be revisited, in case too many
- # convenience libraries get linked in and end up exceeding
- # the spec.
- if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then
- save_libobjs=$libobjs
- fi
- save_output=$output
- output_la=`$echo "X$output" | $Xsed -e "$basename"`
-
- # Clear the reloadable object creation command queue and
- # initialize k to one.
- test_cmds=
- concat_cmds=
- objlist=
- delfiles=
- last_robj=
- k=1
- output=$output_objdir/$output_la-${k}.$objext
- # Loop over the list of objects to be linked.
- for obj in $save_libobjs
- do
- eval test_cmds=\"$reload_cmds $objlist $last_robj\"
- if test "X$objlist" = X ||
- { len=`expr "X$test_cmds" : ".*" 2>/dev/null` &&
- test "$len" -le "$max_cmd_len"; }; then
- objlist="$objlist $obj"
- else
- # The command $test_cmds is almost too long, add a
- # command to the queue.
- if test "$k" -eq 1 ; then
- # The first file doesn't have a previous command to add.
- eval concat_cmds=\"$reload_cmds $objlist $last_robj\"
- else
- # All subsequent reloadable object files will link in
- # the last one created.
- eval concat_cmds=\"\$concat_cmds~$reload_cmds $objlist $last_robj\"
- fi
- last_robj=$output_objdir/$output_la-${k}.$objext
- k=`expr $k + 1`
- output=$output_objdir/$output_la-${k}.$objext
- objlist=$obj
- len=1
- fi
- done
- # Handle the remaining objects by creating one last
- # reloadable object file. All subsequent reloadable object
- # files will link in the last one created.
- test -z "$concat_cmds" || concat_cmds=$concat_cmds~
- eval concat_cmds=\"\${concat_cmds}$reload_cmds $objlist $last_robj\"
-
- if ${skipped_export-false}; then
- $show "generating symbol list for \`$libname.la'"
- export_symbols="$output_objdir/$libname.exp"
- $run $rm $export_symbols
- libobjs=$output
- # Append the command to create the export file.
- eval concat_cmds=\"\$concat_cmds~$export_symbols_cmds\"
- fi
-
- # Set up a command to remove the reloadable object files
- # after they are used.
- i=0
- while test "$i" -lt "$k"
- do
- i=`expr $i + 1`
- delfiles="$delfiles $output_objdir/$output_la-${i}.$objext"
- done
-
- $echo "creating a temporary reloadable object file: $output"
-
- # Loop through the commands generated above and execute them.
- save_ifs="$IFS"; IFS='~'
- for cmd in $concat_cmds; do
- IFS="$save_ifs"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
-
- libobjs=$output
- # Restore the value of output.
- output=$save_output
-
- if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then
- eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
- fi
- # Expand the library linking commands again to reset the
- # value of $libobjs for piecewise linking.
-
- # Do each of the archive commands.
- if test "$module" = yes && test -n "$module_cmds" ; then
- if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
- cmds=$module_expsym_cmds
- else
- cmds=$module_cmds
- fi
- else
- if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then
- cmds=$archive_expsym_cmds
- else
- cmds=$archive_cmds
- fi
- fi
-
- # Append the command to remove the reloadable object files
- # to the just-reset $cmds.
- eval cmds=\"\$cmds~\$rm $delfiles\"
- fi
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || {
- lt_exit=$?
-
- # Restore the uninstalled library and exit
- if test "$mode" = relink; then
- $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)'
- fi
-
- exit $lt_exit
- }
- done
- IFS="$save_ifs"
-
- # Restore the uninstalled library and exit
- if test "$mode" = relink; then
- $run eval '(cd $output_objdir && $rm ${realname}T && $mv $realname ${realname}T && $mv "$realname"U $realname)' || exit $?
-
- if test -n "$convenience"; then
- if test -z "$whole_archive_flag_spec"; then
- $show "${rm}r $gentop"
- $run ${rm}r "$gentop"
- fi
- fi
-
- exit $EXIT_SUCCESS
- fi
-
- # Create links to the real library.
- for linkname in $linknames; do
- if test "$realname" != "$linkname"; then
- $show "(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)"
- $run eval '(cd $output_objdir && $rm $linkname && $LN_S $realname $linkname)' || exit $?
- fi
- done
-
- # If -module or -export-dynamic was specified, set the dlname.
- if test "$module" = yes || test "$export_dynamic" = yes; then
- # On all known operating systems, these are identical.
- dlname="$soname"
- fi
- fi
- ;;
-
- obj)
- if test -n "$deplibs"; then
- $echo "$modename: warning: \`-l' and \`-L' are ignored for objects" 1>&2
- fi
-
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
- $echo "$modename: warning: \`-dlopen' is ignored for objects" 1>&2
- fi
-
- if test -n "$rpath"; then
- $echo "$modename: warning: \`-rpath' is ignored for objects" 1>&2
- fi
-
- if test -n "$xrpath"; then
- $echo "$modename: warning: \`-R' is ignored for objects" 1>&2
- fi
-
- if test -n "$vinfo"; then
- $echo "$modename: warning: \`-version-info' is ignored for objects" 1>&2
- fi
-
- if test -n "$release"; then
- $echo "$modename: warning: \`-release' is ignored for objects" 1>&2
- fi
-
- case $output in
- *.lo)
- if test -n "$objs$old_deplibs"; then
- $echo "$modename: cannot build library object \`$output' from non-libtool objects" 1>&2
- exit $EXIT_FAILURE
- fi
- libobj="$output"
- obj=`$echo "X$output" | $Xsed -e "$lo2o"`
- ;;
- *)
- libobj=
- obj="$output"
- ;;
- esac
-
- # Delete the old objects.
- $run $rm $obj $libobj
-
- # Objects from convenience libraries. This assumes
- # single-version convenience libraries. Whenever we create
- # different ones for PIC/non-PIC, this we'll have to duplicate
- # the extraction.
- reload_conv_objs=
- gentop=
- # reload_cmds runs $LD directly, so let us get rid of
- # -Wl from whole_archive_flag_spec
- wl=
-
- if test -n "$convenience"; then
- if test -n "$whole_archive_flag_spec"; then
- eval reload_conv_objs=\"\$reload_objs $whole_archive_flag_spec\"
- else
- gentop="$output_objdir/${obj}x"
- generated="$generated $gentop"
-
- func_extract_archives $gentop $convenience
- reload_conv_objs="$reload_objs $func_extract_archives_result"
- fi
- fi
-
- # Create the old-style object.
- reload_objs="$objs$old_deplibs "`$echo "X$libobjs" | $SP2NL | $Xsed -e '/\.'${libext}$'/d' -e '/\.lib$/d' -e "$lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
-
- output="$obj"
- cmds=$reload_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
-
- # Exit if we aren't doing a library object file.
- if test -z "$libobj"; then
- if test -n "$gentop"; then
- $show "${rm}r $gentop"
- $run ${rm}r $gentop
- fi
-
- exit $EXIT_SUCCESS
- fi
-
- if test "$build_libtool_libs" != yes; then
- if test -n "$gentop"; then
- $show "${rm}r $gentop"
- $run ${rm}r $gentop
- fi
-
- # Create an invalid libtool object if no PIC, so that we don't
- # accidentally link it into a program.
- # $show "echo timestamp > $libobj"
- # $run eval "echo timestamp > $libobj" || exit $?
- exit $EXIT_SUCCESS
- fi
-
- if test -n "$pic_flag" || test "$pic_mode" != default; then
- # Only do commands if we really have different PIC objects.
- reload_objs="$libobjs $reload_conv_objs"
- output="$libobj"
- cmds=$reload_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
- fi
-
- if test -n "$gentop"; then
- $show "${rm}r $gentop"
- $run ${rm}r $gentop
- fi
-
- exit $EXIT_SUCCESS
- ;;
-
- prog)
- case $host in
- *cygwin*) output=`$echo $output | ${SED} -e 's,.exe$,,;s,$,.exe,'` ;;
- esac
- if test -n "$vinfo"; then
- $echo "$modename: warning: \`-version-info' is ignored for programs" 1>&2
- fi
-
- if test -n "$release"; then
- $echo "$modename: warning: \`-release' is ignored for programs" 1>&2
- fi
-
- if test "$preload" = yes; then
- if test "$dlopen_support" = unknown && test "$dlopen_self" = unknown &&
- test "$dlopen_self_static" = unknown; then
- $echo "$modename: warning: \`AC_LIBTOOL_DLOPEN' not used. Assuming no dlopen support."
- fi
- fi
-
- case $host in
- *-*-rhapsody* | *-*-darwin1.[012])
- # On Rhapsody replace the C library is the System framework
- compile_deplibs=`$echo "X $compile_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
- finalize_deplibs=`$echo "X $finalize_deplibs" | $Xsed -e 's/ -lc / -framework System /'`
- ;;
- esac
-
- case $host in
- *darwin*)
- # Don't allow lazy linking, it breaks C++ global constructors
- if test "$tagname" = CXX ; then
- compile_command="$compile_command ${wl}-bind_at_load"
- finalize_command="$finalize_command ${wl}-bind_at_load"
- fi
- ;;
- esac
-
- compile_command="$compile_command $compile_deplibs"
- finalize_command="$finalize_command $finalize_deplibs"
-
- if test -n "$rpath$xrpath"; then
- # If the user specified any rpath flags, then add them.
- for libdir in $rpath $xrpath; do
- # This is the magic to use -rpath.
- case "$finalize_rpath " in
- *" $libdir "*) ;;
- *) finalize_rpath="$finalize_rpath $libdir" ;;
- esac
- done
- fi
-
- # Now hardcode the library paths
- rpath=
- hardcode_libdirs=
- for libdir in $compile_rpath $finalize_rpath; do
- if test -n "$hardcode_libdir_flag_spec"; then
- if test -n "$hardcode_libdir_separator"; then
- if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
- else
- # Just accumulate the unique libdirs.
- case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
- *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
- ;;
- *)
- hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
- ;;
- esac
- fi
- else
- eval flag=\"$hardcode_libdir_flag_spec\"
- rpath="$rpath $flag"
- fi
- elif test -n "$runpath_var"; then
- case "$perm_rpath " in
- *" $libdir "*) ;;
- *) perm_rpath="$perm_rpath $libdir" ;;
- esac
- fi
- case $host in
- *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2*)
- case :$dllsearchpath: in
- *":$libdir:"*) ;;
- *) dllsearchpath="$dllsearchpath:$libdir";;
- esac
- ;;
- esac
- done
- # Substitute the hardcoded libdirs into the rpath.
- if test -n "$hardcode_libdir_separator" &&
- test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
- eval rpath=\" $hardcode_libdir_flag_spec\"
- fi
- compile_rpath="$rpath"
-
- rpath=
- hardcode_libdirs=
- for libdir in $finalize_rpath; do
- if test -n "$hardcode_libdir_flag_spec"; then
- if test -n "$hardcode_libdir_separator"; then
- if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
- else
- # Just accumulate the unique libdirs.
- case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
- *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*)
- ;;
- *)
- hardcode_libdirs="$hardcode_libdirs$hardcode_libdir_separator$libdir"
- ;;
- esac
- fi
- else
- eval flag=\"$hardcode_libdir_flag_spec\"
- rpath="$rpath $flag"
- fi
- elif test -n "$runpath_var"; then
- case "$finalize_perm_rpath " in
- *" $libdir "*) ;;
- *) finalize_perm_rpath="$finalize_perm_rpath $libdir" ;;
- esac
- fi
- done
- # Substitute the hardcoded libdirs into the rpath.
- if test -n "$hardcode_libdir_separator" &&
- test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
- eval rpath=\" $hardcode_libdir_flag_spec\"
- fi
- finalize_rpath="$rpath"
-
- if test -n "$libobjs" && test "$build_old_libs" = yes; then
- # Transform all the library objects into standard objects.
- compile_command=`$echo "X$compile_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
- finalize_command=`$echo "X$finalize_command" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
- fi
-
- dlsyms=
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
- if test -n "$NM" && test -n "$global_symbol_pipe"; then
- dlsyms="${outputname}S.c"
- else
- $echo "$modename: not configured to extract global symbols from dlpreopened files" 1>&2
- fi
- fi
-
- if test -n "$dlsyms"; then
- case $dlsyms in
- "") ;;
- *.c)
- # Discover the nlist of each of the dlfiles.
- nlist="$output_objdir/${outputname}.nm"
-
- $show "$rm $nlist ${nlist}S ${nlist}T"
- $run $rm "$nlist" "${nlist}S" "${nlist}T"
-
- # Parse the name list into a source file.
- $show "creating $output_objdir/$dlsyms"
-
- test -z "$run" && $echo > "$output_objdir/$dlsyms" "\
-/* $dlsyms - symbol resolution table for \`$outputname' dlsym emulation. */
-/* Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP */
-
-#ifdef __cplusplus
-extern \"C\" {
-#endif
-
-/* Prevent the only kind of declaration conflicts we can make. */
-#define lt_preloaded_symbols some_other_symbol
-
-/* External symbol declarations for the compiler. */\
-"
-
- if test "$dlself" = yes; then
- $show "generating symbol list for \`$output'"
-
- test -z "$run" && $echo ': @PROGRAM@ ' > "$nlist"
-
- # Add our own program objects to the symbol list.
- progfiles=`$echo "X$objs$old_deplibs" | $SP2NL | $Xsed -e "$lo2o" | $NL2SP`
- for arg in $progfiles; do
- $show "extracting global C symbols from \`$arg'"
- $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'"
- done
-
- if test -n "$exclude_expsyms"; then
- $run eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T'
- $run eval '$mv "$nlist"T "$nlist"'
- fi
-
- if test -n "$export_symbols_regex"; then
- $run eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T'
- $run eval '$mv "$nlist"T "$nlist"'
- fi
-
- # Prepare the list of exported symbols
- if test -z "$export_symbols"; then
- export_symbols="$output_objdir/$outputname.exp"
- $run $rm $export_symbols
- $run eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
- else
- $run eval "${SED} -e 's/\([ ][.*^$]\)/\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
- $run eval 'grep -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
- $run eval 'mv "$nlist"T "$nlist"'
- fi
- fi
-
- for arg in $dlprefiles; do
- $show "extracting global C symbols from \`$arg'"
- name=`$echo "$arg" | ${SED} -e 's%^.*/%%'`
- $run eval '$echo ": $name " >> "$nlist"'
- $run eval "$NM $arg | $global_symbol_pipe >> '$nlist'"
- done
-
- if test -z "$run"; then
- # Make sure we have at least an empty file.
- test -f "$nlist" || : > "$nlist"
-
- if test -n "$exclude_expsyms"; then
- $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T
- $mv "$nlist"T "$nlist"
- fi
-
- # Try sorting and uniquifying the output.
- if grep -v "^: " < "$nlist" |
- if sort -k 3 </dev/null >/dev/null 2>&1; then
- sort -k 3
- else
- sort +2
- fi |
- uniq > "$nlist"S; then
- :
- else
- grep -v "^: " < "$nlist" > "$nlist"S
- fi
-
- if test -f "$nlist"S; then
- eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$dlsyms"'
- else
- $echo '/* NONE */' >> "$output_objdir/$dlsyms"
- fi
-
- $echo >> "$output_objdir/$dlsyms" "\
-
-#undef lt_preloaded_symbols
-
-#if defined (__STDC__) && __STDC__
-# define lt_ptr void *
-#else
-# define lt_ptr char *
-# define const
-#endif
-
-/* The mapping between symbol names and symbols. */
-"
-
- case $host in
- *cygwin* | *mingw* )
- $echo >> "$output_objdir/$dlsyms" "\
-/* DATA imports from DLLs on WIN32 can't be const, because
- runtime relocations are performed -- see ld's documentation
- on pseudo-relocs */
-struct {
-"
- ;;
- * )
- $echo >> "$output_objdir/$dlsyms" "\
-const struct {
-"
- ;;
- esac
-
-
- $echo >> "$output_objdir/$dlsyms" "\
- const char *name;
- lt_ptr address;
-}
-lt_preloaded_symbols[] =
-{\
-"
-
- eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$dlsyms"
-
- $echo >> "$output_objdir/$dlsyms" "\
- {0, (lt_ptr) 0}
-};
-
-/* This works around a problem in FreeBSD linker */
-#ifdef FREEBSD_WORKAROUND
-static const void *lt_preloaded_setup() {
- return lt_preloaded_symbols;
-}
-#endif
-
-#ifdef __cplusplus
-}
-#endif\
-"
- fi
-
- pic_flag_for_symtable=
- case $host in
- # compiling the symbol table file with pic_flag works around
- # a FreeBSD bug that causes programs to crash when -lm is
- # linked before any other PIC object. But we must not use
- # pic_flag when linking with -static. The problem exists in
- # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1.
- *-*-freebsd2*|*-*-freebsd3.0*|*-*-freebsdelf3.0*)
- case "$compile_command " in
- *" -static "*) ;;
- *) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND";;
- esac;;
- *-*-hpux*)
- case "$compile_command " in
- *" -static "*) ;;
- *) pic_flag_for_symtable=" $pic_flag";;
- esac
- esac
-
- # Now compile the dynamic symbol file.
- $show "(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable \"$dlsyms\")"
- $run eval '(cd $output_objdir && $LTCC -c$no_builtin_flag$pic_flag_for_symtable "$dlsyms")' || exit $?
-
- # Clean up the generated files.
- $show "$rm $output_objdir/$dlsyms $nlist ${nlist}S ${nlist}T"
- $run $rm "$output_objdir/$dlsyms" "$nlist" "${nlist}S" "${nlist}T"
-
- # Transform the symbol file into the correct name.
- compile_command=`$echo "X$compile_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"`
- finalize_command=`$echo "X$finalize_command" | $Xsed -e "s%@SYMFILE@%$output_objdir/${outputname}S.${objext}%"`
- ;;
- *)
- $echo "$modename: unknown suffix for \`$dlsyms'" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
- else
- # We keep going just in case the user didn't refer to
- # lt_preloaded_symbols. The linker will fail if global_symbol_pipe
- # really was required.
-
- # Nullify the symbol file.
- compile_command=`$echo "X$compile_command" | $Xsed -e "s% @SYMFILE@%%"`
- finalize_command=`$echo "X$finalize_command" | $Xsed -e "s% @SYMFILE@%%"`
- fi
-
- if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
- # Replace the output file specification.
- compile_command=`$echo "X$compile_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
- link_command="$compile_command$compile_rpath"
-
- # We have no uninstalled library dependencies, so finalize right now.
- $show "$link_command"
- $run eval "$link_command"
- status=$?
-
- # Delete the generated files.
- if test -n "$dlsyms"; then
- $show "$rm $output_objdir/${outputname}S.${objext}"
- $run $rm "$output_objdir/${outputname}S.${objext}"
- fi
-
- exit $status
- fi
-
- if test -n "$shlibpath_var"; then
- # We should set the shlibpath_var
- rpath=
- for dir in $temp_rpath; do
- case $dir in
- [\\/]* | [A-Za-z]:[\\/]*)
- # Absolute path.
- rpath="$rpath$dir:"
- ;;
- *)
- # Relative path: add a thisdir entry.
- rpath="$rpath\$thisdir/$dir:"
- ;;
- esac
- done
- temp_rpath="$rpath"
- fi
-
- if test -n "$compile_shlibpath$finalize_shlibpath"; then
- compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
- fi
- if test -n "$finalize_shlibpath"; then
- finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command"
- fi
-
- compile_var=
- finalize_var=
- if test -n "$runpath_var"; then
- if test -n "$perm_rpath"; then
- # We should set the runpath_var.
- rpath=
- for dir in $perm_rpath; do
- rpath="$rpath$dir:"
- done
- compile_var="$runpath_var=\"$rpath\$$runpath_var\" "
- fi
- if test -n "$finalize_perm_rpath"; then
- # We should set the runpath_var.
- rpath=
- for dir in $finalize_perm_rpath; do
- rpath="$rpath$dir:"
- done
- finalize_var="$runpath_var=\"$rpath\$$runpath_var\" "
- fi
- fi
-
- if test "$no_install" = yes; then
- # We don't need to create a wrapper script.
- link_command="$compile_var$compile_command$compile_rpath"
- # Replace the output file specification.
- link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output"'%g'`
- # Delete the old output file.
- $run $rm $output
- # Link the executable and exit
- $show "$link_command"
- $run eval "$link_command" || exit $?
- exit $EXIT_SUCCESS
- fi
-
- if test "$hardcode_action" = relink; then
- # Fast installation is not supported
- link_command="$compile_var$compile_command$compile_rpath"
- relink_command="$finalize_var$finalize_command$finalize_rpath"
-
- $echo "$modename: warning: this platform does not like uninstalled shared libraries" 1>&2
- $echo "$modename: \`$output' will be relinked during installation" 1>&2
- else
- if test "$fast_install" != no; then
- link_command="$finalize_var$compile_command$finalize_rpath"
- if test "$fast_install" = yes; then
- relink_command=`$echo "X$compile_var$compile_command$compile_rpath" | $Xsed -e 's%@OUTPUT@%\$progdir/\$file%g'`
- else
- # fast_install is set to needless
- relink_command=
- fi
- else
- link_command="$compile_var$compile_command$compile_rpath"
- relink_command="$finalize_var$finalize_command$finalize_rpath"
- fi
- fi
-
- # Replace the output file specification.
- link_command=`$echo "X$link_command" | $Xsed -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
-
- # Delete the old output files.
- $run $rm $output $output_objdir/$outputname $output_objdir/lt-$outputname
-
- $show "$link_command"
- $run eval "$link_command" || exit $?
-
- # Now create the wrapper script.
- $show "creating $output"
-
- # Quote the relink command for shipping.
- if test -n "$relink_command"; then
- # Preserve any variables that may affect compiler behavior
- for var in $variables_saved_for_relink; do
- if eval test -z \"\${$var+set}\"; then
- relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command"
- elif eval var_value=\$$var; test -z "$var_value"; then
- relink_command="$var=; export $var; $relink_command"
- else
- var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"`
- relink_command="$var=\"$var_value\"; export $var; $relink_command"
- fi
- done
- relink_command="(cd `pwd`; $relink_command)"
- relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"`
- fi
-
- # Quote $echo for shipping.
- if test "X$echo" = "X$SHELL $progpath --fallback-echo"; then
- case $progpath in
- [\\/]* | [A-Za-z]:[\\/]*) qecho="$SHELL $progpath --fallback-echo";;
- *) qecho="$SHELL `pwd`/$progpath --fallback-echo";;
- esac
- qecho=`$echo "X$qecho" | $Xsed -e "$sed_quote_subst"`
- else
- qecho=`$echo "X$echo" | $Xsed -e "$sed_quote_subst"`
- fi
-
- # Only actually do things if our run command is non-null.
- if test -z "$run"; then
- # win32 will think the script is a binary if it has
- # a .exe suffix, so we strip it off here.
- case $output in
- *.exe) output=`$echo $output|${SED} 's,.exe$,,'` ;;
- esac
- # test for cygwin because mv fails w/o .exe extensions
- case $host in
- *cygwin*)
- exeext=.exe
- outputname=`$echo $outputname|${SED} 's,.exe$,,'` ;;
- *) exeext= ;;
- esac
- case $host in
- *cygwin* | *mingw* )
- cwrappersource=`$echo ${objdir}/lt-${outputname}.c`
- cwrapper=`$echo ${output}.exe`
- $rm $cwrappersource $cwrapper
- trap "$rm $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
-
- cat > $cwrappersource <<EOF
-
-/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
- Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-
- The $output program cannot be directly executed until all the libtool
- libraries that it depends on are installed.
-
- This wrapper executable should never be moved out of the build directory.
- If it is, it will not operate correctly.
-
- Currently, it simply execs the wrapper *script* "/bin/sh $output",
- but could eventually absorb all of the scripts functionality and
- exec $objdir/$outputname directly.
-*/
-EOF
- cat >> $cwrappersource<<"EOF"
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <malloc.h>
-#include <stdarg.h>
-#include <assert.h>
-
-#if defined(PATH_MAX)
-# define LT_PATHMAX PATH_MAX
-#elif defined(MAXPATHLEN)
-# define LT_PATHMAX MAXPATHLEN
-#else
-# define LT_PATHMAX 1024
-#endif
-
-#ifndef DIR_SEPARATOR
-#define DIR_SEPARATOR '/'
-#endif
-
-#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
- defined (__OS2__)
-#define HAVE_DOS_BASED_FILE_SYSTEM
-#ifndef DIR_SEPARATOR_2
-#define DIR_SEPARATOR_2 '\\'
-#endif
-#endif
-
-#ifndef DIR_SEPARATOR_2
-# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR)
-#else /* DIR_SEPARATOR_2 */
-# define IS_DIR_SEPARATOR(ch) \
- (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2))
-#endif /* DIR_SEPARATOR_2 */
-
-#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type)))
-#define XFREE(stale) do { \
- if (stale) { free ((void *) stale); stale = 0; } \
-} while (0)
-
-const char *program_name = NULL;
-
-void * xmalloc (size_t num);
-char * xstrdup (const char *string);
-char * basename (const char *name);
-char * fnqualify(const char *path);
-char * strendzap(char *str, const char *pat);
-void lt_fatal (const char *message, ...);
-
-int
-main (int argc, char *argv[])
-{
- char **newargz;
- int i;
-
- program_name = (char *) xstrdup ((char *) basename (argv[0]));
- newargz = XMALLOC(char *, argc+2);
-EOF
-
- cat >> $cwrappersource <<EOF
- newargz[0] = "$SHELL";
-EOF
-
- cat >> $cwrappersource <<"EOF"
- newargz[1] = fnqualify(argv[0]);
- /* we know the script has the same name, without the .exe */
- /* so make sure newargz[1] doesn't end in .exe */
- strendzap(newargz[1],".exe");
- for (i = 1; i < argc; i++)
- newargz[i+1] = xstrdup(argv[i]);
- newargz[argc+1] = NULL;
-EOF
-
- cat >> $cwrappersource <<EOF
- execv("$SHELL",newargz);
-EOF
-
- cat >> $cwrappersource <<"EOF"
- return 127;
-}
-
-void *
-xmalloc (size_t num)
-{
- void * p = (void *) malloc (num);
- if (!p)
- lt_fatal ("Memory exhausted");
-
- return p;
-}
-
-char *
-xstrdup (const char *string)
-{
- return string ? strcpy ((char *) xmalloc (strlen (string) + 1), string) : NULL
-;
-}
-
-char *
-basename (const char *name)
-{
- const char *base;
-
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
- /* Skip over the disk name in MSDOS pathnames. */
- if (isalpha (name[0]) && name[1] == ':')
- name += 2;
-#endif
-
- for (base = name; *name; name++)
- if (IS_DIR_SEPARATOR (*name))
- base = name + 1;
- return (char *) base;
-}
-
-char *
-fnqualify(const char *path)
-{
- size_t size;
- char *p;
- char tmp[LT_PATHMAX + 1];
-
- assert(path != NULL);
-
- /* Is it qualified already? */
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
- if (isalpha (path[0]) && path[1] == ':')
- return xstrdup (path);
-#endif
- if (IS_DIR_SEPARATOR (path[0]))
- return xstrdup (path);
-
- /* prepend the current directory */
- /* doesn't handle '~' */
- if (getcwd (tmp, LT_PATHMAX) == NULL)
- lt_fatal ("getcwd failed");
- size = strlen(tmp) + 1 + strlen(path) + 1; /* +2 for '/' and '\0' */
- p = XMALLOC(char, size);
- sprintf(p, "%s%c%s", tmp, DIR_SEPARATOR, path);
- return p;
-}
-
-char *
-strendzap(char *str, const char *pat)
-{
- size_t len, patlen;
-
- assert(str != NULL);
- assert(pat != NULL);
-
- len = strlen(str);
- patlen = strlen(pat);
-
- if (patlen <= len)
- {
- str += len - patlen;
- if (strcmp(str, pat) == 0)
- *str = '\0';
- }
- return str;
-}
-
-static void
-lt_error_core (int exit_status, const char * mode,
- const char * message, va_list ap)
-{
- fprintf (stderr, "%s: %s: ", program_name, mode);
- vfprintf (stderr, message, ap);
- fprintf (stderr, ".\n");
-
- if (exit_status >= 0)
- exit (exit_status);
-}
-
-void
-lt_fatal (const char *message, ...)
-{
- va_list ap;
- va_start (ap, message);
- lt_error_core (EXIT_FAILURE, "FATAL", message, ap);
- va_end (ap);
-}
-EOF
- # we should really use a build-platform specific compiler
- # here, but OTOH, the wrappers (shell script and this C one)
- # are only useful if you want to execute the "real" binary.
- # Since the "real" binary is built for $host, then this
- # wrapper might as well be built for $host, too.
- $run $LTCC -s -o $cwrapper $cwrappersource
- ;;
- esac
- $rm $output
- trap "$rm $output; exit $EXIT_FAILURE" 1 2 15
-
- $echo > $output "\
-#! $SHELL
-
-# $output - temporary wrapper script for $objdir/$outputname
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# The $output program cannot be directly executed until all the libtool
-# libraries that it depends on are installed.
-#
-# This wrapper script should never be moved out of the build directory.
-# If it is, it will not operate correctly.
-
-# Sed substitution that helps us do robust quoting. It backslashifies
-# metacharacters that are still active within double-quoted strings.
-Xsed='${SED} -e 1s/^X//'
-sed_quote_subst='$sed_quote_subst'
-
-# The HP-UX ksh and POSIX shell print the target directory to stdout
-# if CDPATH is set.
-(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
-
-relink_command=\"$relink_command\"
-
-# This environment variable determines our operation mode.
-if test \"\$libtool_install_magic\" = \"$magic\"; then
- # install mode needs the following variable:
- notinst_deplibs='$notinst_deplibs'
-else
- # When we are sourced in execute mode, \$file and \$echo are already set.
- if test \"\$libtool_execute_magic\" != \"$magic\"; then
- echo=\"$qecho\"
- file=\"\$0\"
- # Make sure echo works.
- if test \"X\$1\" = X--no-reexec; then
- # Discard the --no-reexec flag, and continue.
- shift
- elif test \"X\`(\$echo '\t') 2>/dev/null\`\" = 'X\t'; then
- # Yippee, \$echo works!
- :
- else
- # Restart under the correct shell, and then maybe \$echo will work.
- exec $SHELL \"\$0\" --no-reexec \${1+\"\$@\"}
- fi
- fi\
-"
- $echo >> $output "\
-
- # Find the directory that this script lives in.
- thisdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*$%%'\`
- test \"x\$thisdir\" = \"x\$file\" && thisdir=.
-
- # Follow symbolic links until we get to the real thisdir.
- file=\`ls -ld \"\$file\" | ${SED} -n 's/.*-> //p'\`
- while test -n \"\$file\"; do
- destdir=\`\$echo \"X\$file\" | \$Xsed -e 's%/[^/]*\$%%'\`
-
- # If there was a directory component, then change thisdir.
- if test \"x\$destdir\" != \"x\$file\"; then
- case \"\$destdir\" in
- [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;;
- *) thisdir=\"\$thisdir/\$destdir\" ;;
- esac
- fi
-
- file=\`\$echo \"X\$file\" | \$Xsed -e 's%^.*/%%'\`
- file=\`ls -ld \"\$thisdir/\$file\" | ${SED} -n 's/.*-> //p'\`
- done
-
- # Try to get the absolute directory name.
- absdir=\`cd \"\$thisdir\" && pwd\`
- test -n \"\$absdir\" && thisdir=\"\$absdir\"
-"
-
- if test "$fast_install" = yes; then
- $echo >> $output "\
- program=lt-'$outputname'$exeext
- progdir=\"\$thisdir/$objdir\"
-
- if test ! -f \"\$progdir/\$program\" || \\
- { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\
- test \"X\$file\" != \"X\$progdir/\$program\"; }; then
-
- file=\"\$\$-\$program\"
-
- if test ! -d \"\$progdir\"; then
- $mkdir \"\$progdir\"
- else
- $rm \"\$progdir/\$file\"
- fi"
-
- $echo >> $output "\
-
- # relink executable if necessary
- if test -n \"\$relink_command\"; then
- if relink_command_output=\`eval \$relink_command 2>&1\`; then :
- else
- $echo \"\$relink_command_output\" >&2
- $rm \"\$progdir/\$file\"
- exit $EXIT_FAILURE
- fi
- fi
-
- $mv \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null ||
- { $rm \"\$progdir/\$program\";
- $mv \"\$progdir/\$file\" \"\$progdir/\$program\"; }
- $rm \"\$progdir/\$file\"
- fi"
- else
- $echo >> $output "\
- program='$outputname'
- progdir=\"\$thisdir/$objdir\"
-"
- fi
-
- $echo >> $output "\
-
- if test -f \"\$progdir/\$program\"; then"
-
- # Export our shlibpath_var if we have one.
- if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
- $echo >> $output "\
- # Add our own library path to $shlibpath_var
- $shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
-
- # Some systems cannot cope with colon-terminated $shlibpath_var
- # The second colon is a workaround for a bug in BeOS R4 sed
- $shlibpath_var=\`\$echo \"X\$$shlibpath_var\" | \$Xsed -e 's/::*\$//'\`
-
- export $shlibpath_var
-"
- fi
-
- # fixup the dll searchpath if we need to.
- if test -n "$dllsearchpath"; then
- $echo >> $output "\
- # Add the dll search path components to the executable PATH
- PATH=$dllsearchpath:\$PATH
-"
- fi
-
- $echo >> $output "\
- if test \"\$libtool_execute_magic\" != \"$magic\"; then
- # Run the actual program with our arguments.
-"
- case $host in
- # Backslashes separate directories on plain windows
- *-*-mingw | *-*-os2*)
- $echo >> $output "\
- exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
-"
- ;;
-
- *)
- $echo >> $output "\
- exec \"\$progdir/\$program\" \${1+\"\$@\"}
-"
- ;;
- esac
- $echo >> $output "\
- \$echo \"\$0: cannot exec \$program \${1+\"\$@\"}\"
- exit $EXIT_FAILURE
- fi
- else
- # The program doesn't exist.
- \$echo \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2
- \$echo \"This script is just a wrapper for \$program.\" 1>&2
- $echo \"See the $PACKAGE documentation for more information.\" 1>&2
- exit $EXIT_FAILURE
- fi
-fi\
-"
- chmod +x $output
- fi
- exit $EXIT_SUCCESS
- ;;
- esac
-
- # See if we need to build an old-fashioned archive.
- for oldlib in $oldlibs; do
-
- if test "$build_libtool_libs" = convenience; then
- oldobjs="$libobjs_save"
- addlibs="$convenience"
- build_libtool_libs=no
- else
- if test "$build_libtool_libs" = module; then
- oldobjs="$libobjs_save"
- build_libtool_libs=no
- else
- oldobjs="$old_deplibs $non_pic_objects"
- fi
- addlibs="$old_convenience"
- fi
-
- if test -n "$addlibs"; then
- gentop="$output_objdir/${outputname}x"
- generated="$generated $gentop"
-
- func_extract_archives $gentop $addlibs
- oldobjs="$oldobjs $func_extract_archives_result"
- fi
-
- # Do each command in the archive commands.
- if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
- cmds=$old_archive_from_new_cmds
- else
- # POSIX demands no paths to be encoded in archives. We have
- # to avoid creating archives with duplicate basenames if we
- # might have to extract them afterwards, e.g., when creating a
- # static archive out of a convenience library, or when linking
- # the entirety of a libtool archive into another (currently
- # not supported by libtool).
- if (for obj in $oldobjs
- do
- $echo "X$obj" | $Xsed -e 's%^.*/%%'
- done | sort | sort -uc >/dev/null 2>&1); then
- :
- else
- $echo "copying selected object files to avoid basename conflicts..."
-
- if test -z "$gentop"; then
- gentop="$output_objdir/${outputname}x"
- generated="$generated $gentop"
-
- $show "${rm}r $gentop"
- $run ${rm}r "$gentop"
- $show "$mkdir $gentop"
- $run $mkdir "$gentop"
- status=$?
- if test "$status" -ne 0 && test ! -d "$gentop"; then
- exit $status
- fi
- fi
-
- save_oldobjs=$oldobjs
- oldobjs=
- counter=1
- for obj in $save_oldobjs
- do
- objbase=`$echo "X$obj" | $Xsed -e 's%^.*/%%'`
- case " $oldobjs " in
- " ") oldobjs=$obj ;;
- *[\ /]"$objbase "*)
- while :; do
- # Make sure we don't pick an alternate name that also
- # overlaps.
- newobj=lt$counter-$objbase
- counter=`expr $counter + 1`
- case " $oldobjs " in
- *[\ /]"$newobj "*) ;;
- *) if test ! -f "$gentop/$newobj"; then break; fi ;;
- esac
- done
- $show "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj"
- $run ln "$obj" "$gentop/$newobj" ||
- $run cp "$obj" "$gentop/$newobj"
- oldobjs="$oldobjs $gentop/$newobj"
- ;;
- *) oldobjs="$oldobjs $obj" ;;
- esac
- done
- fi
-
- eval cmds=\"$old_archive_cmds\"
-
- if len=`expr "X$cmds" : ".*"` &&
- test "$len" -le "$max_cmd_len" || test "$max_cmd_len" -le -1; then
- cmds=$old_archive_cmds
- else
- # the command line is too long to link in one step, link in parts
- $echo "using piecewise archive linking..."
- save_RANLIB=$RANLIB
- RANLIB=:
- objlist=
- concat_cmds=
- save_oldobjs=$oldobjs
-
- # Is there a better way of finding the last object in the list?
- for obj in $save_oldobjs
- do
- last_oldobj=$obj
- done
- for obj in $save_oldobjs
- do
- oldobjs="$objlist $obj"
- objlist="$objlist $obj"
- eval test_cmds=\"$old_archive_cmds\"
- if len=`expr "X$test_cmds" : ".*" 2>/dev/null` &&
- test "$len" -le "$max_cmd_len"; then
- :
- else
- # the above command should be used before it gets too long
- oldobjs=$objlist
- if test "$obj" = "$last_oldobj" ; then
- RANLIB=$save_RANLIB
- fi
- test -z "$concat_cmds" || concat_cmds=$concat_cmds~
- eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\"
- objlist=
- fi
- done
- RANLIB=$save_RANLIB
- oldobjs=$objlist
- if test "X$oldobjs" = "X" ; then
- eval cmds=\"\$concat_cmds\"
- else
- eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
- fi
- fi
- fi
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- eval cmd=\"$cmd\"
- IFS="$save_ifs"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
- done
-
- if test -n "$generated"; then
- $show "${rm}r$generated"
- $run ${rm}r$generated
- fi
-
- # Now create the libtool archive.
- case $output in
- *.la)
- old_library=
- test "$build_old_libs" = yes && old_library="$libname.$libext"
- $show "creating $output"
-
- # Preserve any variables that may affect compiler behavior
- for var in $variables_saved_for_relink; do
- if eval test -z \"\${$var+set}\"; then
- relink_command="{ test -z \"\${$var+set}\" || unset $var || { $var=; export $var; }; }; $relink_command"
- elif eval var_value=\$$var; test -z "$var_value"; then
- relink_command="$var=; export $var; $relink_command"
- else
- var_value=`$echo "X$var_value" | $Xsed -e "$sed_quote_subst"`
- relink_command="$var=\"$var_value\"; export $var; $relink_command"
- fi
- done
- # Quote the link command for shipping.
- relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
- relink_command=`$echo "X$relink_command" | $Xsed -e "$sed_quote_subst"`
- if test "$hardcode_automatic" = yes ; then
- relink_command=
- fi
-
-
- # Only create the output if not a dry run.
- if test -z "$run"; then
- for installed in no yes; do
- if test "$installed" = yes; then
- if test -z "$install_libdir"; then
- break
- fi
- output="$output_objdir/$outputname"i
- # Replace all uninstalled libtool libraries with the installed ones
- newdependency_libs=
- for deplib in $dependency_libs; do
- case $deplib in
- *.la)
- name=`$echo "X$deplib" | $Xsed -e 's%^.*/%%'`
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
- if test -z "$libdir"; then
- $echo "$modename: \`$deplib' is not a valid libtool archive" 1>&2
- exit $EXIT_FAILURE
- fi
- newdependency_libs="$newdependency_libs $libdir/$name"
- ;;
- *) newdependency_libs="$newdependency_libs $deplib" ;;
- esac
- done
- dependency_libs="$newdependency_libs"
- newdlfiles=
- for lib in $dlfiles; do
- name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
- if test -z "$libdir"; then
- $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
- exit $EXIT_FAILURE
- fi
- newdlfiles="$newdlfiles $libdir/$name"
- done
- dlfiles="$newdlfiles"
- newdlprefiles=
- for lib in $dlprefiles; do
- name=`$echo "X$lib" | $Xsed -e 's%^.*/%%'`
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
- if test -z "$libdir"; then
- $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
- exit $EXIT_FAILURE
- fi
- newdlprefiles="$newdlprefiles $libdir/$name"
- done
- dlprefiles="$newdlprefiles"
- else
- newdlfiles=
- for lib in $dlfiles; do
- case $lib in
- [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
- *) abs=`pwd`"/$lib" ;;
- esac
- newdlfiles="$newdlfiles $abs"
- done
- dlfiles="$newdlfiles"
- newdlprefiles=
- for lib in $dlprefiles; do
- case $lib in
- [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
- *) abs=`pwd`"/$lib" ;;
- esac
- newdlprefiles="$newdlprefiles $abs"
- done
- dlprefiles="$newdlprefiles"
- fi
- $rm $output
- # place dlname in correct position for cygwin
- tdlname=$dlname
- case $host,$output,$installed,$module,$dlname in
- *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll) tdlname=../bin/$dlname ;;
- esac
- $echo > $output "\
-# $outputname - a libtool library file
-# Generated by $PROGRAM - GNU $PACKAGE $VERSION$TIMESTAMP
-#
-# Please DO NOT delete this file!
-# It is necessary for linking the library.
-
-# The name that we can dlopen(3).
-dlname='$tdlname'
-
-# Names of this library.
-library_names='$library_names'
-
-# The name of the static archive.
-old_library='$old_library'
-
-# Libraries that this one depends upon.
-dependency_libs='$dependency_libs'
-
-# Version information for $libname.
-current=$current
-age=$age
-revision=$revision
-
-# Is this an already installed library?
-installed=$installed
-
-# Should we warn about portability when linking against -modules?
-shouldnotlink=$module
-
-# Files to dlopen/dlpreopen
-dlopen='$dlfiles'
-dlpreopen='$dlprefiles'
-
-# Directory that this library needs to be installed in:
-libdir='$install_libdir'"
- if test "$installed" = no && test "$need_relink" = yes; then
- $echo >> $output "\
-relink_command=\"$relink_command\""
- fi
- done
- fi
-
- # Do a symbolic link so that the libtool archive can be found in
- # LD_LIBRARY_PATH before the program is installed.
- $show "(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)"
- $run eval '(cd $output_objdir && $rm $outputname && $LN_S ../$outputname $outputname)' || exit $?
- ;;
- esac
- exit $EXIT_SUCCESS
- ;;
-
- # libtool install mode
- install)
- modename="$modename: install"
-
- # There may be an optional sh(1) argument at the beginning of
- # install_prog (especially on Windows NT).
- if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh ||
- # Allow the use of GNU shtool's install command.
- $echo "X$nonopt" | grep shtool > /dev/null; then
- # Aesthetically quote it.
- arg=`$echo "X$nonopt" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- install_prog="$arg "
- arg="$1"
- shift
- else
- install_prog=
- arg=$nonopt
- fi
-
- # The real first argument should be the name of the installation program.
- # Aesthetically quote it.
- arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- install_prog="$install_prog$arg"
-
- # We need to accept at least all the BSD install flags.
- dest=
- files=
- opts=
- prev=
- install_type=
- isdir=no
- stripme=
- for arg
- do
- if test -n "$dest"; then
- files="$files $dest"
- dest=$arg
- continue
- fi
-
- case $arg in
- -d) isdir=yes ;;
- -f)
- case " $install_prog " in
- *[\\\ /]cp\ *) ;;
- *) prev=$arg ;;
- esac
- ;;
- -g | -m | -o) prev=$arg ;;
- -s)
- stripme=" -s"
- continue
- ;;
- -*)
- ;;
- *)
- # If the previous option needed an argument, then skip it.
- if test -n "$prev"; then
- prev=
- else
- dest=$arg
- continue
- fi
- ;;
- esac
-
- # Aesthetically quote the argument.
- arg=`$echo "X$arg" | $Xsed -e "$sed_quote_subst"`
- case $arg in
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- arg="\"$arg\""
- ;;
- esac
- install_prog="$install_prog $arg"
- done
-
- if test -z "$install_prog"; then
- $echo "$modename: you must specify an install program" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- if test -n "$prev"; then
- $echo "$modename: the \`$prev' option requires an argument" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- if test -z "$files"; then
- if test -z "$dest"; then
- $echo "$modename: no file or destination specified" 1>&2
- else
- $echo "$modename: you must specify a destination" 1>&2
- fi
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Strip any trailing slash from the destination.
- dest=`$echo "X$dest" | $Xsed -e 's%/$%%'`
-
- # Check to see that the destination is a directory.
- test -d "$dest" && isdir=yes
- if test "$isdir" = yes; then
- destdir="$dest"
- destname=
- else
- destdir=`$echo "X$dest" | $Xsed -e 's%/[^/]*$%%'`
- test "X$destdir" = "X$dest" && destdir=.
- destname=`$echo "X$dest" | $Xsed -e 's%^.*/%%'`
-
- # Not a directory, so check to see that there is only one file specified.
- set dummy $files
- if test "$#" -gt 2; then
- $echo "$modename: \`$dest' is not a directory" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
- fi
- case $destdir in
- [\\/]* | [A-Za-z]:[\\/]*) ;;
- *)
- for file in $files; do
- case $file in
- *.lo) ;;
- *)
- $echo "$modename: \`$destdir' must be an absolute directory name" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
- done
- ;;
- esac
-
- # This variable tells wrapper scripts just to set variables rather
- # than running their programs.
- libtool_install_magic="$magic"
-
- staticlibs=
- future_libdirs=
- current_libdirs=
- for file in $files; do
-
- # Do each installation.
- case $file in
- *.$libext)
- # Do the static libraries later.
- staticlibs="$staticlibs $file"
- ;;
-
- *.la)
- # Check to see that this really is a libtool archive.
- if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
- else
- $echo "$modename: \`$file' is not a valid libtool archive" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- library_names=
- old_library=
- relink_command=
- # If there is no directory component, then add one.
- case $file in
- */* | *\\*) . $file ;;
- *) . ./$file ;;
- esac
-
- # Add the libdir to current_libdirs if it is the destination.
- if test "X$destdir" = "X$libdir"; then
- case "$current_libdirs " in
- *" $libdir "*) ;;
- *) current_libdirs="$current_libdirs $libdir" ;;
- esac
- else
- # Note the libdir as a future libdir.
- case "$future_libdirs " in
- *" $libdir "*) ;;
- *) future_libdirs="$future_libdirs $libdir" ;;
- esac
- fi
-
- dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`/
- test "X$dir" = "X$file/" && dir=
- dir="$dir$objdir"
-
- if test -n "$relink_command"; then
- # Determine the prefix the user has applied to our future dir.
- inst_prefix_dir=`$echo "$destdir" | $SED "s%$libdir\$%%"`
-
- # Don't allow the user to place us outside of our expected
- # location b/c this prevents finding dependent libraries that
- # are installed to the same prefix.
- # At present, this check doesn't affect windows .dll's that
- # are installed into $libdir/../bin (currently, that works fine)
- # but it's something to keep an eye on.
- if test "$inst_prefix_dir" = "$destdir"; then
- $echo "$modename: error: cannot install \`$file' to a directory not ending in $libdir" 1>&2
- exit $EXIT_FAILURE
- fi
-
- if test -n "$inst_prefix_dir"; then
- # Stick the inst_prefix_dir data into the link command.
- relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"`
- else
- relink_command=`$echo "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
- fi
-
- $echo "$modename: warning: relinking \`$file'" 1>&2
- $show "$relink_command"
- if $run eval "$relink_command"; then :
- else
- $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2
- exit $EXIT_FAILURE
- fi
- fi
-
- # See the names of the shared library.
- set dummy $library_names
- if test -n "$2"; then
- realname="$2"
- shift
- shift
-
- srcname="$realname"
- test -n "$relink_command" && srcname="$realname"T
-
- # Install the shared library and build the symlinks.
- $show "$install_prog $dir/$srcname $destdir/$realname"
- $run eval "$install_prog $dir/$srcname $destdir/$realname" || exit $?
- if test -n "$stripme" && test -n "$striplib"; then
- $show "$striplib $destdir/$realname"
- $run eval "$striplib $destdir/$realname" || exit $?
- fi
-
- if test "$#" -gt 0; then
- # Delete the old symlinks, and create new ones.
- # Try `ln -sf' first, because the `ln' binary might depend on
- # the symlink we replace! Solaris /bin/ln does not understand -f,
- # so we also need to try rm && ln -s.
- for linkname
- do
- if test "$linkname" != "$realname"; then
- $show "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })"
- $run eval "(cd $destdir && { $LN_S -f $realname $linkname || { $rm $linkname && $LN_S $realname $linkname; }; })"
- fi
- done
- fi
-
- # Do each command in the postinstall commands.
- lib="$destdir/$realname"
- cmds=$postinstall_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || {
- lt_exit=$?
-
- # Restore the uninstalled library and exit
- if test "$mode" = relink; then
- $run eval '(cd $output_objdir && $rm ${realname}T && $mv ${realname}U $realname)'
- fi
-
- exit $lt_exit
- }
- done
- IFS="$save_ifs"
- fi
-
- # Install the pseudo-library for information purposes.
- name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
- instname="$dir/$name"i
- $show "$install_prog $instname $destdir/$name"
- $run eval "$install_prog $instname $destdir/$name" || exit $?
-
- # Maybe install the static library, too.
- test -n "$old_library" && staticlibs="$staticlibs $dir/$old_library"
- ;;
-
- *.lo)
- # Install (i.e. copy) a libtool object.
-
- # Figure out destination file name, if it wasn't already specified.
- if test -n "$destname"; then
- destfile="$destdir/$destname"
- else
- destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
- destfile="$destdir/$destfile"
- fi
-
- # Deduce the name of the destination old-style object file.
- case $destfile in
- *.lo)
- staticdest=`$echo "X$destfile" | $Xsed -e "$lo2o"`
- ;;
- *.$objext)
- staticdest="$destfile"
- destfile=
- ;;
- *)
- $echo "$modename: cannot copy a libtool object to \`$destfile'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- # Install the libtool object if requested.
- if test -n "$destfile"; then
- $show "$install_prog $file $destfile"
- $run eval "$install_prog $file $destfile" || exit $?
- fi
-
- # Install the old object if enabled.
- if test "$build_old_libs" = yes; then
- # Deduce the name of the old-style object file.
- staticobj=`$echo "X$file" | $Xsed -e "$lo2o"`
-
- $show "$install_prog $staticobj $staticdest"
- $run eval "$install_prog \$staticobj \$staticdest" || exit $?
- fi
- exit $EXIT_SUCCESS
- ;;
-
- *)
- # Figure out destination file name, if it wasn't already specified.
- if test -n "$destname"; then
- destfile="$destdir/$destname"
- else
- destfile=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
- destfile="$destdir/$destfile"
- fi
-
- # If the file is missing, and there is a .exe on the end, strip it
- # because it is most likely a libtool script we actually want to
- # install
- stripped_ext=""
- case $file in
- *.exe)
- if test ! -f "$file"; then
- file=`$echo $file|${SED} 's,.exe$,,'`
- stripped_ext=".exe"
- fi
- ;;
- esac
-
- # Do a test to see if this is really a libtool program.
- case $host in
- *cygwin*|*mingw*)
- wrapper=`$echo $file | ${SED} -e 's,.exe$,,'`
- ;;
- *)
- wrapper=$file
- ;;
- esac
- if (${SED} -e '4q' $wrapper | grep "^# Generated by .*$PACKAGE")>/dev/null 2>&1; then
- notinst_deplibs=
- relink_command=
-
- # Note that it is not necessary on cygwin/mingw to append a dot to
- # foo even if both foo and FILE.exe exist: automatic-append-.exe
- # behavior happens only for exec(3), not for open(2)! Also, sourcing
- # `FILE.' does not work on cygwin managed mounts.
- #
- # If there is no directory component, then add one.
- case $wrapper in
- */* | *\\*) . ${wrapper} ;;
- *) . ./${wrapper} ;;
- esac
-
- # Check the variables that should have been set.
- if test -z "$notinst_deplibs"; then
- $echo "$modename: invalid libtool wrapper script \`$wrapper'" 1>&2
- exit $EXIT_FAILURE
- fi
-
- finalize=yes
- for lib in $notinst_deplibs; do
- # Check to see that each library is installed.
- libdir=
- if test -f "$lib"; then
- # If there is no directory component, then add one.
- case $lib in
- */* | *\\*) . $lib ;;
- *) . ./$lib ;;
- esac
- fi
- libfile="$libdir/"`$echo "X$lib" | $Xsed -e 's%^.*/%%g'` ### testsuite: skip nested quoting test
- if test -n "$libdir" && test ! -f "$libfile"; then
- $echo "$modename: warning: \`$lib' has not been installed in \`$libdir'" 1>&2
- finalize=no
- fi
- done
-
- relink_command=
- # Note that it is not necessary on cygwin/mingw to append a dot to
- # foo even if both foo and FILE.exe exist: automatic-append-.exe
- # behavior happens only for exec(3), not for open(2)! Also, sourcing
- # `FILE.' does not work on cygwin managed mounts.
- #
- # If there is no directory component, then add one.
- case $wrapper in
- */* | *\\*) . ${wrapper} ;;
- *) . ./${wrapper} ;;
- esac
-
- outputname=
- if test "$fast_install" = no && test -n "$relink_command"; then
- if test "$finalize" = yes && test -z "$run"; then
- tmpdir="/tmp"
- test -n "$TMPDIR" && tmpdir="$TMPDIR"
- tmpdir="$tmpdir/libtool-$$"
- save_umask=`umask`
- umask 0077
- if $mkdir "$tmpdir"; then
- umask $save_umask
- else
- umask $save_umask
- $echo "$modename: error: cannot create temporary directory \`$tmpdir'" 1>&2
- continue
- fi
- file=`$echo "X$file$stripped_ext" | $Xsed -e 's%^.*/%%'`
- outputname="$tmpdir/$file"
- # Replace the output file specification.
- relink_command=`$echo "X$relink_command" | $Xsed -e 's%@OUTPUT@%'"$outputname"'%g'`
-
- $show "$relink_command"
- if $run eval "$relink_command"; then :
- else
- $echo "$modename: error: relink \`$file' with the above command before installing it" 1>&2
- ${rm}r "$tmpdir"
- continue
- fi
- file="$outputname"
- else
- $echo "$modename: warning: cannot relink \`$file'" 1>&2
- fi
- else
- # Install the binary that we compiled earlier.
- file=`$echo "X$file$stripped_ext" | $Xsed -e "s%\([^/]*\)$%$objdir/\1%"`
- fi
- fi
-
- # remove .exe since cygwin /usr/bin/install will append another
- # one anyway
- case $install_prog,$host in
- */usr/bin/install*,*cygwin*)
- case $file:$destfile in
- *.exe:*.exe)
- # this is ok
- ;;
- *.exe:*)
- destfile=$destfile.exe
- ;;
- *:*.exe)
- destfile=`$echo $destfile | ${SED} -e 's,.exe$,,'`
- ;;
- esac
- ;;
- esac
- $show "$install_prog$stripme $file $destfile"
- $run eval "$install_prog\$stripme \$file \$destfile" || exit $?
- test -n "$outputname" && ${rm}r "$tmpdir"
- ;;
- esac
- done
-
- for file in $staticlibs; do
- name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
-
- # Set up the ranlib parameters.
- oldlib="$destdir/$name"
-
- $show "$install_prog $file $oldlib"
- $run eval "$install_prog \$file \$oldlib" || exit $?
-
- if test -n "$stripme" && test -n "$old_striplib"; then
- $show "$old_striplib $oldlib"
- $run eval "$old_striplib $oldlib" || exit $?
- fi
-
- # Do each command in the postinstall commands.
- cmds=$old_postinstall_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || exit $?
- done
- IFS="$save_ifs"
- done
-
- if test -n "$future_libdirs"; then
- $echo "$modename: warning: remember to run \`$progname --finish$future_libdirs'" 1>&2
- fi
-
- if test -n "$current_libdirs"; then
- # Maybe just do a dry run.
- test -n "$run" && current_libdirs=" -n$current_libdirs"
- exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
- else
- exit $EXIT_SUCCESS
- fi
- ;;
-
- # libtool finish mode
- finish)
- modename="$modename: finish"
- libdirs="$nonopt"
- admincmds=
-
- if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
- for dir
- do
- libdirs="$libdirs $dir"
- done
-
- for libdir in $libdirs; do
- if test -n "$finish_cmds"; then
- # Do each command in the finish commands.
- cmds=$finish_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd" || admincmds="$admincmds
- $cmd"
- done
- IFS="$save_ifs"
- fi
- if test -n "$finish_eval"; then
- # Do the single finish_eval.
- eval cmds=\"$finish_eval\"
- $run eval "$cmds" || admincmds="$admincmds
- $cmds"
- fi
- done
- fi
-
- # Exit here if they wanted silent mode.
- test "$show" = : && exit $EXIT_SUCCESS
-
- $echo "----------------------------------------------------------------------"
- $echo "Libraries have been installed in:"
- for libdir in $libdirs; do
- $echo " $libdir"
- done
- $echo
- $echo "If you ever happen to want to link against installed libraries"
- $echo "in a given directory, LIBDIR, you must either use libtool, and"
- $echo "specify the full pathname of the library, or use the \`-LLIBDIR'"
- $echo "flag during linking and do at least one of the following:"
- if test -n "$shlibpath_var"; then
- $echo " - add LIBDIR to the \`$shlibpath_var' environment variable"
- $echo " during execution"
- fi
- if test -n "$runpath_var"; then
- $echo " - add LIBDIR to the \`$runpath_var' environment variable"
- $echo " during linking"
- fi
- if test -n "$hardcode_libdir_flag_spec"; then
- libdir=LIBDIR
- eval flag=\"$hardcode_libdir_flag_spec\"
-
- $echo " - use the \`$flag' linker flag"
- fi
- if test -n "$admincmds"; then
- $echo " - have your system administrator run these commands:$admincmds"
- fi
- if test -f /etc/ld.so.conf; then
- $echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
- fi
- $echo
- $echo "See any operating system documentation about shared libraries for"
- $echo "more information, such as the ld(1) and ld.so(8) manual pages."
- $echo "----------------------------------------------------------------------"
- exit $EXIT_SUCCESS
- ;;
-
- # libtool execute mode
- execute)
- modename="$modename: execute"
-
- # The first argument is the command name.
- cmd="$nonopt"
- if test -z "$cmd"; then
- $echo "$modename: you must specify a COMMAND" 1>&2
- $echo "$help"
- exit $EXIT_FAILURE
- fi
-
- # Handle -dlopen flags immediately.
- for file in $execute_dlfiles; do
- if test ! -f "$file"; then
- $echo "$modename: \`$file' is not a file" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- dir=
- case $file in
- *.la)
- # Check to see that this really is a libtool archive.
- if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then :
- else
- $echo "$modename: \`$lib' is not a valid libtool archive" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- # Read the libtool library.
- dlname=
- library_names=
-
- # If there is no directory component, then add one.
- case $file in
- */* | *\\*) . $file ;;
- *) . ./$file ;;
- esac
-
- # Skip this library if it cannot be dlopened.
- if test -z "$dlname"; then
- # Warn if it was a shared library.
- test -n "$library_names" && $echo "$modename: warning: \`$file' was not linked with \`-export-dynamic'"
- continue
- fi
-
- dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
- test "X$dir" = "X$file" && dir=.
-
- if test -f "$dir/$objdir/$dlname"; then
- dir="$dir/$objdir"
- else
- $echo "$modename: cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'" 1>&2
- exit $EXIT_FAILURE
- fi
- ;;
-
- *.lo)
- # Just add the directory containing the .lo file.
- dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
- test "X$dir" = "X$file" && dir=.
- ;;
-
- *)
- $echo "$modename: warning \`-dlopen' is ignored for non-libtool libraries and objects" 1>&2
- continue
- ;;
- esac
-
- # Get the absolute pathname.
- absdir=`cd "$dir" && pwd`
- test -n "$absdir" && dir="$absdir"
-
- # Now add the directory to shlibpath_var.
- if eval "test -z \"\$$shlibpath_var\""; then
- eval "$shlibpath_var=\"\$dir\""
- else
- eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\""
- fi
- done
-
- # This variable tells wrapper scripts just to set shlibpath_var
- # rather than running their programs.
- libtool_execute_magic="$magic"
-
- # Check if any of the arguments is a wrapper script.
- args=
- for file
- do
- case $file in
- -*) ;;
- *)
- # Do a test to see if this is really a libtool program.
- if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- # If there is no directory component, then add one.
- case $file in
- */* | *\\*) . $file ;;
- *) . ./$file ;;
- esac
-
- # Transform arg to wrapped name.
- file="$progdir/$program"
- fi
- ;;
- esac
- # Quote arguments (to preserve shell metacharacters).
- file=`$echo "X$file" | $Xsed -e "$sed_quote_subst"`
- args="$args \"$file\""
- done
-
- if test -z "$run"; then
- if test -n "$shlibpath_var"; then
- # Export the shlibpath_var.
- eval "export $shlibpath_var"
- fi
-
- # Restore saved environment variables
- if test "${save_LC_ALL+set}" = set; then
- LC_ALL="$save_LC_ALL"; export LC_ALL
- fi
- if test "${save_LANG+set}" = set; then
- LANG="$save_LANG"; export LANG
- fi
-
- # Now prepare to actually exec the command.
- exec_cmd="\$cmd$args"
- else
- # Display what would be done.
- if test -n "$shlibpath_var"; then
- eval "\$echo \"\$shlibpath_var=\$$shlibpath_var\""
- $echo "export $shlibpath_var"
- fi
- $echo "$cmd$args"
- exit $EXIT_SUCCESS
- fi
- ;;
-
- # libtool clean and uninstall mode
- clean | uninstall)
- modename="$modename: $mode"
- rm="$nonopt"
- files=
- rmforce=
- exit_status=0
-
- # This variable tells wrapper scripts just to set variables rather
- # than running their programs.
- libtool_install_magic="$magic"
-
- for arg
- do
- case $arg in
- -f) rm="$rm $arg"; rmforce=yes ;;
- -*) rm="$rm $arg" ;;
- *) files="$files $arg" ;;
- esac
- done
-
- if test -z "$rm"; then
- $echo "$modename: you must specify an RM program" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- fi
-
- rmdirs=
-
- origobjdir="$objdir"
- for file in $files; do
- dir=`$echo "X$file" | $Xsed -e 's%/[^/]*$%%'`
- if test "X$dir" = "X$file"; then
- dir=.
- objdir="$origobjdir"
- else
- objdir="$dir/$origobjdir"
- fi
- name=`$echo "X$file" | $Xsed -e 's%^.*/%%'`
- test "$mode" = uninstall && objdir="$dir"
-
- # Remember objdir for removal later, being careful to avoid duplicates
- if test "$mode" = clean; then
- case " $rmdirs " in
- *" $objdir "*) ;;
- *) rmdirs="$rmdirs $objdir" ;;
- esac
- fi
-
- # Don't error if the file doesn't exist and rm -f was used.
- if (test -L "$file") >/dev/null 2>&1 \
- || (test -h "$file") >/dev/null 2>&1 \
- || test -f "$file"; then
- :
- elif test -d "$file"; then
- exit_status=1
- continue
- elif test "$rmforce" = yes; then
- continue
- fi
-
- rmfiles="$file"
-
- case $name in
- *.la)
- # Possibly a libtool archive, so verify it.
- if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- . $dir/$name
-
- # Delete the libtool libraries and symlinks.
- for n in $library_names; do
- rmfiles="$rmfiles $objdir/$n"
- done
- test -n "$old_library" && rmfiles="$rmfiles $objdir/$old_library"
- test "$mode" = clean && rmfiles="$rmfiles $objdir/$name $objdir/${name}i"
-
- if test "$mode" = uninstall; then
- if test -n "$library_names"; then
- # Do each command in the postuninstall commands.
- cmds=$postuninstall_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd"
- if test "$?" -ne 0 && test "$rmforce" != yes; then
- exit_status=1
- fi
- done
- IFS="$save_ifs"
- fi
-
- if test -n "$old_library"; then
- # Do each command in the old_postuninstall commands.
- cmds=$old_postuninstall_cmds
- save_ifs="$IFS"; IFS='~'
- for cmd in $cmds; do
- IFS="$save_ifs"
- eval cmd=\"$cmd\"
- $show "$cmd"
- $run eval "$cmd"
- if test "$?" -ne 0 && test "$rmforce" != yes; then
- exit_status=1
- fi
- done
- IFS="$save_ifs"
- fi
- # FIXME: should reinstall the best remaining shared library.
- fi
- fi
- ;;
-
- *.lo)
- # Possibly a libtool object, so verify it.
- if (${SED} -e '2q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
-
- # Read the .lo file
- . $dir/$name
-
- # Add PIC object to the list of files to remove.
- if test -n "$pic_object" \
- && test "$pic_object" != none; then
- rmfiles="$rmfiles $dir/$pic_object"
- fi
-
- # Add non-PIC object to the list of files to remove.
- if test -n "$non_pic_object" \
- && test "$non_pic_object" != none; then
- rmfiles="$rmfiles $dir/$non_pic_object"
- fi
- fi
- ;;
-
- *)
- if test "$mode" = clean ; then
- noexename=$name
- case $file in
- *.exe)
- file=`$echo $file|${SED} 's,.exe$,,'`
- noexename=`$echo $name|${SED} 's,.exe$,,'`
- # $file with .exe has already been added to rmfiles,
- # add $file without .exe
- rmfiles="$rmfiles $file"
- ;;
- esac
- # Do a test to see if this is a libtool program.
- if (${SED} -e '4q' $file | grep "^# Generated by .*$PACKAGE") >/dev/null 2>&1; then
- relink_command=
- . $dir/$noexename
-
- # note $name still contains .exe if it was in $file originally
- # as does the version of $file that was added into $rmfiles
- rmfiles="$rmfiles $objdir/$name $objdir/${name}S.${objext}"
- if test "$fast_install" = yes && test -n "$relink_command"; then
- rmfiles="$rmfiles $objdir/lt-$name"
- fi
- if test "X$noexename" != "X$name" ; then
- rmfiles="$rmfiles $objdir/lt-${noexename}.c"
- fi
- fi
- fi
- ;;
- esac
- $show "$rm $rmfiles"
- $run $rm $rmfiles || exit_status=1
- done
- objdir="$origobjdir"
-
- # Try to remove the ${objdir}s in the directories where we deleted files
- for dir in $rmdirs; do
- if test -d "$dir"; then
- $show "rmdir $dir"
- $run rmdir $dir >/dev/null 2>&1
- fi
- done
-
- exit $exit_status
- ;;
-
- "")
- $echo "$modename: you must specify a MODE" 1>&2
- $echo "$generic_help" 1>&2
- exit $EXIT_FAILURE
- ;;
- esac
-
- if test -z "$exec_cmd"; then
- $echo "$modename: invalid operation mode \`$mode'" 1>&2
- $echo "$generic_help" 1>&2
- exit $EXIT_FAILURE
- fi
-fi # test -z "$show_help"
-
-if test -n "$exec_cmd"; then
- eval exec $exec_cmd
- exit $EXIT_FAILURE
-fi
-
-# We need to display help for each of the modes.
-case $mode in
-"") $echo \
-"Usage: $modename [OPTION]... [MODE-ARG]...
-
-Provide generalized library-building support services.
-
- --config show all configuration variables
- --debug enable verbose shell tracing
--n, --dry-run display commands without modifying any files
- --features display basic configuration information and exit
- --finish same as \`--mode=finish'
- --help display this help message and exit
- --mode=MODE use operation mode MODE [default=inferred from MODE-ARGS]
- --quiet same as \`--silent'
- --silent don't print informational messages
- --tag=TAG use configuration variables from tag TAG
- --version print version information
-
-MODE must be one of the following:
-
- clean remove files from the build directory
- compile compile a source file into a libtool object
- execute automatically set library path, then run a program
- finish complete the installation of libtool libraries
- install install libraries or executables
- link create a library or an executable
- uninstall remove libraries from an installed directory
-
-MODE-ARGS vary depending on the MODE. Try \`$modename --help --mode=MODE' for
-a more detailed description of MODE.
-
-Report bugs to <bug-libtool@gnu.org>."
- exit $EXIT_SUCCESS
- ;;
-
-clean)
- $echo \
-"Usage: $modename [OPTION]... --mode=clean RM [RM-OPTION]... FILE...
-
-Remove files from the build directory.
-
-RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed
-to RM.
-
-If FILE is a libtool library, object or program, all the files associated
-with it are deleted. Otherwise, only FILE itself is deleted using RM."
- ;;
-
-compile)
- $echo \
-"Usage: $modename [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE
-
-Compile a source file into a libtool library object.
-
-This mode accepts the following additional options:
-
- -o OUTPUT-FILE set the output file name to OUTPUT-FILE
- -prefer-pic try to building PIC objects only
- -prefer-non-pic try to building non-PIC objects only
- -static always build a \`.o' file suitable for static linking
-
-COMPILE-COMMAND is a command to be used in creating a \`standard' object file
-from the given SOURCEFILE.
-
-The output file name is determined by removing the directory component from
-SOURCEFILE, then substituting the C source code suffix \`.c' with the
-library object suffix, \`.lo'."
- ;;
-
-execute)
- $echo \
-"Usage: $modename [OPTION]... --mode=execute COMMAND [ARGS]...
-
-Automatically set library path, then run a program.
-
-This mode accepts the following additional options:
-
- -dlopen FILE add the directory containing FILE to the library path
-
-This mode sets the library path environment variable according to \`-dlopen'
-flags.
-
-If any of the ARGS are libtool executable wrappers, then they are translated
-into their corresponding uninstalled binary, and any of their required library
-directories are added to the library path.
-
-Then, COMMAND is executed, with ARGS as arguments."
- ;;
-
-finish)
- $echo \
-"Usage: $modename [OPTION]... --mode=finish [LIBDIR]...
-
-Complete the installation of libtool libraries.
-
-Each LIBDIR is a directory that contains libtool libraries.
-
-The commands that this mode executes may require superuser privileges. Use
-the \`--dry-run' option if you just want to see what would be executed."
- ;;
-
-install)
- $echo \
-"Usage: $modename [OPTION]... --mode=install INSTALL-COMMAND...
-
-Install executables or libraries.
-
-INSTALL-COMMAND is the installation command. The first component should be
-either the \`install' or \`cp' program.
-
-The rest of the components are interpreted as arguments to that command (only
-BSD-compatible install options are recognized)."
- ;;
-
-link)
- $echo \
-"Usage: $modename [OPTION]... --mode=link LINK-COMMAND...
-
-Link object files or libraries together to form another library, or to
-create an executable program.
-
-LINK-COMMAND is a command using the C compiler that you would use to create
-a program from several object files.
-
-The following components of LINK-COMMAND are treated specially:
-
- -all-static do not do any dynamic linking at all
- -avoid-version do not add a version suffix if possible
- -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime
- -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols
- -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
- -export-symbols SYMFILE
- try to export only the symbols listed in SYMFILE
- -export-symbols-regex REGEX
- try to export only the symbols matching REGEX
- -LLIBDIR search LIBDIR for required installed libraries
- -lNAME OUTPUT-FILE requires the installed library libNAME
- -module build a library that can dlopened
- -no-fast-install disable the fast-install mode
- -no-install link a not-installable executable
- -no-undefined declare that a library does not refer to external symbols
- -o OUTPUT-FILE create OUTPUT-FILE from the specified objects
- -objectlist FILE Use a list of object files found in FILE to specify objects
- -precious-files-regex REGEX
- don't remove output files matching REGEX
- -release RELEASE specify package release information
- -rpath LIBDIR the created library will eventually be installed in LIBDIR
- -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries
- -static do not do any dynamic linking of libtool libraries
- -version-info CURRENT[:REVISION[:AGE]]
- specify library version info [each variable defaults to 0]
-
-All other options (arguments beginning with \`-') are ignored.
-
-Every other argument is treated as a filename. Files ending in \`.la' are
-treated as uninstalled libtool libraries, other files are standard or library
-object files.
-
-If the OUTPUT-FILE ends in \`.la', then a libtool library is created,
-only library objects (\`.lo' files) may be specified, and \`-rpath' is
-required, except when creating a convenience library.
-
-If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created
-using \`ar' and \`ranlib', or on Windows using \`lib'.
-
-If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file
-is created, otherwise an executable program is created."
- ;;
-
-uninstall)
- $echo \
-"Usage: $modename [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE...
-
-Remove libraries from an installation directory.
-
-RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed
-to RM.
-
-If FILE is a libtool library, all the files associated with it are deleted.
-Otherwise, only FILE itself is deleted using RM."
- ;;
-
-*)
- $echo "$modename: invalid operation mode \`$mode'" 1>&2
- $echo "$help" 1>&2
- exit $EXIT_FAILURE
- ;;
-esac
-
-$echo
-$echo "Try \`$modename --help' for more information about other modes."
-
-exit $?
-
-# The TAGs below are defined such that we never get into a situation
-# in which we disable both kinds of libraries. Given conflicting
-# choices, we go for a static library, that is the most portable,
-# since we can't tell whether shared libraries were disabled because
-# the user asked for that or because the platform doesn't support
-# them. This is particularly important on AIX, because we don't
-# support having both static and shared libraries enabled at the same
-# time on that platform, so we default to a shared-only configuration.
-# If a disable-shared tag is given, we'll fallback to a static-only
-# configuration. But we'll never go from static-only to shared-only.
-
-# ### BEGIN LIBTOOL TAG CONFIG: disable-shared
-build_libtool_libs=no
-build_old_libs=yes
-# ### END LIBTOOL TAG CONFIG: disable-shared
-
-# ### BEGIN LIBTOOL TAG CONFIG: disable-static
-build_old_libs=`case $build_libtool_libs in yes) $echo no;; *) $echo yes;; esac`
-# ### END LIBTOOL TAG CONFIG: disable-static
-
-# Local Variables:
-# mode:shell-script
-# sh-indentation:2
-# End:
diff --git a/missing b/missing
deleted file mode 100755
index fc54c64..0000000
--- a/missing
+++ /dev/null
@@ -1,336 +0,0 @@
-#! /bin/sh
-# Common stub for a few missing GNU programs while installing.
-# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003 Free Software Foundation, Inc.
-# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
-
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2, or (at your option)
-# any later version.
-
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-
-# You should have received a copy of the GNU General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-# 02111-1307, USA.
-
-# As a special exception to the GNU General Public License, if you
-# distribute this file as part of a program that contains a
-# configuration script generated by Autoconf, you may include it under
-# the same distribution terms that you use for the rest of that program.
-
-if test $# -eq 0; then
- echo 1>&2 "Try \`$0 --help' for more information"
- exit 1
-fi
-
-run=:
-
-# In the cases where this matters, `missing' is being run in the
-# srcdir already.
-if test -f configure.ac; then
- configure_ac=configure.ac
-else
- configure_ac=configure.in
-fi
-
-case "$1" in
---run)
- # Try to run requested program, and just exit if it succeeds.
- run=
- shift
- "$@" && exit 0
- ;;
-esac
-
-# If it does not exist, or fails to run (possibly an outdated version),
-# try to emulate it.
-case "$1" in
-
- -h|--h|--he|--hel|--help)
- echo "\
-$0 [OPTION]... PROGRAM [ARGUMENT]...
-
-Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
-error status if there is no known handling for PROGRAM.
-
-Options:
- -h, --help display this help and exit
- -v, --version output version information and exit
- --run try to run the given command, and emulate it if it fails
-
-Supported PROGRAM values:
- aclocal touch file \`aclocal.m4'
- autoconf touch file \`configure'
- autoheader touch file \`config.h.in'
- automake touch all \`Makefile.in' files
- bison create \`y.tab.[ch]', if possible, from existing .[ch]
- flex create \`lex.yy.c', if possible, from existing .c
- help2man touch the output file
- lex create \`lex.yy.c', if possible, from existing .c
- makeinfo touch the output file
- tar try tar, gnutar, gtar, then tar without non-portable flags
- yacc create \`y.tab.[ch]', if possible, from existing .[ch]"
- ;;
-
- -v|--v|--ve|--ver|--vers|--versi|--versio|--version)
- echo "missing 0.4 - GNU automake"
- ;;
-
- -*)
- echo 1>&2 "$0: Unknown \`$1' option"
- echo 1>&2 "Try \`$0 --help' for more information"
- exit 1
- ;;
-
- aclocal*)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified \`acinclude.m4' or \`${configure_ac}'. You might want
- to install the \`Automake' and \`Perl' packages. Grab them from
- any GNU archive site."
- touch aclocal.m4
- ;;
-
- autoconf)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified \`${configure_ac}'. You might want to install the
- \`Autoconf' and \`GNU m4' packages. Grab them from any GNU
- archive site."
- touch configure
- ;;
-
- autoheader)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified \`acconfig.h' or \`${configure_ac}'. You might want
- to install the \`Autoconf' and \`GNU m4' packages. Grab them
- from any GNU archive site."
- files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
- test -z "$files" && files="config.h"
- touch_files=
- for f in $files; do
- case "$f" in
- *:*) touch_files="$touch_files "`echo "$f" |
- sed -e 's/^[^:]*://' -e 's/:.*//'`;;
- *) touch_files="$touch_files $f.in";;
- esac
- done
- touch $touch_files
- ;;
-
- automake*)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
- You might want to install the \`Automake' and \`Perl' packages.
- Grab them from any GNU archive site."
- find . -type f -name Makefile.am -print |
- sed 's/\.am$/.in/' |
- while read f; do touch "$f"; done
- ;;
-
- autom4te)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is needed, and you do not seem to have it handy on your
- system. You might have modified some files without having the
- proper tools for further handling them.
- You can get \`$1' as part of \`Autoconf' from any GNU
- archive site."
-
- file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'`
- test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'`
- if test -f "$file"; then
- touch $file
- else
- test -z "$file" || exec >$file
- echo "#! /bin/sh"
- echo "# Created by GNU Automake missing as a replacement of"
- echo "# $ $@"
- echo "exit 0"
- chmod +x $file
- exit 1
- fi
- ;;
-
- bison|yacc)
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified a \`.y' file. You may need the \`Bison' package
- in order for those modifications to take effect. You can get
- \`Bison' from any GNU archive site."
- rm -f y.tab.c y.tab.h
- if [ $# -ne 1 ]; then
- eval LASTARG="\${$#}"
- case "$LASTARG" in
- *.y)
- SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
- if [ -f "$SRCFILE" ]; then
- cp "$SRCFILE" y.tab.c
- fi
- SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
- if [ -f "$SRCFILE" ]; then
- cp "$SRCFILE" y.tab.h
- fi
- ;;
- esac
- fi
- if [ ! -f y.tab.h ]; then
- echo >y.tab.h
- fi
- if [ ! -f y.tab.c ]; then
- echo 'main() { return 0; }' >y.tab.c
- fi
- ;;
-
- lex|flex)
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified a \`.l' file. You may need the \`Flex' package
- in order for those modifications to take effect. You can get
- \`Flex' from any GNU archive site."
- rm -f lex.yy.c
- if [ $# -ne 1 ]; then
- eval LASTARG="\${$#}"
- case "$LASTARG" in
- *.l)
- SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
- if [ -f "$SRCFILE" ]; then
- cp "$SRCFILE" lex.yy.c
- fi
- ;;
- esac
- fi
- if [ ! -f lex.yy.c ]; then
- echo 'main() { return 0; }' >lex.yy.c
- fi
- ;;
-
- help2man)
- if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- # We have it, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified a dependency of a manual page. You may need the
- \`Help2man' package in order for those modifications to take
- effect. You can get \`Help2man' from any GNU archive site."
-
- file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
- if test -z "$file"; then
- file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'`
- fi
- if [ -f "$file" ]; then
- touch $file
- else
- test -z "$file" || exec >$file
- echo ".ab help2man is required to generate this page"
- exit 1
- fi
- ;;
-
- makeinfo)
- if test -z "$run" && (makeinfo --version) > /dev/null 2>&1; then
- # We have makeinfo, but it failed.
- exit 1
- fi
-
- echo 1>&2 "\
-WARNING: \`$1' is missing on your system. You should only need it if
- you modified a \`.texi' or \`.texinfo' file, or any other file
- indirectly affecting the aspect of the manual. The spurious
- call might also be the consequence of using a buggy \`make' (AIX,
- DU, IRIX). You might want to install the \`Texinfo' package or
- the \`GNU make' package. Grab either from any GNU archive site."
- file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
- if test -z "$file"; then
- file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
- file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file`
- fi
- touch $file
- ;;
-
- tar)
- shift
- if test -n "$run"; then
- echo 1>&2 "ERROR: \`tar' requires --run"
- exit 1
- fi
-
- # We have already tried tar in the generic part.
- # Look for gnutar/gtar before invocation to avoid ugly error
- # messages.
- if (gnutar --version > /dev/null 2>&1); then
- gnutar "$@" && exit 0
- fi
- if (gtar --version > /dev/null 2>&1); then
- gtar "$@" && exit 0
- fi
- firstarg="$1"
- if shift; then
- case "$firstarg" in
- *o*)
- firstarg=`echo "$firstarg" | sed s/o//`
- tar "$firstarg" "$@" && exit 0
- ;;
- esac
- case "$firstarg" in
- *h*)
- firstarg=`echo "$firstarg" | sed s/h//`
- tar "$firstarg" "$@" && exit 0
- ;;
- esac
- fi
-
- echo 1>&2 "\
-WARNING: I can't seem to be able to run \`tar' with the given arguments.
- You may want to install GNU tar or Free paxutils, or check the
- command line arguments."
- exit 1
- ;;
-
- *)
- echo 1>&2 "\
-WARNING: \`$1' is needed, and you do not seem to have it handy on your
- system. You might have modified some files without having the
- proper tools for further handling them. Check the \`README' file,
- it often tells you about the needed prerequisites for installing
- this package. You may also peek at any GNU archive site, in case
- some other package would contain this missing \`$1' program."
- exit 1
- ;;
-esac
-
-exit 0
diff --git a/mkinstalldirs b/mkinstalldirs
deleted file mode 100755
index d2d5f21..0000000
--- a/mkinstalldirs
+++ /dev/null
@@ -1,111 +0,0 @@
-#! /bin/sh
-# mkinstalldirs --- make directory hierarchy
-# Author: Noah Friedman <friedman@prep.ai.mit.edu>
-# Created: 1993-05-16
-# Public domain
-
-errstatus=0
-dirmode=""
-
-usage="\
-Usage: mkinstalldirs [-h] [--help] [-m mode] dir ..."
-
-# process command line arguments
-while test $# -gt 0 ; do
- case $1 in
- -h | --help | --h*) # -h for help
- echo "$usage" 1>&2
- exit 0
- ;;
- -m) # -m PERM arg
- shift
- test $# -eq 0 && { echo "$usage" 1>&2; exit 1; }
- dirmode=$1
- shift
- ;;
- --) # stop option processing
- shift
- break
- ;;
- -*) # unknown option
- echo "$usage" 1>&2
- exit 1
- ;;
- *) # first non-opt arg
- break
- ;;
- esac
-done
-
-for file
-do
- if test -d "$file"; then
- shift
- else
- break
- fi
-done
-
-case $# in
- 0) exit 0 ;;
-esac
-
-case $dirmode in
- '')
- if mkdir -p -- . 2>/dev/null; then
- echo "mkdir -p -- $*"
- exec mkdir -p -- "$@"
- fi
- ;;
- *)
- if mkdir -m "$dirmode" -p -- . 2>/dev/null; then
- echo "mkdir -m $dirmode -p -- $*"
- exec mkdir -m "$dirmode" -p -- "$@"
- fi
- ;;
-esac
-
-for file
-do
- set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'`
- shift
-
- pathcomp=
- for d
- do
- pathcomp="$pathcomp$d"
- case $pathcomp in
- -*) pathcomp=./$pathcomp ;;
- esac
-
- if test ! -d "$pathcomp"; then
- echo "mkdir $pathcomp"
-
- mkdir "$pathcomp" || lasterr=$?
-
- if test ! -d "$pathcomp"; then
- errstatus=$lasterr
- else
- if test ! -z "$dirmode"; then
- echo "chmod $dirmode $pathcomp"
- lasterr=""
- chmod "$dirmode" "$pathcomp" || lasterr=$?
-
- if test ! -z "$lasterr"; then
- errstatus=$lasterr
- fi
- fi
- fi
- fi
-
- pathcomp="$pathcomp/"
- done
-done
-
-exit $errstatus
-
-# Local Variables:
-# mode: shell-script
-# sh-indentation: 2
-# End:
-# mkinstalldirs ends here