From: ticktock35 Date: Mon, 15 Dec 2008 04:52:22 +0000 (+0000) Subject: opkg: X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=d879963c09e74fed1d1ad2168d2d1fa1aa01f442;p=oweals%2Fopkg-lede.git 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 --- 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 for 100+ filenames in tar file ( again )! - * applied patch from 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 , 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 - * 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 - -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 - * 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 - * Two more fixed memory leaks. Contributed by Nils Faerber. - -2004-08-17 Florian - * 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 - * 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 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 - * 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 - * 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 - 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 - * 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 - * 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 - * configure.ac: update to 0.99.113 - * libopkg.c: patch from drw to fix opkg list -2004-02-19 florian - * Some minor changes to make code compile on more compilers. -2004-02-14 jamey - * configure.ac: updated to 0.99.112 - * libbb/unarchive.c: copied in oldgnu tar compatibility mode from latest busybox. -2004-02-13 jamey - * configure.ac: updated to 0.99.111 - * pkg.c: wim delvaux's patch for status file in other destinations -2004-01-23 florian - * Applied Dan's patch that adds a package download command to - libopkg. -2004-01-20 florian - * 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 - * Added void* parameter to some callbacks. - -2003-12-02 florian - * Added familiar/opkg-cl.control.in, which is a prototype of - control file for opkg-cl package creation. -2003-12-01 florian - * 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 - * 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 - * 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 - * configure.ac: updated to 0.99.82 - * pkg_hash.c: ignore Replaces directive when a package replaces itself -2003-04-10 Jamey Hicks - * configure.ac: updated to 0.99.81 - * pkg.c: clear state_want and state_flags for any uninstallable package -2003-04-10 Jamey Hicks - * 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 - * 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 - * 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 - * configure.ac: updated to 0.99.77 - * opkg_cmd.c: implemented whatdepends - * opkg_conf.c: fixed typo -2003-04-03 Jamey Hicks - * 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 - * 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 - * 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 - * configure.ac: updated to 0.99.73 - * pkg_hash.c: remove latest_installed heuristic because it prevents upgrades. -2003-04-03 Jamey Hicks - * 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 - * 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 - * 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 - * 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 - * 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 - * 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 - * 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 - * configure.ac: updated to 0.99.65 - * opkg_cmd.c, opkg_conf.c: applied opkg dest installation patch from Ben Lau - * 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 - * 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 - * configure.ac: updated to 0.99.61 - * familiar/postinst: mkdir -p /etc/opkg -2003-03-24 Jamey Hicks - * 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 - * 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 - * 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 - * 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 - * 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 - * 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 - * configure.ac: updated to 0.99.53 - * pkg_depends.c: let SW_INSTALL satisfy dependences (instead of SS_INSTALL) -2003-03-01 Daniele Nicolodi - * 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 (patch from Daniele Nicolodi ) - * 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 - * 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 - * configure.ac: incremented version to 0.99.50 - * opkg_cmd.c: write out status after doing an upgrade -2003-02-27 Jamey Hicks (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 (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 (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 (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 (per patch from Philip Blundell ) - * 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 - * configure.ac: incremented version number to 0.99.44 - * args.c: added doc for -force-overwrite -2002-11-26 Jamey Hicks - * 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 - * 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 - * 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 - * 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 - * configure.ac: incremented version number to 0.99.39 - * applied patches from Aman Gupta for better handling of dests -2002-11-?? Jamey Hicks - * configure.ac: incremented version number to 0.99.38 -2002-11-07 Jamey Hicks - * 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 - * 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 - * configure.ac: incremented version number to 0.99.36 - * changed verbose_get to verbose_wget as documented -2002-08-08 Jamey Hicks - * 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 - * 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 - * configure.ac: incremented version number to 0.99.32 - * pkg.c: removed chroot breakage -2002-08-07 Jamey Hicks - * 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 - * 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 - * configure.ac: incremented version number to 0.99.29 - * pkg.c: fixed a segv when printing Replaces field -2002-07-24 Jamey Hicks - * 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 - * configure.ac: incremented version number to 0.99.27 -2002-07-23 Jamey Hicks - * 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 - * configure.ac: incremented version number to 0.99.25 - * many cleanups trying to regain stability -2002-07-22 Jamey Hicks - * configure.ac: incremented version number to 0.99.24 - * various files: trying to stomp a segv in conflicts checking. -2002-07-17 Jamey Hicks - * 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 - * 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 - * configure.ac: incremented version number to 0.99.21 after - applying dependent removal and conflicts patch. - -2002-07-14 Jamey Hicks - - * 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 - - * 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 - - * pkg_depends.c (pkg_hash_fetch_conflicts): use new abstract_pkg_vec - structure in checking provided_by - -2002-07-07 Jamey Hicks - - * configure.ac: incremented version number to 0.99.18 - * fixed a segv due to type error in provides support - -2002-07-07 Jamey Hicks - - * 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 - - * pkg_depends.c (pkg_hash_fetch_conflicts): check for conflicts - found before returning - -2002-07-04 Abhaya Shenoy - * 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 - - * 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 - - * 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 - - * 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 - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - /), as well as for isntalled - packages, (from /. - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * 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 - - * pkg_parse.c: Fixed a bug in parsing the 3 state fields. - -2002-02-06 Carl Worth - - * pkg.c: Expanded pkg_status field to the full 3 fields: state_want, - state_flag, and state_status. - -2001-12-11 Carl Worth - - * 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 for 100+ filenames in tar file ( again )! + * applied patch from 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 , 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 + * 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 + +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 + * 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 + * Two more fixed memory leaks. Contributed by Nils Faerber. + +2004-08-17 Florian + * 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 + * 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 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 + * 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 + * 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 + 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 + * 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 + * 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 + * configure.ac: update to 0.99.113 + * libopkg.c: patch from drw to fix opkg list +2004-02-19 florian + * Some minor changes to make code compile on more compilers. +2004-02-14 jamey + * configure.ac: updated to 0.99.112 + * libbb/unarchive.c: copied in oldgnu tar compatibility mode from latest busybox. +2004-02-13 jamey + * configure.ac: updated to 0.99.111 + * pkg.c: wim delvaux's patch for status file in other destinations +2004-01-23 florian + * Applied Dan's patch that adds a package download command to + libopkg. +2004-01-20 florian + * 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 + * Added void* parameter to some callbacks. + +2003-12-02 florian + * Added familiar/opkg-cl.control.in, which is a prototype of + control file for opkg-cl package creation. +2003-12-01 florian + * 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 + * 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 + * 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 + * configure.ac: updated to 0.99.82 + * pkg_hash.c: ignore Replaces directive when a package replaces itself +2003-04-10 Jamey Hicks + * configure.ac: updated to 0.99.81 + * pkg.c: clear state_want and state_flags for any uninstallable package +2003-04-10 Jamey Hicks + * 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 + * 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 + * 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 + * configure.ac: updated to 0.99.77 + * opkg_cmd.c: implemented whatdepends + * opkg_conf.c: fixed typo +2003-04-03 Jamey Hicks + * 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 + * 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 + * 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 + * configure.ac: updated to 0.99.73 + * pkg_hash.c: remove latest_installed heuristic because it prevents upgrades. +2003-04-03 Jamey Hicks + * 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 + * 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 + * 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 + * 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 + * 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 + * 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 + * 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 + * configure.ac: updated to 0.99.65 + * opkg_cmd.c, opkg_conf.c: applied opkg dest installation patch from Ben Lau + * 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 + * 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 + * configure.ac: updated to 0.99.61 + * familiar/postinst: mkdir -p /etc/opkg +2003-03-24 Jamey Hicks + * 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 + * 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 + * 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 + * 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 + * 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 + * 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 + * configure.ac: updated to 0.99.53 + * pkg_depends.c: let SW_INSTALL satisfy dependences (instead of SS_INSTALL) +2003-03-01 Daniele Nicolodi + * 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 (patch from Daniele Nicolodi ) + * 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 + * 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 + * configure.ac: incremented version to 0.99.50 + * opkg_cmd.c: write out status after doing an upgrade +2003-02-27 Jamey Hicks (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 (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 (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 (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 (per patch from Philip Blundell ) + * 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 + * configure.ac: incremented version number to 0.99.44 + * args.c: added doc for -force-overwrite +2002-11-26 Jamey Hicks + * 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 + * 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 + * 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 + * 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 + * configure.ac: incremented version number to 0.99.39 + * applied patches from Aman Gupta for better handling of dests +2002-11-?? Jamey Hicks + * configure.ac: incremented version number to 0.99.38 +2002-11-07 Jamey Hicks + * 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 + * 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 + * configure.ac: incremented version number to 0.99.36 + * changed verbose_get to verbose_wget as documented +2002-08-08 Jamey Hicks + * 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 + * 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 + * configure.ac: incremented version number to 0.99.32 + * pkg.c: removed chroot breakage +2002-08-07 Jamey Hicks + * 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 + * 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 + * configure.ac: incremented version number to 0.99.29 + * pkg.c: fixed a segv when printing Replaces field +2002-07-24 Jamey Hicks + * 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 + * configure.ac: incremented version number to 0.99.27 +2002-07-23 Jamey Hicks + * 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 + * configure.ac: incremented version number to 0.99.25 + * many cleanups trying to regain stability +2002-07-22 Jamey Hicks + * configure.ac: incremented version number to 0.99.24 + * various files: trying to stomp a segv in conflicts checking. +2002-07-17 Jamey Hicks + * 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 + * 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 + * configure.ac: incremented version number to 0.99.21 after + applying dependent removal and conflicts patch. + +2002-07-14 Jamey Hicks + + * 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 + + * 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 + + * pkg_depends.c (pkg_hash_fetch_conflicts): use new abstract_pkg_vec + structure in checking provided_by + +2002-07-07 Jamey Hicks + + * configure.ac: incremented version number to 0.99.18 + * fixed a segv due to type error in provides support + +2002-07-07 Jamey Hicks + + * 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 + + * pkg_depends.c (pkg_hash_fetch_conflicts): check for conflicts + found before returning + +2002-07-04 Abhaya Shenoy + * 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 + + * 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 + + * 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 + + * 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 + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + /), as well as for isntalled + packages, (from /. + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * 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 + + * pkg_parse.c: Fixed a bug in parsing the 3 state fields. + +2002-02-06 Carl Worth + + * pkg.c: Expanded pkg_status field to the full 3 fields: state_want, + state_flag, and state_status. + +2001-12-11 Carl Worth + + * 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 . -# -# 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 or send patches to -# . - -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 . -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 . -# Please send patches to . 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 ." - -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 /* 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 - - 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 - #include - - 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 - 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 - #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' /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 - echo i586-unisys-sysv4 - exit ;; - *:UNIX_System_V:4*:FTX*) - # From Gerald Hewes . - # 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 < -# include -#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 - 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 -# 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 < 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 . 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 ." - -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 . - -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 . -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 -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 -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 -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 -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 , 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 <&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 </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 <> ${libobj}T </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 <> ${libobj}T <&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 </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 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 <> $cwrappersource<<"EOF" -#include -#include -#include -#include -#include -#include - -#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 <> $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 <> $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 ." - 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 , 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 -# 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