0.5.15cnc5-alt1
- Specfile cleanup. - Rediffed patches. - Fixed --help/--version segfault. - Fixed some compilation warnings. - Relocated methods to /usr/lib/apt/methods/.
This commit is contained in:
parent
4ef124c6d0
commit
0501f88ac1
@ -1,5 +1,5 @@
|
|||||||
copy: *.8
|
|
||||||
copy: *.conf
|
copy: *.conf
|
||||||
|
copy: *.old
|
||||||
copy: *.patch
|
copy: *.patch
|
||||||
copy: *.po
|
copy: *.po
|
||||||
copy: *.rsync
|
copy: *.rsync
|
||||||
|
497
ChangeLog-rpm.old
Normal file
497
ChangeLog-rpm.old
Normal file
@ -0,0 +1,497 @@
|
|||||||
|
* Mon Jun 10 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt6
|
||||||
|
|
||||||
|
- fixes in genbasedir from apt-utils:
|
||||||
|
+ srclist generation: now it correctly includes the information on produced
|
||||||
|
binaries (the list was empty before), and also correctly treats --mapi
|
||||||
|
(the fixed bug caused misbehaviour of 'apt-get source', in the "2nd branch
|
||||||
|
of DoSource()" as referenced by me in previous changelogs);
|
||||||
|
+ --flat option.
|
||||||
|
|
||||||
|
* Sun Jun 09 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt5
|
||||||
|
|
||||||
|
- renamed the 'build' subpackage to 'utils' (because there is already
|
||||||
|
an 'apt-build' project at freshmeat.net).
|
||||||
|
|
||||||
|
* Sun Jun 09 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt4
|
||||||
|
|
||||||
|
- separate subpkg 'build': analoguous to rpm-build, contains teh utilities to
|
||||||
|
generate indices (as a consequence less dependencies of 'apt' pkg,
|
||||||
|
little size);
|
||||||
|
- fix the work of 'apt-get source' for source packages with multiple binaries
|
||||||
|
with help of feedback and debugging patches from Anton Denisov
|
||||||
|
<fire@kgpu.kamchatka.ru> (only the first branch of control flow in DoSource()
|
||||||
|
is fixed, but that should be enough for normal use).
|
||||||
|
|
||||||
|
* Tue Mar 26 2002 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc55-alt3
|
||||||
|
|
||||||
|
- Added librpm-4.0.4 build support.
|
||||||
|
- Built with librpm-4.0.4, updated buildrequires.
|
||||||
|
|
||||||
|
* Thu Mar 21 2002 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc55-alt2
|
||||||
|
|
||||||
|
- Added kernel-aureal and NVIDIA_kernel to default AllowedDupPkgs.
|
||||||
|
- Updated patch for pkgRPMPM::ExecRPM.
|
||||||
|
- Reenabled rsh method.
|
||||||
|
- Updated rpmpriorities.
|
||||||
|
- fixed genbasedir patch.
|
||||||
|
- Set explicit Packager tag.
|
||||||
|
- Dropped obsolete trigger.
|
||||||
|
- libapt: Conflicts: apt < %version-%release.
|
||||||
|
- Renamed patches.
|
||||||
|
|
||||||
|
* Wed Mar 13 2002 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc55-alt1
|
||||||
|
|
||||||
|
- apt-0.3.19cnc55 integrated
|
||||||
|
- Fixed:
|
||||||
|
+ rpmpm-exec_rpm patch
|
||||||
|
+ genbasedir
|
||||||
|
- Removed:
|
||||||
|
+ rpmpm-nodeps patch (already upstream)
|
||||||
|
+ rsh method (already upstream)
|
||||||
|
|
||||||
|
* Mon Dec 10 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt6
|
||||||
|
|
||||||
|
- Fixed rpm --nodeps option usage in pkgRPMPM::ExecRPM (#0000215).
|
||||||
|
|
||||||
|
* Fri Nov 23 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt5
|
||||||
|
|
||||||
|
- Applied scoring algorithm patch (Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
- Updated package requires.
|
||||||
|
|
||||||
|
* Mon Nov 19 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt4
|
||||||
|
|
||||||
|
- Dropped outdated pofile (already upstream).
|
||||||
|
- Corrected "Executing RPM" message generation.
|
||||||
|
|
||||||
|
* Fri Nov 16 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt3
|
||||||
|
|
||||||
|
- Updated patches: genbasedir, configure-db3, i18n.
|
||||||
|
|
||||||
|
* Thu Nov 15 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc53-alt2
|
||||||
|
|
||||||
|
+ apt-0.3.19cnc53-2cl integrated. Most of our patches moved to upstream
|
||||||
|
- Fixed (from Conectiva's changelog):
|
||||||
|
+ fixed bug in mirror patch
|
||||||
|
+ cleaned up gen{pkg,src}list (Alexander Bokovoy <ab@altlinux.ru
|
||||||
|
+ fixed crash bug in genpkglist
|
||||||
|
+ configure.in patch to detect rpmdb (Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
+ * Skips correctly over empty package directories
|
||||||
|
+ * Adds the --bz2only argument which makes genbasedir
|
||||||
|
+ to generate only the .bz2 compressed versions of pkglist
|
||||||
|
+ and srclist (space gain...)
|
||||||
|
+ * Doesn't change the timestamps on pkglists/srclists if
|
||||||
|
+ the contents are not modified (making possible for example
|
||||||
|
+ to make several consecutive runs of genbasedir without
|
||||||
|
+ having the apt clients download the indexes again and again).
|
||||||
|
+ * Some minor cleanups (remove the temporary files in /tmp
|
||||||
|
+ at the end of the script etc).
|
||||||
|
+ (Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
+ cleanup patch for gensrclist (Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
+ fixed multi-arch pkg handling (Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
+ updated russian translation (Alexander Bokovoy <ab@altlinux.ru>
|
||||||
|
+ updated i18n (Dmitry Levin <ldv@alt-linux.org>)
|
||||||
|
+ replaced Apt::GPG::Pubring with Apt::GPG::PubringPath
|
||||||
|
also uses --homedir instead of --keyring in gpg
|
||||||
|
(Alexander Bokovoy <ab@altlinux.ru>)
|
||||||
|
+ patch to detect replaced (instead of just removed) packages
|
||||||
|
Dmitry Levin <ldv@alt-linux.org>
|
||||||
|
+ updated mirrors patch
|
||||||
|
+ Fixed mirrors infinite loop bug (closes: #4420).
|
||||||
|
+ Fixed error handling.
|
||||||
|
- Added:
|
||||||
|
+ added kernel-tape to default AllowedDupPkgs
|
||||||
|
+ added patch to fix bug in genbasedir with empty dirs
|
||||||
|
(Stelian Pop <stelian.pop@fr.alcove.com>)
|
||||||
|
+ added -K (RPM::Check-Signatures) option to verify rpm sigs
|
||||||
|
+ Added mirrors patch.
|
||||||
|
|
||||||
|
* Fri Nov 02 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc52-alt6
|
||||||
|
|
||||||
|
- Initial build with rpm4.
|
||||||
|
|
||||||
|
* Thu Oct 04 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt5
|
||||||
|
|
||||||
|
- Fixed i18n support and probably smth else
|
||||||
|
(configure.in, config.h.in and i18n.h were broken, kojima sux).
|
||||||
|
- Implemented 18n for apt-pkg/rpm, updated POTFILES.in and russian translation.
|
||||||
|
|
||||||
|
* Mon Oct 01 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt4
|
||||||
|
|
||||||
|
- Removed "^(kernel|alsa)[0-9]*-headers" from RPM::HoldPkgs list.
|
||||||
|
- Added (experimental) replaced packages support.
|
||||||
|
|
||||||
|
* Fri Sep 07 2001 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc52-alt3.1
|
||||||
|
|
||||||
|
- apt-cdrom fix (patch 6) reworked: apt-cdrom used to not detect a second
|
||||||
|
list file (srclist) if both (pkglist and srclist) were present in one
|
||||||
|
directory on the disk (in non-thorough mode); hopefully now it works how
|
||||||
|
we expect it to do.
|
||||||
|
|
||||||
|
* Thu Aug 09 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt3
|
||||||
|
|
||||||
|
- Libification.
|
||||||
|
- Reworked compilation options again: we add only '-fno-exceptions' now.
|
||||||
|
|
||||||
|
* Tue Aug 07 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt2
|
||||||
|
|
||||||
|
- More code cleanup in tools/gen{pkg,src}list.cc.
|
||||||
|
- Added %optflags_nocpp to compilation options.
|
||||||
|
|
||||||
|
* Mon Aug 06 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc52-alt1
|
||||||
|
|
||||||
|
- cnc52, gcc 3 and Solaris fixes
|
||||||
|
- RPM4 check is disabled for the moment
|
||||||
|
- File method fix has been integrated into mainstream
|
||||||
|
- RPM::RemoveOptions, RPM::UpdateOptions have been added
|
||||||
|
- Generation of Package list fixed
|
||||||
|
|
||||||
|
* Thu Aug 02 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc51-alt4
|
||||||
|
|
||||||
|
- Added trigger for better apt-conf-* migration.
|
||||||
|
|
||||||
|
* Tue Jul 31 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc51-alt3
|
||||||
|
|
||||||
|
- Updated:
|
||||||
|
+ rpmpriorities,
|
||||||
|
+ AllowedDupPkgs,
|
||||||
|
+ HoldPkgs.
|
||||||
|
- Moved *.list to apt-conf-* packages.
|
||||||
|
|
||||||
|
* Fri Jul 20 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc51-alt2
|
||||||
|
|
||||||
|
- Fixed:
|
||||||
|
+ Bug in file method which prevented authentication from working correctly
|
||||||
|
|
||||||
|
* Fri Jul 20 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc51-alt1
|
||||||
|
|
||||||
|
- cnc51
|
||||||
|
|
||||||
|
* Wed Jun 27 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc46-alt2
|
||||||
|
|
||||||
|
- cnc46
|
||||||
|
- kernel(|24)-{headers,source} added to HoldPkgs
|
||||||
|
- REPOSITORIO-APT-HOWTO added (Portugal)
|
||||||
|
- AllowedDupPackages -> AllowedDupPkgs
|
||||||
|
|
||||||
|
* Thu Jun 07 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc38-alt4
|
||||||
|
|
||||||
|
- Various fixes in /usr/bin/genbasedir.
|
||||||
|
|
||||||
|
* Thu May 17 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc38-alt3
|
||||||
|
|
||||||
|
- Fixed build.
|
||||||
|
- Updated rpmpriorities.
|
||||||
|
|
||||||
|
* Mon Apr 16 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc38-alt2
|
||||||
|
|
||||||
|
- More duplicate packages from kernel series allowed.
|
||||||
|
|
||||||
|
* Sun Apr 15 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc38-alt1
|
||||||
|
|
||||||
|
- cnc38
|
||||||
|
- Updated:
|
||||||
|
+ apt-cdrom now works correctly
|
||||||
|
+ default architecture has been changed to i586
|
||||||
|
+ ssh method as wrapper to rsh one
|
||||||
|
|
||||||
|
* Mon Mar 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc37-ipl3mdk
|
||||||
|
|
||||||
|
- Updated:
|
||||||
|
+ New patch for genbasedir to allow pass default key to GnuPG
|
||||||
|
|
||||||
|
* Sun Mar 18 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc37-ipl2mdk
|
||||||
|
|
||||||
|
- Fixed:
|
||||||
|
+ Build/installation of manpages without yodl sources;
|
||||||
|
+ Uncompressed small patches.
|
||||||
|
- Updated:
|
||||||
|
+ AllowedDupPackages list according to new kernel naming scheme;
|
||||||
|
+ URLs to use new domain name.
|
||||||
|
|
||||||
|
* Sat Mar 17 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc37-ipl1mdk
|
||||||
|
|
||||||
|
- Fixed:
|
||||||
|
+ APT::GPG::Pubring renamed to APT::GPG::PubringPath
|
||||||
|
+ Pubring support patch changed to use --homedir instead of --keyring
|
||||||
|
- Updated:
|
||||||
|
+ APT cnc37
|
||||||
|
+ Fingerprint and repository sources changed to reflect ALT Linux
|
||||||
|
new public key ring
|
||||||
|
|
||||||
|
* Mon Feb 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc36-ipl4mdk
|
||||||
|
|
||||||
|
- Sisyphus source repository added to sources.list
|
||||||
|
|
||||||
|
* Mon Feb 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc36-ipl3mdk
|
||||||
|
|
||||||
|
- New version
|
||||||
|
|
||||||
|
* Fri Feb 16 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc35-ipl2mdk
|
||||||
|
|
||||||
|
- Static library compilation added
|
||||||
|
- Static library goes to apt-devel-static due sizes of library
|
||||||
|
|
||||||
|
* Thu Feb 15 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc35-ipl1mdk
|
||||||
|
|
||||||
|
- New version
|
||||||
|
- Rsh method from upstream apt-get ported
|
||||||
|
- Spec file follows libification of rpm now
|
||||||
|
|
||||||
|
* Mon Jan 22 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc32-ipl4mdk
|
||||||
|
|
||||||
|
- New upstream version
|
||||||
|
- Russian translation updated
|
||||||
|
- Rebuild with new RPM library
|
||||||
|
|
||||||
|
* Mon Jan 22 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc28-ipl1mdk
|
||||||
|
|
||||||
|
- New upstream version
|
||||||
|
- cnc28 still lacks correct GNUPG checking code, our patch is neccessary.
|
||||||
|
- Genbasedir slightly patched again.
|
||||||
|
|
||||||
|
* Sun Jan 21 2001 Alexander Bokovoy <ab@avilink.net> ipl11mdk
|
||||||
|
|
||||||
|
- Typo in methods/gpg.cc fixed.
|
||||||
|
|
||||||
|
* Sun Jan 21 2001 Alexander Bokovoy <ab@avilink.net> ipl10mdk
|
||||||
|
|
||||||
|
- APT::GPG::Pubring option to specify default gnupg public ring added to check
|
||||||
|
distributors' signs automatically via default pubring in RPM package
|
||||||
|
- ftp user password changed to IPL one.
|
||||||
|
|
||||||
|
* Tue Jan 09 2001 Dmitry V. Levin <ldv@fandra.org> 0.3.19cnc27-ipl7mdk
|
||||||
|
|
||||||
|
- Specfile cleanup.
|
||||||
|
|
||||||
|
* Mon Jan 08 2001 Alexander Bokovoy <ab@avilink.net> ipl5mdk
|
||||||
|
|
||||||
|
- genbasedir help message fixed
|
||||||
|
|
||||||
|
* Mon Jan 08 2001 Alexander Bokovoy <ab@avilink.net> ipl4mdk
|
||||||
|
|
||||||
|
- Integration with main IPL package:
|
||||||
|
- Russian translation for command line messages added
|
||||||
|
- Russian translation of package summary/description
|
||||||
|
|
||||||
|
* Thu Jan 04 2001 AEN <aen@logic.ru>
|
||||||
|
|
||||||
|
- Real Sisyphus URL & IPLabs Fingerptint added
|
||||||
|
- changed rpmpriorities
|
||||||
|
|
||||||
|
* Thu Jan 04 2001 AEN <aen@logic.ru>
|
||||||
|
|
||||||
|
- build for RE
|
||||||
|
|
||||||
|
* Tue Dec 12 2000 Frederic Lepied <flepied@mandrakesoft.com> 0.3.19cnc27-1mdk
|
||||||
|
|
||||||
|
- first mandrake version.
|
||||||
|
|
||||||
|
* Thu Dec 07 2000 Andreas Hasenack <andreas@conectiva.com>
|
||||||
|
|
||||||
|
- damn! Wrong URL in sources.list, atualizacoes.conectiva.com
|
||||||
|
doesn't exist, of course...
|
||||||
|
|
||||||
|
* Thu Dec 07 2000 Andreas Hasenack <andreas@conectiva.com>
|
||||||
|
|
||||||
|
- updated sources.list with new mirrors and new download tree
|
||||||
|
- removed (noreplace) for the sources.list file for this
|
||||||
|
upgrade. It will be easier for the user. The (noreplace)
|
||||||
|
should be back in place after this update as we expect no
|
||||||
|
further big modifications for that file, only new mirrors.
|
||||||
|
|
||||||
|
* Wed Dec 06 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- fixed prob in vendors.list
|
||||||
|
|
||||||
|
* Tue Dec 05 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc27
|
||||||
|
|
||||||
|
* Wed Nov 08 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc26
|
||||||
|
|
||||||
|
* Mon Nov 06 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc25
|
||||||
|
|
||||||
|
* Thu Nov 02 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc24
|
||||||
|
|
||||||
|
* Thu Nov 02 2000 Rud<E1> Moura <ruda@conectiva.com>
|
||||||
|
|
||||||
|
- updated source.list (again)
|
||||||
|
|
||||||
|
* Thu Nov 02 2000 Rud<E1> Moura <ruda@conectiva.com>
|
||||||
|
|
||||||
|
- updated source.list
|
||||||
|
|
||||||
|
* Wed Nov 01 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc23
|
||||||
|
- added cache directories for gen{pkg,src}list
|
||||||
|
- pt_BR manpages
|
||||||
|
|
||||||
|
* Tue Oct 31 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc22
|
||||||
|
- Requires -> PreReq in apt-devel
|
||||||
|
|
||||||
|
* Mon Oct 30 2000 Alfredo Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- collapsed libapt-pkg-devel and -doc to apt-devel
|
||||||
|
|
||||||
|
* Mon Oct 30 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc21
|
||||||
|
|
||||||
|
* Sun Oct 29 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc20
|
||||||
|
|
||||||
|
* Sun Oct 29 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc19
|
||||||
|
- added gensrclist
|
||||||
|
- support for apt-get source
|
||||||
|
|
||||||
|
* Fri Oct 27 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc18
|
||||||
|
|
||||||
|
* Thu Oct 26 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc17
|
||||||
|
- new manpages
|
||||||
|
|
||||||
|
* Wed Oct 25 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc16
|
||||||
|
|
||||||
|
* Sun Oct 22 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc15
|
||||||
|
|
||||||
|
* Sat Oct 21 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc14
|
||||||
|
|
||||||
|
* Thu Oct 19 2000 Claudio Matsuoka <claudio@conectiva.com>
|
||||||
|
|
||||||
|
- new upstream release: 0.3.9cnc13
|
||||||
|
|
||||||
|
* Tue Oct 17 2000 Eliphas Levy Theodoro <eliphas@conectiva.com>
|
||||||
|
|
||||||
|
- added rpmpriorities to filelist and install
|
||||||
|
|
||||||
|
* Tue Oct 17 2000 Claudio Matsuoka <claudio@conectiva.com>
|
||||||
|
|
||||||
|
- updated to 0.3.19cnc12
|
||||||
|
- fresh CVS snapshot including: support to Acquire::ComprExtension,
|
||||||
|
debug messages removed, fixed apt-cdrom, RPM DB path, rpmlib call
|
||||||
|
in pkgRpmLock::Close(), package priority kludge removed, i18n
|
||||||
|
improvements, and genbasedir/genpkglist updates.
|
||||||
|
- handling language setting in genpkglist to make aptitude happy
|
||||||
|
|
||||||
|
* Wed Oct 11 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc11
|
||||||
|
- fixed problem with shard lib symlinks
|
||||||
|
|
||||||
|
* Tue Oct 10 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc10
|
||||||
|
|
||||||
|
* Mon Oct 02 2000 Claudio Matsuoka <claudio@conectiva.com>
|
||||||
|
|
||||||
|
- fixed brown paper bag bug with method permissions
|
||||||
|
- added parameter --sign to genbasedir
|
||||||
|
- added html/text doc files
|
||||||
|
|
||||||
|
* Sat Sep 30 2000 Claudio Matsuoka <claudio@conectiva.com>
|
||||||
|
|
||||||
|
- bumped to 0.3.19cnc9
|
||||||
|
- added vendors.list
|
||||||
|
- added gpg method
|
||||||
|
- fixed minor stuff to make Aptitude work
|
||||||
|
- added missing manpages
|
||||||
|
- fixed shared libs
|
||||||
|
- split in apt, libapt-pkg, libapt-pkg-devel, libapt-pkg-doc
|
||||||
|
- rewrote genbasedir in shell script (original was in TCL)
|
||||||
|
- misc cosmetic changes
|
||||||
|
|
||||||
|
* Tue Sep 26 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc8
|
||||||
|
|
||||||
|
* Wed Sep 20 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc7
|
||||||
|
|
||||||
|
* Mon Sep 18 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc6
|
||||||
|
|
||||||
|
* Sat Sep 16 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc5
|
||||||
|
|
||||||
|
* Fri Sep 15 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc4
|
||||||
|
|
||||||
|
* Tue Sep 12 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- released version 0.3.19cnc3
|
||||||
|
|
||||||
|
* Tue Sep 05 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- renamed package to apt, with version 0.3.19cncV
|
||||||
|
|
||||||
|
* Tue Sep 05 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- 0.10
|
||||||
|
- added genpkglist and rapt-config
|
||||||
|
- program names changed back to apt-*
|
||||||
|
|
||||||
|
* Mon Sep 04 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- 0.9
|
||||||
|
|
||||||
|
* Mon Sep 04 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- 0.8
|
||||||
|
|
||||||
|
* Mon Sep 04 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- 0.7
|
||||||
|
|
||||||
|
* Fri Sep 01 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- fixed typo in sources.list
|
||||||
|
|
||||||
|
* Thu Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- version 0.6
|
||||||
|
|
||||||
|
* Thu Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- version 0.5
|
||||||
|
|
||||||
|
* Thu Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- version 0.4
|
||||||
|
|
||||||
|
* Wed Aug 30 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- version 0.3
|
||||||
|
|
||||||
|
* Mon Aug 28 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- second try. new release with direct hdlist handling
|
||||||
|
|
||||||
|
* Thu Aug 10 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
||||||
|
|
||||||
|
- initial package creation. Yeah, it's totally broken for sure.
|
||||||
|
|
@ -1,47 +0,0 @@
|
|||||||
On Tue, Nov 20, 2001 at 02:28:53PM +0200, Matilainen Panu wrote:
|
|
||||||
|
|
||||||
> > I think this is the same bug (if it's a bug of course).
|
|
||||||
[...]
|
|
||||||
> The sane-split? I got it working by changing sane-frontends to have
|
|
||||||
> Provides: sane = %{version}
|
|
||||||
> and sane-backends
|
|
||||||
> Conflicts: sane < %{version}
|
|
||||||
>
|
|
||||||
> With the additional version information it manages to sort this out
|
|
||||||
> correctly.
|
|
||||||
|
|
||||||
I managed to find a hack permitting this to work without any
|
|
||||||
package modifications: when package scores are calculated
|
|
||||||
(based on package priorities and Depends:), I've added some
|
|
||||||
additionnal code to increment the priority of a package which
|
|
||||||
obsoletes another. This additionnal 'point' score makes the
|
|
||||||
right package to be selected for installation.
|
|
||||||
|
|
||||||
It works for me in simple cases, but it definately needs more
|
|
||||||
testing.
|
|
||||||
|
|
||||||
Comments ?
|
|
||||||
|
|
||||||
Stelian.
|
|
||||||
|
|
||||||
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/algorithms.cc.orig Wed Nov 21 17:45:34 2001
|
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/algorithms.cc Wed Nov 21 17:46:12 2001
|
|
||||||
@@ -566,6 +566,8 @@
|
|
||||||
{
|
|
||||||
if (D->Type == pkgCache::Dep::Depends || D->Type == pkgCache::Dep::PreDepends)
|
|
||||||
Scores[D.TargetPkg()->ID]++;
|
|
||||||
+ if (D->Type == pkgCache::Dep::Obsoletes)
|
|
||||||
+ Scores[I->ID]++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
--
|
|
||||||
Stelian Pop <stelian.pop@fr.alcove.com>
|
|
||||||
|---------------- Free Software Engineer -----------------|
|
|
||||||
| Alcôve - http://www.alcove.com - Tel: +33 1 49 22 68 00 |
|
|
||||||
|------------- Alcôve, liberating software ---------------|
|
|
||||||
_______________________________________________
|
|
||||||
Apt-rpm mailing list
|
|
||||||
Apt-rpm@distro.conectiva.com.br
|
|
||||||
http://distro.conectiva.com.br/mailman/listinfo/apt-rpm
|
|
@ -1,6 +1,7 @@
|
|||||||
--- apt-0.5.5cnc1/apt-pkg/deb/debsystem.cc.orig 2002-07-23 21:54:51 +0400
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/deb/debsystem.cc apt-0.5.15cnc5/apt-pkg/deb/debsystem.cc
|
||||||
+++ apt-0.5.5cnc1/apt-pkg/deb/debsystem.cc 2003-02-13 16:05:56 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/deb/debsystem.cc 2003-12-23 23:18:33 +0300
|
||||||
@@ -185,6 +185,8 @@
|
+++ apt-0.5.15cnc5/apt-pkg/deb/debsystem.cc 2004-01-16 15:12:44 +0300
|
||||||
|
@@ -185,6 +185,8 @@ bool debSystem::ArchiveSupported(const c
|
||||||
signed debSystem::Score(Configuration const &Cnf)
|
signed debSystem::Score(Configuration const &Cnf)
|
||||||
{
|
{
|
||||||
signed Score = 0;
|
signed Score = 0;
|
40
apt-0.5.15cnc5-alt-defaults.patch
Normal file
40
apt-0.5.15cnc5-alt-defaults.patch
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpackagedata.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpackagedata.cc 2003-12-23 23:19:36 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.cc 2004-01-16 15:14:46 +0300
|
||||||
|
@@ -21,7 +21,7 @@ RPMPackageData::RPMPackageData()
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
// Populate priorities
|
||||||
|
- string FileName = _config->FindFile("Dir::Etc::rpmpriorities");
|
||||||
|
+ string FileName = _config->FindFile("Dir::Etc") + "pkgpriorities";
|
||||||
|
FileFd F(FileName, FileFd::ReadOnly);
|
||||||
|
if (_error->PendingError())
|
||||||
|
{
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpm.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpm.cc 2003-12-23 23:19:20 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc 2004-01-16 15:14:33 +0300
|
||||||
|
@@ -493,7 +493,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (_config->FindB("RPM::Order",false) == false)
|
||||||
|
+ if (_config->FindB("RPM::Order",true) == false)
|
||||||
|
Args[n++] = "--noorder";
|
||||||
|
|
||||||
|
bool FilesInArgs = true;
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/buildlib/archtable apt-0.5.15cnc5/buildlib/archtable
|
||||||
|
--- apt-0.5.15cnc5.orig/buildlib/archtable 2003-12-23 23:15:23 +0300
|
||||||
|
+++ apt-0.5.15cnc5/buildlib/archtable 2004-01-16 15:14:33 +0300
|
||||||
|
@@ -5,8 +5,10 @@
|
||||||
|
|
||||||
|
# The left side is a regex for awk
|
||||||
|
|
||||||
|
-i.86 i386
|
||||||
|
-pentium i386
|
||||||
|
+i[34]86 i386
|
||||||
|
+i.86 i586
|
||||||
|
+pentium.* i586
|
||||||
|
+athlon i586
|
||||||
|
sparc sparc
|
||||||
|
sparc64 sparc
|
||||||
|
alpha.* alpha
|
36
apt-0.5.15cnc5-alt-distro.patch
Normal file
36
apt-0.5.15cnc5-alt-distro.patch
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.cc 2003-12-23 23:19:32 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.cc 2004-01-16 15:11:40 +0300
|
||||||
|
@@ -132,7 +132,7 @@ bool rpmSystem::Initialize(Configuration
|
||||||
|
Cnf.CndSet("Dir::Etc::translateparts", "translate.list.d");
|
||||||
|
Cnf.CndSet("Dir::State::prefetch", "prefetch");
|
||||||
|
Cnf.CndSet("Dir::Locale","/usr/share/locale");
|
||||||
|
- Cnf.CndSet("Acquire::DistroID","Conectiva"); // hee hee
|
||||||
|
+ Cnf.CndSet("Acquire::DistroID","ALT Linux"); // hee hee
|
||||||
|
Cnf.CndSet("Acquire::CDROM::Mount", "/mnt/cdrom");
|
||||||
|
Cnf.CndSet("Acquire::CDROM::Copy-All", "true");
|
||||||
|
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-cdrom.cc apt-0.5.15cnc5/cmdline/apt-cdrom.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/cmdline/apt-cdrom.cc 2003-12-23 23:31:19 +0300
|
||||||
|
+++ apt-0.5.15cnc5/cmdline/apt-cdrom.cc 2004-01-16 15:11:40 +0300
|
||||||
|
@@ -700,7 +700,7 @@ bool DoAdd(CommandLine &)
|
||||||
|
Name.empty() == true)
|
||||||
|
{
|
||||||
|
// CNC:2003-11-25
|
||||||
|
- cout << _("Please provide a name for this Disc, such as 'Distribution Disk 1'");
|
||||||
|
+ cout << _("Please provide a name for this Disc, such as 'ALT Linux Disk 1'");
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
Name = PromptLine("");
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/methods/ftp.cc apt-0.5.15cnc5/methods/ftp.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/methods/ftp.cc 2003-12-23 23:24:24 +0300
|
||||||
|
+++ apt-0.5.15cnc5/methods/ftp.cc 2004-01-16 15:11:40 +0300
|
||||||
|
@@ -190,7 +190,7 @@ bool FTPConn::Login()
|
||||||
|
// Setup the variables needed for authentication
|
||||||
|
string User = "anonymous";
|
||||||
|
// CNC:2003-06-16
|
||||||
|
- string Pass = "apt_get_ftp_2.1@rpm.linux.user";
|
||||||
|
+ string Pass = "apt_get_ftp_2.1@alt.linux.user";
|
||||||
|
|
||||||
|
// Fill in the user/pass
|
||||||
|
if (ServerName.User.empty() == false)
|
130
apt-0.5.15cnc5-alt-fixes.patch
Normal file
130
apt-0.5.15cnc5-alt-fixes.patch
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/pkgsystem.h apt-0.5.15cnc5/apt-pkg/pkgsystem.h
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/pkgsystem.h 2003-12-23 23:23:22 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/pkgsystem.h 2004-01-16 14:33:07 +0300
|
||||||
|
@@ -90,7 +90,7 @@ class pkgSystem
|
||||||
|
// Return a list of system index files..
|
||||||
|
virtual bool AddStatusFiles(std::vector<pkgIndexFile *> &List) = 0;
|
||||||
|
// CNC:2003-11-21
|
||||||
|
- virtual bool AddSourceFiles(std::vector<pkgIndexFile *> &List) {};
|
||||||
|
+ virtual void AddSourceFiles(std::vector<pkgIndexFile *> &List) {};
|
||||||
|
virtual bool FindIndex(pkgCache::PkgFileIterator File,
|
||||||
|
pkgIndexFile *&Found) const = 0;
|
||||||
|
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmhandler.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmhandler.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmhandler.cc 2003-12-23 23:19:22 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmhandler.cc 2004-01-16 14:30:11 +0300
|
||||||
|
@@ -87,7 +87,7 @@ bool RPMFileHandler::Jump(unsigned Offse
|
||||||
|
{
|
||||||
|
if (FD == NULL)
|
||||||
|
return false;
|
||||||
|
- if (lseek(Fileno(FD),Offset,SEEK_SET) != Offset)
|
||||||
|
+ if (lseek(Fileno(FD),Offset,SEEK_SET) != (off_t)Offset)
|
||||||
|
return false;
|
||||||
|
return Skip();
|
||||||
|
}
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpm.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmpm.cc 2003-12-23 23:19:20 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc 2004-01-16 14:29:19 +0300
|
||||||
|
@@ -392,7 +392,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
|
||||||
|
Args[n++] = _config->Find("Dir::Bin::rpm","rpm").c_str();
|
||||||
|
|
||||||
|
- bool nodeps;
|
||||||
|
+ bool nodeps = false;
|
||||||
|
|
||||||
|
switch (op)
|
||||||
|
{
|
||||||
|
@@ -415,6 +415,8 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
operation = "-e";
|
||||||
|
nodeps = true;
|
||||||
|
break;
|
||||||
|
+ default:
|
||||||
|
+ return false;
|
||||||
|
}
|
||||||
|
Args[n++] = operation;
|
||||||
|
|
||||||
|
@@ -654,8 +656,7 @@ pkgRPMLibPM::~pkgRPMLibPM()
|
||||||
|
|
||||||
|
bool pkgRPMLibPM::AddToTransaction(Item::RPMOps op, vector<const char*> &files)
|
||||||
|
{
|
||||||
|
- int debug = _config->FindB("Debug::pkgRPMPM", false);
|
||||||
|
- int n = 0, rc, xx;
|
||||||
|
+ int rc;
|
||||||
|
FD_t fd;
|
||||||
|
rpmHeader hdr;
|
||||||
|
|
||||||
|
@@ -735,7 +736,6 @@ bool pkgRPMLibPM::Process(vector<const c
|
||||||
|
{
|
||||||
|
int rc = 0;
|
||||||
|
bool Success = false;
|
||||||
|
- int debug = _config->FindB("Debug::pkgRPMPM", false);
|
||||||
|
string Dir = _config->Find("RPM::RootDir");
|
||||||
|
rpmReadConfigFiles(NULL, NULL);
|
||||||
|
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.cc 2003-12-23 23:19:32 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.cc 2004-01-16 14:33:07 +0300
|
||||||
|
@@ -249,7 +249,7 @@ bool rpmSystem::AddStatusFiles(vector<pk
|
||||||
|
// System::AddSourceFiles - Register aditional source files /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
-bool rpmSystem::AddSourceFiles(vector<pkgIndexFile *> &List)
|
||||||
|
+void rpmSystem::AddSourceFiles(vector<pkgIndexFile *> &List)
|
||||||
|
{
|
||||||
|
const Configuration::Item *Top;
|
||||||
|
Top = _config->Tree("APT::Arguments");
|
||||||
|
@@ -266,7 +266,6 @@ bool rpmSystem::AddSourceFiles(vector<pk
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
- return true;
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
#ifdef OLD_FILEDEPS
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.h apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.h
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsystem.h 2003-12-23 23:19:37 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmsystem.h 2004-01-16 14:33:07 +0300
|
||||||
|
@@ -60,7 +60,7 @@ class rpmSystem : public pkgSystem
|
||||||
|
virtual bool ArchiveSupported(const char *Type);
|
||||||
|
virtual signed Score(Configuration const &Cnf);
|
||||||
|
virtual bool AddStatusFiles(vector<pkgIndexFile *> &List);
|
||||||
|
- virtual bool AddSourceFiles(vector<pkgIndexFile *> &List);
|
||||||
|
+ virtual void AddSourceFiles(vector<pkgIndexFile *> &List);
|
||||||
|
virtual bool FindIndex(pkgCache::PkgFileIterator File,
|
||||||
|
pkgIndexFile *&Found) const;
|
||||||
|
virtual bool ProcessCache(pkgDepCache &Cache,pkgProblemResolver &Fix);
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-get.cc apt-0.5.15cnc5/cmdline/apt-get.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/cmdline/apt-get.cc 2003-12-23 23:30:50 +0300
|
||||||
|
+++ apt-0.5.15cnc5/cmdline/apt-get.cc 2004-01-16 21:55:48 +0300
|
||||||
|
@@ -3078,6 +3078,15 @@ int main(int argc,const char *argv[])
|
||||||
|
return 100;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // See if the help should be shown
|
||||||
|
+ if (_config->FindB("help") == true ||
|
||||||
|
+ _config->FindB("version") == true ||
|
||||||
|
+ CmdL.FileSize() == 0)
|
||||||
|
+ {
|
||||||
|
+ ShowHelp(CmdL);
|
||||||
|
+ return 0;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
// CNC:2003-11-21
|
||||||
|
if (CmdL.FileSize() != 1)
|
||||||
|
{
|
||||||
|
@@ -3102,15 +3111,6 @@ int main(int argc,const char *argv[])
|
||||||
|
_config->Set("APT::Arguments::", *I);
|
||||||
|
}
|
||||||
|
|
||||||
|
- // See if the help should be shown
|
||||||
|
- if (_config->FindB("help") == true ||
|
||||||
|
- _config->FindB("version") == true ||
|
||||||
|
- CmdL.FileSize() == 0)
|
||||||
|
- {
|
||||||
|
- ShowHelp(CmdL);
|
||||||
|
- return 0;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
// Deal with stdout not being a tty
|
||||||
|
if (ttyname(STDOUT_FILENO) == 0 && _config->FindI("quiet",0) < 1)
|
||||||
|
_config->Set("quiet","1");
|
@ -27,9 +27,14 @@ which helps to determine which of the branches is really used.)
|
|||||||
|
|
||||||
imz@altlinux.ru, 28 Sep 2002.
|
imz@altlinux.ru, 28 Sep 2002.
|
||||||
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/deb/debsrcrecords.h.getsrc 2002-07-25 22:07:18 +0400
|
Ported to apt-0.5.15cnc4.
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/deb/debsrcrecords.h 2002-10-29 00:45:07 +0300
|
|
||||||
@@ -34,6 +34,9 @@
|
avd@altlinux.org 2003-12-09
|
||||||
|
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/deb/debsrcrecords.h apt-0.5.15cnc5/apt-pkg/deb/debsrcrecords.h
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/deb/debsrcrecords.h 2003-12-23 23:19:00 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/deb/debsrcrecords.h 2004-01-16 15:18:13 +0300
|
||||||
|
@@ -34,6 +34,9 @@ class debSrcRecordParser : public pkgSrc
|
||||||
virtual bool Step() {iOffset = Tags.Offset(); return Tags.Step(Sect);};
|
virtual bool Step() {iOffset = Tags.Offset(); return Tags.Step(Sect);};
|
||||||
virtual bool Jump(unsigned long Off) {iOffset = Off; return Tags.Jump(Sect,Off);};
|
virtual bool Jump(unsigned long Off) {iOffset = Off; return Tags.Jump(Sect,Off);};
|
||||||
|
|
||||||
@ -39,23 +44,13 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
virtual string Package() const {return Sect.FindS("Package");};
|
virtual string Package() const {return Sect.FindS("Package");};
|
||||||
virtual string Version() const {return Sect.FindS("Version");};
|
virtual string Version() const {return Sect.FindS("Version");};
|
||||||
virtual string Maintainer() const {return Sect.FindS("Maintainer");};
|
virtual string Maintainer() const {return Sect.FindS("Maintainer");};
|
||||||
--- apt-0.5.4cnc9/apt-pkg/rpm/rpmsrcrecords.h.getsrc 2002-08-09 00:07:33 +0400
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmrecords.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmrecords.cc
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/rpm/rpmsrcrecords.h 2002-10-29 00:45:07 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmrecords.cc 2003-12-23 23:19:50 +0300
|
||||||
@@ -44,6 +44,8 @@
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmrecords.cc 2004-01-16 15:18:13 +0300
|
||||||
virtual bool Step();
|
@@ -178,7 +178,12 @@ string rpmRecordParser::SourcePkg()
|
||||||
virtual bool Jump(unsigned long Off);
|
|
||||||
|
|
||||||
+ virtual string FileName() const;
|
|
||||||
+
|
|
||||||
virtual string Package() const;
|
|
||||||
virtual string Version() const;
|
|
||||||
virtual string Maintainer() const;
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/rpm/rpmrecords.cc.getsrc 2002-08-19 20:37:48 +0400
|
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/rpm/rpmrecords.cc 2002-10-29 01:02:58 +0300
|
|
||||||
@@ -174,7 +174,12 @@
|
|
||||||
/* */
|
|
||||||
string rpmRecordParser::SourcePkg()
|
|
||||||
{
|
{
|
||||||
|
// This must be the *package* name, not the *file* name. We have no
|
||||||
|
// current way to extract it safely from the file name.
|
||||||
- return "";
|
- return "";
|
||||||
+ char *str;
|
+ char *str;
|
||||||
+ int_32 count, type;
|
+ int_32 count, type;
|
||||||
@ -66,9 +61,10 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/rpm/rpmsrcrecords.cc.getsrc 2002-08-09 00:07:33 +0400
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsrcrecords.cc apt-0.5.15cnc5/apt-pkg/rpm/rpmsrcrecords.cc
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/rpm/rpmsrcrecords.cc 2002-10-29 00:57:41 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsrcrecords.cc 2003-12-23 23:20:00 +0300
|
||||||
@@ -143,6 +143,20 @@
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmsrcrecords.cc 2004-01-16 15:18:13 +0300
|
||||||
|
@@ -123,6 +123,20 @@ bool rpmSrcRecordParser::Jump(unsigned l
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,9 +85,22 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
string rpmSrcRecordParser::Package() const
|
string rpmSrcRecordParser::Package() const
|
||||||
{
|
{
|
||||||
char *str;
|
char *str;
|
||||||
--- apt-0.5.4cnc9/apt-pkg/srcrecords.cc.getsrc 2002-07-23 21:54:50 +0400
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsrcrecords.h apt-0.5.15cnc5/apt-pkg/rpm/rpmsrcrecords.h
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/srcrecords.cc 2002-10-29 00:45:07 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/rpm/rpmsrcrecords.h 2003-12-23 23:20:01 +0300
|
||||||
@@ -82,7 +82,7 @@
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmsrcrecords.h 2004-01-16 15:18:13 +0300
|
||||||
|
@@ -44,6 +44,8 @@ public:
|
||||||
|
virtual bool Step();
|
||||||
|
virtual bool Jump(unsigned long Off);
|
||||||
|
|
||||||
|
+ virtual string FileName() const;
|
||||||
|
+
|
||||||
|
virtual string Package() const;
|
||||||
|
virtual string Version() const;
|
||||||
|
virtual string Maintainer() const;
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/srcrecords.cc apt-0.5.15cnc5/apt-pkg/srcrecords.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/apt-pkg/srcrecords.cc 2003-12-23 23:19:13 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/srcrecords.cc 2004-01-16 15:18:13 +0300
|
||||||
|
@@ -82,7 +82,7 @@ bool pkgSrcRecords::Restart()
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
// SrcRecords::Find - Find the first source package with the given name /*{{{*/
|
// SrcRecords::Find - Find the first source package with the given name /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
@ -100,7 +109,7 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
returns the first found. A 'cursor' like system is used to allow this
|
returns the first found. A 'cursor' like system is used to allow this
|
||||||
function to be called multiple times to get successive entries */
|
function to be called multiple times to get successive entries */
|
||||||
pkgSrcRecords::Parser *pkgSrcRecords::Find(const char *Package,bool SrcOnly)
|
pkgSrcRecords::Parser *pkgSrcRecords::Find(const char *Package,bool SrcOnly)
|
||||||
@@ -92,6 +92,8 @@
|
@@ -92,6 +92,8 @@ pkgSrcRecords::Parser *pkgSrcRecords::Fi
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
@ -109,7 +118,7 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
// Step to the next record, possibly switching files
|
// Step to the next record, possibly switching files
|
||||||
while ((*Current)->Step() == false)
|
while ((*Current)->Step() == false)
|
||||||
{
|
{
|
||||||
@@ -107,7 +109,7 @@
|
@@ -107,7 +109,7 @@ pkgSrcRecords::Parser *pkgSrcRecords::Fi
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// Source name hit
|
// Source name hit
|
||||||
@ -117,10 +126,11 @@ imz@altlinux.ru, 28 Sep 2002.
|
|||||||
+ if ((*Current)->FileName() == Package)
|
+ if ((*Current)->FileName() == Package)
|
||||||
return *Current;
|
return *Current;
|
||||||
|
|
||||||
if (SrcOnly == true)
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/srcrecords.h.getsrc 2002-07-25 22:07:18 +0400
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/srcrecords.h apt-0.5.15cnc5/apt-pkg/srcrecords.h
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/srcrecords.h 2002-10-29 00:45:07 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/srcrecords.h 2003-12-23 23:20:10 +0300
|
||||||
@@ -66,6 +66,8 @@
|
+++ apt-0.5.15cnc5/apt-pkg/srcrecords.h 2004-01-16 15:18:13 +0300
|
||||||
|
@@ -66,6 +66,8 @@ class pkgSrcRecords
|
||||||
virtual unsigned long Offset() = 0;
|
virtual unsigned long Offset() = 0;
|
||||||
virtual string AsStr() = 0;
|
virtual string AsStr() = 0;
|
||||||
|
|
@ -1,12 +1,12 @@
|
|||||||
2003-06-24 Dmitry V. Levin <ldv@altlinux.org>
|
2004-01-16 Dmitry V. Levin <ldv@altlinux.org>
|
||||||
|
|
||||||
* cmdline/apt-get.cc (TryToInstall):
|
* cmdline/apt-get.cc (TryToInstall):
|
||||||
Optimize pure virtual packages install.
|
Optimize pure virtual packages install.
|
||||||
Add APT::Install::Virtual support.
|
Add APT::Install::Virtual support.
|
||||||
|
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc 2003-06-24 21:24:10 +0400
|
--- apt-0.5.15cnc5/cmdline/apt-get.cc.orig 2003-12-23 23:30:50 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-get.cc 2003-06-24 21:29:08 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-get.cc 2004-01-16 15:06:11 +0300
|
||||||
@@ -1042,13 +1042,25 @@ bool TryToInstall(pkgCache::PkgIterator
|
@@ -1208,14 +1208,24 @@ bool TryToInstall(pkgCache::PkgIterator
|
||||||
{
|
{
|
||||||
/* This is a pure virtual package and there is a single available
|
/* This is a pure virtual package and there is a single available
|
||||||
provides */
|
provides */
|
||||||
@ -15,25 +15,33 @@
|
|||||||
+ if (Cache[Pkg].CandidateVer == 0 && Pkg->ProvidesList != 0)
|
+ if (Cache[Pkg].CandidateVer == 0 && Pkg->ProvidesList != 0)
|
||||||
{
|
{
|
||||||
- pkgCache::PkgIterator Tmp = Pkg.ProvidesList().OwnerPkg();
|
- pkgCache::PkgIterator Tmp = Pkg.ProvidesList().OwnerPkg();
|
||||||
- ioprintf(c1out,_("Note, selecting %s instead of %s\n"),
|
- // CNC:2003-11-21 - Check if the current candidate is really
|
||||||
|
- // providing that dependency
|
||||||
|
- ioprintf(c1out,_("Selecting %s for '%s'\n"),
|
||||||
- Tmp.Name(),Pkg.Name());
|
- Tmp.Name(),Pkg.Name());
|
||||||
- Pkg = Tmp;
|
|
||||||
+ if (!Remove)
|
+ if (!Remove)
|
||||||
+ for (pkgCache::PrvIterator pv = Pkg.ProvidesList(); pv.end() == false; pv++)
|
+ for (pkgCache::PrvIterator pv = Pkg.ProvidesList(); pv.end() == false; pv++)
|
||||||
+ {
|
+ {
|
||||||
+ pkgCache::PkgIterator po = pv.OwnerPkg();
|
+ pkgCache::PkgIterator Tmp = pv.OwnerPkg();
|
||||||
+ // Just marked for install?
|
+ // Just marked for install?
|
||||||
+ if (Cache[po].Install() && Cache[po].NewInstall())
|
+ if (Cache[Tmp].Install() && Cache[Tmp].NewInstall())
|
||||||
+ return true;
|
+ return true;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ if ((Pkg.ProvidesList()->NextProvides == 0 ||
|
+ if ((Pkg.ProvidesList()->NextProvides == 0 ||
|
||||||
+ (!Remove && _config->FindB("APT::Install::Virtual", false))))
|
+ (!Remove && _config->FindB("APT::Install::Virtual", false))))
|
||||||
+ {
|
+ {
|
||||||
+ pkgCache::PkgIterator po = Pkg.ProvidesList().OwnerPkg();
|
+ pkgCache::PkgIterator Tmp = Pkg.ProvidesList().OwnerPkg();
|
||||||
+ ioprintf(c1out,_("Note, selecting %s instead of %s\n"),
|
+ ioprintf(c1out,_("Note, selecting %s instead of %s\n"),
|
||||||
+ po.Name(),Pkg.Name());
|
+ Tmp.Name(),Pkg.Name());
|
||||||
+ Pkg = po;
|
+
|
||||||
|
pkgCache::VerIterator Ver = Cache[Tmp].CandidateVerIter(Cache);
|
||||||
|
pkgCache::PrvIterator Prv = Ver.ProvidesList();
|
||||||
|
bool Found = false;
|
||||||
|
@@ -1249,6 +1259,7 @@ bool TryToInstall(pkgCache::PkgIterator
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Pkg = Tmp;
|
||||||
+ }
|
+ }
|
||||||
}
|
}
|
||||||
|
|
21
apt-0.5.15cnc5-alt-libtool.patch
Normal file
21
apt-0.5.15cnc5-alt-libtool.patch
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/configure.in apt-0.5.15cnc5/configure.in
|
||||||
|
--- apt-0.5.15cnc5.orig/configure.in 2003-12-23 23:15:40 +0300
|
||||||
|
+++ apt-0.5.15cnc5/configure.in 2004-01-16 19:50:16 +0300
|
||||||
|
@@ -11,8 +11,6 @@ AM_MAINTAINER_MODE
|
||||||
|
|
||||||
|
AC_CONFIG_HEADER([include/config.h:buildlib/config.h.in])
|
||||||
|
|
||||||
|
-AC_PROG_LIBTOOL
|
||||||
|
-
|
||||||
|
dnl Check our C compiler
|
||||||
|
AC_PROG_CC
|
||||||
|
AM_PROG_CC_C_O
|
||||||
|
@@ -22,6 +20,8 @@ dnl Check for other programs
|
||||||
|
AC_PROG_CXX
|
||||||
|
AC_PROG_CPP
|
||||||
|
|
||||||
|
+AC_PROG_LIBTOOL
|
||||||
|
+
|
||||||
|
dnl Checks for sockets
|
||||||
|
SAVE_LIBS="$LIBS"
|
||||||
|
LIBS=""
|
@ -1,6 +1,7 @@
|
|||||||
--- apt-0.5.4cnc3.orig/apt-pkg/acquire-item.cc Sat Jul 27 13:02:53 2002
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/acquire-item.cc apt-0.5.15cnc5/apt-pkg/acquire-item.cc
|
||||||
+++ apt-0.5.4cnc3/apt-pkg/acquire-item.cc Sat Jul 27 13:34:34 2002
|
--- apt-0.5.15cnc5.orig/apt-pkg/acquire-item.cc 2003-12-23 23:20:28 +0300
|
||||||
@@ -786,7 +786,10 @@
|
+++ apt-0.5.15cnc5/apt-pkg/acquire-item.cc 2004-01-16 15:26:05 +0300
|
||||||
|
@@ -824,7 +824,10 @@ void pkgAcqArchive::Done(string Message,
|
||||||
{
|
{
|
||||||
if (Md5Hash != MD5)
|
if (Md5Hash != MD5)
|
||||||
{
|
{
|
||||||
@ -12,7 +13,7 @@
|
|||||||
ErrorText = _("MD5Sum mismatch");
|
ErrorText = _("MD5Sum mismatch");
|
||||||
Rename(DestFile,DestFile + ".FAILED");
|
Rename(DestFile,DestFile + ".FAILED");
|
||||||
return;
|
return;
|
||||||
@@ -916,6 +919,9 @@
|
@@ -968,6 +971,9 @@ void pkgAcqFile::Done(string Message,uns
|
||||||
{
|
{
|
||||||
if (Md5Hash != MD5)
|
if (Md5Hash != MD5)
|
||||||
{
|
{
|
||||||
@ -22,9 +23,10 @@
|
|||||||
Status = StatError;
|
Status = StatError;
|
||||||
ErrorText = "MD5Sum mismatch";
|
ErrorText = "MD5Sum mismatch";
|
||||||
Rename(DestFile,DestFile + ".FAILED");
|
Rename(DestFile,DestFile + ".FAILED");
|
||||||
--- apt-0.5.4cnc3.orig/cmdline/apt-get.cc Sat Jul 27 13:02:53 2002
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-get.cc apt-0.5.15cnc5/cmdline/apt-get.cc
|
||||||
+++ apt-0.5.4cnc3/cmdline/apt-get.cc Sat Jul 27 13:41:35 2002
|
--- apt-0.5.15cnc5.orig/cmdline/apt-get.cc 2003-12-23 23:30:50 +0300
|
||||||
@@ -1709,6 +1709,9 @@
|
+++ apt-0.5.15cnc5/cmdline/apt-get.cc 2004-01-16 15:26:05 +0300
|
||||||
|
@@ -2382,6 +2382,9 @@ bool DoSource(CommandLine &CmdL)
|
||||||
I->Type != "tar")
|
I->Type != "tar")
|
||||||
continue;
|
continue;
|
||||||
|
|
@ -1,6 +1,7 @@
|
|||||||
--- apt-0.5.5cnc1/methods/gpg.cc.orig 2003-01-31 16:58:32 +0300
|
diff -uprk.orig apt-0.5.15cnc5.orig/methods/gpg.cc apt-0.5.15cnc5/methods/gpg.cc
|
||||||
+++ apt-0.5.5cnc1/methods/gpg.cc 2003-02-07 19:09:05 +0300
|
--- apt-0.5.15cnc5.orig/methods/gpg.cc 2003-12-23 23:24:04 +0300
|
||||||
@@ -195,7 +195,7 @@ char *getFileSigner(const char *file, co
|
+++ apt-0.5.15cnc5/methods/gpg.cc 2004-01-16 15:23:02 +0300
|
||||||
|
@@ -196,7 +196,7 @@ char *getFileSigner(const char *file, co
|
||||||
else if (pid == 0)
|
else if (pid == 0)
|
||||||
{
|
{
|
||||||
string path = _config->Find("Dir::Bin::gpg", "/usr/bin/gpg");
|
string path = _config->Find("Dir::Bin::gpg", "/usr/bin/gpg");
|
||||||
@ -9,7 +10,7 @@
|
|||||||
const char *argv[16];
|
const char *argv[16];
|
||||||
int argc = 0;
|
int argc = 0;
|
||||||
|
|
||||||
@@ -206,17 +206,16 @@ char *getFileSigner(const char *file, co
|
@@ -207,17 +207,16 @@ char *getFileSigner(const char *file, co
|
||||||
dup2(fd[1], STDERR_FILENO);
|
dup2(fd[1], STDERR_FILENO);
|
||||||
|
|
||||||
unsetenv("LANG");
|
unsetenv("LANG");
|
@ -3,8 +3,9 @@
|
|||||||
* apt-pkg/packagemanager.cc (pkgPackageManager::CheckRConflicts):
|
* apt-pkg/packagemanager.cc (pkgPackageManager::CheckRConflicts):
|
||||||
Ignore versionless reverse dependencies.
|
Ignore versionless reverse dependencies.
|
||||||
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/packagemanager.cc.orig 2002-12-26 21:29:50 +0300
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/packagemanager.cc apt-0.5.15cnc5/apt-pkg/packagemanager.cc
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/packagemanager.cc 2002-12-26 21:30:48 +0300
|
--- apt-0.5.15cnc5.orig/apt-pkg/packagemanager.cc 2003-12-23 23:20:35 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/packagemanager.cc 2004-01-16 15:27:18 +0300
|
||||||
@@ -216,7 +216,7 @@ bool pkgPackageManager::CheckRConflicts(
|
@@ -216,7 +216,7 @@ bool pkgPackageManager::CheckRConflicts(
|
||||||
if (D.ParentPkg() == Pkg || D.ParentVer() != D.ParentPkg().CurrentVer())
|
if (D.ParentPkg() == Pkg || D.ParentVer() != D.ParentPkg().CurrentVer())
|
||||||
continue;
|
continue;
|
@ -1,7 +1,7 @@
|
|||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/init.cc apt-0.5.5cnc4.1/apt-pkg/init.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/apt-pkg/init.cc apt-0.5.15cnc5/apt-pkg/init.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/apt-pkg/init.cc 2003-09-28 14:11:04 +0400
|
--- apt-0.5.15cnc5.orig/apt-pkg/init.cc 2004-01-16 15:21:38 +0300
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/init.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/apt-pkg/init.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -36,44 +36,44 @@ bool pkgInitConfig(Configuration &Cnf)
|
@@ -40,44 +40,44 @@ bool pkgInitConfig(Configuration &Cnf)
|
||||||
// General APT things
|
// General APT things
|
||||||
if (strcmp(COMMON_OS,"linux") == 0 ||
|
if (strcmp(COMMON_OS,"linux") == 0 ||
|
||||||
strcmp(COMMON_OS,"unknown") == 0)
|
strcmp(COMMON_OS,"unknown") == 0)
|
||||||
@ -55,7 +55,7 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/init.cc apt-0.5.5cnc4.1/apt-pkg/ini
|
|||||||
- Cnf.Set("Dir::Etc::main","apt.conf");
|
- Cnf.Set("Dir::Etc::main","apt.conf");
|
||||||
- Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
- Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
||||||
- Cnf.Set("Dir::Etc::preferences","preferences");
|
- Cnf.Set("Dir::Etc::preferences","preferences");
|
||||||
- Cnf.Set("Dir::Bin::methods","/usr/lib/apt");
|
- Cnf.Set("Dir::Bin::methods",LIBDIR "/apt/methods");
|
||||||
- Cnf.Set("Acquire::ComprExtension", ".bz2");
|
- Cnf.Set("Acquire::ComprExtension", ".bz2");
|
||||||
+ Cnf.CndSet("Dir::Etc::sourceparts","sources.list.d");
|
+ Cnf.CndSet("Dir::Etc::sourceparts","sources.list.d");
|
||||||
+ Cnf.CndSet("Dir::Etc::vendorlist","vendors.list");
|
+ Cnf.CndSet("Dir::Etc::vendorlist","vendors.list");
|
||||||
@ -63,15 +63,15 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/init.cc apt-0.5.5cnc4.1/apt-pkg/ini
|
|||||||
+ Cnf.CndSet("Dir::Etc::main","apt.conf");
|
+ Cnf.CndSet("Dir::Etc::main","apt.conf");
|
||||||
+ Cnf.CndSet("Dir::Etc::parts","apt.conf.d");
|
+ Cnf.CndSet("Dir::Etc::parts","apt.conf.d");
|
||||||
+ Cnf.CndSet("Dir::Etc::preferences","preferences");
|
+ Cnf.CndSet("Dir::Etc::preferences","preferences");
|
||||||
+ Cnf.CndSet("Dir::Bin::methods","/usr/lib/apt");
|
+ Cnf.CndSet("Dir::Bin::methods",LIBDIR "/apt/methods");
|
||||||
+ Cnf.CndSet("Acquire::ComprExtension", ".bz2");
|
+ Cnf.CndSet("Acquire::ComprExtension", ".bz2");
|
||||||
|
|
||||||
bool Res = true;
|
bool Res = true;
|
||||||
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-cache.cc apt-0.5.5cnc4.1/cmdline/apt-cache.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-cache.cc apt-0.5.15cnc5/cmdline/apt-cache.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-cache.cc 2003-03-08 02:10:43 +0300
|
--- apt-0.5.15cnc5.orig/cmdline/apt-cache.cc 2003-12-23 23:31:15 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-cache.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-cache.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -1611,8 +1611,8 @@ int main(int argc,const char *argv[])
|
@@ -1952,8 +1952,8 @@ int main(int argc,const char *argv[])
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
// Parse the command line and initialize the package library
|
||||||
CommandLine CmdL(Args,_config);
|
CommandLine CmdL(Args,_config);
|
||||||
@ -82,10 +82,10 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-cache.cc apt-0.5.5cnc4.1/cmdlin
|
|||||||
pkgInitSystem(*_config,_system) == false)
|
pkgInitSystem(*_config,_system) == false)
|
||||||
{
|
{
|
||||||
_error->DumpErrors();
|
_error->DumpErrors();
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-cdrom.cc apt-0.5.5cnc4.1/cmdline/apt-cdrom.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-cdrom.cc apt-0.5.15cnc5/cmdline/apt-cdrom.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-cdrom.cc 2003-09-28 14:11:04 +0400
|
--- apt-0.5.15cnc5.orig/cmdline/apt-cdrom.cc 2003-12-23 23:31:19 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-cdrom.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-cdrom.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -904,8 +904,8 @@ int main(int argc,const char *argv[])
|
@@ -901,8 +901,8 @@ int main(int argc,const char *argv[])
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
// Parse the command line and initialize the package library
|
||||||
CommandLine CmdL(Args,_config);
|
CommandLine CmdL(Args,_config);
|
||||||
@ -96,9 +96,9 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-cdrom.cc apt-0.5.5cnc4.1/cmdlin
|
|||||||
pkgInitSystem(*_config,_system) == false)
|
pkgInitSystem(*_config,_system) == false)
|
||||||
{
|
{
|
||||||
_error->DumpErrors();
|
_error->DumpErrors();
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-config.cc apt-0.5.5cnc4.1/cmdline/apt-config.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-config.cc apt-0.5.15cnc5/cmdline/apt-config.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-config.cc 2003-03-08 02:10:37 +0300
|
--- apt-0.5.15cnc5.orig/cmdline/apt-config.cc 2003-12-23 23:31:21 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-config.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-config.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -109,8 +109,8 @@ int main(int argc,const char *argv[])
|
@@ -109,8 +109,8 @@ int main(int argc,const char *argv[])
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
// Parse the command line and initialize the package library
|
||||||
@ -110,24 +110,10 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-config.cc apt-0.5.5cnc4.1/cmdli
|
|||||||
pkgInitSystem(*_config,_system) == false)
|
pkgInitSystem(*_config,_system) == false)
|
||||||
{
|
{
|
||||||
_error->DumpErrors();
|
_error->DumpErrors();
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-extracttemplates.cc apt-0.5.5cnc4.1/cmdline/apt-extracttemplates.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-get.cc apt-0.5.15cnc5/cmdline/apt-get.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-extracttemplates.cc 2003-03-08 02:10:21 +0300
|
--- apt-0.5.15cnc5.orig/cmdline/apt-get.cc 2003-12-23 23:30:50 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-extracttemplates.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-get.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -359,8 +359,8 @@ int main(int argc, const char **argv)
|
@@ -3067,8 +3067,8 @@ int main(int argc,const char *argv[])
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
|
||||||
CommandLine CmdL(Args,_config);
|
|
||||||
- if (pkgInitConfig(*_config) == false ||
|
|
||||||
- CmdL.Parse(argc,argv) == false ||
|
|
||||||
+ if (CmdL.Parse(argc,argv) == false ||
|
|
||||||
+ pkgInitConfig(*_config) == false ||
|
|
||||||
pkgInitSystem(*_config,_system) == false)
|
|
||||||
{
|
|
||||||
_error->DumpErrors();
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/apt-get.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc 2003-09-28 14:11:04 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-get.cc 2003-09-28 14:11:22 +0400
|
|
||||||
@@ -2497,8 +2497,8 @@ int main(int argc,const char *argv[])
|
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
// Parse the command line and initialize the package library
|
||||||
CommandLine CmdL(Args,_config);
|
CommandLine CmdL(Args,_config);
|
||||||
@ -138,10 +124,10 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/
|
|||||||
pkgInitSystem(*_config,_system) == false)
|
pkgInitSystem(*_config,_system) == false)
|
||||||
{
|
{
|
||||||
if (_config->FindB("version") == true)
|
if (_config->FindB("version") == true)
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-shell.cc apt-0.5.5cnc4.1/cmdline/apt-shell.cc
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/apt-shell.cc apt-0.5.15cnc5/cmdline/apt-shell.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-shell.cc 2003-03-08 02:10:37 +0300
|
--- apt-0.5.15cnc5.orig/cmdline/apt-shell.cc 2003-12-23 23:31:46 +0300
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-shell.cc 2003-09-28 14:11:22 +0400
|
+++ apt-0.5.15cnc5/cmdline/apt-shell.cc 2004-01-16 15:21:01 +0300
|
||||||
@@ -3738,8 +3738,8 @@ int main(int argc,const char *argv[])
|
@@ -4303,8 +4303,8 @@ int main(int argc,const char *argv[])
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
// Parse the command line and initialize the package library
|
||||||
CommandLine CmdL(CommandArgs(""),_config);
|
CommandLine CmdL(CommandArgs(""),_config);
|
||||||
@ -152,17 +138,3 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-shell.cc apt-0.5.5cnc4.1/cmdlin
|
|||||||
pkgInitSystem(*_config,_system) == false)
|
pkgInitSystem(*_config,_system) == false)
|
||||||
{
|
{
|
||||||
if (_config->FindB("version") == true)
|
if (_config->FindB("version") == true)
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-sortpkgs.cc apt-0.5.5cnc4.1/cmdline/apt-sortpkgs.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-sortpkgs.cc 2003-03-08 02:10:30 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-sortpkgs.cc 2003-09-28 14:11:22 +0400
|
|
||||||
@@ -180,8 +180,8 @@ int main(unsigned int argc,const char *a
|
|
||||||
|
|
||||||
// Parse the command line and initialize the package library
|
|
||||||
CommandLine CmdL(Args,_config);
|
|
||||||
- if (pkgInitConfig(*_config) == false ||
|
|
||||||
- CmdL.Parse(argc,argv) == false ||
|
|
||||||
+ if (CmdL.Parse(argc,argv) == false ||
|
|
||||||
+ pkgInitConfig(*_config) == false ||
|
|
||||||
pkgInitSystem(*_config,_system) == false)
|
|
||||||
{
|
|
||||||
_error->DumpErrors();
|
|
39
apt-0.5.15cnc5-alt-rpm-build.patch
Normal file
39
apt-0.5.15cnc5-alt-rpm-build.patch
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/configure.in apt-0.5.15cnc5/configure.in
|
||||||
|
--- apt-0.5.15cnc5.orig/configure.in 2003-12-23 23:15:40 +0300
|
||||||
|
+++ apt-0.5.15cnc5/configure.in 2004-01-15 19:08:18 +0300
|
||||||
|
@@ -72,7 +72,7 @@ else
|
||||||
|
[AC_MSG_ERROR([Can't find libbz2 library])])
|
||||||
|
AC_CHECK_LIB(z,gzopen, [],
|
||||||
|
[AC_MSG_ERROR([Can't find libz library])])
|
||||||
|
- AC_CHECK_HEADERS(db1/db.h)
|
||||||
|
+ dnl AC_CHECK_HEADERS(db1/db.h)
|
||||||
|
|
||||||
|
CPPFLAGS="$CPPFLAGS -I/usr/include/rpm"
|
||||||
|
AC_CHECK_HEADER(rpm/rpmlib.h, [],
|
||||||
|
@@ -80,12 +80,13 @@ else
|
||||||
|
|
||||||
|
if test $RPM_VERSION_MAJOR -lt 4; then
|
||||||
|
RPMLIBS="-lrpm -lz -lbz2 -lpopt"
|
||||||
|
+ AC_CHECK_HEADERS(db1/db.h)
|
||||||
|
else
|
||||||
|
AC_CHECK_LIB(rpmdb,rpmdbOpen,
|
||||||
|
[RPMDBLIBS="-lrpmdb"],
|
||||||
|
- [RPMDBLIBS="-ldb-3.1"],
|
||||||
|
+ [RPMDBLIBS="-ldb"],
|
||||||
|
[-lrpm -lrpmio -lz -lbz2 -lpopt])
|
||||||
|
- RPMLIBS="-lrpm $RPMDBLIBS -lrpmio -lz -lbz2 -lpopt"
|
||||||
|
+ RPMLIBS="-lrpm $RPMDBLIBS"
|
||||||
|
fi
|
||||||
|
AC_MSG_CHECKING(for RPM libraries)
|
||||||
|
AC_MSG_RESULT($RPMLIBS)
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/tools/cached_md5.cc apt-0.5.15cnc5/tools/cached_md5.cc
|
||||||
|
--- apt-0.5.15cnc5.orig/tools/cached_md5.cc 2003-12-23 23:16:37 +0300
|
||||||
|
+++ apt-0.5.15cnc5/tools/cached_md5.cc 2004-01-15 19:07:44 +0300
|
||||||
|
@@ -7,6 +7,7 @@
|
||||||
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <rpm/rpmlib.h>
|
||||||
|
+#include <rpm/misc.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/stat.h>
|
128
apt-0.5.15cnc5-alt-rpm-fancypercent.patch
Normal file
128
apt-0.5.15cnc5-alt-rpm-fancypercent.patch
Normal file
@ -0,0 +1,128 @@
|
|||||||
|
2004-01-16 Dmitry V. Levin <ldv@altlinux.org>
|
||||||
|
|
||||||
|
* apt-pkg/rpm/rpmpm.cc(pkgRPMPM::ExecRPM,pkgRPMLibPM::Process):
|
||||||
|
Honor "quiet" config option.
|
||||||
|
Pass "fancypercent" option.
|
||||||
|
|
||||||
|
--- apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc.orig 2004-01-16 14:56:02 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc 2004-01-16 14:58:37 +0300
|
||||||
|
@@ -389,6 +389,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
const char *operation;
|
||||||
|
unsigned int n = 0;
|
||||||
|
bool Interactive = _config->FindB("RPM::Interactive",true);
|
||||||
|
+ int quiet = _config->FindI("quiet",0);
|
||||||
|
|
||||||
|
Args[n++] = _config->Find("Dir::Bin::rpm","rpm").c_str();
|
||||||
|
|
||||||
|
@@ -397,18 +398,12 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
switch (op)
|
||||||
|
{
|
||||||
|
case Item::RPMInstall:
|
||||||
|
- if (Interactive)
|
||||||
|
- operation = "-ivh";
|
||||||
|
- else
|
||||||
|
- operation = "-iv";
|
||||||
|
+ operation = "-i";
|
||||||
|
nodeps = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Item::RPMUpgrade:
|
||||||
|
- if (Interactive)
|
||||||
|
- operation = "-Uvh";
|
||||||
|
- else
|
||||||
|
- operation = "-Uv";
|
||||||
|
+ operation = "-U";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Item::RPMErase:
|
||||||
|
@@ -420,8 +415,22 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
}
|
||||||
|
Args[n++] = operation;
|
||||||
|
|
||||||
|
- if (Interactive == false && op != Item::RPMErase)
|
||||||
|
- Args[n++] = "--percent";
|
||||||
|
+ if (quiet <= 2 && op != Item::RPMErase)
|
||||||
|
+ {
|
||||||
|
+ Args[n++] = "-v";
|
||||||
|
+ if (quiet <= 1)
|
||||||
|
+ {
|
||||||
|
+ if (Interactive)
|
||||||
|
+ {
|
||||||
|
+ Args[n++] = "-h";
|
||||||
|
+ if (quiet <= 0)
|
||||||
|
+ Args[n++] = "--fancypercent";
|
||||||
|
+ } else
|
||||||
|
+ {
|
||||||
|
+ Args[n++] = "--percent";
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
|
||||||
|
string rootdir = _config->Find("RPM::RootDir", "");
|
||||||
|
if (!rootdir.empty())
|
||||||
|
@@ -550,6 +559,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (quiet <= 2)
|
||||||
|
cout << _("Executing RPM (")<<cmd<<")..." << endl;
|
||||||
|
|
||||||
|
cout << flush;
|
||||||
|
@@ -629,6 +639,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
|
||||||
|
return _error->Error(_("Sub-process %s exited unexpectedly"),Args[0]);
|
||||||
|
}
|
||||||
|
+ if (quiet <= 2)
|
||||||
|
cout << _("Done.") << endl;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
@@ -745,6 +756,7 @@ bool pkgRPMLibPM::Process(vector<const c
|
||||||
|
int rc = 0;
|
||||||
|
bool Success = false;
|
||||||
|
string Dir = _config->Find("RPM::RootDir");
|
||||||
|
+ int quiet = _config->FindI("quiet",0);
|
||||||
|
rpmReadConfigFiles(NULL, NULL);
|
||||||
|
|
||||||
|
int probFilter = 0;
|
||||||
|
@@ -791,10 +803,21 @@ bool pkgRPMLibPM::Process(vector<const c
|
||||||
|
probFilter |= RPMPROB_FILTER_REPLACENEWFILES;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (_config->FindB("RPM::Interactive", true))
|
||||||
|
- notifyFlags |= INSTALL_LABEL | INSTALL_HASH;
|
||||||
|
- else
|
||||||
|
- notifyFlags |= INSTALL_LABEL | INSTALL_PERCENT;
|
||||||
|
+ if (quiet <= 2)
|
||||||
|
+ notifyFlags |= INSTALL_LABEL;
|
||||||
|
+
|
||||||
|
+ if (quiet <= 1)
|
||||||
|
+ {
|
||||||
|
+ if (_config->FindB("RPM::Interactive", true))
|
||||||
|
+ {
|
||||||
|
+ notifyFlags |= INSTALL_HASH;
|
||||||
|
+ extern int fancyPercents;
|
||||||
|
+ fancyPercents = (quiet <= 0) ? 1 : 0;
|
||||||
|
+ } else
|
||||||
|
+ {
|
||||||
|
+ notifyFlags |= INSTALL_PERCENT;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
|
||||||
|
if (uninstall.empty() == false)
|
||||||
|
AddToTransaction(Item::RPMErase, uninstall);
|
||||||
|
@@ -848,6 +871,7 @@ bool pkgRPMLibPM::Process(vector<const c
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (quiet <= 2)
|
||||||
|
cout << _("Committing changes...") << endl << flush;
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
@@ -872,6 +896,7 @@ bool pkgRPMLibPM::Process(vector<const c
|
||||||
|
if (rc < 0)
|
||||||
|
_error->Warning(_("Some errors occurred while running transaction"));
|
||||||
|
else
|
||||||
|
+ if (quiet <= 2)
|
||||||
|
cout << _("Done.") << endl;
|
||||||
|
}
|
||||||
|
rpmpsFree(probs);
|
31
apt-0.5.15cnc5-alt-rpm_cmd.patch
Normal file
31
apt-0.5.15cnc5-alt-rpm_cmd.patch
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
2004-01-16 Dmitry V. Levin <ldv@altlinux.org>
|
||||||
|
|
||||||
|
* apt-pkg/rpm/rpmpm.cc(pkgRPMPM::ExecRPM):
|
||||||
|
Report actual options being passed to rpm.
|
||||||
|
|
||||||
|
--- apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc.orig 2004-01-16 14:55:17 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc 2004-01-16 14:56:02 +0300
|
||||||
|
@@ -497,6 +497,14 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
|
||||||
|
if (_config->FindB("RPM::Order",false) == false)
|
||||||
|
Args[n++] = "--noorder";
|
||||||
|
+
|
||||||
|
+ string cmd;
|
||||||
|
+ for (unsigned i = 0; i < n; ++i)
|
||||||
|
+ {
|
||||||
|
+ if (!cmd.empty())
|
||||||
|
+ cmd += ' ';
|
||||||
|
+ cmd += Args[i];
|
||||||
|
+ }
|
||||||
|
|
||||||
|
bool FilesInArgs = true;
|
||||||
|
char *ArgsFileName = NULL;
|
||||||
|
@@ -542,7 +550,7 @@ bool pkgRPMExtPM::ExecRPM(Item::RPMOps o
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
- cout << _("Executing RPM (")<<operation<<")..." << endl;
|
||||||
|
+ cout << _("Executing RPM (")<<cmd<<")..." << endl;
|
||||||
|
|
||||||
|
cout << flush;
|
||||||
|
clog << flush;
|
39
apt-0.5.15cnc5-alt-tinfo.patch
Normal file
39
apt-0.5.15cnc5-alt-tinfo.patch
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/Makefile.am apt-0.5.15cnc5/cmdline/Makefile.am
|
||||||
|
--- apt-0.5.15cnc5.orig/cmdline/Makefile.am 2003-12-23 23:31:00 +0300
|
||||||
|
+++ apt-0.5.15cnc5/cmdline/Makefile.am 2004-01-16 15:10:00 +0300
|
||||||
|
@@ -12,6 +12,6 @@ LDADD = ../apt-pkg/libapt-pkg.la $(RPMLI
|
||||||
|
apt_cache_SOURCES = apt-cache.cc
|
||||||
|
apt_get_SOURCES = apt-get.cc acqprogress.cc acqprogress.h
|
||||||
|
apt_shell_SOURCES = apt-shell.cc acqprogress.cc acqprogress.h
|
||||||
|
-apt_shell_LDADD = $(LDADD) -lreadline -lncurses
|
||||||
|
+apt_shell_LDADD = $(LDADD) -lreadline -ltinfo
|
||||||
|
apt_config_SOURCES = apt-config.cc
|
||||||
|
apt_cdrom_SOURCES = apt-cdrom.cc rpmindexcopy.cc rpmindexcopy.h
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/cmdline/Makefile.in apt-0.5.15cnc5/cmdline/Makefile.in
|
||||||
|
--- apt-0.5.15cnc5.orig/cmdline/Makefile.in 2003-12-23 23:30:26 +0300
|
||||||
|
+++ apt-0.5.15cnc5/cmdline/Makefile.in 2004-01-16 15:10:00 +0300
|
||||||
|
@@ -181,7 +181,7 @@ LDADD = ../apt-pkg/libapt-pkg.la $(RPMLI
|
||||||
|
apt_cache_SOURCES = apt-cache.cc
|
||||||
|
apt_get_SOURCES = apt-get.cc acqprogress.cc acqprogress.h
|
||||||
|
apt_shell_SOURCES = apt-shell.cc acqprogress.cc acqprogress.h
|
||||||
|
-apt_shell_LDADD = $(LDADD) -lreadline -lncurses
|
||||||
|
+apt_shell_LDADD = $(LDADD) -lreadline -ltinfo
|
||||||
|
apt_config_SOURCES = apt-config.cc
|
||||||
|
apt_cdrom_SOURCES = apt-cdrom.cc rpmindexcopy.cc rpmindexcopy.h
|
||||||
|
subdir = cmdline
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5.orig/configure.in apt-0.5.15cnc5/configure.in
|
||||||
|
--- apt-0.5.15cnc5.orig/configure.in 2003-12-23 23:15:40 +0300
|
||||||
|
+++ apt-0.5.15cnc5/configure.in 2004-01-16 15:10:00 +0300
|
||||||
|
@@ -121,10 +121,10 @@ fi
|
||||||
|
AM_CONDITIONAL(WITH_LUA, test "$enable_scripts" != "no")
|
||||||
|
|
||||||
|
dnl Check for apt-shell dependencies
|
||||||
|
-AC_CHECK_LIB(ncurses,tputs,
|
||||||
|
+AC_CHECK_LIB(tinfo,tputs,
|
||||||
|
[AC_CHECK_HEADER(readline/readline.h,
|
||||||
|
[AC_CHECK_LIB(readline,rl_completion_matches,
|
||||||
|
- [compile_aptshell=yes],,[-lncurses])])])
|
||||||
|
+ [compile_aptshell=yes],,[-ltinfo])])])
|
||||||
|
AM_CONDITIONAL(COMPILE_APTSHELL, test "$compile_aptshell" = "yes")
|
||||||
|
|
||||||
|
dnl Converts the ARCH to be something singular for this general CPU family
|
@ -70,14 +70,26 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/algorithms.h apt-0.5.5cnc4.1/apt-pk
|
|||||||
};
|
};
|
||||||
|
|
||||||
bool pkgDistUpgrade(pkgDepCache &Cache);
|
bool pkgDistUpgrade(pkgDepCache &Cache);
|
||||||
|
diff -uprk.orig apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.h.orig apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.h
|
||||||
|
--- apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.h.orig 2003-12-23 23:19:39 +0300
|
||||||
|
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpackagedata.h 2004-01-12 18:27:13 +0300
|
||||||
|
@@ -70,7 +70,7 @@
|
||||||
|
{
|
||||||
|
if (Priorities.find(Package) != Priorities.end())
|
||||||
|
return Priorities[Package];
|
||||||
|
- return pkgCache::State::Standard;
|
||||||
|
+ return pkgCache::State::Optional;
|
||||||
|
};
|
||||||
|
inline pkgCache::Flag::PkgFlags PkgFlags(string Package)
|
||||||
|
{return Flags[Package];};
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/apt-get.cc
|
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/apt-get.cc
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc 2003-09-29 17:21:22 +0400
|
--- apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc 2003-09-29 17:21:22 +0400
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-get.cc 2003-09-29 17:27:28 +0400
|
+++ apt-0.5.5cnc4.1/cmdline/apt-get.cc 2003-09-29 17:27:28 +0400
|
||||||
@@ -1056,7 +1056,17 @@ bool TryToInstall(pkgCache::PkgIterator
|
@@ -1222,7 +1222,17 @@ bool TryToInstall(pkgCache::PkgIterator
|
||||||
if ((Pkg.ProvidesList()->NextProvides == 0 ||
|
if ((Pkg.ProvidesList()->NextProvides == 0 ||
|
||||||
(!Remove && _config->FindB("APT::Install::Virtual", false))))
|
(!Remove && _config->FindB("APT::Install::Virtual", false))))
|
||||||
{
|
{
|
||||||
- pkgCache::PkgIterator po = Pkg.ProvidesList().OwnerPkg();
|
- pkgCache::PkgIterator Tmp = Pkg.ProvidesList().OwnerPkg();
|
||||||
+ unsigned long Size = 0;
|
+ unsigned long Size = 0;
|
||||||
+ for (pkgCache::PrvIterator I = Pkg.ProvidesList(); I.end() == false; I++)
|
+ for (pkgCache::PrvIterator I = Pkg.ProvidesList(); I.end() == false; I++)
|
||||||
+ Size++;
|
+ Size++;
|
||||||
@ -87,8 +99,8 @@ diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/
|
|||||||
+ *PEnd++ = I.OwnerPkg();
|
+ *PEnd++ = I.OwnerPkg();
|
||||||
+ Fix.MakeScores();
|
+ Fix.MakeScores();
|
||||||
+ qsort(PList,PEnd - PList,sizeof(*PList),&(Fix.ScoreSort));
|
+ qsort(PList,PEnd - PList,sizeof(*PList),&(Fix.ScoreSort));
|
||||||
+ pkgCache::PkgIterator po = pkgCache::PkgIterator(*Pkg.Cache(), *PList);
|
+ pkgCache::PkgIterator Tmp = pkgCache::PkgIterator(*Pkg.Cache(), *PList);
|
||||||
+
|
+
|
||||||
ioprintf(c1out,_("Note, selecting %s instead of %s\n"),
|
ioprintf(c1out,_("Note, selecting %s instead of %s\n"),
|
||||||
po.Name(),Pkg.Name());
|
Tmp.Name(),Pkg.Name());
|
||||||
Pkg = po;
|
|
@ -1,36 +0,0 @@
|
|||||||
diff -ur apt-0.5.4cnc3.orig/tools/genbasedir apt-0.5.4cnc3/tools/genbasedir
|
|
||||||
--- apt-0.5.4cnc3.orig/tools/genbasedir Sat Jul 27 13:02:53 2002
|
|
||||||
+++ apt-0.5.4cnc3/tools/genbasedir Sat Jul 27 14:05:42 2002
|
|
||||||
@@ -26,6 +26,8 @@
|
|
||||||
genbasedir /home/ftp/pub/conectiva\n\
|
|
||||||
genbasedir /home/ftp/pub/conectiva main extra devel\n\
|
|
||||||
"
|
|
||||||
+GENPKGLIST=genpkglist-0.5
|
|
||||||
+GENSRCLIST=gensrclist-0.5
|
|
||||||
|
|
||||||
getsize()
|
|
||||||
{
|
|
||||||
@@ -178,9 +180,9 @@
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test x$updateinfo = x; then
|
|
||||||
- (cd $basedir; genpkglist $progress $bloat --index /tmp/srcidx.$comp.$$ $topdir $comp)
|
|
||||||
+ (cd $basedir; "$GENPKGLIST" $progress $bloat --index /tmp/srcidx.$comp.$$ $topdir $comp)
|
|
||||||
else
|
|
||||||
- (cd $basedir; genpkglist $progress $bloat --index /tmp/srcidx.$comp.$$ --info $updateinfo $topdir $comp)
|
|
||||||
+ (cd $basedir; "$GENPKGLIST" $progress $bloat --index /tmp/srcidx.$comp.$$ --info $updateinfo $topdir $comp)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f $basedir/pkglist.$comp ]; then
|
|
||||||
@@ -230,9 +232,9 @@
|
|
||||||
srctopdir=`cd $topdir; pwd`
|
|
||||||
fi
|
|
||||||
if [ $mapi -ne 0 ]; then
|
|
||||||
- (cd $basedir; gensrclist $progress $flat --mapi $srctopdir $comp /tmp/srcidx.$comp.$$)
|
|
||||||
+ (cd $basedir; "$GENSRCLIST" $progress $flat --mapi $srctopdir $comp /tmp/srcidx.$comp.$$)
|
|
||||||
else
|
|
||||||
- (cd $basedir; gensrclist $progress $flat $srctopdir $comp /tmp/srcidx.$$)
|
|
||||||
+ (cd $basedir; "$GENSRCLIST" $progress $flat $srctopdir $comp /tmp/srcidx.$$)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f $basedir/srclist.$comp ]; then
|
|
@ -1,41 +0,0 @@
|
|||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-item.cc apt-0.5.4cnc9.bz2/apt-pkg/acquire-item.cc
|
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/acquire-item.cc 2002-12-17 12:00:20 +0300
|
|
||||||
+++ apt-0.5.4cnc9.bz2/apt-pkg/acquire-item.cc 2002-12-19 17:17:41 +0300
|
|
||||||
@@ -188,7 +188,7 @@
|
|
||||||
|
|
||||||
// Create the item
|
|
||||||
// CNC:2002-07-03
|
|
||||||
- Desc.URI = URI + ".bz2";
|
|
||||||
+ Desc.URI = URI + _config->Find("Acquire::ComprExtension", ".bz2");
|
|
||||||
Desc.Description = URIDesc;
|
|
||||||
Desc.Owner = this;
|
|
||||||
Desc.ShortDesc = ShortDesc;
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/init.cc apt-0.5.4cnc9.bz2/apt-pkg/init.cc
|
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/init.cc 2002-12-17 12:00:54 +0300
|
|
||||||
+++ apt-0.5.4cnc9.bz2/apt-pkg/init.cc 2002-12-19 17:28:15 +0300
|
|
||||||
@@ -71,6 +71,7 @@
|
|
||||||
Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
|
||||||
Cnf.Set("Dir::Etc::preferences","preferences");
|
|
||||||
Cnf.Set("Dir::Bin::methods","/usr/lib/apt/methods");
|
|
||||||
+ Cnf.Set("Acquire::ComprExtension", ".bz2");
|
|
||||||
|
|
||||||
bool Res = true;
|
|
||||||
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/file.cc apt-0.5.4cnc9.bz2/methods/file.cc
|
|
||||||
--- apt-0.5.4cnc9.orig/methods/file.cc 2002-07-23 21:54:53 +0400
|
|
||||||
+++ apt-0.5.4cnc9.bz2/methods/file.cc 2002-12-19 17:24:32 +0300
|
|
||||||
@@ -52,9 +52,11 @@
|
|
||||||
Res.IMSHit = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
- // See if we can compute a file without a .gz exentsion
|
|
||||||
- string::size_type Pos = File.rfind(".gz");
|
|
||||||
- if (Pos + 3 == File.length())
|
|
||||||
+ // See if we can compute a file without a .gz or .bz2 exentsion
|
|
||||||
+ // Should we check here both .gz and .bz2 extensions?
|
|
||||||
+ string ComprExtension = _config->Find("Acquire::ComprExtension", ".bz2");
|
|
||||||
+ string::size_type Pos = File.rfind(ComprExtension);
|
|
||||||
+ if (Pos + ComprExtension.length() == File.length())
|
|
||||||
{
|
|
||||||
File = string(File,0,Pos);
|
|
||||||
if (stat(File.c_str(),&Buf) == 0)
|
|
@ -1,58 +0,0 @@
|
|||||||
2003-01-21 Anton Kachalov <mouse@altlinux.org>
|
|
||||||
|
|
||||||
* apt-pkg/versionmatch.cc (pkgVersionMatch::Find):
|
|
||||||
Add APT::Install::VirtualVersion support.
|
|
||||||
* cmdline/apt-get.cc (TryToChangeVer):
|
|
||||||
Substitute virtual package with real one.
|
|
||||||
|
|
||||||
--- apt-0.5.4cnc9/apt-pkg/versionmatch.cc.orig 2002-07-23 21:54:50 +0400
|
|
||||||
+++ apt-0.5.4cnc9/apt-pkg/versionmatch.cc 2003-01-21 16:42:55 +0300
|
|
||||||
@@ -15,6 +15,7 @@
|
|
||||||
#pragma implementation "apt-pkg/versionmatch.h"
|
|
||||||
#endif
|
|
||||||
#include <apt-pkg/versionmatch.h>
|
|
||||||
+#include <apt-pkg/configuration.h>
|
|
||||||
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
@@ -158,6 +159,19 @@ pkgCache::VerIterator pkgVersionMatch::Find
|
|
||||||
return Ver;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (_config->FindB("APT::Install::VirtualVersion",false) == false)
|
|
||||||
+ return Ver;
|
|
||||||
+
|
|
||||||
+ pkgCache::PrvIterator Prv = Pkg.ProvidesList();
|
|
||||||
+ for (; Prv.end() == false; Prv++)
|
|
||||||
+ {
|
|
||||||
+ if (Type == Version)
|
|
||||||
+ {
|
|
||||||
+ if (MatchVer(Prv.ProvideVersion(),VerStr,VerPrefixMatch) == true)
|
|
||||||
+ return Prv.OwnerVer();
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
// This will be Ended by now.
|
|
||||||
return Ver;
|
|
||||||
}
|
|
||||||
--- apt-0.5.4cnc9/cmdline/apt-get.cc.orig 2002-10-18 22:32:12 +0400
|
|
||||||
+++ apt-0.5.4cnc9/cmdline/apt-get.cc 2003-01-23 15:33:45 +0300
|
|
||||||
@@ -1119,7 +1119,7 @@
|
|
||||||
// TryToChangeVer - Try to change a candidate version /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
-bool TryToChangeVer(pkgCache::PkgIterator Pkg,pkgDepCache &Cache,
|
|
||||||
+bool TryToChangeVer(pkgCache::PkgIterator &Pkg,pkgDepCache &Cache,
|
|
||||||
const char *VerTag,bool IsRel)
|
|
||||||
{
|
|
||||||
pkgVersionMatch Match(VerTag,(IsRel == true?pkgVersionMatch::Release :
|
|
||||||
@@ -1143,6 +1143,9 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
Cache.SetCandidateVersion(Ver);
|
|
||||||
+ if (Ver.ParentPkg() != Pkg) {
|
|
||||||
+ Pkg = Ver.ParentPkg();
|
|
||||||
+ }
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,11 +0,0 @@
|
|||||||
--- apt-0.5.5cnc1/apt-pkg/rpm/rpmpackagedata.cc.orig 2003-01-29 16:52:32 +0300
|
|
||||||
+++ apt-0.5.5cnc1/apt-pkg/rpm/rpmpackagedata.cc 2003-02-07 18:31:11 +0300
|
|
||||||
@@ -16,7 +16,7 @@
|
|
||||||
RPMPackageData::RPMPackageData()
|
|
||||||
{
|
|
||||||
// Populate priorities
|
|
||||||
- string FileName = _config->FindFile("Dir::Etc::rpmpriorities");
|
|
||||||
+ string FileName = _config->FindFile("Dir::Etc") + "pkgpriorities";
|
|
||||||
FileFd F(FileName, FileFd::ReadOnly);
|
|
||||||
if (_error->PendingError())
|
|
||||||
{
|
|
@ -1,33 +0,0 @@
|
|||||||
--- apt-0.5.5cnc1/apt-pkg/rpm/rpmsystem.cc.orig 2002-11-25 21:25:28 +0300
|
|
||||||
+++ apt-0.5.5cnc1/apt-pkg/rpm/rpmsystem.cc 2003-02-07 18:13:09 +0300
|
|
||||||
@@ -125,7 +125,7 @@
|
|
||||||
Cnf.CndSet("Dir::Etc::translateparts", "translate.list.d");
|
|
||||||
Cnf.CndSet("Dir::State::prefetch", "prefetch");
|
|
||||||
Cnf.CndSet("Dir::Locale","/usr/share/locale");
|
|
||||||
- Cnf.CndSet("Acquire::DistroID","Conectiva"); // hee hee
|
|
||||||
+ Cnf.CndSet("Acquire::DistroID","ALT Linux"); // hee hee
|
|
||||||
Cnf.CndSet("Acquire::CDROM::Mount", "/mnt/cdrom");
|
|
||||||
Cnf.CndSet("Acquire::CDROM::Copy-All", "true");
|
|
||||||
|
|
||||||
--- apt-0.5.5cnc2/cmdline/apt-cdrom.cc.orig 2003-02-21 17:09:14 +0300
|
|
||||||
+++ apt-0.5.5cnc2/cmdline/apt-cdrom.cc 2003-02-25 15:33:02 +0300
|
|
||||||
@@ -700,7 +700,7 @@ bool DoAdd(CommandLine &)
|
|
||||||
{
|
|
||||||
// CNC:2002-07-11
|
|
||||||
#ifdef HAVE_RPM
|
|
||||||
- cout << "Please provide a name for this Disc, such as 'Conectiva Disk 1'";
|
|
||||||
+ cout << "Please provide a name for this Disc, such as 'ALT Linux Disk 1'";
|
|
||||||
#else
|
|
||||||
cout << "Please provide a name for this Disc, such as 'Debian 2.1r1 Disk 1'";
|
|
||||||
#endif
|
|
||||||
--- apt-0.5.5cnc2/methods/ftp.cc.orig 2003-02-21 17:12:17 +0300
|
|
||||||
+++ apt-0.5.5cnc2/methods/ftp.cc 2003-02-25 16:02:07 +0300
|
|
||||||
@@ -189,7 +189,7 @@ bool FTPConn::Login()
|
|
||||||
|
|
||||||
// Setup the variables needed for authentication
|
|
||||||
string User = "anonymous";
|
|
||||||
- string Pass = "apt_get_ftp_2.1@debian.linux.user";
|
|
||||||
+ string Pass = "apt_get_ftp_2.1@alt.linux.user";
|
|
||||||
|
|
||||||
// Fill in the user/pass
|
|
||||||
if (ServerName.User.empty() == false)
|
|
@ -1,66 +0,0 @@
|
|||||||
diff -uprk.orig apt-0.5.5cnc2.orig/configure.in apt-0.5.5cnc2/configure.in
|
|
||||||
--- apt-0.5.5cnc2.orig/configure.in 2003-02-21 17:06:40 +0300
|
|
||||||
+++ apt-0.5.5cnc2/configure.in 2003-02-25 16:04:31 +0300
|
|
||||||
@@ -56,10 +56,12 @@ dnl if test "$PTHREADLIB" != "-lpthread"
|
|
||||||
dnl AC_MSG_ERROR(failed: I need posix threads, pthread)
|
|
||||||
dnl fi
|
|
||||||
|
|
||||||
+DB2LIB=
|
|
||||||
+dnl ALT: uncomment this to build apt-ftparchive
|
|
||||||
dnl Check for DB2
|
|
||||||
-AC_CHECK_HEADER(db2/db.h,
|
|
||||||
- [AC_CHECK_LIB(db2,db_open,
|
|
||||||
- [AC_DEFINE(HAVE_DB2) DB2LIB="-ldb2"])])
|
|
||||||
+dnl AC_CHECK_HEADER(db2/db.h,
|
|
||||||
+dnl [AC_CHECK_LIB(db2,db_open,
|
|
||||||
+dnl [AC_DEFINE(HAVE_DB2) DB2LIB="-ldb2"])])
|
|
||||||
AC_SUBST(DB2LIB)
|
|
||||||
|
|
||||||
dnl CNC:2002-07-03
|
|
||||||
@@ -69,7 +71,6 @@ SAVE_LIBS="$LIBS"
|
|
||||||
SAVE_CPPFLAGS="$CPPFLAGS"
|
|
||||||
|
|
||||||
CPPFLAGS="$SAVE_CPPFLAGS -I/usr/include/rpm"
|
|
||||||
-AC_CHECK_HEADERS(db1/db.h)
|
|
||||||
AC_CHECK_HEADER(rpm/rpmlib.h, rpm_header_ok=1, rpm_header_ok=0)
|
|
||||||
|
|
||||||
if test $rpm_header_ok = 1; then
|
|
||||||
@@ -77,7 +78,7 @@ if test $rpm_header_ok = 1; then
|
|
||||||
LIBS="$SAVE_LIBS -lrpm -lrpmio -lz -lbz2 -lpopt"
|
|
||||||
AC_CHECK_LIB(rpmdb,rpmdbOpen,
|
|
||||||
[RPMDBLIBS="-lrpmdb"],
|
|
||||||
- [RPMDBLIBS="-ldb-3.1"])
|
|
||||||
+ [RPMDBLIBS="-ldb"])
|
|
||||||
|
|
||||||
LIBS="$SAVE_LIBS $RPMDBLIBS -lrpmio -lz -lbz2 -lpopt"
|
|
||||||
AC_CHECK_LIB(rpm,rpmdbGetIteratorOffset,
|
|
||||||
@@ -96,6 +97,7 @@ if test $rpm_header_ok = 1; then
|
|
||||||
[AC_DEFINE_UNQUOTED(HAVE_RPM, 1)
|
|
||||||
RPMLIBS="-lrpm -ldb1 -lz -lbz2 -lpopt"
|
|
||||||
SAVE_CPPFLAGS="$SAVE_CPPFLAGS -I/usr/include/rpm"
|
|
||||||
+ AC_CHECK_HEADERS(db1/db.h)
|
|
||||||
rpm_version="3"])
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
diff -uprk.orig apt-0.5.5cnc2.orig/tools/cached_md5.cc apt-0.5.5cnc2/tools/cached_md5.cc
|
|
||||||
--- apt-0.5.5cnc2.orig/tools/cached_md5.cc 2003-02-21 17:12:36 +0300
|
|
||||||
+++ apt-0.5.5cnc2/tools/cached_md5.cc 2003-02-25 16:03:17 +0300
|
|
||||||
@@ -7,6 +7,7 @@
|
|
||||||
#include <errno.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <rpm/rpmlib.h>
|
|
||||||
+#include <rpm/misc.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
diff -uprk.orig apt-0.5.5cnc2.orig/tools/hdlist2pkglist.cc apt-0.5.5cnc2/tools/hdlist2pkglist.cc
|
|
||||||
--- apt-0.5.5cnc2.orig/tools/hdlist2pkglist.cc 2003-02-21 17:12:30 +0300
|
|
||||||
+++ apt-0.5.5cnc2/tools/hdlist2pkglist.cc 2003-02-25 16:03:17 +0300
|
|
||||||
@@ -7,6 +7,7 @@
|
|
||||||
#include <errno.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <rpmlib.h>
|
|
||||||
+#include <rpm/misc.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <sys/stat.h>
|
|
@ -1,20 +0,0 @@
|
|||||||
--- apt-0.5.5cnc3.orig/cmdline/apt-cdrom.cc 2003-02-28 04:19:12 +1200
|
|
||||||
+++ apt-0.5.5cnc3/cmdline/apt-cdrom.cc 2003-03-04 11:34:11 +1200
|
|
||||||
@@ -853,7 +853,7 @@ int ShowHelp()
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
cout <<
|
|
||||||
- "Usage: apt-cdrom [options] command\n"
|
|
||||||
+ _("Usage: apt-cdrom [options] command\n"
|
|
||||||
"\n"
|
|
||||||
"apt-cdrom is a tool to add CDROM's to APT's source list. The\n"
|
|
||||||
"CDROM mount point and device information is taken from apt.conf\n"
|
|
||||||
@@ -872,7 +872,7 @@ int ShowHelp()
|
|
||||||
" -a Thorough scan mode\n"
|
|
||||||
" -c=? Read this configuration file\n"
|
|
||||||
" -o=? Set an arbitary configuration option, eg -o dir::cache=/tmp\n"
|
|
||||||
- "See fstab(5)\n";
|
|
||||||
+ "See fstab(5)\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,40 +0,0 @@
|
|||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/init.cc apt-0.5.5cnc4.1/apt-pkg/init.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/apt-pkg/init.cc 2003-06-25 18:35:05 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/init.cc 2003-06-25 18:35:45 +0400
|
|
||||||
@@ -72,7 +72,7 @@ bool pkgInitConfig(Configuration &Cnf)
|
|
||||||
Cnf.Set("Dir::Etc::main","apt.conf");
|
|
||||||
Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
|
||||||
Cnf.Set("Dir::Etc::preferences","preferences");
|
|
||||||
- Cnf.Set("Dir::Bin::methods","/usr/lib/apt/methods");
|
|
||||||
+ Cnf.Set("Dir::Bin::methods","/usr/lib/apt");
|
|
||||||
Cnf.Set("Acquire::ComprExtension", ".bz2");
|
|
||||||
|
|
||||||
bool Res = true;
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/rpm/rpmpm.cc apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpm.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/apt-pkg/rpm/rpmpm.cc 2003-06-25 18:35:05 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpm.cc 2003-06-25 18:43:01 +0400
|
|
||||||
@@ -332,7 +332,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (_config->FindB("RPM::Order",false) == false)
|
|
||||||
+ if (_config->FindB("RPM::Order",true) == false)
|
|
||||||
Args[n++] = "--noorder";
|
|
||||||
|
|
||||||
string cmd;
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/buildlib/archtable apt-0.5.5cnc4.1/buildlib/archtable
|
|
||||||
--- apt-0.5.5cnc4.1.orig/buildlib/archtable 2003-03-08 02:14:52 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/buildlib/archtable 2003-06-25 18:37:36 +0400
|
|
||||||
@@ -5,8 +5,10 @@
|
|
||||||
|
|
||||||
# The left side is a regex for awk
|
|
||||||
|
|
||||||
-i.86 i386
|
|
||||||
-pentium i386
|
|
||||||
+i[34]86 i386
|
|
||||||
+i.86 i586
|
|
||||||
+pentium.* i586
|
|
||||||
+athlon i586
|
|
||||||
sparc sparc
|
|
||||||
sparc64 sparc
|
|
||||||
alpha.* alpha
|
|
@ -1,31 +0,0 @@
|
|||||||
2002-10-23 Dmitry V. Levin <ldv@altlinux.org>
|
|
||||||
|
|
||||||
* apt-pkg/rpm/rpmpm.cc(pkgRPMPM::ExecRPM):
|
|
||||||
Report actual options being passed to rpm.
|
|
||||||
|
|
||||||
--- apt-0.5.5cnc4/apt-pkg/rpm/rpmpm.cc.orig 2003-03-07 17:40:44 +0300
|
|
||||||
+++ apt-0.5.5cnc4/apt-pkg/rpm/rpmpm.cc 2003-03-07 19:24:07 +0300
|
|
||||||
@@ -333,6 +333,14 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
if (_config->FindB("RPM::Order",false) == false)
|
|
||||||
Args[n++] = "--noorder";
|
|
||||||
|
|
||||||
+ string cmd;
|
|
||||||
+ for (unsigned i = 0; i < n; ++i)
|
|
||||||
+ {
|
|
||||||
+ if (!cmd.empty())
|
|
||||||
+ cmd += ' ';
|
|
||||||
+ cmd += Args[i];
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
for (vector<const char*>::iterator I = files.begin(); I != files.end(); I++)
|
|
||||||
Args[n++] = *I;
|
|
||||||
|
|
||||||
@@ -346,7 +354,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
- cout << _("Executing RPM (")<<operation<<")..." << endl;
|
|
||||||
+ cout << _("Executing RPM (")<<cmd<<")..." << endl;
|
|
||||||
|
|
||||||
cout << flush;
|
|
||||||
clog << flush;
|
|
@ -1,26 +0,0 @@
|
|||||||
--- apt-0.5.5cnc4.1/configure.in.orig 2003-03-08 03:07:11 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/configure.in 2003-03-11 13:08:10 +0300
|
|
||||||
@@ -125,10 +125,10 @@
|
|
||||||
[AC_MSG_RESULT(no)])
|
|
||||||
|
|
||||||
dnl Check for apt-shell dependencies
|
|
||||||
-AC_CHECK_LIB(ncurses,tputs,
|
|
||||||
+AC_CHECK_LIB(tinfo,tputs,
|
|
||||||
[AC_CHECK_HEADER(readline/readline.h,
|
|
||||||
[AC_CHECK_LIB(readline,readline,
|
|
||||||
- [COMPILE_APTSHELL=yes],,[-lncurses])])])
|
|
||||||
+ [COMPILE_APTSHELL=yes],,[-ltinfo])])])
|
|
||||||
AC_SUBST(COMPILE_APTSHELL)
|
|
||||||
|
|
||||||
dnl Converts the ARCH to be something singular for this general CPU family
|
|
||||||
--- apt-0.5.5cnc4.1/cmdline/makefile.orig 2003-03-08 02:10:32 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/makefile 2003-03-11 13:08:19 +0300
|
|
||||||
@@ -27,7 +27,7 @@
|
|
||||||
ifdef COMPILE_APTSHELL
|
|
||||||
# The apt-shell program
|
|
||||||
PROGRAM=apt-shell
|
|
||||||
-SLIBS = -lapt-pkg -lreadline -lncurses $(RPMLIBS)
|
|
||||||
+SLIBS = -lapt-pkg -lreadline -ltinfo $(RPMLIBS)
|
|
||||||
LIB_MAKES = apt-pkg/makefile
|
|
||||||
SOURCE = apt-shell.cc acqprogress.cc
|
|
||||||
include $(PROGRAM_H)
|
|
@ -1,55 +0,0 @@
|
|||||||
2003-04-28 Anton Kachalov <mouse@altlinux.org>
|
|
||||||
|
|
||||||
* apt-pkg/versionmatch.cc (pkgVersionMatch::MatchVer):
|
|
||||||
Ignore serial while matching version string.
|
|
||||||
Check both for version and version-release while matching version string.
|
|
||||||
|
|
||||||
--- apt-0.5.5cnc4.1/apt-pkg/versionmatch.cc.orig 2003-03-25 19:40:45 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/versionmatch.cc 2003-04-28 19:35:30 +0400
|
|
||||||
@@ -124,18 +124,36 @@ pkgVersionMatch::pkgVersionMatch(string
|
|
||||||
/* */
|
|
||||||
bool pkgVersionMatch::MatchVer(const char *A,string B,bool Prefix)
|
|
||||||
{
|
|
||||||
- const char *Ab = A;
|
|
||||||
- const char *Ae = Ab + strlen(A);
|
|
||||||
+ string s(A), sc(A);
|
|
||||||
+ const char *Ab = s.c_str(), *Ac = sc.c_str();
|
|
||||||
+
|
|
||||||
+ for (string::iterator i = s.begin(), k = sc.begin(); i != s.end(); ++i,++k)
|
|
||||||
+ {
|
|
||||||
+ if (*i == ':')
|
|
||||||
+ {
|
|
||||||
+ Ab = &(*i) + 1;
|
|
||||||
+ Ac = &(*k) + 1;
|
|
||||||
+ }
|
|
||||||
+ else if (*i == '-')
|
|
||||||
+ {
|
|
||||||
+ *i = 0;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ const char *Ae = Ab + strlen(Ab);
|
|
||||||
+ const char *Af = Ac + strlen(Ac);
|
|
||||||
|
|
||||||
// Strings are not a compatible size.
|
|
||||||
- if ((unsigned)(Ae - Ab) != B.length() && Prefix == false ||
|
|
||||||
- (unsigned)(Ae - Ab) < B.length())
|
|
||||||
- return false;
|
|
||||||
-
|
|
||||||
- // Match (leading?)
|
|
||||||
- if (stringcasecmp(B,Ab,Ab + B.length()) == 0)
|
|
||||||
- return true;
|
|
||||||
-
|
|
||||||
+ if (((unsigned)(Ae - Ab) == B.length() || Prefix == true) &&
|
|
||||||
+ (unsigned)(Ae - Ab) >= B.length() &&
|
|
||||||
+ stringcasecmp(B,Ab,Ab + B.length()) == 0)
|
|
||||||
+ return true;
|
|
||||||
+ else if (((unsigned)(Af - Ac) == B.length() || Prefix == true) &&
|
|
||||||
+ (unsigned)(Af - Ac) >= B.length() &&
|
|
||||||
+ stringcasecmp(B,Ac,Ac + B.length()) == 0)
|
|
||||||
+ return true;
|
|
||||||
+
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,231 +0,0 @@
|
|||||||
2003-06-24 Dmitry V. Levin <ldv@altlinux.org>
|
|
||||||
|
|
||||||
* apt-pkg/versionmatch.cc (pkgVersionMatch::MatchVer):
|
|
||||||
Use pkgVersioningSystem's CheckDep for normal (non-prefix) match.
|
|
||||||
* apt-pkg/versionmatch.h (class pkgVersionMatch):
|
|
||||||
Added "int VerOp" private member.
|
|
||||||
Added argument to constructor.
|
|
||||||
* apt-pkg/versionmatch.cc (pkgVersionMatch::pkgVersionMatch):
|
|
||||||
Initialize VerOp.
|
|
||||||
* cmdline/apt-get.cc (DoInstall):
|
|
||||||
Changed parser to initialize VerOp.
|
|
||||||
* cmdline/apt-get.cc (TryToChangeVer): Use it.
|
|
||||||
* cmdline/apt-get.cc (op2str): New function.
|
|
||||||
* cmdline/apt-get.cc (TryToChangeVer): Use it.
|
|
||||||
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/versionmatch.cc apt-0.5.5cnc4.1/apt-pkg/versionmatch.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/apt-pkg/versionmatch.cc 2003-06-24 15:43:54 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/versionmatch.cc 2003-06-24 15:18:19 +0400
|
|
||||||
@@ -15,6 +15,7 @@
|
|
||||||
#pragma implementation "apt-pkg/versionmatch.h"
|
|
||||||
#endif
|
|
||||||
#include <apt-pkg/versionmatch.h>
|
|
||||||
+#include <apt-pkg/version.h>
|
|
||||||
#include <apt-pkg/configuration.h>
|
|
||||||
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
@@ -27,7 +28,7 @@
|
|
||||||
// VersionMatch::pkgVersionMatch - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Break up the data string according to the selected type */
|
|
||||||
-pkgVersionMatch::pkgVersionMatch(string Data,MatchType Type) : Type(Type)
|
|
||||||
+pkgVersionMatch::pkgVersionMatch(string Data,MatchType Type,int Op) : VerOp(Op), Type(Type)
|
|
||||||
{
|
|
||||||
MatchAll = false;
|
|
||||||
VerPrefixMatch = false;
|
|
||||||
@@ -162,13 +163,22 @@ bool pkgVersionMatch::MatchVer(const cha
|
|
||||||
/* */
|
|
||||||
pkgCache::VerIterator pkgVersionMatch::Find(pkgCache::PkgIterator Pkg)
|
|
||||||
{
|
|
||||||
+ pkgVersioningSystem *VS = Pkg.Cache()->VS;
|
|
||||||
pkgCache::VerIterator Ver = Pkg.VersionList();
|
|
||||||
+
|
|
||||||
for (; Ver.end() == false; Ver++)
|
|
||||||
{
|
|
||||||
if (Type == Version)
|
|
||||||
{
|
|
||||||
- if (MatchVer(Ver.VerStr(),VerStr,VerPrefixMatch) == true)
|
|
||||||
- return Ver;
|
|
||||||
+ if (VerPrefixMatch)
|
|
||||||
+ {
|
|
||||||
+ if (MatchVer(Ver.VerStr(),VerStr,VerPrefixMatch) == true)
|
|
||||||
+ return Ver;
|
|
||||||
+ } else {
|
|
||||||
+ if (VS->CheckDep(Ver.VerStr(),VerOp,VerStr.c_str()) == true)
|
|
||||||
+ return Ver;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -185,9 +195,14 @@ pkgCache::VerIterator pkgVersionMatch::F
|
|
||||||
{
|
|
||||||
if (Type == Version)
|
|
||||||
{
|
|
||||||
- if (MatchVer(Prv.ProvideVersion(),VerStr,VerPrefixMatch) == true)
|
|
||||||
- return Prv.OwnerVer();
|
|
||||||
- continue;
|
|
||||||
+ if (VerPrefixMatch)
|
|
||||||
+ {
|
|
||||||
+ if (MatchVer(Prv.ProvideVersion(),VerStr,VerPrefixMatch) == true)
|
|
||||||
+ return Prv.OwnerVer();
|
|
||||||
+ } else {
|
|
||||||
+ if (VS->CheckDep(Prv.ProvideVersion(),VerOp,VerStr.c_str()) == true)
|
|
||||||
+ return Prv.OwnerVer();
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// This will be Ended by now.
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/apt-pkg/versionmatch.h apt-0.5.5cnc4.1/apt-pkg/versionmatch.h
|
|
||||||
--- apt-0.5.5cnc4.1.orig/apt-pkg/versionmatch.h 2003-03-08 02:12:11 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/versionmatch.h 2003-06-24 14:22:28 +0400
|
|
||||||
@@ -45,6 +45,7 @@ class pkgVersionMatch
|
|
||||||
// Version Matching
|
|
||||||
string VerStr;
|
|
||||||
bool VerPrefixMatch;
|
|
||||||
+ int VerOp;
|
|
||||||
|
|
||||||
// Release Matching
|
|
||||||
string RelVerStr;
|
|
||||||
@@ -66,7 +67,7 @@ class pkgVersionMatch
|
|
||||||
bool FileMatch(pkgCache::PkgFileIterator File);
|
|
||||||
pkgCache::VerIterator Find(pkgCache::PkgIterator Pkg);
|
|
||||||
|
|
||||||
- pkgVersionMatch(string Data,MatchType Type);
|
|
||||||
+ pkgVersionMatch(string Data,MatchType Type,int Op = 0);
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
||||||
diff -uprk.orig apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc apt-0.5.5cnc4.1/cmdline/apt-get.cc
|
|
||||||
--- apt-0.5.5cnc4.1.orig/cmdline/apt-get.cc 2003-06-24 15:43:54 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/cmdline/apt-get.cc 2003-06-24 15:39:37 +0400
|
|
||||||
@@ -1172,29 +1172,40 @@ bool TryToInstall(pkgCache::PkgIterator
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
+static const char *op2str(int op)
|
|
||||||
+{
|
|
||||||
+ switch (op & 0x0f)
|
|
||||||
+ {
|
|
||||||
+ case pkgCache::Dep::LessEq: return "<=";
|
|
||||||
+ case pkgCache::Dep::GreaterEq: return ">=";
|
|
||||||
+ case pkgCache::Dep::Less: return "<";
|
|
||||||
+ case pkgCache::Dep::Greater: return ">";
|
|
||||||
+ case pkgCache::Dep::Equals: return "=";
|
|
||||||
+ case pkgCache::Dep::NotEquals: return "!";
|
|
||||||
+ default: return "";
|
|
||||||
+ }
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
// TryToChangeVer - Try to change a candidate version /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool TryToChangeVer(pkgCache::PkgIterator &Pkg,pkgDepCache &Cache,
|
|
||||||
- const char *VerTag,bool IsRel)
|
|
||||||
+ int VerOp,const char *VerTag,bool IsRel)
|
|
||||||
{
|
|
||||||
pkgVersionMatch Match(VerTag,(IsRel == true?pkgVersionMatch::Release :
|
|
||||||
- pkgVersionMatch::Version));
|
|
||||||
+ pkgVersionMatch::Version),VerOp);
|
|
||||||
|
|
||||||
pkgCache::VerIterator Ver = Match.Find(Pkg);
|
|
||||||
|
|
||||||
if (Ver.end() == true)
|
|
||||||
- {
|
|
||||||
- if (IsRel == true)
|
|
||||||
- return _error->Error(_("Release '%s' for '%s' was not found"),
|
|
||||||
- VerTag,Pkg.Name());
|
|
||||||
- return _error->Error(_("Version '%s' for '%s' was not found"),
|
|
||||||
- VerTag,Pkg.Name());
|
|
||||||
- }
|
|
||||||
+ return _error->Error(_("%s %s'%s' for '%s' was not found"),
|
|
||||||
+ IsRel ? _("Release") : _("Version"),
|
|
||||||
+ op2str(VerOp), VerTag,Pkg.Name());
|
|
||||||
|
|
||||||
if (strcmp(VerTag,Ver.VerStr()) != 0)
|
|
||||||
{
|
|
||||||
- ioprintf(c1out,_("Selected version %s (%s) for %s\n"),
|
|
||||||
+ ioprintf(c1out,_("Selected %s %s (%s) for %s\n"),
|
|
||||||
+ IsRel ? _("release") : _("version"),
|
|
||||||
Ver.VerStr(),Ver.RelStr().c_str(),Pkg.Name());
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1455,6 +1466,7 @@ bool DoInstall(CommandLine &CmdL)
|
|
||||||
bool Remove = DefRemove;
|
|
||||||
char *VerTag = 0;
|
|
||||||
bool VerIsRel = false;
|
|
||||||
+ int VerOp = 0;
|
|
||||||
while (Cache->FindPkg(S).end() == true)
|
|
||||||
{
|
|
||||||
// Handle an optional end tag indicating what to do
|
|
||||||
@@ -1472,15 +1484,47 @@ bool DoInstall(CommandLine &CmdL)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
- char *Slash = strchr(S,'=');
|
|
||||||
- if (Slash != 0)
|
|
||||||
+ char *sep = strpbrk(S,"=><");
|
|
||||||
+ if (sep)
|
|
||||||
{
|
|
||||||
+ char *p;
|
|
||||||
+ int eq = 0, gt = 0, lt = 0;
|
|
||||||
+
|
|
||||||
VerIsRel = false;
|
|
||||||
- *Slash = 0;
|
|
||||||
- VerTag = Slash + 1;
|
|
||||||
+ for (p = sep; *p && strchr("=><",*p); ++p)
|
|
||||||
+ switch (*p)
|
|
||||||
+ {
|
|
||||||
+ case '=': eq = 1; break;
|
|
||||||
+ case '>': gt = 1; break;
|
|
||||||
+ case '<': lt = 1; break;
|
|
||||||
+ }
|
|
||||||
+ if (eq)
|
|
||||||
+ {
|
|
||||||
+ if (lt && gt)
|
|
||||||
+ return _error->Error(_("Couldn't parse name: %s"),S);
|
|
||||||
+ else if (lt)
|
|
||||||
+ VerOp = pkgCache::Dep::LessEq;
|
|
||||||
+ else if (gt)
|
|
||||||
+ VerOp = pkgCache::Dep::GreaterEq;
|
|
||||||
+ else
|
|
||||||
+ VerOp = pkgCache::Dep::Equals;
|
|
||||||
+ }
|
|
||||||
+ else
|
|
||||||
+ {
|
|
||||||
+ if (lt && gt)
|
|
||||||
+ VerOp = pkgCache::Dep::NotEquals;
|
|
||||||
+ else if (lt)
|
|
||||||
+ VerOp = pkgCache::Dep::Less;
|
|
||||||
+ else if (gt)
|
|
||||||
+ VerOp = pkgCache::Dep::Greater;
|
|
||||||
+ else
|
|
||||||
+ return _error->Error(_("Couldn't parse name: %s"),S);
|
|
||||||
+ }
|
|
||||||
+ *sep = '\0';
|
|
||||||
+ VerTag = p;
|
|
||||||
}
|
|
||||||
|
|
||||||
- Slash = strchr(S,'/');
|
|
||||||
+ char *Slash = strchr(S,'/');
|
|
||||||
if (Slash != 0)
|
|
||||||
{
|
|
||||||
VerIsRel = true;
|
|
||||||
@@ -1530,7 +1574,7 @@ bool DoInstall(CommandLine &CmdL)
|
|
||||||
Pkg.Name(),S);
|
|
||||||
|
|
||||||
if (VerTag != 0)
|
|
||||||
- if (TryToChangeVer(Pkg,Cache,VerTag,VerIsRel) == false)
|
|
||||||
+ if (TryToChangeVer(Pkg,Cache,VerOp,VerTag,VerIsRel) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
Hit |= TryToInstall(Pkg,Cache,Fix,Remove,BrokenFix,
|
|
||||||
@@ -1544,7 +1588,7 @@ bool DoInstall(CommandLine &CmdL)
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (VerTag != 0)
|
|
||||||
- if (TryToChangeVer(Pkg,Cache,VerTag,VerIsRel) == false)
|
|
||||||
+ if (TryToChangeVer(Pkg,Cache,VerOp,VerTag,VerIsRel) == false)
|
|
||||||
return false;
|
|
||||||
if (TryToInstall(Pkg,Cache,Fix,Remove,BrokenFix,ExpectedInst) == false)
|
|
||||||
return false;
|
|
@ -1,46 +0,0 @@
|
|||||||
2003-09-28 Dmitry V. Levin <ldv@altlinux.org>
|
|
||||||
|
|
||||||
* apt-pkg/rpm/rpmpm.cc(pkgRPMPM::ExecRPM):
|
|
||||||
Honor "quiet" config option.
|
|
||||||
Pass "fancypercent" option.
|
|
||||||
|
|
||||||
--- apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpm.cc.orig 2003-09-28 14:18:22 +0400
|
|
||||||
+++ apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpm.cc 2003-09-28 14:22:42 +0400
|
|
||||||
@@ -227,6 +227,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
const char *operation;
|
|
||||||
unsigned int n = 0;
|
|
||||||
bool Interactive = _config->FindB("RPM::Interactive",true);
|
|
||||||
+ int quiet = _config->FindI("quiet",0);
|
|
||||||
|
|
||||||
Args[n++] = _config->Find("Dir::Bin::rpm","rpm").c_str();
|
|
||||||
|
|
||||||
@@ -235,7 +236,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
switch (op)
|
|
||||||
{
|
|
||||||
case Item::RPMInstall:
|
|
||||||
- if (Interactive)
|
|
||||||
+ if (Interactive && quiet < 2)
|
|
||||||
operation = "-ivh";
|
|
||||||
else
|
|
||||||
operation = "-iv";
|
|
||||||
@@ -243,7 +244,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Item::RPMUpgrade:
|
|
||||||
- if (Interactive)
|
|
||||||
+ if (Interactive && quiet < 2)
|
|
||||||
operation = "-Uvh";
|
|
||||||
else
|
|
||||||
operation = "-Uv";
|
|
||||||
@@ -256,8 +257,10 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op,
|
|
||||||
}
|
|
||||||
Args[n++] = operation;
|
|
||||||
|
|
||||||
- if (Interactive == false && op != Item::RPMErase)
|
|
||||||
+ if (Interactive == false && quiet == 0 && op != Item::RPMErase)
|
|
||||||
Args[n++] = "--percent";
|
|
||||||
+ if (Interactive && quiet == 0)
|
|
||||||
+ Args[n++] = "--fancypercent";
|
|
||||||
|
|
||||||
string rootdir = _config->Find("RPM::RootDir", "");
|
|
||||||
if (!rootdir.empty())
|
|
@ -1,7 +1,8 @@
|
|||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-item.h apt-0.5.4cnc9.rsync/apt-pkg/acquire-item.h
|
Index: apt-rpm.rsync/apt-pkg/acquire-item.h
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/acquire-item.h 2002-07-23 21:54:50 +0400
|
===================================================================
|
||||||
+++ apt-0.5.4cnc9.rsync/apt-pkg/acquire-item.h 2002-12-17 11:34:33 +0300
|
--- apt-rpm.rsync/apt-pkg/acquire-item.h (revision 137)
|
||||||
@@ -59,6 +59,9 @@
|
+++ apt-rpm.rsync/apt-pkg/acquire-item.h (working copy)
|
||||||
|
@@ -61,6 +61,9 @@
|
||||||
|
|
||||||
// File to write the fetch into
|
// File to write the fetch into
|
||||||
string DestFile;
|
string DestFile;
|
||||||
@ -11,43 +12,10 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-item.h apt-0.5.4cnc
|
|||||||
|
|
||||||
// Action members invoked by the worker
|
// Action members invoked by the worker
|
||||||
virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
|
virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-method.cc apt-0.5.4cnc9.rsync/apt-pkg/acquire-method.cc
|
Index: apt-rpm.rsync/apt-pkg/acquire-worker.cc
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/acquire-method.cc 2002-07-23 21:54:50 +0400
|
===================================================================
|
||||||
+++ apt-0.5.4cnc9.rsync/apt-pkg/acquire-method.cc 2002-12-17 11:34:33 +0300
|
--- apt-rpm.rsync/apt-pkg/acquire-worker.cc (revision 137)
|
||||||
@@ -135,7 +135,7 @@
|
+++ apt-rpm.rsync/apt-pkg/acquire-worker.cc (working copy)
|
||||||
if (Queue == 0)
|
|
||||||
abort();
|
|
||||||
|
|
||||||
- char S[1024] = "";
|
|
||||||
+ char S[2048] = "";
|
|
||||||
char *End = S;
|
|
||||||
|
|
||||||
End += snprintf(S,sizeof(S),"200 URI Start\nURI: %s\n",Queue->Uri.c_str());
|
|
||||||
@@ -150,6 +150,10 @@
|
|
||||||
End += snprintf(End,sizeof(S)-4 - (End - S),"Resume-Point: %lu\n",
|
|
||||||
Res.ResumePoint);
|
|
||||||
|
|
||||||
+ if (!Res.TmpFilename.empty())
|
|
||||||
+ End += snprintf(End,sizeof(S)-4 - (End - S),"Tmp-Filename: %s\n",
|
|
||||||
+ Res.TmpFilename.c_str());
|
|
||||||
+
|
|
||||||
strcat(End,"\n");
|
|
||||||
if (write(STDOUT_FILENO,S,strlen(S)) != (signed)strlen(S))
|
|
||||||
exit(100);
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-method.h apt-0.5.4cnc9.rsync/apt-pkg/acquire-method.h
|
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/acquire-method.h 2002-07-23 21:54:50 +0400
|
|
||||||
+++ apt-0.5.4cnc9.rsync/apt-pkg/acquire-method.h 2002-12-17 11:34:33 +0300
|
|
||||||
@@ -47,6 +47,7 @@
|
|
||||||
time_t LastModified;
|
|
||||||
bool IMSHit;
|
|
||||||
string Filename;
|
|
||||||
+ string TmpFilename;
|
|
||||||
unsigned long Size;
|
|
||||||
unsigned long ResumePoint;
|
|
||||||
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-worker.cc apt-0.5.4cnc9.rsync/apt-pkg/acquire-worker.cc
|
|
||||||
--- apt-0.5.4cnc9.orig/apt-pkg/acquire-worker.cc 2002-07-23 21:54:50 +0400
|
|
||||||
+++ apt-0.5.4cnc9.rsync/apt-pkg/acquire-worker.cc 2002-12-17 11:34:33 +0300
|
|
||||||
@@ -235,6 +235,7 @@
|
@@ -235,6 +235,7 @@
|
||||||
CurrentSize = 0;
|
CurrentSize = 0;
|
||||||
TotalSize = atoi(LookupTag(Message,"Size","0").c_str());
|
TotalSize = atoi(LookupTag(Message,"Size","0").c_str());
|
||||||
@ -69,27 +37,47 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/apt-pkg/acquire-worker.cc apt-0.5.4
|
|||||||
return;
|
return;
|
||||||
CurrentSize = Buf.st_size;
|
CurrentSize = Buf.st_size;
|
||||||
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/makefile apt-0.5.4cnc9.rsync/methods/makefile
|
Index: apt-rpm.rsync/apt-pkg/acquire-method.cc
|
||||||
--- apt-0.5.4cnc9.orig/methods/makefile 2002-07-25 22:07:19 +0400
|
===================================================================
|
||||||
+++ apt-0.5.4cnc9.rsync/methods/makefile 2002-12-17 11:34:33 +0300
|
--- apt-rpm.rsync/apt-pkg/acquire-method.cc (revision 137)
|
||||||
@@ -63,6 +63,13 @@
|
+++ apt-rpm.rsync/apt-pkg/acquire-method.cc (working copy)
|
||||||
SOURCE = gpg.cc
|
@@ -135,7 +135,7 @@
|
||||||
include $(PROGRAM_H)
|
if (Queue == 0)
|
||||||
|
abort();
|
||||||
+# The rsync method
|
|
||||||
+PROGRAM=rsync
|
- char S[1024] = "";
|
||||||
+SLIBS = -lapt-pkg $(SOCKETLIBS) $(RPMLIBS)
|
+ char S[2048] = "";
|
||||||
+LIB_MAKES = apt-pkg/makefile
|
char *End = S;
|
||||||
+SOURCE = rsync.cc
|
|
||||||
+include $(PROGRAM_H)
|
End += snprintf(S,sizeof(S),"200 URI Start\nURI: %s\n",Queue->Uri.c_str());
|
||||||
+
|
@@ -150,6 +150,10 @@
|
||||||
# SSH and vzip2 method symlink
|
End += snprintf(End,sizeof(S)-4 - (End - S),"Resume-Point: %lu\n",
|
||||||
all: $(BIN)/ssh $(BIN)/bzip2
|
Res.ResumePoint);
|
||||||
veryclean: clean-$(BIN)/ssh clean-$(BIN)/bzip2
|
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsync/methods/rsync.cc
|
+ if (!Res.TmpFilename.empty())
|
||||||
--- apt-0.5.4cnc9.orig/methods/rsync.cc 1970-01-01 03:00:00 +0300
|
+ End += snprintf(End,sizeof(S)-4 - (End - S),"Tmp-Filename: %s\n",
|
||||||
+++ apt-0.5.4cnc9.rsync/methods/rsync.cc 2002-12-17 13:25:56 +0300
|
+ Res.TmpFilename.c_str());
|
||||||
@@ -0,0 +1,468 @@
|
+
|
||||||
|
strcat(End,"\n");
|
||||||
|
if (write(STDOUT_FILENO,S,strlen(S)) != (signed)strlen(S))
|
||||||
|
exit(100);
|
||||||
|
Index: apt-rpm.rsync/apt-pkg/acquire-method.h
|
||||||
|
===================================================================
|
||||||
|
--- apt-rpm.rsync/apt-pkg/acquire-method.h (revision 137)
|
||||||
|
+++ apt-rpm.rsync/apt-pkg/acquire-method.h (working copy)
|
||||||
|
@@ -47,6 +47,7 @@
|
||||||
|
time_t LastModified;
|
||||||
|
bool IMSHit;
|
||||||
|
string Filename;
|
||||||
|
+ string TmpFilename;
|
||||||
|
unsigned long Size;
|
||||||
|
unsigned long ResumePoint;
|
||||||
|
|
||||||
|
Index: apt-rpm.rsync/methods/rsync.cc
|
||||||
|
===================================================================
|
||||||
|
--- apt-rpm.rsync/methods/rsync.cc (working copy)
|
||||||
|
+++ apt-rpm.rsync/methods/rsync.cc (working copy)
|
||||||
|
@@ -0,0 +1,570 @@
|
||||||
+// -*- mode: cpp; mode: fold -*-
|
+// -*- mode: cpp; mode: fold -*-
|
||||||
+// Description /*{{{*/
|
+// Description /*{{{*/
|
||||||
+// $Id$
|
+// $Id$
|
||||||
@ -124,6 +112,7 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+#include <arpa/inet.h>
|
+#include <arpa/inet.h>
|
||||||
+#include <netdb.h>
|
+#include <netdb.h>
|
||||||
+
|
+
|
||||||
|
+#include "apti18n.h"
|
||||||
+#include "rfc2553emu.h"
|
+#include "rfc2553emu.h"
|
||||||
+#include "connect.h"
|
+#include "connect.h"
|
||||||
+#include "rsync-method.h"
|
+#include "rsync-method.h"
|
||||||
@ -319,17 +308,45 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+ return false;
|
+ return false;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
|
+/* Parse rysnc output
|
||||||
|
+ * Need to parse lines like:
|
||||||
|
+ *
|
||||||
|
+ * ^opening tcp connection to rsync.altlinux.ru port 873
|
||||||
|
+ * ^[11948] i=0 <NULL> FILENAME mode=0100664 len=171935
|
||||||
|
+ * ^FILENAME
|
||||||
|
+ * ^renaming .FILENAME.bWM2bW to FILENAME
|
||||||
|
+ * ^set modtime of FILENAME to (1048860997) Fri Mar 28 17:16:37 2003
|
||||||
|
+ * ^recv_files finished
|
||||||
|
+ *
|
||||||
|
+ */
|
||||||
+void RsyncMethod::RsyncConnExec::ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf)
|
+void RsyncMethod::RsyncConnExec::ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf)
|
||||||
+{
|
+{
|
||||||
+ static const char * TMPFN = "Tmp-Filename: ";
|
+ static const char * TMPFN = "Tmp-Filename: ";
|
||||||
+ static const char * SIZE = "Size: ";
|
+ static const char * SIZE = "Size: ";
|
||||||
+ static const char * START = "Start: ";
|
+ static const char * START = "Start: ";
|
||||||
+ static const char * DONE = "Done: ";
|
+ static const char * DONE = "recv_files finished";
|
||||||
+ static const char * FAILED= "Failed: ";
|
+ static const char * FAILED= "Failed: ";
|
||||||
+ const char * ptr;
|
+ const char * ptr;
|
||||||
+
|
+
|
||||||
+ //if ( RsyncMethod::Debug )
|
+ if ( RsyncMethod::Debug )
|
||||||
+ // cerr << "ParseOutput: " << buf << endl;
|
+ cerr << "ParseOutput: " << buf << endl;
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,"opening tcp connection");
|
||||||
|
+ if (ptr) {
|
||||||
|
+ if ( RsyncMethod::Debug )
|
||||||
|
+ cerr << endl << "Status: Connecting" << endl;
|
||||||
|
+ State = Connecting;
|
||||||
|
+ Owner->Status(_("Connecting"));
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ // [PID] i=0 DIRNAME FILENAME mode=XXXXXXX len=YYYYYY
|
||||||
|
+ if (buf[0]=='[') {
|
||||||
|
+ ptr = strstr(buf,"i=0 ");
|
||||||
|
+ if (ptr == 0) return;
|
||||||
|
+ ptr += 4; // skip "i=0 "
|
||||||
|
+ ptr = strchr(ptr,' '); // skip DIRNAME
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ ptr = strstr(buf,TMPFN);
|
+ ptr = strstr(buf,TMPFN);
|
||||||
+ if (ptr) {
|
+ if (ptr) {
|
||||||
@ -401,7 +418,7 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+ argv.add(program.c_str());
|
+ argv.add(program.c_str());
|
||||||
+ argv.add("-Lpt");
|
+ argv.add("-Lpt");
|
||||||
+ argv.add("--partial");
|
+ argv.add("--partial");
|
||||||
+ argv.add("--apt-support");
|
+ AddOptions(argv);
|
||||||
+ if (RsyncMethod::Timeout>0) {
|
+ if (RsyncMethod::Timeout>0) {
|
||||||
+ argv.add("--timeout");
|
+ argv.add("--timeout");
|
||||||
+ char S[10];
|
+ char S[10];
|
||||||
@ -471,6 +488,76 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+ return false;
|
+ return false;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
|
+// Parse output of rsync process with --apt-support option
|
||||||
|
+void RsyncMethod::RsyncConnExecExt::ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf)
|
||||||
|
+{
|
||||||
|
+ static const char * TMPFN = "Tmp-Filename: ";
|
||||||
|
+ static const char * SIZE = "Size: ";
|
||||||
|
+ static const char * START = "Start: ";
|
||||||
|
+ static const char * DONE = "Done: ";
|
||||||
|
+ static const char * FAILED= "Failed: ";
|
||||||
|
+ const char * ptr;
|
||||||
|
+
|
||||||
|
+ //if ( RsyncMethod::Debug )
|
||||||
|
+ // cerr << "ParseOutput: " << buf << endl;
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,TMPFN);
|
||||||
|
+ if (ptr) {
|
||||||
|
+ ptr += strlen(TMPFN);
|
||||||
|
+ const char *ptr2 = ptr;
|
||||||
|
+ while (*ptr2!=0 && !isspace(*ptr2))
|
||||||
|
+ ++ptr2;
|
||||||
|
+ if (ptr!=ptr2) {
|
||||||
|
+ char *tmpfn = new char[ptr2-ptr+1];
|
||||||
|
+ bzero(tmpfn, ptr2-ptr+1);
|
||||||
|
+ strncpy(tmpfn, ptr, ptr2-ptr);
|
||||||
|
+ if (RsyncMethod::Debug)
|
||||||
|
+ cerr << endl << "RSYNC: " << TMPFN << tmpfn << endl;
|
||||||
|
+ FRes.TmpFilename = string(tmpfn);
|
||||||
|
+ delete tmpfn;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,SIZE);
|
||||||
|
+ if (ptr) {
|
||||||
|
+ ptr += strlen(SIZE);
|
||||||
|
+ unsigned long size = atol(ptr);
|
||||||
|
+ if (RsyncMethod::Debug)
|
||||||
|
+ cerr << "RSYNC: " << SIZE << size << endl;
|
||||||
|
+ FRes.Size = size;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,START);
|
||||||
|
+ if (ptr) {
|
||||||
|
+ State = Fetching;
|
||||||
|
+ dynamic_cast<RsyncMethod*>(Owner)->Start(FRes);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,DONE);
|
||||||
|
+ if (ptr)
|
||||||
|
+ State = Done;
|
||||||
|
+
|
||||||
|
+ ptr = strstr(buf,FAILED);
|
||||||
|
+ if (ptr) {
|
||||||
|
+ State = Failed;
|
||||||
|
+ ptr += strlen(FAILED);
|
||||||
|
+ const char *ptr2 = ptr;
|
||||||
|
+ while (*ptr2!=0 && *ptr2!='\n')
|
||||||
|
+ ++ptr2;
|
||||||
|
+ if (ptr!=ptr2) {
|
||||||
|
+ char *tmp = new char[ptr2-ptr+1];
|
||||||
|
+ bzero(tmp, ptr2-ptr+1);
|
||||||
|
+ strncpy(tmp, ptr, ptr2-ptr);
|
||||||
|
+ _error->Error("%s",tmp);
|
||||||
|
+ if (RsyncMethod::Debug)
|
||||||
|
+ cerr << endl << FAILED << tmp << endl;
|
||||||
|
+ delete tmp;
|
||||||
|
+ } else {
|
||||||
|
+ _error->Error("Child process failed (no description)");
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+}
|
||||||
|
+
|
||||||
+// RsyncMethod::RsyncMethod - Constructor /*{{{*/
|
+// RsyncMethod::RsyncMethod - Constructor /*{{{*/
|
||||||
+// ---------------------------------------------------------------------
|
+// ---------------------------------------------------------------------
|
||||||
+/* */
|
+/* */
|
||||||
@ -529,7 +616,10 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+
|
+
|
||||||
+ // Don't compare now for the same server uri
|
+ // Don't compare now for the same server uri
|
||||||
+ delete server;
|
+ delete server;
|
||||||
+ server = new RsyncConnExec(Get,proxy,RsyncProg);
|
+ if ( _config->FindB("Acquire::rsync::apt-support",true) )
|
||||||
|
+ server = new RsyncConnExecExt(Get,proxy,RsyncProg);
|
||||||
|
+ else
|
||||||
|
+ server = new RsyncConnExec(Get,proxy,RsyncProg);
|
||||||
+
|
+
|
||||||
+ if ( server->Get(this,Res,File,Itm->DestFile.c_str()) ) {
|
+ if ( server->Get(this,Res,File,Itm->DestFile.c_str()) ) {
|
||||||
+ if ( stat(Itm->DestFile.c_str(), &st)==0 ) {
|
+ if ( stat(Itm->DestFile.c_str(), &st)==0 ) {
|
||||||
@ -558,10 +648,11 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync.cc apt-0.5.4cnc9.rsyn
|
|||||||
+
|
+
|
||||||
+ return Mth.Run();
|
+ return Mth.Run();
|
||||||
+}
|
+}
|
||||||
diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync-method.h apt-0.5.4cnc9.rsync/methods/rsync-method.h
|
Index: apt-rpm.rsync/methods/rsync-method.h
|
||||||
--- apt-0.5.4cnc9.orig/methods/rsync-method.h 1970-01-01 03:00:00 +0300
|
===================================================================
|
||||||
+++ apt-0.5.4cnc9.rsync/methods/rsync-method.h 2002-12-17 11:34:33 +0300
|
--- apt-rpm.rsync/methods/rsync-method.h (working copy)
|
||||||
@@ -0,0 +1,102 @@
|
+++ apt-rpm.rsync/methods/rsync-method.h (working copy)
|
||||||
|
@@ -0,0 +1,116 @@
|
||||||
+// -*- mode: cpp; mode: fold -*-
|
+// -*- mode: cpp; mode: fold -*-
|
||||||
+// Description /*{{{*/
|
+// Description /*{{{*/
|
||||||
+// $Id$
|
+// $Id$
|
||||||
@ -600,7 +691,7 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync-method.h apt-0.5.4cnc
|
|||||||
+class RsyncMethod : public pkgAcqMethod
|
+class RsyncMethod : public pkgAcqMethod
|
||||||
+{
|
+{
|
||||||
+ protected:
|
+ protected:
|
||||||
+ enum ConnType {ConnTypeExec, ConnTypeProto};
|
+ enum ConnType {ConnTypeExec, ConnTypeExecExt, ConnTypeProto};
|
||||||
+
|
+
|
||||||
+ class RsyncConn
|
+ class RsyncConn
|
||||||
+ {
|
+ {
|
||||||
@ -633,7 +724,9 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync-method.h apt-0.5.4cnc
|
|||||||
+
|
+
|
||||||
+ protected:
|
+ protected:
|
||||||
+ bool WaitChild(pkgAcqMethod *Owner, FetchResult &FRes, const char *To);
|
+ bool WaitChild(pkgAcqMethod *Owner, FetchResult &FRes, const char *To);
|
||||||
+ void ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf);
|
+ virtual void ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf);
|
||||||
|
+ virtual void AddOptions(Argv &argv)
|
||||||
|
+ { argv.add("-vvvv"); };
|
||||||
+
|
+
|
||||||
+ public:
|
+ public:
|
||||||
+ RsyncConnExec(URI u, const string &_proxy, const string &prog);
|
+ RsyncConnExec(URI u, const string &_proxy, const string &prog);
|
||||||
@ -642,6 +735,18 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync-method.h apt-0.5.4cnc
|
|||||||
+ virtual bool Get(pkgAcqMethod *Owner, FetchResult &FRes, const char *From, const char *To);
|
+ virtual bool Get(pkgAcqMethod *Owner, FetchResult &FRes, const char *From, const char *To);
|
||||||
+ };
|
+ };
|
||||||
+
|
+
|
||||||
|
+ class RsyncConnExecExt: public RsyncConnExec
|
||||||
|
+ {
|
||||||
|
+ protected:
|
||||||
|
+ virtual void ParseOutput(pkgAcqMethod *Owner, FetchResult &FRes, const char *buf);
|
||||||
|
+ virtual void AddOptions(Argv &argv)
|
||||||
|
+ { argv.add("--apt-support"); };
|
||||||
|
+
|
||||||
|
+ public:
|
||||||
|
+ RsyncConnExecExt(URI u, const string &_proxy, const string &prog):
|
||||||
|
+ RsyncConnExec(u, _proxy, prog) {};
|
||||||
|
+ };
|
||||||
|
+
|
||||||
+ static RsyncConn *server;
|
+ static RsyncConn *server;
|
||||||
+ static ConnType connType;
|
+ static ConnType connType;
|
||||||
+ static bool Debug;
|
+ static bool Debug;
|
||||||
@ -664,3 +769,23 @@ diff -urN -X apt.excludes apt-0.5.4cnc9.orig/methods/rsync-method.h apt-0.5.4cnc
|
|||||||
+};
|
+};
|
||||||
+
|
+
|
||||||
+#endif
|
+#endif
|
||||||
|
Index: apt-rpm.rsync/methods/Makefile.am
|
||||||
|
===================================================================
|
||||||
|
--- apt-rpm.rsync/methods/Makefile.am (revision 137)
|
||||||
|
+++ apt-rpm.rsync/methods/Makefile.am (working copy)
|
||||||
|
@@ -1,6 +1,6 @@
|
||||||
|
|
||||||
|
methodsdir=${libdir}/apt/methods
|
||||||
|
-methods_PROGRAMS = cdrom copy file ftp gpg gzip bzip2 http rsh ssh
|
||||||
|
+methods_PROGRAMS = cdrom copy file ftp gpg gzip bzip2 http rsh ssh rsync
|
||||||
|
|
||||||
|
LDADD = ../apt-pkg/libapt-pkg.la
|
||||||
|
|
||||||
|
@@ -12,6 +12,7 @@
|
||||||
|
bzip2_SOURCES = $(gzip_SOURCES)
|
||||||
|
rsh_SOURCES = rsh.cc rsh.h
|
||||||
|
ssh_SOURCES = $(rsh_SOURCES)
|
||||||
|
+rsync_SOURCES = rsync.cc rsync-method.h
|
||||||
|
|
||||||
|
http_SOURCES = \
|
||||||
|
http.cc \
|
@ -1,61 +0,0 @@
|
|||||||
diff -ur apt-0.5.5cnc4.1/apt-pkg/algorithms.cc apt-0.5.5cnc4.1_20030324a/apt-pkg/algorithms.cc
|
|
||||||
--- apt-0.5.5cnc4.1/apt-pkg/algorithms.cc 2003-03-08 02:12:08 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1_20030324a/apt-pkg/algorithms.cc 2003-03-24 20:27:31 +0300
|
|
||||||
@@ -419,7 +419,8 @@
|
|
||||||
if (_config->FindB("APT::Remove-Depends",false) == true)
|
|
||||||
Fix.RemoveDepends();
|
|
||||||
|
|
||||||
- return Fix.Resolve();
|
|
||||||
+ // CNC:2003-03-22
|
|
||||||
+ return Fix.Resolve(true);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// AllUpgrade - Upgrade as many packages as possible /*{{{*/
|
|
||||||
@@ -1029,6 +1030,22 @@
|
|
||||||
if ((Flags[Pkg->ID] & Protected) != 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
+ // CNC:2003-03-22
|
|
||||||
+ pkgDepCache::State State(&Cache);
|
|
||||||
+ if (BrokenFix == true && DoUpgrade(Pkg) == true)
|
|
||||||
+ {
|
|
||||||
+ if (Cache[I].InstBroken() == false &&
|
|
||||||
+ State.BrokenCount() >= Cache.BrokenCount())
|
|
||||||
+ {
|
|
||||||
+ if (Debug == true)
|
|
||||||
+ clog << " Installing " << Pkg.Name() << endl;
|
|
||||||
+ Change = true;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ else
|
|
||||||
+ State.Restore();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
if (Debug == true)
|
|
||||||
clog << " Added " << Pkg.Name() << " to the remove list" << endl;
|
|
||||||
|
|
||||||
@@ -1405,7 +1422,7 @@
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (L->Priority != R->Priority)
|
|
||||||
- return R->Priority - L->Priority;
|
|
||||||
+ return L->Priority - R->Priority;
|
|
||||||
return strcmp(L.ParentPkg().Name(),R.ParentPkg().Name());
|
|
||||||
}
|
|
||||||
void pkgPrioSortList(pkgCache &Cache,pkgCache::Version **List)
|
|
||||||
diff -ur apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpackagedata.h apt-0.5.5cnc4.1_20030324a/apt-pkg/rpm/rpmpackagedata.h
|
|
||||||
--- apt-0.5.5cnc4.1/apt-pkg/rpm/rpmpackagedata.h 2003-03-08 02:12:32 +0300
|
|
||||||
+++ apt-0.5.5cnc4.1_20030324a/apt-pkg/rpm/rpmpackagedata.h 2003-03-21 02:30:15 +0300
|
|
||||||
@@ -67,7 +67,11 @@
|
|
||||||
public:
|
|
||||||
|
|
||||||
inline pkgCache::State::VerPriority VerPriority(string Package)
|
|
||||||
- {return Priorities[Package];};
|
|
||||||
+ {
|
|
||||||
+ if (Priorities.find(Package) != Priorities.end())
|
|
||||||
+ return Priorities[Package];
|
|
||||||
+ return pkgCache::State::Optional;
|
|
||||||
+ };
|
|
||||||
inline pkgCache::Flag::PkgFlags PkgFlags(string Package)
|
|
||||||
{return Flags[Package];};
|
|
||||||
|
|
50
apt.8
50
apt.8
@ -1,50 +0,0 @@
|
|||||||
.\" This manpage is copyright (C) 1998 Branden Robinson <branden@debian.org>.
|
|
||||||
.\"
|
|
||||||
.\" This is free software; you may 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 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 APT; if not, write to the Free Software
|
|
||||||
.\" Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
||||||
.\" 02111-1307 USA
|
|
||||||
.TH apt 8 "16 June 1998" "Debian GNU/Linux"
|
|
||||||
.SH NAME
|
|
||||||
apt \- Advanced Package Tool
|
|
||||||
.SH SYNOPSIS
|
|
||||||
.B apt
|
|
||||||
.SH DESCRIPTION
|
|
||||||
APT is a management system for software packages. It is still
|
|
||||||
under development; the snazzy front ends are not yet available. In the
|
|
||||||
meantime, please see
|
|
||||||
.BR apt-get (8).
|
|
||||||
.SH OPTIONS
|
|
||||||
None.
|
|
||||||
.SH FILES
|
|
||||||
None.
|
|
||||||
.SH SEE ALSO
|
|
||||||
.BR apt-cache (8),
|
|
||||||
.BR apt-get (8),
|
|
||||||
.BR apt.conf (5),
|
|
||||||
.BR sources.list (5)
|
|
||||||
.SH DIAGNOSTICS
|
|
||||||
apt returns zero on normal operation, decimal 100 on error.
|
|
||||||
.SH BUGS
|
|
||||||
This manpage isn't even started.
|
|
||||||
.PP
|
|
||||||
See <http://bugs.debian.org/apt>. If you wish to report a
|
|
||||||
bug in
|
|
||||||
.BR apt ,
|
|
||||||
please see
|
|
||||||
.I /usr/share/doc/debian/bug-reporting.txt
|
|
||||||
or the
|
|
||||||
.BR bug (1)
|
|
||||||
command.
|
|
||||||
.SH AUTHOR
|
|
||||||
apt was written by the APT team <apt@packages.debian.org>.
|
|
802
apt.spec
802
apt.spec
@ -1,65 +1,63 @@
|
|||||||
# hey Emacs, its -*- mode: rpm-spec; coding: cyrillic-cp1251; -*-
|
# hey Emacs, its -*- mode: rpm-spec; coding: cyrillic-cp1251; -*-
|
||||||
|
|
||||||
Name: apt
|
Name: apt
|
||||||
Version: 0.5.5cnc4.1
|
Version: 0.5.15cnc5
|
||||||
Release: alt7
|
Release: alt1
|
||||||
|
|
||||||
Summary: Debian's Advanced Packaging Tool with RPM support
|
Summary: Debian's Advanced Packaging Tool with RPM support
|
||||||
Summary(ru_RU.CP1251): Debian APT - Óñîâåðøåíñòâîâàííîå ñðåäñòâî óïðàâëåíèÿ ïàêåòàìè ñ ïîääåðæêîé RPM
|
Summary(ru_RU.CP1251): Debian APT - Óñîâåðøåíñòâîâàííîå ñðåäñòâî óïðàâëåíèÿ ïàêåòàìè ñ ïîääåðæêîé RPM
|
||||||
License: GPL
|
License: GPL
|
||||||
Group: System/Configuration/Packaging
|
Group: System/Configuration/Packaging
|
||||||
|
Url: https://moin.conectiva.com.br/AptRpm
|
||||||
Packager: APT Development Team <apt@packages.altlinux.org>
|
Packager: APT Development Team <apt@packages.altlinux.org>
|
||||||
|
|
||||||
%def_without static
|
|
||||||
|
|
||||||
Source0: http://moin.conectiva.com.br/files/AptRpm/attachments/%name-%version.tar.bz2
|
Source0: http://moin.conectiva.com.br/files/AptRpm/attachments/%name-%version.tar.bz2
|
||||||
Source1: apt.conf
|
Source1: apt.conf
|
||||||
Source2: genbasedir
|
Source2: genbasedir
|
||||||
Source3: README.rsync
|
Source3: README.rsync
|
||||||
Source4: apt.8
|
Source4: apt.ru.po
|
||||||
Source5: apt.ru.po
|
Source5: ChangeLog-rpm.old
|
||||||
|
|
||||||
Patch1: apt-0.5.5cnc2-alt-distro.patch
|
Patch1: apt-0.5.15cnc5-alt-libtool.patch
|
||||||
Patch2: apt-0.5.5cnc2-alt-rpm.patch
|
|
||||||
Patch3: apt-0.5.4cnc9-alt-getsrc.patch
|
Patch11: apt-0.5.15cnc5-alt-fixes.patch
|
||||||
Patch4: apt-0.5.4cnc3-alt-md5hash-debug.patch
|
Patch12: apt-0.5.15cnc5-alt-tinfo.patch
|
||||||
Patch5: apt-0.5.4cnc9-alt-rsync.patch
|
Patch13: apt-0.5.15cnc5-alt-rpm-build.patch
|
||||||
Patch6: apt-0.5.5cnc4-alt-rpm_cmd.patch
|
Patch14: apt-0.5.15cnc5-alt-distro.patch
|
||||||
Patch7: apt-0.5.5cnc4.1-alt-rpm-fancypercent.patch
|
Patch15: apt-0.5.15cnc5-alt-debsystem.patch
|
||||||
Patch8: apt-0.5.5cnc1-alt-pkgpriorities.patch
|
Patch16: apt-0.5.15cnc5-alt-defaults.patch
|
||||||
Patch9: apt-0.5.4cnc9-alt-bz2.patch
|
Patch17: apt-0.5.5cnc5-alt-rsync.patch
|
||||||
Patch10: apt-0.5.4cnc9-alt-packagemanager-CheckRConflicts.patch
|
Patch18: apt-0.5.15cnc5-alt-getsrc.patch
|
||||||
Patch11: apt-0.5.5cnc4-alt-install_virtual.patch
|
Patch19: apt-0.5.15cnc5-alt-parseargs.patch
|
||||||
Patch12: apt-0.5.4cnc9-alt-install_virtual_version.patch
|
Patch20: apt-0.5.15cnc5-alt-rpm_cmd.patch
|
||||||
Patch13: apt-0.5.5cnc1-alt-methods_gpg_homedir.patch
|
Patch21: apt-0.5.15cnc5-alt-rpm-fancypercent.patch
|
||||||
Patch14: apt-0.5.4cnc9-alt-pkgorderlist_score.patch
|
Patch22: apt-0.5.15cnc5-alt-methods_gpg_homedir.patch
|
||||||
Patch15: apt-0.5.5cnc1-alt-debsystem.patch
|
Patch23: apt-0.5.15cnc5-alt-md5hash-debug.patch
|
||||||
Patch16: apt-0.5.5cnc3-alt-i18n-apt-cdrom.patch
|
Patch24: apt-0.5.15cnc5-alt-packagemanager-CheckRConflicts.patch
|
||||||
Patch17: apt-0.5.5cnc4-alt-tinfo.patch
|
Patch25: apt-0.5.5cnc4.1-alt-fixpriorsort.patch
|
||||||
Patch18: apt-cnc-20030322-algo.patch
|
Patch26: apt-0.5.4cnc9-alt-pkgorderlist_score.patch
|
||||||
Patch19: apt-0.5.5cnc4-alt-versionmatch.patch
|
Patch27: apt-0.5.15cnc5-alt-install_virtual.patch
|
||||||
Patch20: apt-0.5.5cnc4-alt-versionmatch2.patch
|
Patch28: apt-0.5.15cnc5-alt-virtual_scores.patch
|
||||||
Patch21: apt-0.5.5cnc4-alt-defaults.patch
|
|
||||||
Patch22: apt-0.5.5cnc4.1-alt-fixpriorsort.patch
|
|
||||||
Patch23: apt-0.5.5cnc4.1-alt-parseargs.patch
|
|
||||||
Patch24: apt-0.5.5cnc4.1-alt-virtual_scores.patch
|
|
||||||
|
|
||||||
# Need to be adopted. Or not?
|
|
||||||
Patch31: apt-0.3.19cnc53-stelian-apt-pkg-algorithms-scores.patch
|
|
||||||
# Normally not applied, but useful.
|
# Normally not applied, but useful.
|
||||||
Patch32: apt-0.5.4cnc9-alt-getsrc-debug.patch
|
Patch101: apt-0.5.4cnc9-alt-getsrc-debug.patch
|
||||||
# Obsolete.
|
|
||||||
Patch33: apt-0.5.4cnc3-alt-select-genlist.patch
|
|
||||||
|
|
||||||
PreReq: %__subst
|
PreReq: %__subst
|
||||||
Requires: libapt = %version-%release
|
Requires: libapt = %version-%release
|
||||||
Requires: %{get_dep rpm}, /etc/apt/pkgpriorities, apt-conf, gnupg, alt-gpgkeys
|
Requires: rpm >= 4.0.4-alt28, /etc/apt/pkgpriorities, apt-conf, gnupg, alt-gpgkeys
|
||||||
Obsoletes: apt-0.5
|
Obsoletes: apt-0.5
|
||||||
|
|
||||||
BuildPreReq: librpm-devel >= 4.0.4, rpm-build >= 4.0.4
|
# new rpmlib.
|
||||||
|
BuildPreReq: librpm-devel >= 4.0.4-alt28
|
||||||
|
|
||||||
# Automatically added by buildreq on Tue Mar 11 2003
|
# for docs.
|
||||||
BuildRequires: docbook-dtds docbook-utils gcc-c++ libreadline-devel librpm-devel libstdc++-devel libtinfo-devel openjade perl-SGMLSpm sgml-common xml-common
|
BuildPreReq: docbook-utils
|
||||||
|
|
||||||
|
%def_disable static
|
||||||
|
%{?_enable_static:BuildPreReq: glibc-devel-static}
|
||||||
|
|
||||||
|
# all the rest.
|
||||||
|
BuildPreReq: gcc-c++ libreadline-devel libstdc++-devel libtinfo-devel
|
||||||
|
|
||||||
%define risk_usage_en This package is still under development.
|
%define risk_usage_en This package is still under development.
|
||||||
|
|
||||||
@ -88,19 +86,20 @@ capability and several other unique features.
|
|||||||
Summary: APT's core libraries
|
Summary: APT's core libraries
|
||||||
Group: System/Libraries
|
Group: System/Libraries
|
||||||
Obsoletes: libapt-0.5
|
Obsoletes: libapt-0.5
|
||||||
|
PreReq: librpm >= 4.0.4-alt28
|
||||||
|
|
||||||
%package -n libapt-devel
|
%package -n libapt-devel
|
||||||
Summary: Development files and documentation for APT's core libs
|
Summary: Development files and documentation for APT's core libs
|
||||||
Summary(ru_RU.CP1251): Ôàéëû è äîêóìåíòàöèÿ äëÿ ðàçðàáîò÷èêîâ, èñïîëüçóþùèõ áèáëèîòåêè APT
|
Summary(ru_RU.CP1251): Ôàéëû è äîêóìåíòàöèÿ äëÿ ðàçðàáîò÷èêîâ, èñïîëüçóþùèõ áèáëèîòåêè APT
|
||||||
Group: Development/C
|
Group: Development/C
|
||||||
Requires: libapt = %version-%release
|
Requires: libapt = %version-%release, librpm-devel >= 4.0.4-alt28
|
||||||
Obsoletes: libapt-0.5-devel
|
Obsoletes: libapt-0.5-devel
|
||||||
|
|
||||||
%package -n libapt-devel-static
|
%package -n libapt-devel-static
|
||||||
Summary: Development static library for APT's libs
|
Summary: Development static library for APT's libs
|
||||||
Summary(ru_RU.CP1251): Ñòàòè÷åñêàÿ áèáëèîòåêà APT äëÿ ðàçðàáîò÷èêîâ, èñïîëüçóþùèõ áèáëèîòåêè APT
|
Summary(ru_RU.CP1251): Ñòàòè÷åñêàÿ áèáëèîòåêà APT äëÿ ðàçðàáîò÷èêîâ, èñïîëüçóþùèõ áèáëèîòåêè APT
|
||||||
Group: Development/C
|
Group: Development/C
|
||||||
Requires: libapt-devel = %version-%release
|
Requires: libapt-devel = %version-%release, librpm-devel-static >= 4.0.4-alt28
|
||||||
Obsoletes: libapt-0.5-devel-static
|
Obsoletes: libapt-0.5-devel-static
|
||||||
|
|
||||||
%package utils
|
%package utils
|
||||||
@ -109,7 +108,7 @@ Summary: Utilities to create APT repositaries (the indices)
|
|||||||
Summary(ru_RU.CP1251): Óòèëèòû äëÿ ïîñòðîåíèÿ APT-ðåïîçèòàðèåâ (èíäåêñîâ)
|
Summary(ru_RU.CP1251): Óòèëèòû äëÿ ïîñòðîåíèÿ APT-ðåïîçèòàðèåâ (èíäåêñîâ)
|
||||||
Group: Development/Other
|
Group: Development/Other
|
||||||
Requires: %name = %version-%release, mktemp >= 1:1.3.1, getopt
|
Requires: %name = %version-%release, mktemp >= 1:1.3.1, getopt
|
||||||
Requires: %{get_dep rpm}, gnupg, sed
|
Requires: gnupg, sed
|
||||||
Obsoletes: apt-0.5-utils
|
Obsoletes: apt-0.5-utils
|
||||||
|
|
||||||
%package rsync
|
%package rsync
|
||||||
@ -189,17 +188,8 @@ This package contains method 'rsync' for APT.
|
|||||||
%risk_usage
|
%risk_usage
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q -n apt-%version
|
%setup -q
|
||||||
%patch1 -p1
|
%patch1 -p1
|
||||||
%patch2 -p1
|
|
||||||
%patch3 -p1
|
|
||||||
%patch4 -p1
|
|
||||||
%patch5 -p1
|
|
||||||
%patch6 -p1
|
|
||||||
%patch7 -p1
|
|
||||||
%patch8 -p1
|
|
||||||
%patch9 -p1
|
|
||||||
%patch10 -p1
|
|
||||||
%patch11 -p1
|
%patch11 -p1
|
||||||
%patch12 -p1
|
%patch12 -p1
|
||||||
%patch13 -p1
|
%patch13 -p1
|
||||||
@ -214,85 +204,57 @@ This package contains method 'rsync' for APT.
|
|||||||
%patch22 -p1
|
%patch22 -p1
|
||||||
%patch23 -p1
|
%patch23 -p1
|
||||||
%patch24 -p1
|
%patch24 -p1
|
||||||
|
%patch25 -p1
|
||||||
|
%patch26 -p1
|
||||||
|
%patch27 -p1
|
||||||
|
%patch28 -p1
|
||||||
|
|
||||||
# Need to be adopted. Or not?
|
|
||||||
#%patch31 -p1
|
|
||||||
# Turn it on only if you want to see the debugging messages:
|
# Turn it on only if you want to see the debugging messages:
|
||||||
#%patch32 -p1 -b .getsrc-debug
|
#%patch101 -p1 -b .getsrc-debug
|
||||||
# Obsolete.
|
|
||||||
#%patch33 -p1
|
|
||||||
|
|
||||||
%__install -p -m644 %SOURCE3 %SOURCE4 .
|
%__install -p -m644 %SOURCE3 %SOURCE5 .
|
||||||
%__install -p -m644 %SOURCE5 po/ru.po
|
%__install -p -m644 %SOURCE4 po/ru.po
|
||||||
|
|
||||||
find -type f -name \*.orig -print -delete
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%add_optflags -fno-exceptions -D_GNU_SOURCE
|
|
||||||
pushd doc
|
|
||||||
[ -f apt.8 ] || %__install -p -m644 %SOURCE4 .
|
|
||||||
popd
|
|
||||||
|
|
||||||
# Fix gettextization.
|
|
||||||
if [ ! -s po/LINGUAS ]; then
|
|
||||||
%__sed -ne 's/^ALL_LINGUAS="\([^"]*\)"$/\1/p' configure.in >>po/LINGUAS
|
|
||||||
%__subst 's/^\(ALL_LINGUAS=\)/#\1/g' configure.in
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Fix url.
|
# Fix url.
|
||||||
%__subst -p 's,/usr/share/common-licenses/GPL,/usr/share/license/GPL,' COPYING
|
%__subst -p 's,/usr/share/common-licenses/GPL,/usr/share/license/GPL,' COPYING
|
||||||
|
|
||||||
libtoolize --copy --force
|
%__aclocal -I buildlib
|
||||||
aclocal -I buildlib
|
# rsync patch update only methods/Makefile.am so need to run automake
|
||||||
autoconf
|
%__automake
|
||||||
|
%__autoconf
|
||||||
|
|
||||||
%configure --with-proc-multiply=1 --with-procs=%__nprocs
|
# --disable-dependency-tracking Speeds up one-time builds
|
||||||
|
%configure --includedir=%_includedir/apt-pkg %{subst_enable static}
|
||||||
|
|
||||||
|
# Probably this obsolete now?
|
||||||
find -type f -print0 |
|
find -type f -print0 |
|
||||||
xargs -r0 %__grep -EZl '/var(/lib)?/state/apt' -- |
|
xargs -r0 %__grep -EZl '/var(/lib)?/state/apt' -- |
|
||||||
xargs -r0 %__subst 's,/var\(/lib\)\?/state/apt,%_localstatedir/apt,g' --
|
xargs -r0 %__subst -p 's,/var\(/lib\)\?/state/apt,%_localstatedir/%name,g' --
|
||||||
|
%make_build
|
||||||
%make clean
|
|
||||||
|
|
||||||
%make_build %{?_enable_static:STATICLIBS=1} NOISY=1
|
|
||||||
|
|
||||||
%install
|
%install
|
||||||
%__mkdir_p $RPM_BUILD_ROOT{%_bindir,%_libdir/apt,%_mandir/man{1,5,8},%_includedir/apt-pkg,%_includedir/apt-inst,%_sysconfdir/apt/{apt.conf,sources.list,vendors.list}.d}
|
%__mkdir_p %buildroot%_sysconfdir/%name/{%name.conf,sources.list,vendors.list}.d
|
||||||
%__mkdir_p $RPM_BUILD_ROOT%_localstatedir/apt/{lists/partial,prefetch}
|
%__mkdir_p %buildroot%_libdir/%name/scripts
|
||||||
%__mkdir_p $RPM_BUILD_ROOT/var/cache/apt/{archives/partial,gen{pkg,src}list}
|
%__mkdir_p %buildroot%_localstatedir/%name/{lists/partial,prefetch}
|
||||||
|
%__mkdir_p %buildroot%_cachedir/%name/{archives/partial,gen{pkg,src}list}
|
||||||
|
|
||||||
%__cp -a bin/lib*.so* $RPM_BUILD_ROOT%_libdir/
|
%makeinstall includedir=%buildroot%_includedir/apt-pkg
|
||||||
%if_enabled static
|
|
||||||
%__cp -a bin/lib*.a* $RPM_BUILD_ROOT%_libdir/
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%__install -p -m755 bin/methods/* $RPM_BUILD_ROOT%_libdir/apt/
|
%__install -p -m755 %SOURCE2 %buildroot%_bindir/
|
||||||
%__install -p -m755 bin/apt-* $RPM_BUILD_ROOT%_bindir/
|
%__install -p -m644 %SOURCE1 %buildroot%_sysconfdir/%name/
|
||||||
%__install -p -m755 bin/{%name-*,*list} %SOURCE2 $RPM_BUILD_ROOT%_bindir/
|
|
||||||
|
|
||||||
%__install -p -m644 apt-pkg/{,*/}*.h $RPM_BUILD_ROOT%_includedir/apt-pkg/
|
# This is still needed.
|
||||||
%__install -p -m644 apt-inst/{,*/}*.h $RPM_BUILD_ROOT%_includedir/apt-inst/
|
%__ln_s -f rsh %buildroot%_libdir/%name/methods/ssh
|
||||||
|
%__ln_s -f gzip %buildroot%_libdir/%name/methods/bzip2
|
||||||
|
|
||||||
%__install -p -m644 doc/*.1 $RPM_BUILD_ROOT%_man1dir/
|
# Cleanup
|
||||||
%__install -p -m644 doc/*.5 $RPM_BUILD_ROOT%_man5dir/
|
find %buildroot%_includedir -type f -name rpmshowprogress.h -print -delete
|
||||||
%__install -p -m644 doc/*.8 $RPM_BUILD_ROOT%_man8dir/
|
%__rm -f %buildroot%_libdir/*.la
|
||||||
|
|
||||||
%__install -p -m644 %SOURCE1 $RPM_BUILD_ROOT%_sysconfdir/apt/
|
%__bzip2 -9fk ChangeLog-rpm.old
|
||||||
|
|
||||||
%__ln_s -f rsh $RPM_BUILD_ROOT%_libdir/apt/ssh
|
%find_lang %name
|
||||||
%__ln_s -f gzip $RPM_BUILD_ROOT%_libdir/apt/bzip2
|
|
||||||
|
|
||||||
%__mkdir_p $RPM_BUILD_ROOT%_datadir
|
|
||||||
%__rm -rf $RPM_BUILD_ROOT%_datadir/locale
|
|
||||||
%__cp -a locale $RPM_BUILD_ROOT%_datadir/
|
|
||||||
|
|
||||||
%define docdir %_docdir/%name-%version
|
|
||||||
%__mkdir_p $RPM_BUILD_ROOT%docdir
|
|
||||||
%__cp -a README* TODO COPYING AUTHORS* doc/examples \
|
|
||||||
$RPM_BUILD_ROOT%docdir/
|
|
||||||
|
|
||||||
%find_lang --output=%name.lang \
|
|
||||||
apt libapt-pkg3.3
|
|
||||||
|
|
||||||
%triggerun -- apt < 0.5.4
|
%triggerun -- apt < 0.5.4
|
||||||
CONF=/etc/apt/apt.conf
|
CONF=/etc/apt/apt.conf
|
||||||
@ -305,30 +267,30 @@ fi
|
|||||||
|
|
||||||
%files -f %name.lang
|
%files -f %name.lang
|
||||||
%_bindir/apt-*
|
%_bindir/apt-*
|
||||||
%_libdir/apt
|
%_libdir/%name
|
||||||
%exclude %_libdir/apt/rsync
|
%exclude %_libdir/%name/methods/rsync
|
||||||
%dir %_sysconfdir/apt
|
%dir %_sysconfdir/%name
|
||||||
%config(noreplace) %_sysconfdir/apt/apt.conf
|
%config(noreplace) %_sysconfdir/%name/%name.conf
|
||||||
%dir %_sysconfdir/apt/*.d
|
%dir %_sysconfdir/%name/*.d
|
||||||
%_mandir/man?/*
|
%_mandir/man?/*
|
||||||
%docdir
|
%_localstatedir/%name
|
||||||
%_localstatedir/apt
|
%doc README* TODO COPYING AUTHORS* doc/examples ChangeLog-rpm.old.bz2
|
||||||
|
|
||||||
%defattr(2770,root,rpm,2770)
|
%defattr(2770,root,rpm,2770)
|
||||||
%_cachedir/apt/archives
|
%_cachedir/%name/archives
|
||||||
|
|
||||||
%files utils
|
%files utils
|
||||||
%_bindir/*
|
%_bindir/*
|
||||||
%exclude %_bindir/apt-*
|
%exclude %_bindir/apt-*
|
||||||
|
|
||||||
%defattr(2770,root,rpm,2770)
|
%defattr(2770,root,rpm,2770)
|
||||||
%_cachedir/apt/gen*list
|
%_cachedir/%name/gen*list
|
||||||
|
|
||||||
%files -n libapt
|
%files -n libapt
|
||||||
%_libdir/*.so.*
|
%_libdir/*.so.*
|
||||||
|
|
||||||
%defattr(2770,root,rpm,2770)
|
%defattr(2770,root,rpm,2770)
|
||||||
%dir %_cachedir/apt
|
%dir %_cachedir/%name
|
||||||
|
|
||||||
%files -n libapt-devel
|
%files -n libapt-devel
|
||||||
%_libdir/*.so
|
%_libdir/*.so
|
||||||
@ -340,25 +302,185 @@ fi
|
|||||||
%endif
|
%endif
|
||||||
|
|
||||||
%files rsync
|
%files rsync
|
||||||
%dir %_libdir/apt
|
%dir %_libdir/%name
|
||||||
%_libdir/apt/rsync
|
%dir %_libdir/%name/methods
|
||||||
|
%_libdir/%name/methods/rsync
|
||||||
|
# Probably %%doc with README.rsync?
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
* Sun Sep 28 2003 Dmitry V. Levin <ldv@altlinux.org> 0.5.5cnc4.1-alt7
|
* Fri Jan 16 2004 Dmitry V. Levin <ldv@altlinux.org> 0.5.15cnc5-alt1
|
||||||
- apt-pkg/rpm/rpmpm.cc(pkgRPMPM::ExecRPM): honor "quiet" option.
|
- Specfile cleanup.
|
||||||
- Additional sorting hacks for virtual packages (mouse).
|
- Rediffed patches.
|
||||||
|
- Fixed --help/--version segfault.
|
||||||
|
- Fixed some compilation warnings.
|
||||||
|
- Relocated methods to %_libdir/%name/methods/.
|
||||||
|
|
||||||
* Wed Sep 03 2003 Rider <rider@altlinux.ru> 0.5.5cnc4.1-alt6
|
* Thu Jan 15 2004 Dmitry V. Levin <ldv@altlinux.org> 0.5.15cnc5-alt0.3
|
||||||
- Fixed sorting of equal packages names with different versions (Mouse).
|
- Updated:
|
||||||
- Fixed parsing command line arguments (Mouse).
|
+ apt-0.5.15cnc5-alt-rpm
|
||||||
|
+ apt-0.5.15cnc5-alt-rpm-fancypercent
|
||||||
|
|
||||||
* Tue Jun 24 2003 Dmitry V. Levin <ldv@altlinux.org> 0.5.5cnc4.1-alt5
|
* Tue Jan 13 2004 Anton Kachalov <mouse@altlinux.ru> 0.5.15cnc5-alt0.2
|
||||||
- apt-get: Optimize pure virtual packages install.
|
- Updated and applied:
|
||||||
- libapt,apt-get: Use pkgVersioningSystem's CheckDep algorithm
|
+ apt-0.5.15cnc5-alt-install_virtual
|
||||||
for normal version match.
|
+ apt-0.5.15cnc5-alt-virtual_scores
|
||||||
- Changed some defaults in code rather then in /etc/apt.conf;
|
- Removed:
|
||||||
cleaned up /etc/apt.conf file.
|
+ apt-0.5.4cnc9-alt-install_virtual_version (merged upstream).
|
||||||
- Do not build static libraries by default.
|
|
||||||
|
* Fri Dec 26 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc5-alt0.1
|
||||||
|
- Updated to 0.5.15cnc4.
|
||||||
|
- Updated alt-rpm.patch.
|
||||||
|
|
||||||
|
* Tue Dec 09 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc4-alt0.2
|
||||||
|
- Updated and applied alt-getsrc.patch.
|
||||||
|
- Following patches still stay unapplied:
|
||||||
|
+ alt-install_virtual.patch
|
||||||
|
+ alt-install_virtual_version.patch
|
||||||
|
+ alt-virtual_scores.patch
|
||||||
|
|
||||||
|
* Mon Dec 08 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc4-alt0.1
|
||||||
|
- Updated to 0.5.15cnc4.
|
||||||
|
- Updated alt-distro.patch.
|
||||||
|
- Updated russian translation.
|
||||||
|
- Get rid of %_libdir/*.la files.
|
||||||
|
- Still have disabled patches.
|
||||||
|
|
||||||
|
* Tue Nov 25 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc3-alt0.1
|
||||||
|
- Updated to 0.5.15cnc3
|
||||||
|
- Temporary disabled patches:
|
||||||
|
+ apt-0.5.4cnc9-alt-getsrc.patch
|
||||||
|
+ apt-0.5.5cnc4-alt-install_virtual.patch
|
||||||
|
+ apt-0.5.5cnc4.1-alt-virtual_scores.patch
|
||||||
|
- Merged upstream patches:
|
||||||
|
+ apt-0.5.15cnc1-upstream-pinning-fix.patch
|
||||||
|
- NOTE:
|
||||||
|
+ this release can not be used with hasher (until we 'll
|
||||||
|
update temporary disabled patches);
|
||||||
|
+ all packages which uses libapt need to be rebuilt (library version
|
||||||
|
changed).
|
||||||
|
- TODO:
|
||||||
|
+ check and update our patches (most important);
|
||||||
|
+ update russian translation.
|
||||||
|
|
||||||
|
* Tue Nov 11 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc1-alt0.2
|
||||||
|
- added apt-0.5.15cnc1-upstream-pinning-fix.patch.
|
||||||
|
- Updated russian translation.
|
||||||
|
|
||||||
|
* Sat Nov 08 2003 Anton V. Denisov <avd@altlinux.org> 0.5.15cnc1-alt0.1
|
||||||
|
- Updated to 0.5.15cnc1, renumbered patches.
|
||||||
|
- Removed patches:
|
||||||
|
+ apt-0.5.5cnc5-panu-nodigest.patch
|
||||||
|
- Updated patches:
|
||||||
|
+ alt-distro.patch
|
||||||
|
+ alt-rpm_cmd.patch
|
||||||
|
+ alt-defaults.patch
|
||||||
|
- Merged upstream patches:
|
||||||
|
+ alt-bz2.patch
|
||||||
|
+ alt-versionmatch.patch
|
||||||
|
+ alt-versionmatch2.patch
|
||||||
|
+ alt-cleanups.patch
|
||||||
|
+ apt-0.5.12_apt-get_backports.patch
|
||||||
|
+ apt-0.5.12_apt-cache_backports.patch
|
||||||
|
+ apt-0.5.12_doc_backports.patch
|
||||||
|
+ apt-0.5.12_methods_backports.patch
|
||||||
|
+ apt-0.5.12_apt-pkg_backports.patch
|
||||||
|
+ apt-0.5.12_acqprogress_backports.patch
|
||||||
|
+ apt-0.5.12_tests_backports.patch
|
||||||
|
+ apt-0.5.14_apt_get_and_docs.patch
|
||||||
|
- Temporary disabled patches:
|
||||||
|
+ alt-install_virtual_version.patch (need to be updated by author)
|
||||||
|
- Following patches wasn't accepted by upstream (what to do with it?):
|
||||||
|
+ alt-packagemanager-CheckRConflicts.patch
|
||||||
|
+ alt-debsystem.patch
|
||||||
|
+ alt-install_virtual.patch
|
||||||
|
+ alt-fixpriorsort.patch
|
||||||
|
+ alt-rpm-fancypercent.patch
|
||||||
|
+ alt-virtual_scores.patch
|
||||||
|
+ alt-parseargs.patch
|
||||||
|
|
||||||
|
* Thu Oct 09 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.8
|
||||||
|
- added BuildRequires: python (fix build in hasher).
|
||||||
|
- partial merge with upstream APT (0.5.14):
|
||||||
|
+ apt-0.5.14_apt_get_and_docs.patch
|
||||||
|
|
||||||
|
* Wed Oct 08 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.7
|
||||||
|
- added apt-0.5.5cnc6-alt-cleanups.patch (fixed some compiler warnings)
|
||||||
|
- sync with apt-0.5.5cnc4.1-alt7:
|
||||||
|
+ updated alt-fixpriorsort.patch
|
||||||
|
+ updated alt-rpm-fancypercent.patch
|
||||||
|
+ updated alt-parseargs.patch (and update it for cnc6)
|
||||||
|
+ added alt-virtual_scores.patch
|
||||||
|
+ renamed spec file.
|
||||||
|
|
||||||
|
* Tue Oct 07 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.5
|
||||||
|
- partial merge with upstream APT (0.5.12):
|
||||||
|
+ apt-0.5.12_apt-cache_backports.patch
|
||||||
|
+ apt-0.5.12_apt-get_backports.patch
|
||||||
|
+ apt-0.5.12_doc_backports.patch
|
||||||
|
+ apt-0.5.12_methods_backports.patch
|
||||||
|
+ apt-0.5.12_apt-pkg_backports.patch
|
||||||
|
+ apt-0.5.12_acqprogress_backports.patch
|
||||||
|
+ apt-0.5.12_tests_backports.patch
|
||||||
|
|
||||||
|
* Mon Oct 06 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.4
|
||||||
|
- sync with apt-0.5.5cnc4.1-alt6:
|
||||||
|
+ added apt-0.5.5cnc4.1-alt-parseargs.patch
|
||||||
|
+ added apt-0.5.5cnc6-alt-fixpriorsort.patch
|
||||||
|
|
||||||
|
* Fri Sep 05 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.3
|
||||||
|
- s/$RPM_BUILD_ROOT/%%buildroot/g in spec file.
|
||||||
|
- Updated BuildRequires in Sisyphus (20030704) env.
|
||||||
|
- Updated russian translation.
|
||||||
|
- sync with apt-0.5.5cnc4.1-alt5:
|
||||||
|
+ added apt-0.5.5cnc4-alt-defaults.patch
|
||||||
|
+ cleaned up /etc/apt.conf file.
|
||||||
|
+ updated alt-install_virtual.patch
|
||||||
|
+ added apt-0.5.5cnc4-alt-versionmatch2.patch
|
||||||
|
+ do not build static libraries by default.
|
||||||
|
|
||||||
|
* Mon Jun 16 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc6-alt0.1
|
||||||
|
- Updated to 0.5.5cnc6.
|
||||||
|
- Re-added patches due to upstream changes:
|
||||||
|
+ alt-debsystem.patch (apt-pkg/deb/debsystem.cc was added again).
|
||||||
|
- Downgraded patches due to upstream changes:
|
||||||
|
+ alt-getsrc.patch (apt-pkg/deb/debsrcrecords.h was added again).
|
||||||
|
- Packaged directories:
|
||||||
|
+ Dir::Bin::scripts (/usr/lib/apt/scripts);
|
||||||
|
- Updated %%doc (contrib dir added).
|
||||||
|
|
||||||
|
* Fri Jun 06 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc5-alt0.5
|
||||||
|
- old changelog entries come back as rpm_old_changelog.
|
||||||
|
- updated %%find_lang call.
|
||||||
|
- added -I m4 for %%__aclocal call.
|
||||||
|
- more macroszification.
|
||||||
|
- My Mother birthday edition.
|
||||||
|
|
||||||
|
* Tue Jun 03 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc5-alt0.4
|
||||||
|
- %%install section reworked (%%makeinstall use).
|
||||||
|
- %%build section cleaned up.
|
||||||
|
- %%_libdir/*.la moved to libapt-devel subpackage.
|
||||||
|
- %name.8 removed from sources.
|
||||||
|
- Dropped obsolete old patches.
|
||||||
|
- Dropped old changelog entries.
|
||||||
|
|
||||||
|
* Tue Jun 03 2003 Anton V. Denisov <avd@altlinux.org> 0.5.5cnc5-alt0.3
|
||||||
|
- Updated to 0.5.5cnc5, renumbered patches.
|
||||||
|
- Added patches:
|
||||||
|
+ apt-0.5.5cnc5-panu-nodigest.patch
|
||||||
|
- Updated patches:
|
||||||
|
+ alt-getsrc
|
||||||
|
+ alt-rsync
|
||||||
|
+ alt-tinfo
|
||||||
|
+ alt-rpm (check this one)
|
||||||
|
- Removed patches due to upstream changes:
|
||||||
|
+ alt-debsystem
|
||||||
|
- Merged upstream patches:
|
||||||
|
+ alt-i18n-apt-cdrom
|
||||||
|
+ apt-cnc-20030322-algo
|
||||||
|
- Updated russian translation.
|
||||||
|
- Explicitly use autoconf-2.5 and automake-1.7 for build.
|
||||||
|
- Major changes in spec file (need more changes).
|
||||||
|
- Updated buildrequires (libbeecrypt-devel and glibc-devel-static added).
|
||||||
|
|
||||||
* Mon Apr 28 2003 Dmitry V. Levin <ldv@altlinux.org> 0.5.5cnc4.1-alt4
|
* Mon Apr 28 2003 Dmitry V. Levin <ldv@altlinux.org> 0.5.5cnc4.1-alt4
|
||||||
- apt-get: substitute virtual package with real one (mouse).
|
- apt-get: substitute virtual package with real one (mouse).
|
||||||
@ -589,414 +711,6 @@ fi
|
|||||||
- It's a just build for Deadalus - not for actual use.
|
- It's a just build for Deadalus - not for actual use.
|
||||||
- I just built it but not test yet.
|
- I just built it but not test yet.
|
||||||
|
|
||||||
* Wed Jun 10 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt6
|
|
||||||
- fixes in genbasedir from apt-utils:
|
|
||||||
+ srclist generation: now it correctly includes the information on produced
|
|
||||||
binaries (the list was empty before), and also correctly treats --mapi
|
|
||||||
(the fixed bug caused misbehaviour of 'apt-get source', in the "2nd branch
|
|
||||||
of DoSource()" as referenced by me in previous changelogs);
|
|
||||||
+ --flat option.
|
|
||||||
|
|
||||||
* Mon Jun 09 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt5
|
|
||||||
- renamed the 'build' subpackage to 'utils' (because there is already
|
|
||||||
an 'apt-build' project at freshmeat.net).
|
|
||||||
|
|
||||||
* Mon Jun 09 2002 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc55-alt4
|
|
||||||
- separate subpkg 'build': analoguous to rpm-build, contains teh utilities to
|
|
||||||
generate indices (as a consequence less dependencies of 'apt' pkg,
|
|
||||||
little size);
|
|
||||||
- fix the work of 'apt-get source' for source packages with multiple binaries
|
|
||||||
with help of feedback and debugging patches from Anton Denisov
|
|
||||||
<fire@kgpu.kamchatka.ru> (only the first branch of control flow in DoSource()
|
|
||||||
is fixed, but that should be enough for normal use).
|
|
||||||
|
|
||||||
* Tue Mar 26 2002 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc55-alt3
|
|
||||||
- Added librpm-4.0.4 build support.
|
|
||||||
- Built with librpm-4.0.4, updated buildrequires.
|
|
||||||
|
|
||||||
* Thu Mar 21 2002 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc55-alt2
|
|
||||||
- Added kernel-aureal and NVIDIA_kernel to default AllowedDupPkgs.
|
|
||||||
- Updated patch for pkgRPMPM::ExecRPM.
|
|
||||||
- Reenabled rsh method.
|
|
||||||
- Updated rpmpriorities.
|
|
||||||
- fixed genbasedir patch.
|
|
||||||
- Set explicit Packager tag.
|
|
||||||
- Dropped obsolete trigger.
|
|
||||||
- lib%name: Conflicts: %name < %%version-%%release.
|
|
||||||
- Renamed patches.
|
|
||||||
|
|
||||||
* Wed Mar 13 2002 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc55-alt1
|
|
||||||
- apt-0.3.19cnc55 integrated
|
|
||||||
- Fixed:
|
|
||||||
+ rpmpm-exec_rpm patch
|
|
||||||
+ genbasedir
|
|
||||||
- Removed:
|
|
||||||
+ rpmpm-nodeps patch (already upstream)
|
|
||||||
+ rsh method (already upstream)
|
|
||||||
|
|
||||||
* Mon Dec 10 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt6
|
|
||||||
- Fixed rpm --nodeps option usage in pkgRPMPM::ExecRPM (#0000215).
|
|
||||||
|
|
||||||
* Fri Nov 23 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt5
|
|
||||||
- Applied scoring algorithm patch (Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
- Updated package requires.
|
|
||||||
|
|
||||||
* Mon Nov 19 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt4
|
|
||||||
- Dropped outdated pofile (already upstream).
|
|
||||||
- Corrected "Executing RPM" message generation.
|
|
||||||
|
|
||||||
* Fri Nov 16 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc53-alt3
|
|
||||||
- Updated patches: genbasedir, configure-db3, i18n.
|
|
||||||
|
|
||||||
* Wed Nov 15 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc53-alt2
|
|
||||||
+ apt-0.3.19cnc53-2cl integrated. Most of our patches moved to upstream
|
|
||||||
- Fixed (from Conectiva's changelog):
|
|
||||||
+ fixed bug in mirror patch
|
|
||||||
+ cleaned up gen{pkg,src}list (Alexander Bokovoy <ab@altlinux.ru
|
|
||||||
+ fixed crash bug in genpkglist
|
|
||||||
+ configure.in patch to detect rpmdb (Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
+ * Skips correctly over empty package directories
|
|
||||||
+ * Adds the --bz2only argument which makes genbasedir
|
|
||||||
+ to generate only the .bz2 compressed versions of pkglist
|
|
||||||
+ and srclist (space gain...)
|
|
||||||
+ * Doesn't change the timestamps on pkglists/srclists if
|
|
||||||
+ the contents are not modified (making possible for example
|
|
||||||
+ to make several consecutive runs of genbasedir without
|
|
||||||
+ having the apt clients download the indexes again and again).
|
|
||||||
+ * Some minor cleanups (remove the temporary files in /tmp
|
|
||||||
+ at the end of the script etc).
|
|
||||||
+ (Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
+ cleanup patch for gensrclist (Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
+ fixed multi-arch pkg handling (Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
+ updated russian translation (Alexander Bokovoy <ab@altlinux.ru>
|
|
||||||
+ updated i18n (Dmitry Levin <ldv@alt-linux.org>)
|
|
||||||
+ replaced Apt::GPG::Pubring with Apt::GPG::PubringPath
|
|
||||||
also uses --homedir instead of --keyring in gpg
|
|
||||||
(Alexander Bokovoy <ab@altlinux.ru>)
|
|
||||||
+ patch to detect replaced (instead of just removed) packages
|
|
||||||
Dmitry Levin <ldv@alt-linux.org>
|
|
||||||
+ updated mirrors patch
|
|
||||||
+ Fixed mirrors infinite loop bug (closes: #4420).
|
|
||||||
+ Fixed error handling.
|
|
||||||
- Added:
|
|
||||||
+ added kernel-tape to default AllowedDupPkgs
|
|
||||||
+ added patch to fix bug in genbasedir with empty dirs
|
|
||||||
(Stelian Pop <stelian.pop@fr.alcove.com>)
|
|
||||||
+ added -K (RPM::Check-Signatures) option to verify rpm sigs
|
|
||||||
+ Added mirrors patch.
|
|
||||||
|
|
||||||
* Fri Nov 02 2001 Dmitry V. Levin <ldv@alt-linux.org> 0.3.19cnc52-alt6
|
|
||||||
- Initial build with rpm4.
|
|
||||||
|
|
||||||
* Thu Oct 04 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt5
|
|
||||||
- Fixed i18n support and probably smth else
|
|
||||||
(configure.in, config.h.in and i18n.h were broken, kojima sux).
|
|
||||||
- Implemented 18n for apt-pkg/rpm, updated POTFILES.in and russian translation.
|
|
||||||
|
|
||||||
* Mon Oct 01 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt4
|
|
||||||
- Removed "^(kernel|alsa)[0-9]*-headers" from RPM::HoldPkgs list.
|
|
||||||
- Added (experimental) replaced packages support.
|
|
||||||
|
|
||||||
* Fri Sep 07 2001 Ivan Zakharyaschev <imz@altlinux.ru> 0.3.19cnc52-alt3.1
|
|
||||||
- apt-cdrom fix (patch 6) reworked: apt-cdrom used to not detect a second
|
|
||||||
list file (srclist) if both (pkglist and srclist) were present in one
|
|
||||||
directory on the disk (in non-thorough mode); hopefully now it works how
|
|
||||||
we expect it to do.
|
|
||||||
|
|
||||||
* Thu Aug 09 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt3
|
|
||||||
- Libification.
|
|
||||||
- Reworked compilation options again: we add only '-fno-exceptions' now.
|
|
||||||
|
|
||||||
* Tue Aug 07 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc52-alt2
|
|
||||||
- More code cleanup in tools/gen{pkg,src}list.cc.
|
|
||||||
- Added %%optflags_nocpp to compilation options.
|
|
||||||
|
|
||||||
* Mon Aug 06 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc52-alt1
|
|
||||||
- cnc52, gcc 3 and Solaris fixes
|
|
||||||
- RPM4 check is disabled for the moment
|
|
||||||
- File method fix has been integrated into mainstream
|
|
||||||
- RPM::RemoveOptions, RPM::UpdateOptions have been added
|
|
||||||
- Generation of Package list fixed
|
|
||||||
|
|
||||||
* Thu Aug 02 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc51-alt4
|
|
||||||
- Added trigger for better apt-conf-* migration.
|
|
||||||
|
|
||||||
* Tue Jul 31 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc51-alt3
|
|
||||||
- Updated:
|
|
||||||
+ rpmpriorities,
|
|
||||||
+ AllowedDupPkgs,
|
|
||||||
+ HoldPkgs.
|
|
||||||
- Moved *.list to apt-conf-* packages.
|
|
||||||
|
|
||||||
* Fri Jul 20 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc51-alt2
|
|
||||||
- Fixed:
|
|
||||||
+ Bug in file method which prevented authentication from working correctly
|
|
||||||
|
|
||||||
* Fri Jul 20 2001 Alexander Bokovoy <ab@altlinux.ru> 0.3.19cnc51-alt1
|
|
||||||
- cnc51
|
|
||||||
|
|
||||||
* Wed Jun 27 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc46-alt2
|
|
||||||
- cnc46
|
|
||||||
- kernel(|24)-{headers,source} added to HoldPkgs
|
|
||||||
- REPOSITORIO-APT-HOWTO added (Portugal)
|
|
||||||
- AllowedDupPackages -> AllowedDupPkgs
|
|
||||||
|
|
||||||
* Thu Jun 07 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc38-alt4
|
|
||||||
- Various fixes in %_bindir/genbasedir.
|
|
||||||
|
|
||||||
* Thu May 17 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc38-alt3
|
|
||||||
- Fixed build.
|
|
||||||
- Updated rpmpriorities.
|
|
||||||
|
|
||||||
* Mon Apr 16 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc38-alt2
|
|
||||||
- More duplicate packages from kernel series allowed.
|
|
||||||
|
|
||||||
* Sun Apr 15 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc38-alt1
|
|
||||||
- cnc38
|
|
||||||
- Updated:
|
|
||||||
+ apt-cdrom now works correctly
|
|
||||||
+ default architecture has been changed to i586
|
|
||||||
+ ssh method as wrapper to rsh one
|
|
||||||
|
|
||||||
* Mon Mar 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc37-ipl3mdk
|
|
||||||
- Updated:
|
|
||||||
+ New patch for genbasedir to allow pass default key to GnuPG
|
|
||||||
|
|
||||||
* Sun Mar 18 2001 Dmitry V. Levin <ldv@altlinux.ru> 0.3.19cnc37-ipl2mdk
|
|
||||||
- Fixed:
|
|
||||||
+ Build/installation of manpages without yodl sources;
|
|
||||||
+ Uncompressed small patches.
|
|
||||||
- Updated:
|
|
||||||
+ AllowedDupPackages list according to new kernel naming scheme;
|
|
||||||
+ URLs to use new domain name.
|
|
||||||
|
|
||||||
* Sat Mar 17 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc37-ipl1mdk
|
|
||||||
- Fixed:
|
|
||||||
+ APT::GPG::Pubring renamed to APT::GPG::PubringPath
|
|
||||||
+ Pubring support patch changed to use --homedir instead of --keyring
|
|
||||||
- Updated:
|
|
||||||
+ APT cnc37
|
|
||||||
+ Fingerprint and repository sources changed to reflect ALT Linux
|
|
||||||
new public key ring
|
|
||||||
|
|
||||||
* Mon Feb 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc36-ipl4mdk
|
|
||||||
- Sisyphus source repository added to sources.list
|
|
||||||
|
|
||||||
* Mon Feb 19 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc36-ipl3mdk
|
|
||||||
- New version
|
|
||||||
|
|
||||||
* Fri Feb 16 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc35-ipl2mdk
|
|
||||||
- Static library compilation added
|
|
||||||
- Static library goes to apt-devel-static due sizes of library
|
|
||||||
|
|
||||||
* Thu Feb 15 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc35-ipl1mdk
|
|
||||||
- New version
|
|
||||||
- Rsh method from upstream apt-get ported
|
|
||||||
- Spec file follows libification of rpm now
|
|
||||||
|
|
||||||
* Mon Jan 22 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc32-ipl4mdk
|
|
||||||
- New upstream version
|
|
||||||
- Russian translation updated
|
|
||||||
- Rebuild with new RPM library
|
|
||||||
|
|
||||||
* Mon Jan 22 2001 Alexander Bokovoy <ab@avilink.net> 0.3.19cnc28-ipl1mdk
|
|
||||||
- New upstream version
|
|
||||||
- cnc28 still lacks correct GNUPG checking code, our patch is neccessary.
|
|
||||||
- Genbasedir slightly patched again.
|
|
||||||
|
|
||||||
* Sun Jan 21 2001 Alexander Bokovoy <ab@avilink.net> ipl11mdk
|
|
||||||
- Typo in methods/gpg.cc fixed.
|
|
||||||
|
|
||||||
* Sun Jan 21 2001 Alexander Bokovoy <ab@avilink.net> ipl10mdk
|
|
||||||
- APT::GPG::Pubring option to specify default gnupg public ring added to check
|
|
||||||
distributors' signs automatically via default pubring in RPM package
|
|
||||||
- ftp user password changed to IPL one.
|
|
||||||
|
|
||||||
* Tue Jan 09 2001 Dmitry V. Levin <ldv@fandra.org> 0.3.19cnc27-ipl7mdk
|
|
||||||
- Specfile cleanup.
|
|
||||||
|
|
||||||
* Mon Jan 08 2001 Alexander Bokovoy <ab@avilink.net> ipl5mdk
|
|
||||||
- genbasedir help message fixed
|
|
||||||
|
|
||||||
* Mon Jan 08 2001 Alexander Bokovoy <ab@avilink.net> ipl4mdk
|
|
||||||
- Integration with main IPL package:
|
|
||||||
- Russian translation for command line messages added
|
|
||||||
- Russian translation of package summary/description
|
|
||||||
|
|
||||||
* Thu Jan 04 2001 AEN <aen@logic.ru>
|
|
||||||
- Real Sisyphus URL & IPLabs Fingerptint added
|
|
||||||
- changed rpmpriorities
|
|
||||||
|
|
||||||
* Thu Jan 04 2001 AEN <aen@logic.ru>
|
|
||||||
- build for RE
|
|
||||||
|
|
||||||
* Tue Dec 12 2000 Frederic Lepied <flepied@mandrakesoft.com> 0.3.19cnc27-1mdk
|
|
||||||
- first mandrake version.
|
|
||||||
|
|
||||||
* Thu Dec 07 2000 Andreas Hasenack <andreas@conectiva.com>
|
|
||||||
- damn! Wrong URL in sources.list, atualizacoes.conectiva.com
|
|
||||||
doesn't exist, of course...
|
|
||||||
|
|
||||||
* Thu Dec 07 2000 Andreas Hasenack <andreas@conectiva.com>
|
|
||||||
- updated sources.list with new mirrors and new download tree
|
|
||||||
- removed (noreplace) for the sources.list file for this
|
|
||||||
upgrade. It will be easier for the user. The (noreplace)
|
|
||||||
should be back in place after this update as we expect no
|
|
||||||
further big modifications for that file, only new mirrors.
|
|
||||||
|
|
||||||
* Wed Dec 06 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- fixed prob in vendors.list
|
|
||||||
|
|
||||||
* Tue Dec 05 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc27
|
|
||||||
|
|
||||||
* Wed Nov 08 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc26
|
|
||||||
|
|
||||||
* Mon Nov 06 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc25
|
|
||||||
|
|
||||||
* Thu Nov 02 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc24
|
|
||||||
|
|
||||||
* Thu Nov 02 2000 Rud<E1> Moura <ruda@conectiva.com>
|
|
||||||
- updated source.list (again)
|
|
||||||
|
|
||||||
* Thu Nov 02 2000 Rud<E1> Moura <ruda@conectiva.com>
|
|
||||||
- updated source.list
|
|
||||||
|
|
||||||
* Wed Nov 01 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc23
|
|
||||||
- added cache directories for gen{pkg,src}list
|
|
||||||
- pt_BR manpages
|
|
||||||
|
|
||||||
* Tue Oct 31 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc22
|
|
||||||
- Requires -> PreReq in apt-devel
|
|
||||||
|
|
||||||
* Mon Oct 30 2000 Alfredo Kojima <kojima@conectiva.com>
|
|
||||||
- collapsed libapt-pkg-devel and -doc to apt-devel
|
|
||||||
|
|
||||||
* Mon Oct 30 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc21
|
|
||||||
|
|
||||||
* Sun Oct 29 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc20
|
|
||||||
|
|
||||||
* Sun Oct 29 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc19
|
|
||||||
- added gensrclist
|
|
||||||
- support for apt-get source
|
|
||||||
|
|
||||||
* Fri Oct 27 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc18
|
|
||||||
|
|
||||||
* Thu Oct 26 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc17
|
|
||||||
- new manpages
|
|
||||||
|
|
||||||
* Wed Oct 25 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc16
|
|
||||||
|
|
||||||
* Sun Oct 22 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc15
|
|
||||||
|
|
||||||
* Sat Oct 21 2000 Alfredo K. Kojima <kojima@conectiva.com.br>
|
|
||||||
- released version 0.3.19cnc14
|
|
||||||
|
|
||||||
* Thu Oct 19 2000 Claudio Matsuoka <claudio@conectiva.com>
|
|
||||||
- new upstream release: 0.3.9cnc13
|
|
||||||
|
|
||||||
* Tue Oct 17 2000 Eliphas Levy Theodoro <eliphas@conectiva.com>
|
|
||||||
- added rpmpriorities to filelist and install
|
|
||||||
|
|
||||||
* Tue Oct 17 2000 Claudio Matsuoka <claudio@conectiva.com>
|
|
||||||
- updated to 0.3.19cnc12
|
|
||||||
- fresh CVS snapshot including: support to Acquire::ComprExtension,
|
|
||||||
debug messages removed, fixed apt-cdrom, RPM DB path, rpmlib call
|
|
||||||
in pkgRpmLock::Close(), package priority kludge removed, i18n
|
|
||||||
improvements, and genbasedir/genpkglist updates.
|
|
||||||
- handling language setting in genpkglist to make aptitude happy
|
|
||||||
|
|
||||||
* Wed Oct 11 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc11
|
|
||||||
- fixed problem with shard lib symlinks
|
|
||||||
|
|
||||||
* Tue Oct 10 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc10
|
|
||||||
|
|
||||||
* Mon Oct 2 2000 Claudio Matsuoka <claudio@conectiva.com>
|
|
||||||
- fixed brown paper bag bug with method permissions
|
|
||||||
- added parameter --sign to genbasedir
|
|
||||||
- added html/text doc files
|
|
||||||
|
|
||||||
* Sat Sep 30 2000 Claudio Matsuoka <claudio@conectiva.com>
|
|
||||||
- bumped to 0.3.19cnc9
|
|
||||||
- added vendors.list
|
|
||||||
- added gpg method
|
|
||||||
- fixed minor stuff to make Aptitude work
|
|
||||||
- added missing manpages
|
|
||||||
- fixed shared libs
|
|
||||||
- split in apt, libapt-pkg, libapt-pkg-devel, libapt-pkg-doc
|
|
||||||
- rewrote genbasedir in shell script (original was in TCL)
|
|
||||||
- misc cosmetic changes
|
|
||||||
|
|
||||||
* Tue Sep 26 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc8
|
|
||||||
|
|
||||||
* Wed Sep 20 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc7
|
|
||||||
|
|
||||||
* Mon Sep 18 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc6
|
|
||||||
|
|
||||||
* Sat Sep 16 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc5
|
|
||||||
|
|
||||||
* Fri Sep 15 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc4
|
|
||||||
|
|
||||||
* Mon Sep 12 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- released version 0.3.19cnc3
|
|
||||||
|
|
||||||
* Mon Sep 5 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- renamed package to apt, with version 0.3.19cncV
|
|
||||||
|
|
||||||
* Mon Sep 5 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- 0.10
|
|
||||||
- added genpkglist and rapt-config
|
|
||||||
- program names changed back to apt-*
|
|
||||||
|
|
||||||
* Mon Sep 4 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- 0.9
|
|
||||||
|
|
||||||
* Mon Sep 4 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- 0.8
|
|
||||||
|
|
||||||
* Mon Sep 4 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- 0.7
|
|
||||||
|
|
||||||
* Fri Sep 1 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- fixed typo in sources.list
|
|
||||||
|
|
||||||
* Tue Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- version 0.6
|
|
||||||
|
|
||||||
* Tue Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- version 0.5
|
|
||||||
|
|
||||||
* Tue Aug 31 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- version 0.4
|
|
||||||
|
|
||||||
* Wed Aug 30 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- version 0.3
|
|
||||||
|
|
||||||
* Thu Aug 28 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- second try. new release with direct hdlist handling
|
|
||||||
|
|
||||||
* Thu Aug 10 2000 Alfredo K. Kojima <kojima@conectiva.com>
|
|
||||||
- initial package creation. Yeah, it's totally broken for sure.
|
|
||||||
|
|
||||||
# Local Variables:
|
# Local Variables:
|
||||||
# compile-command: "rpmbuild -ba --target=i586 apt.spec"
|
# compile-command: "rpmbuild -ba --target=i586 apt.spec"
|
||||||
# End:
|
# End:
|
||||||
|
435
apt/ABOUT-NLS
Normal file
435
apt/ABOUT-NLS
Normal file
@ -0,0 +1,435 @@
|
|||||||
|
Notes on the Free Translation Project
|
||||||
|
*************************************
|
||||||
|
|
||||||
|
Free software is going international! The Free Translation Project
|
||||||
|
is a way to get maintainers of free software, translators, and users all
|
||||||
|
together, so that will gradually become able to speak many languages.
|
||||||
|
A few packages already provide translations for their messages.
|
||||||
|
|
||||||
|
If you found this `ABOUT-NLS' file inside a distribution, you may
|
||||||
|
assume that the distributed package does use GNU `gettext' internally,
|
||||||
|
itself available at your nearest GNU archive site. But you do _not_
|
||||||
|
need to install GNU `gettext' prior to configuring, installing or using
|
||||||
|
this package with messages translated.
|
||||||
|
|
||||||
|
Installers will find here some useful hints. These notes also
|
||||||
|
explain how users should proceed for getting the programs to use the
|
||||||
|
available translations. They tell how people wanting to contribute and
|
||||||
|
work at translations should contact the appropriate team.
|
||||||
|
|
||||||
|
When reporting bugs in the `intl/' directory or bugs which may be
|
||||||
|
related to internationalization, you should tell about the version of
|
||||||
|
`gettext' which is used. The information can be found in the
|
||||||
|
`intl/VERSION' file, in internationalized packages.
|
||||||
|
|
||||||
|
Quick configuration advice
|
||||||
|
==========================
|
||||||
|
|
||||||
|
If you want to exploit the full power of internationalization, you
|
||||||
|
should configure it using
|
||||||
|
|
||||||
|
./configure --with-included-gettext
|
||||||
|
|
||||||
|
to force usage of internationalizing routines provided within this
|
||||||
|
package, despite the existence of internationalizing capabilities in the
|
||||||
|
operating system where this package is being installed. So far, only
|
||||||
|
the `gettext' implementation in the GNU C library version 2 provides as
|
||||||
|
many features (such as locale alias, message inheritance, automatic
|
||||||
|
charset conversion or plural form handling) as the implementation here.
|
||||||
|
It is also not possible to offer this additional functionality on top
|
||||||
|
of a `catgets' implementation. Future versions of GNU `gettext' will
|
||||||
|
very likely convey even more functionality. So it might be a good idea
|
||||||
|
to change to GNU `gettext' as soon as possible.
|
||||||
|
|
||||||
|
So you need _not_ provide this option if you are using GNU libc 2 or
|
||||||
|
you have installed a recent copy of the GNU gettext package with the
|
||||||
|
included `libintl'.
|
||||||
|
|
||||||
|
INSTALL Matters
|
||||||
|
===============
|
||||||
|
|
||||||
|
Some packages are "localizable" when properly installed; the
|
||||||
|
programs they contain can be made to speak your own native language.
|
||||||
|
Most such packages use GNU `gettext'. Other packages have their own
|
||||||
|
ways to internationalization, predating GNU `gettext'.
|
||||||
|
|
||||||
|
By default, this package will be installed to allow translation of
|
||||||
|
messages. It will automatically detect whether the system already
|
||||||
|
provides the GNU `gettext' functions. If not, the GNU `gettext' own
|
||||||
|
library will be used. This library is wholly contained within this
|
||||||
|
package, usually in the `intl/' subdirectory, so prior installation of
|
||||||
|
the GNU `gettext' package is _not_ required. Installers may use
|
||||||
|
special options at configuration time for changing the default
|
||||||
|
behaviour. The commands:
|
||||||
|
|
||||||
|
./configure --with-included-gettext
|
||||||
|
./configure --disable-nls
|
||||||
|
|
||||||
|
will respectively bypass any pre-existing `gettext' to use the
|
||||||
|
internationalizing routines provided within this package, or else,
|
||||||
|
_totally_ disable translation of messages.
|
||||||
|
|
||||||
|
When you already have GNU `gettext' installed on your system and run
|
||||||
|
configure without an option for your new package, `configure' will
|
||||||
|
probably detect the previously built and installed `libintl.a' file and
|
||||||
|
will decide to use this. This might be not what is desirable. You
|
||||||
|
should use the more recent version of the GNU `gettext' library. I.e.
|
||||||
|
if the file `intl/VERSION' shows that the library which comes with this
|
||||||
|
package is more recent, you should use
|
||||||
|
|
||||||
|
./configure --with-included-gettext
|
||||||
|
|
||||||
|
to prevent auto-detection.
|
||||||
|
|
||||||
|
The configuration process will not test for the `catgets' function
|
||||||
|
and therefore it will not be used. The reason is that even an
|
||||||
|
emulation of `gettext' on top of `catgets' could not provide all the
|
||||||
|
extensions of the GNU `gettext' library.
|
||||||
|
|
||||||
|
Internationalized packages have usually many `po/LL.po' files, where
|
||||||
|
LL gives an ISO 639 two-letter code identifying the language. Unless
|
||||||
|
translations have been forbidden at `configure' time by using the
|
||||||
|
`--disable-nls' switch, all available translations are installed
|
||||||
|
together with the package. However, the environment variable `LINGUAS'
|
||||||
|
may be set, prior to configuration, to limit the installed set.
|
||||||
|
`LINGUAS' should then contain a space separated list of two-letter
|
||||||
|
codes, stating which languages are allowed.
|
||||||
|
|
||||||
|
Using This Package
|
||||||
|
==================
|
||||||
|
|
||||||
|
As a user, if your language has been installed for this package, you
|
||||||
|
only have to set the `LANG' environment variable to the appropriate
|
||||||
|
`LL_CC' combination. Here `LL' is an ISO 639 two-letter language code,
|
||||||
|
and `CC' is an ISO 3166 two-letter country code. For example, let's
|
||||||
|
suppose that you speak German and live in Germany. At the shell
|
||||||
|
prompt, merely execute `setenv LANG de_DE' (in `csh'),
|
||||||
|
`export LANG; LANG=de_DE' (in `sh') or `export LANG=de_DE' (in `bash').
|
||||||
|
This can be done from your `.login' or `.profile' file, once and for
|
||||||
|
all.
|
||||||
|
|
||||||
|
You might think that the country code specification is redundant.
|
||||||
|
But in fact, some languages have dialects in different countries. For
|
||||||
|
example, `de_AT' is used for Austria, and `pt_BR' for Brazil. The
|
||||||
|
country code serves to distinguish the dialects.
|
||||||
|
|
||||||
|
The locale naming convention of `LL_CC', with `LL' denoting the
|
||||||
|
language and `CC' denoting the country, is the one use on systems based
|
||||||
|
on GNU libc. On other systems, some variations of this scheme are
|
||||||
|
used, such as `LL' or `LL_CC.ENCODING'. You can get the list of
|
||||||
|
locales supported by your system for your country by running the command
|
||||||
|
`locale -a | grep '^LL''.
|
||||||
|
|
||||||
|
Not all programs have translations for all languages. By default, an
|
||||||
|
English message is shown in place of a nonexistent translation. If you
|
||||||
|
understand other languages, you can set up a priority list of languages.
|
||||||
|
This is done through a different environment variable, called
|
||||||
|
`LANGUAGE'. GNU `gettext' gives preference to `LANGUAGE' over `LANG'
|
||||||
|
for the purpose of message handling, but you still need to have `LANG'
|
||||||
|
set to the primary language; this is required by other parts of the
|
||||||
|
system libraries. For example, some Swedish users who would rather
|
||||||
|
read translations in German than English for when Swedish is not
|
||||||
|
available, set `LANGUAGE' to `sv:de' while leaving `LANG' to `sv_SE'.
|
||||||
|
|
||||||
|
In the `LANGUAGE' environment variable, but not in the `LANG'
|
||||||
|
environment variable, `LL_CC' combinations can be abbreviated as `LL'
|
||||||
|
to denote the language's main dialect. For example, `de' is equivalent
|
||||||
|
to `de_DE' (German as spoken in Germany), and `pt' to `pt_PT'
|
||||||
|
(Portuguese as spoken in Portugal) in this context.
|
||||||
|
|
||||||
|
Translating Teams
|
||||||
|
=================
|
||||||
|
|
||||||
|
For the Free Translation Project to be a success, we need interested
|
||||||
|
people who like their own language and write it well, and who are also
|
||||||
|
able to synergize with other translators speaking the same language.
|
||||||
|
Each translation team has its own mailing list. The up-to-date list of
|
||||||
|
teams can be found at the Free Translation Project's homepage,
|
||||||
|
`http://www.iro.umontreal.ca/contrib/po/HTML/', in the "National teams"
|
||||||
|
area.
|
||||||
|
|
||||||
|
If you'd like to volunteer to _work_ at translating messages, you
|
||||||
|
should become a member of the translating team for your own language.
|
||||||
|
The subscribing address is _not_ the same as the list itself, it has
|
||||||
|
`-request' appended. For example, speakers of Swedish can send a
|
||||||
|
message to `sv-request@li.org', having this message body:
|
||||||
|
|
||||||
|
subscribe
|
||||||
|
|
||||||
|
Keep in mind that team members are expected to participate
|
||||||
|
_actively_ in translations, or at solving translational difficulties,
|
||||||
|
rather than merely lurking around. If your team does not exist yet and
|
||||||
|
you want to start one, or if you are unsure about what to do or how to
|
||||||
|
get started, please write to `translation@iro.umontreal.ca' to reach the
|
||||||
|
coordinator for all translator teams.
|
||||||
|
|
||||||
|
The English team is special. It works at improving and uniformizing
|
||||||
|
the terminology in use. Proven linguistic skill are praised more than
|
||||||
|
programming skill, here.
|
||||||
|
|
||||||
|
Available Packages
|
||||||
|
==================
|
||||||
|
|
||||||
|
Languages are not equally supported in all packages. The following
|
||||||
|
matrix shows the current state of internationalization, as of August
|
||||||
|
2002. The matrix shows, in regard of each package, for which languages
|
||||||
|
PO files have been submitted to translation coordination, with a
|
||||||
|
translation percentage of at least 50%.
|
||||||
|
|
||||||
|
Ready PO files be bg ca cs da de el en eo es et fi fr
|
||||||
|
+----------------------------------------+
|
||||||
|
a2ps | [] [] [] [] |
|
||||||
|
ap-utils | |
|
||||||
|
bash | [] [] [] [] |
|
||||||
|
bfd | [] [] |
|
||||||
|
binutils | [] [] |
|
||||||
|
bison | [] [] [] [] |
|
||||||
|
clisp | |
|
||||||
|
clisp | [] [] [] [] |
|
||||||
|
clisplow | |
|
||||||
|
cpio | [] [] [] [] |
|
||||||
|
darkstat | () |
|
||||||
|
diffutils | [] [] [] [] [] [] |
|
||||||
|
enscript | [] [] |
|
||||||
|
error | [] [] [] |
|
||||||
|
fetchmail | [] () [] [] [] () |
|
||||||
|
fileutils | [] [] [] [] [] |
|
||||||
|
findutils | [] [] [] [] [] [] |
|
||||||
|
flex | [] [] [] [] [] |
|
||||||
|
gas | [] [] |
|
||||||
|
gawk | [] [] [] |
|
||||||
|
gcal | [] [] |
|
||||||
|
gcc | [] [] |
|
||||||
|
gettext | [] [] [] [] [] |
|
||||||
|
gnupg | [] [] [] [] [] [] [] |
|
||||||
|
gprof | [] [] |
|
||||||
|
gpsdrive | () () () () () |
|
||||||
|
grep | [] [] [] [] [] [] [] [] |
|
||||||
|
gretl | [] |
|
||||||
|
gthumb | () () () |
|
||||||
|
hello | [] [] [] [] [] [] [] [] [] |
|
||||||
|
id-utils | [] [] [] |
|
||||||
|
indent | [] [] [] [] [] |
|
||||||
|
jpilot | () [] [] [] |
|
||||||
|
jwhois | [] [] |
|
||||||
|
kbd | [] [] [] |
|
||||||
|
ld | [] [] |
|
||||||
|
libc | [] [] [] [] [] [] [] [] |
|
||||||
|
libiconv | [] [] [] [] |
|
||||||
|
lifelines | () () |
|
||||||
|
lilypond | [] [] |
|
||||||
|
lingoteach | [] [] |
|
||||||
|
lingoteach_lessons| () () |
|
||||||
|
lynx | [] [] [] [] [] |
|
||||||
|
m4 | [] [] [] [] [] |
|
||||||
|
make | [] [] [] [] |
|
||||||
|
man-db | [] () () [] () () |
|
||||||
|
mysecretdiary | [] [] [] |
|
||||||
|
nano | [] () [] [] [] [] |
|
||||||
|
nano_1_0 | [] () [] [] [] [] |
|
||||||
|
opcodes | [] [] [] |
|
||||||
|
parted | [] [] [] [] [] |
|
||||||
|
ptx | [] [] [] [] [] [] [] |
|
||||||
|
python | |
|
||||||
|
recode | [] [] [] [] [] [] |
|
||||||
|
sed | [] [] [] [] [] [] [] [] [] [] |
|
||||||
|
sh-utils | [] [] [] [] |
|
||||||
|
sharutils | [] [] [] [] [] [] [] |
|
||||||
|
sketch | () [] () |
|
||||||
|
soundtracker | [] [] [] |
|
||||||
|
sp | [] |
|
||||||
|
tar | [] [] [] [] [] [] |
|
||||||
|
texinfo | [] [] [] [] [] |
|
||||||
|
textutils | [] [] [] [] [] |
|
||||||
|
util-linux | [] [] [] [] [] [] |
|
||||||
|
vorbis-tools | [] |
|
||||||
|
wastesedge | |
|
||||||
|
wdiff | [] [] [] [] [] [] |
|
||||||
|
wget | [] [] [] [] [] [] [] [] [] [] |
|
||||||
|
+----------------------------------------+
|
||||||
|
be bg ca cs da de el en eo es et fi fr
|
||||||
|
0 2 19 10 30 44 9 1 12 44 17 6 53
|
||||||
|
|
||||||
|
gl he hr hu id it ja ko lv nb nl nn
|
||||||
|
+-------------------------------------+
|
||||||
|
a2ps | () () [] |
|
||||||
|
ap-utils | |
|
||||||
|
bash | [] |
|
||||||
|
bfd | [] |
|
||||||
|
binutils | [] |
|
||||||
|
bison | [] [] [] [] |
|
||||||
|
clisp | |
|
||||||
|
clisp | [] |
|
||||||
|
clisplow | |
|
||||||
|
cpio | [] [] [] [] |
|
||||||
|
darkstat | |
|
||||||
|
diffutils | [] [] [] [] [] |
|
||||||
|
enscript | [] [] |
|
||||||
|
error | [] |
|
||||||
|
fetchmail | [] |
|
||||||
|
fileutils | [] [] [] |
|
||||||
|
findutils | [] [] [] [] [] [] [] [] |
|
||||||
|
flex | [] |
|
||||||
|
gas | |
|
||||||
|
gawk | [] |
|
||||||
|
gcal | |
|
||||||
|
gcc | [] |
|
||||||
|
gettext | [] [] |
|
||||||
|
gnupg | [] [] [] [] |
|
||||||
|
gprof | [] |
|
||||||
|
gpsdrive | [] () () |
|
||||||
|
grep | [] [] [] [] [] [] [] |
|
||||||
|
gretl | |
|
||||||
|
gthumb | () () |
|
||||||
|
hello | [] [] [] [] [] [] [] [] [] [] [] [] |
|
||||||
|
id-utils | [] [] |
|
||||||
|
indent | [] [] [] [] |
|
||||||
|
jpilot | () () |
|
||||||
|
jwhois | [] [] |
|
||||||
|
kbd | |
|
||||||
|
ld | |
|
||||||
|
libc | [] [] [] [] |
|
||||||
|
libiconv | [] [] [] |
|
||||||
|
lifelines | |
|
||||||
|
lilypond | [] |
|
||||||
|
lingoteach | [] |
|
||||||
|
lingoteach_lessons| |
|
||||||
|
lynx | [] [] [] [] |
|
||||||
|
m4 | [] [] [] [] |
|
||||||
|
make | [] [] [] [] [] [] |
|
||||||
|
man-db | () () |
|
||||||
|
mysecretdiary | [] |
|
||||||
|
nano | [] [] [] [] |
|
||||||
|
nano_1_0 | [] [] [] [] [] |
|
||||||
|
opcodes | [] [] |
|
||||||
|
parted | [] [] [] |
|
||||||
|
ptx | [] [] [] [] [] |
|
||||||
|
python | |
|
||||||
|
recode | [] [] [] |
|
||||||
|
sed | [] [] [] [] [] [] [] [] |
|
||||||
|
sh-utils | [] [] [] |
|
||||||
|
sharutils | [] [] [] |
|
||||||
|
sketch | () |
|
||||||
|
soundtracker | [] [] |
|
||||||
|
sp | |
|
||||||
|
tar | [] [] [] [] [] [] |
|
||||||
|
texinfo | [] [] [] |
|
||||||
|
textutils | [] [] [] [] |
|
||||||
|
util-linux | () [] |
|
||||||
|
vorbis-tools | [] |
|
||||||
|
wastesedge | |
|
||||||
|
wdiff | [] [] [] |
|
||||||
|
wget | [] [] [] [] [] [] |
|
||||||
|
+-------------------------------------+
|
||||||
|
gl he hr hu id it ja ko lv nb nl nn
|
||||||
|
23 9 12 19 16 13 26 9 1 7 19 3
|
||||||
|
|
||||||
|
no pl pt pt_BR ru sk sl sv tr uk zh_CN zh_TW
|
||||||
|
+----------------------------------------------+
|
||||||
|
a2ps | () () () [] [] [] [] [] | 10
|
||||||
|
ap-utils | () | 0
|
||||||
|
bash | [] | 6
|
||||||
|
bfd | [] [] | 5
|
||||||
|
binutils | [] [] | 5
|
||||||
|
bison | [] [] [] [] | 12
|
||||||
|
clisp | | 0
|
||||||
|
clisp | | 5
|
||||||
|
clisplow | | 0
|
||||||
|
cpio | [] [] [] [] | 12
|
||||||
|
darkstat | [] [] () () | 2
|
||||||
|
diffutils | [] [] [] [] [] [] | 17
|
||||||
|
enscript | [] [] [] [] | 8
|
||||||
|
error | [] [] [] | 7
|
||||||
|
fetchmail | () () [] | 6
|
||||||
|
fileutils | [] [] [] [] [] [] | 14
|
||||||
|
findutils | [] [] [] [] [] [] [] | 21
|
||||||
|
flex | [] [] [] | 9
|
||||||
|
gas | [] | 3
|
||||||
|
gawk | [] [] | 6
|
||||||
|
gcal | [] [] | 4
|
||||||
|
gcc | [] | 4
|
||||||
|
gettext | [] [] [] [] [] [] | 13
|
||||||
|
gnupg | [] [] [] | 14
|
||||||
|
gprof | [] [] | 5
|
||||||
|
gpsdrive | [] [] | 3
|
||||||
|
grep | [] [] [] [] [] | 20
|
||||||
|
gretl | | 1
|
||||||
|
gthumb | () () [] | 1
|
||||||
|
hello | [] [] [] [] [] [] [] | 28
|
||||||
|
id-utils | [] [] [] [] | 9
|
||||||
|
indent | [] [] [] [] [] | 14
|
||||||
|
jpilot | () () [] [] | 5
|
||||||
|
jwhois | [] () () [] [] | 7
|
||||||
|
kbd | [] [] | 5
|
||||||
|
ld | [] [] | 4
|
||||||
|
libc | [] [] [] [] [] [] | 18
|
||||||
|
libiconv | [] [] [] [] [] | 12
|
||||||
|
lifelines | [] | 1
|
||||||
|
lilypond | [] | 4
|
||||||
|
lingoteach | [] [] | 5
|
||||||
|
lingoteach_lessons| () | 0
|
||||||
|
lynx | [] [] [] [] | 13
|
||||||
|
m4 | [] [] [] [] | 13
|
||||||
|
make | [] [] [] [] [] | 15
|
||||||
|
man-db | | 3
|
||||||
|
mysecretdiary | [] [] [] | 7
|
||||||
|
nano | [] [] [] [] | 13
|
||||||
|
nano_1_0 | [] [] [] [] | 14
|
||||||
|
opcodes | [] [] [] | 8
|
||||||
|
parted | [] [] [] [] | 12
|
||||||
|
ptx | [] [] [] [] [] [] [] | 19
|
||||||
|
python | | 0
|
||||||
|
recode | [] [] [] [] [] [] | 15
|
||||||
|
sed | [] [] [] [] [] [] | 24
|
||||||
|
sh-utils | [] [] | 9
|
||||||
|
sharutils | [] [] [] [] | 14
|
||||||
|
sketch | [] () [] | 4
|
||||||
|
soundtracker | [] | 6
|
||||||
|
sp | | 1
|
||||||
|
tar | [] [] [] [] [] [] [] | 19
|
||||||
|
texinfo | [] [] | 10
|
||||||
|
textutils | [] [] [] [] [] | 14
|
||||||
|
util-linux | [] [] [] | 10
|
||||||
|
vorbis-tools | [] | 3
|
||||||
|
wastesedge | | 0
|
||||||
|
wdiff | [] [] [] [] [] | 14
|
||||||
|
wget | [] [] [] [] [] [] [] [] | 24
|
||||||
|
+----------------------------------------------+
|
||||||
|
37 teams no pl pt pt_BR ru sk sl sv tr uk zh_CN zh_TW
|
||||||
|
68 domains 4 15 2 28 28 12 10 49 43 4 1 9 609
|
||||||
|
|
||||||
|
Some counters in the preceding matrix are higher than the number of
|
||||||
|
visible blocks let us expect. This is because a few extra PO files are
|
||||||
|
used for implementing regional variants of languages, or language
|
||||||
|
dialects.
|
||||||
|
|
||||||
|
For a PO file in the matrix above to be effective, the package to
|
||||||
|
which it applies should also have been internationalized and
|
||||||
|
distributed as such by its maintainer. There might be an observable
|
||||||
|
lag between the mere existence a PO file and its wide availability in a
|
||||||
|
distribution.
|
||||||
|
|
||||||
|
If August 2002 seems to be old, you may fetch a more recent copy of
|
||||||
|
this `ABOUT-NLS' file on most GNU archive sites. The most up-to-date
|
||||||
|
matrix with full percentage details can be found at
|
||||||
|
`http://www.iro.umontreal.ca/contrib/po/HTML/matrix.html'.
|
||||||
|
|
||||||
|
Using `gettext' in new packages
|
||||||
|
===============================
|
||||||
|
|
||||||
|
If you are writing a freely available program and want to
|
||||||
|
internationalize it you are welcome to use GNU `gettext' in your
|
||||||
|
package. Of course you have to respect the GNU Library General Public
|
||||||
|
License which covers the use of the GNU `gettext' library. This means
|
||||||
|
in particular that even non-free programs can use `libintl' as a shared
|
||||||
|
library, whereas only free software can use `libintl' as a static
|
||||||
|
library or use modified versions of `libintl'.
|
||||||
|
|
||||||
|
Once the sources are changed appropriately and the setup can handle
|
||||||
|
to use of `gettext' the only thing missing are the translations. The
|
||||||
|
Free Translation Project is also available for packages which are not
|
||||||
|
developed inside the GNU project. Therefore the information given above
|
||||||
|
applies also for every other Free Software Project. Contact
|
||||||
|
`translation@iro.umontreal.ca' to make the `.pot' files available to
|
||||||
|
the translation teams.
|
||||||
|
|
@ -1,83 +0,0 @@
|
|||||||
General Information
|
|
||||||
~~~~~~~~~~~~~~~~~~~
|
|
||||||
To compile this you need a couple things
|
|
||||||
- A working POSIX system with working POSIX gcc, g++, make (GNU),
|
|
||||||
ar, sh, awk and sed in the path
|
|
||||||
- GNU Make 3.74 or so, -- normal UNIX make will NOT work
|
|
||||||
* Note 3.77 is broken.
|
|
||||||
- A working ANSI C++ compiler, this is not g++ 2.7.*
|
|
||||||
g++ 2.8 works OK and newer egcs work well also. Nobody has tried it
|
|
||||||
on other compilers :< You will need a properly working STL as well.
|
|
||||||
- A C library with the usual POSIX functions and a BSD socket layer.
|
|
||||||
If you OS conforms to the Single Unix Spec then you are fine:
|
|
||||||
http://www.opengroup.org/onlinepubs/7908799/index.html
|
|
||||||
|
|
||||||
** NOTICE **
|
|
||||||
The C++ global constructors do not link correctly when using non-shared
|
|
||||||
libaries. This is probably the correct behavior of the linker, but I have
|
|
||||||
not yet had time to devise a work around for it. The correct thing to
|
|
||||||
do is add a reference to debSystem in apt-pkg/init.cc,
|
|
||||||
assert(&debSystem == 0) would be fine for instance.
|
|
||||||
|
|
||||||
Guidelines
|
|
||||||
~~~~~~~~~~
|
|
||||||
I am not interested in making 'ultra portable code'. I will accept patches
|
|
||||||
to make the code that already exists conform more to SUS or POSIX, but
|
|
||||||
I don't really care if your not-SUS OS doesn't work. It is simply too
|
|
||||||
much work to maintain patches for dysfunctional OSs. I highly suggest you
|
|
||||||
contact your vendor and express intrest in a conforming C library.
|
|
||||||
|
|
||||||
That said, there are lots of finniky problems that must be delt with even
|
|
||||||
between the supported OS's. Primarily the path I choose to take is to put
|
|
||||||
a shim header file in build/include that transparently adds the required
|
|
||||||
functionality. Patches to make autoconf detect these cases and generate the
|
|
||||||
required shims are OK.
|
|
||||||
|
|
||||||
Current shims:
|
|
||||||
* C99 integer types 'inttypes.h'
|
|
||||||
* sys/statvfs.h to convert from BSD/old-glibc statfs to SUS statvfs
|
|
||||||
* rfc2553 hostname resolution (methods/rfc*), shims to normal gethostbyname.
|
|
||||||
The more adventerous could steal the KAME IPv6 enabled resolvers for those
|
|
||||||
OS's with IPv6 support but no rfc2553 (why?)
|
|
||||||
* define _XOPEN_EXTENDED_SOURCE to bring in h_errno on HP-UX
|
|
||||||
* socklen_t shim in netdb.h if the OS does not have socklen_t
|
|
||||||
|
|
||||||
The only completely non-shimed OS is Linux with glibc2.1, glibc2.0 requires
|
|
||||||
the first three shims.
|
|
||||||
|
|
||||||
Platform Notes
|
|
||||||
~~~~~~~~~~~~~~
|
|
||||||
Debian GNU Linux 2.1 'slink'
|
|
||||||
Debian GNU Linux 'potato'
|
|
||||||
Debian GNU Linux 'woody'
|
|
||||||
* All Archs
|
|
||||||
- Works flawlessly
|
|
||||||
- You will want to have debiandoc-sgml and docbook2man installed to get
|
|
||||||
best results.
|
|
||||||
- No IPv6 Support in glibc's < 2.1.
|
|
||||||
|
|
||||||
Sun Solaris
|
|
||||||
SunOS cab101 5.7 Generic_106541-04 sun4u sparc
|
|
||||||
SunOS csu201 5.8 Generic_108528-04 sun4u sparc
|
|
||||||
- Works fine
|
|
||||||
- Note, no IPv6 Support, OS lacks RFC 2553 hostname resolution
|
|
||||||
|
|
||||||
OpenBSD
|
|
||||||
OpenBSD gsb086 2.5 CMPUT#0 i386 unknown
|
|
||||||
OpenBSD csu101 2.7 CMPUT#1 i386 unknown
|
|
||||||
- OS needs 'ranlib' to generate the symbol table after 'ar'.. (not using
|
|
||||||
GNU ar with the gnu tool chain :<)
|
|
||||||
- '2.5' does not have RFC 2553 hostname resolution, but '2.7' does
|
|
||||||
- Testing on '2.7' suggests the OS has a bug in its handling of
|
|
||||||
ftruncate on files that have been written via mmap. It fills the page
|
|
||||||
that crosses the truncation boundary with 0's.
|
|
||||||
|
|
||||||
HP-UX
|
|
||||||
HP-UX nyquist B.10.20 C 9000/780 2016574337 32-user license
|
|
||||||
- Evil OS, does not conform very well to SUS
|
|
||||||
1) snprintf exists but is not prototyped, ignore spurios warnings
|
|
||||||
2) No socklen_t
|
|
||||||
3) Requires -D_XOPEN_SOURCE_EXTENDED for h_errno
|
|
||||||
configure should fix the last two (see above)
|
|
||||||
- Note, no IPv6 Support, OS lacks RFC 2553 hostname resolution
|
|
||||||
|
|
36
apt/Makefile
36
apt/Makefile
@ -1,36 +0,0 @@
|
|||||||
# -*- make -*-
|
|
||||||
|
|
||||||
# This is the top level make file for APT, it recurses to each lower
|
|
||||||
# level make file and runs it with the proper target
|
|
||||||
ifndef NOISY
|
|
||||||
.SILENT:
|
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: default
|
|
||||||
default: startup all
|
|
||||||
|
|
||||||
.PHONY: headers library clean veryclean all binary program doc
|
|
||||||
all headers library clean veryclean binary program doc dirs:
|
|
||||||
# CNC:2003-02-15
|
|
||||||
$(MAKE) -C apt-pkg $@
|
|
||||||
#$(MAKE) -C apt-inst $@
|
|
||||||
$(MAKE) -C methods $@
|
|
||||||
$(MAKE) -C cmdline $@
|
|
||||||
#$(MAKE) -C ftparchive $@
|
|
||||||
#$(MAKE) -C dselect $@
|
|
||||||
$(MAKE) -C doc $@
|
|
||||||
$(MAKE) -C tools $@
|
|
||||||
$(MAKE) -C po $@
|
|
||||||
|
|
||||||
# Some very common aliases
|
|
||||||
.PHONY: maintainer-clean dist-clean distclean pristine sanity
|
|
||||||
maintainer-clean dist-clean distclean pristine sanity: veryclean
|
|
||||||
|
|
||||||
# The startup target builds the necessary configure scripts. It should
|
|
||||||
# be used after a CVS checkout.
|
|
||||||
CONVERTED=environment.mak include/config.h include/apti18n.h makefile
|
|
||||||
include buildlib/configure.mak
|
|
||||||
$(BUILDDIR)/include/config.h: buildlib/config.h.in
|
|
||||||
$(BUILDDIR)/include/apti18n.h: buildlib/apti18n.h.in
|
|
||||||
$(BUILDDIR)/environment.mak: buildlib/environment.mak.in
|
|
||||||
$(BUILDDIR)/makefile: buildlib/makefile.in
|
|
43
apt/Makefile.am
Normal file
43
apt/Makefile.am
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
|
||||||
|
SUBDIRS = buildlib intl lua apt-pkg methods cmdline tools doc m4 po
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I m4 -I buildlib
|
||||||
|
|
||||||
|
EXTRA_DIST = \
|
||||||
|
AUTHORS.RPM \
|
||||||
|
COPYING.GPL \
|
||||||
|
rpmpriorities \
|
||||||
|
test/conf.cc \
|
||||||
|
test/extract-control.cc \
|
||||||
|
test/hash.cc \
|
||||||
|
test/makefile \
|
||||||
|
test/mthdcat.cc \
|
||||||
|
test/rpmver.cc \
|
||||||
|
test/scratch.cc \
|
||||||
|
test/testdeb.cc \
|
||||||
|
test/testextract.cc \
|
||||||
|
test/uri.cc \
|
||||||
|
test/versions.lst \
|
||||||
|
test/versiontest.cc \
|
||||||
|
python/apt.i \
|
||||||
|
python/apt.py \
|
||||||
|
python/apt_wrap.cxx \
|
||||||
|
python/Makefile \
|
||||||
|
python/swig-1.3.16-cxx.patch \
|
||||||
|
contrib/apt-rpm/apt-rpm \
|
||||||
|
contrib/apt-rpm/apt-rpm.1 \
|
||||||
|
contrib/apt-files/README \
|
||||||
|
contrib/apt-files/apt-files.lua \
|
||||||
|
contrib/apt-files/apt-files.conf \
|
||||||
|
contrib/apt-files/convert.py \
|
||||||
|
contrib/install-devel/README \
|
||||||
|
contrib/install-devel/install-devel.lua \
|
||||||
|
contrib/apt-groupinstall/README \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.lua \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.py \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.conf \
|
||||||
|
contrib/proxypasswd/README \
|
||||||
|
contrib/proxypasswd/proxypasswd.lua
|
||||||
|
contrib/guess/README \
|
||||||
|
contrib/guess/guess.lua \
|
||||||
|
contrib/guess/guess.conf
|
637
apt/Makefile.in
Normal file
637
apt/Makefile.in
Normal file
@ -0,0 +1,637 @@
|
|||||||
|
# Makefile.in generated by automake 1.7.9 from Makefile.am.
|
||||||
|
# @configure_input@
|
||||||
|
|
||||||
|
# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003
|
||||||
|
# Free Software Foundation, Inc.
|
||||||
|
# This Makefile.in is free software; the Free Software Foundation
|
||||||
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
||||||
|
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
||||||
|
# PARTICULAR PURPOSE.
|
||||||
|
|
||||||
|
@SET_MAKE@
|
||||||
|
|
||||||
|
srcdir = @srcdir@
|
||||||
|
top_srcdir = @top_srcdir@
|
||||||
|
VPATH = @srcdir@
|
||||||
|
pkgdatadir = $(datadir)/@PACKAGE@
|
||||||
|
pkglibdir = $(libdir)/@PACKAGE@
|
||||||
|
pkgincludedir = $(includedir)/@PACKAGE@
|
||||||
|
top_builddir = .
|
||||||
|
|
||||||
|
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
||||||
|
INSTALL = @INSTALL@
|
||||||
|
install_sh_DATA = $(install_sh) -c -m 644
|
||||||
|
install_sh_PROGRAM = $(install_sh) -c
|
||||||
|
install_sh_SCRIPT = $(install_sh) -c
|
||||||
|
INSTALL_HEADER = $(INSTALL_DATA)
|
||||||
|
transform = $(program_transform_name)
|
||||||
|
NORMAL_INSTALL = :
|
||||||
|
PRE_INSTALL = :
|
||||||
|
POST_INSTALL = :
|
||||||
|
NORMAL_UNINSTALL = :
|
||||||
|
PRE_UNINSTALL = :
|
||||||
|
POST_UNINSTALL = :
|
||||||
|
host_triplet = @host@
|
||||||
|
ACLOCAL = @ACLOCAL@
|
||||||
|
ALLOCA = @ALLOCA@
|
||||||
|
AMDEP_FALSE = @AMDEP_FALSE@
|
||||||
|
AMDEP_TRUE = @AMDEP_TRUE@
|
||||||
|
AMTAR = @AMTAR@
|
||||||
|
AUTOCONF = @AUTOCONF@
|
||||||
|
AUTOHEADER = @AUTOHEADER@
|
||||||
|
AUTOMAKE = @AUTOMAKE@
|
||||||
|
AWK = @AWK@
|
||||||
|
BUILD_INCLUDED_LIBINTL = @BUILD_INCLUDED_LIBINTL@
|
||||||
|
CATOBJEXT = @CATOBJEXT@
|
||||||
|
CC = @CC@
|
||||||
|
CCDEPMODE = @CCDEPMODE@
|
||||||
|
CFLAGS = @CFLAGS@
|
||||||
|
COMPILE_APTSHELL_FALSE = @COMPILE_APTSHELL_FALSE@
|
||||||
|
COMPILE_APTSHELL_TRUE = @COMPILE_APTSHELL_TRUE@
|
||||||
|
COMPILE_MANPAGES_FALSE = @COMPILE_MANPAGES_FALSE@
|
||||||
|
COMPILE_MANPAGES_TRUE = @COMPILE_MANPAGES_TRUE@
|
||||||
|
CPP = @CPP@
|
||||||
|
CPPFLAGS = @CPPFLAGS@
|
||||||
|
CXX = @CXX@
|
||||||
|
CXXDEPMODE = @CXXDEPMODE@
|
||||||
|
CXXFLAGS = @CXXFLAGS@
|
||||||
|
CYGPATH_W = @CYGPATH_W@
|
||||||
|
DATADIRNAME = @DATADIRNAME@
|
||||||
|
DEFS = @DEFS@
|
||||||
|
DEPDIR = @DEPDIR@
|
||||||
|
DOCBOOK2MAN = @DOCBOOK2MAN@
|
||||||
|
ECHO = @ECHO@
|
||||||
|
ECHO_C = @ECHO_C@
|
||||||
|
ECHO_N = @ECHO_N@
|
||||||
|
ECHO_T = @ECHO_T@
|
||||||
|
EGREP = @EGREP@
|
||||||
|
EXEEXT = @EXEEXT@
|
||||||
|
GENCAT = @GENCAT@
|
||||||
|
GLIBC21 = @GLIBC21@
|
||||||
|
GLIBC_VER = @GLIBC_VER@
|
||||||
|
GMSGFMT = @GMSGFMT@
|
||||||
|
HAVE_TIMEGM = @HAVE_TIMEGM@
|
||||||
|
INSTALL_DATA = @INSTALL_DATA@
|
||||||
|
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
||||||
|
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
||||||
|
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
||||||
|
INSTOBJEXT = @INSTOBJEXT@
|
||||||
|
INTLBISON = @INTLBISON@
|
||||||
|
INTLLIBS = @INTLLIBS@
|
||||||
|
INTLOBJS = @INTLOBJS@
|
||||||
|
INTL_LIBTOOL_SUFFIX_PREFIX = @INTL_LIBTOOL_SUFFIX_PREFIX@
|
||||||
|
LDFLAGS = @LDFLAGS@
|
||||||
|
LIBICONV = @LIBICONV@
|
||||||
|
LIBINTL = @LIBINTL@
|
||||||
|
LIBOBJS = @LIBOBJS@
|
||||||
|
LIBS = @LIBS@
|
||||||
|
LIBSTDCPP_VER = @LIBSTDCPP_VER@
|
||||||
|
LIBTOOL = @LIBTOOL@
|
||||||
|
LN_S = @LN_S@
|
||||||
|
LTLIBICONV = @LTLIBICONV@
|
||||||
|
LTLIBINTL = @LTLIBINTL@
|
||||||
|
LTLIBOBJS = @LTLIBOBJS@
|
||||||
|
MAINT = @MAINT@
|
||||||
|
MAINTAINER_MODE_FALSE = @MAINTAINER_MODE_FALSE@
|
||||||
|
MAINTAINER_MODE_TRUE = @MAINTAINER_MODE_TRUE@
|
||||||
|
MAKEINFO = @MAKEINFO@
|
||||||
|
MKINSTALLDIRS = @MKINSTALLDIRS@
|
||||||
|
MSGFMT = @MSGFMT@
|
||||||
|
MSGMERGE = @MSGMERGE@
|
||||||
|
NEED_INTTYPES_H_FALSE = @NEED_INTTYPES_H_FALSE@
|
||||||
|
NEED_INTTYPES_H_TRUE = @NEED_INTTYPES_H_TRUE@
|
||||||
|
NEED_NETDB_H_FALSE = @NEED_NETDB_H_FALSE@
|
||||||
|
NEED_NETDB_H_TRUE = @NEED_NETDB_H_TRUE@
|
||||||
|
NEED_SOCKLEN_T_DEFINE = @NEED_SOCKLEN_T_DEFINE@
|
||||||
|
NEED_STATVFS_H_FALSE = @NEED_STATVFS_H_FALSE@
|
||||||
|
NEED_STATVFS_H_TRUE = @NEED_STATVFS_H_TRUE@
|
||||||
|
OBJEXT = @OBJEXT@
|
||||||
|
PACKAGE = @PACKAGE@
|
||||||
|
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
||||||
|
PACKAGE_NAME = @PACKAGE_NAME@
|
||||||
|
PACKAGE_STRING = @PACKAGE_STRING@
|
||||||
|
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
||||||
|
PACKAGE_VERSION = @PACKAGE_VERSION@
|
||||||
|
PATH_SEPARATOR = @PATH_SEPARATOR@
|
||||||
|
POSUB = @POSUB@
|
||||||
|
PTHREADLIB = @PTHREADLIB@
|
||||||
|
RANLIB = @RANLIB@
|
||||||
|
RPMLIBS = @RPMLIBS@
|
||||||
|
RPM_PATH = @RPM_PATH@
|
||||||
|
SET_MAKE = @SET_MAKE@
|
||||||
|
SHELL = @SHELL@
|
||||||
|
SOCKETLIBS = @SOCKETLIBS@
|
||||||
|
STRIP = @STRIP@
|
||||||
|
USE_INCLUDED_LIBINTL = @USE_INCLUDED_LIBINTL@
|
||||||
|
USE_NLS = @USE_NLS@
|
||||||
|
VERSION = @VERSION@
|
||||||
|
WITH_LUA_FALSE = @WITH_LUA_FALSE@
|
||||||
|
WITH_LUA_TRUE = @WITH_LUA_TRUE@
|
||||||
|
XGETTEXT = @XGETTEXT@
|
||||||
|
ac_ct_CC = @ac_ct_CC@
|
||||||
|
ac_ct_CXX = @ac_ct_CXX@
|
||||||
|
ac_ct_RANLIB = @ac_ct_RANLIB@
|
||||||
|
ac_ct_STRIP = @ac_ct_STRIP@
|
||||||
|
am__fastdepCC_FALSE = @am__fastdepCC_FALSE@
|
||||||
|
am__fastdepCC_TRUE = @am__fastdepCC_TRUE@
|
||||||
|
am__fastdepCXX_FALSE = @am__fastdepCXX_FALSE@
|
||||||
|
am__fastdepCXX_TRUE = @am__fastdepCXX_TRUE@
|
||||||
|
am__include = @am__include@
|
||||||
|
am__leading_dot = @am__leading_dot@
|
||||||
|
am__quote = @am__quote@
|
||||||
|
bindir = @bindir@
|
||||||
|
build = @build@
|
||||||
|
build_alias = @build_alias@
|
||||||
|
build_cpu = @build_cpu@
|
||||||
|
build_os = @build_os@
|
||||||
|
build_vendor = @build_vendor@
|
||||||
|
datadir = @datadir@
|
||||||
|
exec_prefix = @exec_prefix@
|
||||||
|
host = @host@
|
||||||
|
host_alias = @host_alias@
|
||||||
|
host_cpu = @host_cpu@
|
||||||
|
host_os = @host_os@
|
||||||
|
host_vendor = @host_vendor@
|
||||||
|
includedir = @includedir@
|
||||||
|
infodir = @infodir@
|
||||||
|
install_sh = @install_sh@
|
||||||
|
libdir = @libdir@
|
||||||
|
libexecdir = @libexecdir@
|
||||||
|
localstatedir = @localstatedir@
|
||||||
|
mandir = @mandir@
|
||||||
|
oldincludedir = @oldincludedir@
|
||||||
|
prefix = @prefix@
|
||||||
|
program_transform_name = @program_transform_name@
|
||||||
|
sbindir = @sbindir@
|
||||||
|
sharedstatedir = @sharedstatedir@
|
||||||
|
sysconfdir = @sysconfdir@
|
||||||
|
target_alias = @target_alias@
|
||||||
|
|
||||||
|
SUBDIRS = buildlib intl lua apt-pkg methods cmdline tools doc m4 po
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I m4 -I buildlib
|
||||||
|
|
||||||
|
EXTRA_DIST = \
|
||||||
|
AUTHORS.RPM \
|
||||||
|
COPYING.GPL \
|
||||||
|
rpmpriorities \
|
||||||
|
test/conf.cc \
|
||||||
|
test/extract-control.cc \
|
||||||
|
test/hash.cc \
|
||||||
|
test/makefile \
|
||||||
|
test/mthdcat.cc \
|
||||||
|
test/rpmver.cc \
|
||||||
|
test/scratch.cc \
|
||||||
|
test/testdeb.cc \
|
||||||
|
test/testextract.cc \
|
||||||
|
test/uri.cc \
|
||||||
|
test/versions.lst \
|
||||||
|
test/versiontest.cc \
|
||||||
|
python/apt.i \
|
||||||
|
python/apt.py \
|
||||||
|
python/apt_wrap.cxx \
|
||||||
|
python/Makefile \
|
||||||
|
python/swig-1.3.16-cxx.patch \
|
||||||
|
contrib/apt-rpm/apt-rpm \
|
||||||
|
contrib/apt-rpm/apt-rpm.1 \
|
||||||
|
contrib/apt-files/README \
|
||||||
|
contrib/apt-files/apt-files.lua \
|
||||||
|
contrib/apt-files/apt-files.conf \
|
||||||
|
contrib/apt-files/convert.py \
|
||||||
|
contrib/install-devel/README \
|
||||||
|
contrib/install-devel/install-devel.lua \
|
||||||
|
contrib/apt-groupinstall/README \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.lua \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.py \
|
||||||
|
contrib/apt-groupinstall/apt-groupinstall.conf \
|
||||||
|
contrib/proxypasswd/README \
|
||||||
|
contrib/proxypasswd/proxypasswd.lua
|
||||||
|
|
||||||
|
subdir = .
|
||||||
|
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
||||||
|
mkinstalldirs = $(SHELL) $(top_srcdir)/buildlib/mkinstalldirs
|
||||||
|
CONFIG_HEADER = $(top_builddir)/include/config.h
|
||||||
|
CONFIG_CLEAN_FILES = intl/Makefile
|
||||||
|
DIST_SOURCES =
|
||||||
|
|
||||||
|
RECURSIVE_TARGETS = info-recursive dvi-recursive pdf-recursive \
|
||||||
|
ps-recursive install-info-recursive uninstall-info-recursive \
|
||||||
|
all-recursive install-data-recursive install-exec-recursive \
|
||||||
|
installdirs-recursive install-recursive uninstall-recursive \
|
||||||
|
check-recursive installcheck-recursive
|
||||||
|
DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/configure \
|
||||||
|
./buildlib/config.h.in ABOUT-NLS AUTHORS COPYING Makefile.am \
|
||||||
|
TODO aclocal.m4 configure configure.in
|
||||||
|
DIST_SUBDIRS = $(SUBDIRS)
|
||||||
|
all: all-recursive
|
||||||
|
|
||||||
|
.SUFFIXES:
|
||||||
|
|
||||||
|
am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
|
||||||
|
configure.lineno
|
||||||
|
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
||||||
|
cd $(top_srcdir) && \
|
||||||
|
$(AUTOMAKE) --foreign Makefile
|
||||||
|
Makefile: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
|
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)
|
||||||
|
|
||||||
|
$(top_builddir)/config.status: $(srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||||
|
$(SHELL) ./config.status --recheck
|
||||||
|
$(srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(srcdir)/configure.in $(ACLOCAL_M4) $(CONFIGURE_DEPENDENCIES)
|
||||||
|
cd $(srcdir) && $(AUTOCONF)
|
||||||
|
|
||||||
|
$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ configure.in m4/codeset.m4 m4/gettext.m4 m4/glibc21.m4 m4/iconv.m4 m4/intdiv0.m4 m4/inttypes-pri.m4 m4/inttypes.m4 m4/inttypes_h.m4 m4/isc-posix.m4 m4/lcmessage.m4 m4/lib-ld.m4 m4/lib-link.m4 m4/lib-prefix.m4 m4/progtest.m4 m4/stdint_h.m4 m4/uintmax_t.m4 m4/ulonglong.m4 buildlib/tools.m4
|
||||||
|
cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
|
||||||
|
|
||||||
|
include/config.h: include/stamp-h1
|
||||||
|
@if test ! -f $@; then \
|
||||||
|
rm -f include/stamp-h1; \
|
||||||
|
$(MAKE) include/stamp-h1; \
|
||||||
|
else :; fi
|
||||||
|
|
||||||
|
include/stamp-h1: $(srcdir)/./buildlib/config.h.in $(top_builddir)/config.status
|
||||||
|
@rm -f include/stamp-h1
|
||||||
|
cd $(top_builddir) && $(SHELL) ./config.status include/config.h
|
||||||
|
|
||||||
|
$(srcdir)/./buildlib/config.h.in: @MAINTAINER_MODE_TRUE@ $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
||||||
|
cd $(top_srcdir) && $(AUTOHEADER)
|
||||||
|
touch $(srcdir)/./buildlib/config.h.in
|
||||||
|
|
||||||
|
distclean-hdr:
|
||||||
|
-rm -f include/config.h include/stamp-h1
|
||||||
|
intl/Makefile: $(top_builddir)/config.status $(top_srcdir)/intl/Makefile.in
|
||||||
|
cd $(top_builddir) && $(SHELL) ./config.status $@
|
||||||
|
|
||||||
|
mostlyclean-libtool:
|
||||||
|
-rm -f *.lo
|
||||||
|
|
||||||
|
clean-libtool:
|
||||||
|
-rm -rf .libs _libs
|
||||||
|
|
||||||
|
distclean-libtool:
|
||||||
|
-rm -f libtool
|
||||||
|
uninstall-info-am:
|
||||||
|
|
||||||
|
# This directory's subdirectories are mostly independent; you can cd
|
||||||
|
# into them and run `make' without going through this Makefile.
|
||||||
|
# To change the values of `make' variables: instead of editing Makefiles,
|
||||||
|
# (1) if the variable is set in `config.status', edit `config.status'
|
||||||
|
# (which will cause the Makefiles to be regenerated when you run `make');
|
||||||
|
# (2) otherwise, pass the desired values on the `make' command line.
|
||||||
|
$(RECURSIVE_TARGETS):
|
||||||
|
@set fnord $$MAKEFLAGS; amf=$$2; \
|
||||||
|
dot_seen=no; \
|
||||||
|
target=`echo $@ | sed s/-recursive//`; \
|
||||||
|
list='$(SUBDIRS)'; for subdir in $$list; do \
|
||||||
|
echo "Making $$target in $$subdir"; \
|
||||||
|
if test "$$subdir" = "."; then \
|
||||||
|
dot_seen=yes; \
|
||||||
|
local_target="$$target-am"; \
|
||||||
|
else \
|
||||||
|
local_target="$$target"; \
|
||||||
|
fi; \
|
||||||
|
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
||||||
|
|| case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
|
||||||
|
done; \
|
||||||
|
if test "$$dot_seen" = "no"; then \
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
|
||||||
|
fi; test -z "$$fail"
|
||||||
|
|
||||||
|
mostlyclean-recursive clean-recursive distclean-recursive \
|
||||||
|
maintainer-clean-recursive:
|
||||||
|
@set fnord $$MAKEFLAGS; amf=$$2; \
|
||||||
|
dot_seen=no; \
|
||||||
|
case "$@" in \
|
||||||
|
distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
|
||||||
|
*) list='$(SUBDIRS)' ;; \
|
||||||
|
esac; \
|
||||||
|
rev=''; for subdir in $$list; do \
|
||||||
|
if test "$$subdir" = "."; then :; else \
|
||||||
|
rev="$$subdir $$rev"; \
|
||||||
|
fi; \
|
||||||
|
done; \
|
||||||
|
rev="$$rev ."; \
|
||||||
|
target=`echo $@ | sed s/-recursive//`; \
|
||||||
|
for subdir in $$rev; do \
|
||||||
|
echo "Making $$target in $$subdir"; \
|
||||||
|
if test "$$subdir" = "."; then \
|
||||||
|
local_target="$$target-am"; \
|
||||||
|
else \
|
||||||
|
local_target="$$target"; \
|
||||||
|
fi; \
|
||||||
|
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
||||||
|
|| case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \
|
||||||
|
done && test -z "$$fail"
|
||||||
|
tags-recursive:
|
||||||
|
list='$(SUBDIRS)'; for subdir in $$list; do \
|
||||||
|
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
|
||||||
|
done
|
||||||
|
ctags-recursive:
|
||||||
|
list='$(SUBDIRS)'; for subdir in $$list; do \
|
||||||
|
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \
|
||||||
|
done
|
||||||
|
|
||||||
|
ETAGS = etags
|
||||||
|
ETAGSFLAGS =
|
||||||
|
|
||||||
|
CTAGS = ctags
|
||||||
|
CTAGSFLAGS =
|
||||||
|
|
||||||
|
tags: TAGS
|
||||||
|
|
||||||
|
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) ' { files[$$0] = 1; } \
|
||||||
|
END { for (i in files) print i; }'`; \
|
||||||
|
mkid -fID $$unique
|
||||||
|
|
||||||
|
TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
tags=; \
|
||||||
|
here=`pwd`; \
|
||||||
|
if (etags --etags-include --version) >/dev/null 2>&1; then \
|
||||||
|
include_option=--etags-include; \
|
||||||
|
else \
|
||||||
|
include_option=--include; \
|
||||||
|
fi; \
|
||||||
|
list='$(SUBDIRS)'; for subdir in $$list; do \
|
||||||
|
if test "$$subdir" = .; then :; else \
|
||||||
|
test -f $$subdir/TAGS && \
|
||||||
|
tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \
|
||||||
|
fi; \
|
||||||
|
done; \
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) ' { files[$$0] = 1; } \
|
||||||
|
END { for (i in files) print i; }'`; \
|
||||||
|
test -z "$(ETAGS_ARGS)$$tags$$unique" \
|
||||||
|
|| $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
||||||
|
$$tags $$unique
|
||||||
|
|
||||||
|
ctags: CTAGS
|
||||||
|
CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
||||||
|
$(TAGS_FILES) $(LISP)
|
||||||
|
tags=; \
|
||||||
|
here=`pwd`; \
|
||||||
|
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
||||||
|
unique=`for i in $$list; do \
|
||||||
|
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
||||||
|
done | \
|
||||||
|
$(AWK) ' { files[$$0] = 1; } \
|
||||||
|
END { for (i in files) print i; }'`; \
|
||||||
|
test -z "$(CTAGS_ARGS)$$tags$$unique" \
|
||||||
|
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
||||||
|
$$tags $$unique
|
||||||
|
|
||||||
|
GTAGS:
|
||||||
|
here=`$(am__cd) $(top_builddir) && pwd` \
|
||||||
|
&& cd $(top_srcdir) \
|
||||||
|
&& gtags -i $(GTAGS_ARGS) $$here
|
||||||
|
|
||||||
|
distclean-tags:
|
||||||
|
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
||||||
|
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
||||||
|
|
||||||
|
top_distdir = .
|
||||||
|
distdir = $(PACKAGE)-$(VERSION)
|
||||||
|
|
||||||
|
am__remove_distdir = \
|
||||||
|
{ test ! -d $(distdir) \
|
||||||
|
|| { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \
|
||||||
|
&& rm -fr $(distdir); }; }
|
||||||
|
|
||||||
|
GZIP_ENV = --best
|
||||||
|
distuninstallcheck_listfiles = find . -type f -print
|
||||||
|
distcleancheck_listfiles = find . -type f -print
|
||||||
|
|
||||||
|
distdir: $(DISTFILES)
|
||||||
|
$(am__remove_distdir)
|
||||||
|
mkdir $(distdir)
|
||||||
|
$(mkinstalldirs) $(distdir)/./buildlib $(distdir)/contrib/apt-files $(distdir)/contrib/apt-groupinstall $(distdir)/contrib/apt-rpm $(distdir)/contrib/install-devel $(distdir)/contrib/proxypasswd $(distdir)/intl $(distdir)/po $(distdir)/python $(distdir)/test
|
||||||
|
@srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \
|
||||||
|
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \
|
||||||
|
list='$(DISTFILES)'; for file in $$list; do \
|
||||||
|
case $$file in \
|
||||||
|
$(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \
|
||||||
|
$(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \
|
||||||
|
esac; \
|
||||||
|
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
||||||
|
dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
|
||||||
|
if test "$$dir" != "$$file" && test "$$dir" != "."; then \
|
||||||
|
dir="/$$dir"; \
|
||||||
|
$(mkinstalldirs) "$(distdir)$$dir"; \
|
||||||
|
else \
|
||||||
|
dir=''; \
|
||||||
|
fi; \
|
||||||
|
if test -d $$d/$$file; then \
|
||||||
|
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
||||||
|
cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
|
||||||
|
fi; \
|
||||||
|
cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
|
||||||
|
else \
|
||||||
|
test -f $(distdir)/$$file \
|
||||||
|
|| cp -p $$d/$$file $(distdir)/$$file \
|
||||||
|
|| exit 1; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
list='$(SUBDIRS)'; for subdir in $$list; do \
|
||||||
|
if test "$$subdir" = .; then :; else \
|
||||||
|
test -d $(distdir)/$$subdir \
|
||||||
|
|| mkdir $(distdir)/$$subdir \
|
||||||
|
|| exit 1; \
|
||||||
|
(cd $$subdir && \
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) \
|
||||||
|
top_distdir="$(top_distdir)" \
|
||||||
|
distdir=../$(distdir)/$$subdir \
|
||||||
|
distdir) \
|
||||||
|
|| exit 1; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
-find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \
|
||||||
|
! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
|
||||||
|
! -type d ! -perm -400 -exec chmod a+r {} \; -o \
|
||||||
|
! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \
|
||||||
|
|| chmod -R a+r $(distdir)
|
||||||
|
dist-gzip: distdir
|
||||||
|
$(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
||||||
|
$(am__remove_distdir)
|
||||||
|
|
||||||
|
dist-bzip2: distdir
|
||||||
|
$(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2
|
||||||
|
$(am__remove_distdir)
|
||||||
|
|
||||||
|
dist dist-all: distdir
|
||||||
|
$(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
||||||
|
$(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2
|
||||||
|
$(am__remove_distdir)
|
||||||
|
|
||||||
|
# This target untars the dist file and tries a VPATH configuration. Then
|
||||||
|
# it guarantees that the distribution is self-contained by making another
|
||||||
|
# tarfile.
|
||||||
|
distcheck: dist
|
||||||
|
$(am__remove_distdir)
|
||||||
|
GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(AMTAR) xf -
|
||||||
|
chmod -R a-w $(distdir); chmod a+w $(distdir)
|
||||||
|
mkdir $(distdir)/_build
|
||||||
|
mkdir $(distdir)/_inst
|
||||||
|
chmod a-w $(distdir)
|
||||||
|
dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \
|
||||||
|
&& dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \
|
||||||
|
&& cd $(distdir)/_build \
|
||||||
|
&& ../configure --srcdir=.. --prefix="$$dc_install_base" \
|
||||||
|
--with-included-gettext \
|
||||||
|
$(DISTCHECK_CONFIGURE_FLAGS) \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) dvi \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) check \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) install \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) installcheck \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) uninstall \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \
|
||||||
|
distuninstallcheck \
|
||||||
|
&& chmod -R a-w "$$dc_install_base" \
|
||||||
|
&& ({ \
|
||||||
|
(cd ../.. && $(mkinstalldirs) "$$dc_destdir") \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \
|
||||||
|
distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \
|
||||||
|
} || { rm -rf "$$dc_destdir"; exit 1; }) \
|
||||||
|
&& rm -rf "$$dc_destdir" \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) dist-gzip \
|
||||||
|
&& rm -f $(distdir).tar.gz \
|
||||||
|
&& $(MAKE) $(AM_MAKEFLAGS) distcleancheck
|
||||||
|
$(am__remove_distdir)
|
||||||
|
@echo "$(distdir).tar.gz is ready for distribution" | \
|
||||||
|
sed 'h;s/./=/g;p;x;p;x'
|
||||||
|
distuninstallcheck:
|
||||||
|
@cd $(distuninstallcheck_dir) \
|
||||||
|
&& test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \
|
||||||
|
|| { echo "ERROR: files left after uninstall:" ; \
|
||||||
|
if test -n "$(DESTDIR)"; then \
|
||||||
|
echo " (check DESTDIR support)"; \
|
||||||
|
fi ; \
|
||||||
|
$(distuninstallcheck_listfiles) ; \
|
||||||
|
exit 1; } >&2
|
||||||
|
distcleancheck: distclean
|
||||||
|
@if test '$(srcdir)' = . ; then \
|
||||||
|
echo "ERROR: distcleancheck can only run from a VPATH build" ; \
|
||||||
|
exit 1 ; \
|
||||||
|
fi
|
||||||
|
@test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
|
||||||
|
|| { echo "ERROR: files left in build directory after distclean:" ; \
|
||||||
|
$(distcleancheck_listfiles) ; \
|
||||||
|
exit 1; } >&2
|
||||||
|
check-am: all-am
|
||||||
|
check: check-recursive
|
||||||
|
all-am: Makefile
|
||||||
|
installdirs: installdirs-recursive
|
||||||
|
installdirs-am:
|
||||||
|
|
||||||
|
install: install-recursive
|
||||||
|
install-exec: install-exec-recursive
|
||||||
|
install-data: install-data-recursive
|
||||||
|
uninstall: uninstall-recursive
|
||||||
|
|
||||||
|
install-am: all-am
|
||||||
|
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
||||||
|
|
||||||
|
installcheck: installcheck-recursive
|
||||||
|
install-strip:
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||||
|
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||||
|
`test -z '$(STRIP)' || \
|
||||||
|
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
||||||
|
mostlyclean-generic:
|
||||||
|
|
||||||
|
clean-generic:
|
||||||
|
|
||||||
|
distclean-generic:
|
||||||
|
-rm -f $(CONFIG_CLEAN_FILES)
|
||||||
|
|
||||||
|
maintainer-clean-generic:
|
||||||
|
@echo "This command is intended for maintainers to use"
|
||||||
|
@echo "it deletes files that may require special tools to rebuild."
|
||||||
|
clean: clean-recursive
|
||||||
|
|
||||||
|
clean-am: clean-generic clean-libtool mostlyclean-am
|
||||||
|
|
||||||
|
distclean: distclean-recursive
|
||||||
|
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||||
|
-rm -f Makefile
|
||||||
|
distclean-am: clean-am distclean-generic distclean-hdr distclean-libtool \
|
||||||
|
distclean-tags
|
||||||
|
|
||||||
|
dvi: dvi-recursive
|
||||||
|
|
||||||
|
dvi-am:
|
||||||
|
|
||||||
|
info: info-recursive
|
||||||
|
|
||||||
|
info-am:
|
||||||
|
|
||||||
|
install-data-am:
|
||||||
|
|
||||||
|
install-exec-am:
|
||||||
|
|
||||||
|
install-info: install-info-recursive
|
||||||
|
|
||||||
|
install-man:
|
||||||
|
|
||||||
|
installcheck-am:
|
||||||
|
|
||||||
|
maintainer-clean: maintainer-clean-recursive
|
||||||
|
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
||||||
|
-rm -rf $(top_srcdir)/autom4te.cache
|
||||||
|
-rm -f Makefile
|
||||||
|
maintainer-clean-am: distclean-am maintainer-clean-generic
|
||||||
|
|
||||||
|
mostlyclean: mostlyclean-recursive
|
||||||
|
|
||||||
|
mostlyclean-am: mostlyclean-generic mostlyclean-libtool
|
||||||
|
|
||||||
|
pdf: pdf-recursive
|
||||||
|
|
||||||
|
pdf-am:
|
||||||
|
|
||||||
|
ps: ps-recursive
|
||||||
|
|
||||||
|
ps-am:
|
||||||
|
|
||||||
|
uninstall-am: uninstall-info-am
|
||||||
|
|
||||||
|
uninstall-info: uninstall-info-recursive
|
||||||
|
|
||||||
|
.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am clean \
|
||||||
|
clean-generic clean-libtool clean-recursive ctags \
|
||||||
|
ctags-recursive dist dist-all dist-bzip2 dist-gzip distcheck \
|
||||||
|
distclean distclean-generic distclean-hdr distclean-libtool \
|
||||||
|
distclean-recursive distclean-tags distcleancheck distdir \
|
||||||
|
distuninstallcheck dvi dvi-am dvi-recursive info info-am \
|
||||||
|
info-recursive install install-am install-data install-data-am \
|
||||||
|
install-data-recursive install-exec install-exec-am \
|
||||||
|
install-exec-recursive install-info install-info-am \
|
||||||
|
install-info-recursive install-man install-recursive \
|
||||||
|
install-strip installcheck installcheck-am installdirs \
|
||||||
|
installdirs-am installdirs-recursive maintainer-clean \
|
||||||
|
maintainer-clean-generic maintainer-clean-recursive mostlyclean \
|
||||||
|
mostlyclean-generic mostlyclean-libtool mostlyclean-recursive \
|
||||||
|
pdf pdf-am pdf-recursive ps ps-am ps-recursive tags \
|
||||||
|
tags-recursive uninstall uninstall-am uninstall-info-am \
|
||||||
|
uninstall-info-recursive uninstall-recursive
|
||||||
|
|
||||||
|
contrib/guess/README \
|
||||||
|
contrib/guess/guess.lua \
|
||||||
|
contrib/guess/guess.conf
|
||||||
|
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
||||||
|
# Otherwise a system limit (for SysV at least) may be exceeded.
|
||||||
|
.NOEXPORT:
|
112
apt/README.make
112
apt/README.make
@ -1,112 +0,0 @@
|
|||||||
The Make System
|
|
||||||
~~~ ~~~~ ~~~~~~
|
|
||||||
To compile this program you require GNU Make. In fact you probably need
|
|
||||||
GNU Make 3.76.1 or newer. The makefiles contained make use of many
|
|
||||||
GNU Make specific features and will not run on other makes.
|
|
||||||
|
|
||||||
The make system has a number of interesting properties that are not found
|
|
||||||
in other systems such as automake or the GNU makefile standards. In
|
|
||||||
general some semblance of expectedness is kept so as not to be too
|
|
||||||
surprising. Basically the following will work as expected:
|
|
||||||
|
|
||||||
./configure
|
|
||||||
make
|
|
||||||
or
|
|
||||||
cd build
|
|
||||||
../configure
|
|
||||||
make
|
|
||||||
|
|
||||||
There are a number of other things that are possible that may make software
|
|
||||||
development and software packaging simpler. The first of these is the
|
|
||||||
environment.mak file. When configure is run it creates an environment.mak
|
|
||||||
file in the build directory. This contains -all- configurable parameters
|
|
||||||
for all of the make files in all of the subdirectories. Changing one
|
|
||||||
of these parameters will have an immediate effect. The use of makefile.in
|
|
||||||
and configure substitutions across build makefiles is not used at all.
|
|
||||||
|
|
||||||
Furthermore, the make system runs with a current directory equal to the
|
|
||||||
source directory irregardless of the destination directory. This means
|
|
||||||
#include "" and #include <> work as expected and more importantly
|
|
||||||
running 'make' in the source directory will work as expected. The
|
|
||||||
environment variable or make parameter 'BUILD' sets the build directory.
|
|
||||||
It may be an absolute path or a path relative to the top level directory.
|
|
||||||
By default build-arch/ then build/ will be used with a fall back to ./ This
|
|
||||||
means you can get all the advantages of a build directory without having to
|
|
||||||
cd into it to edit your source code!
|
|
||||||
|
|
||||||
The make system also performs dependency generation on the fly as the
|
|
||||||
compiler runs. This is extremely fast and accurate. There is however
|
|
||||||
one failure condition that occures when a header file is erased. In
|
|
||||||
this case you should run make clean to purge the .o and .d files to
|
|
||||||
rebuild.
|
|
||||||
|
|
||||||
The final significant deviation from normal make practicies is
|
|
||||||
in how the build directory is managed. It is not mearly a mirror of
|
|
||||||
the source directory but is logically divided in the following manner
|
|
||||||
bin/
|
|
||||||
methods/
|
|
||||||
doc/
|
|
||||||
examples/
|
|
||||||
include/
|
|
||||||
apt-pkg/
|
|
||||||
obj/
|
|
||||||
apt-pkg/
|
|
||||||
cmndline/
|
|
||||||
[...]
|
|
||||||
Only .o and .d files are placed in the obj/ subdirectory. The final compiled
|
|
||||||
binaries are placed in bin, published headers for inter-component linking
|
|
||||||
are placed in include/ and documentation is generated into doc/. This means
|
|
||||||
all runnable programs are within the bin/ directory, a huge benifit for
|
|
||||||
debugging inter-program relationships. The .so files are also placed in
|
|
||||||
bin/ for simplicity.
|
|
||||||
|
|
||||||
By default make is put into silent mode. During operation there should be
|
|
||||||
no shell or compiler messages only status messages from the makefiles,
|
|
||||||
if any pop up that indicates there may be a problem with your environment.
|
|
||||||
For debugging you can disable this by setting NOISY=1, ala
|
|
||||||
make NOISY=1
|
|
||||||
|
|
||||||
Using the makefiles
|
|
||||||
~~~~~ ~~~ ~~~~~~~~~
|
|
||||||
The makefiles for the components are really simple. The complexity is hidden
|
|
||||||
within the buildlib/ directory. Each makefile defines a set of make variables
|
|
||||||
for the bit it is going to make then includes a makefile fragment from
|
|
||||||
the buildlib/. This fragment generates the necessary rules based on the
|
|
||||||
originally defined variables. This process can be repeated as many times as
|
|
||||||
necessary for as many programs or libraries as are in the directory.
|
|
||||||
|
|
||||||
Many of the make fragments have some useful properties involving sub
|
|
||||||
directories and other interesting features. They are more completely
|
|
||||||
described in the fragment code in buildlib. Some tips on writing fragments
|
|
||||||
are included in buildlib/defaults.mak
|
|
||||||
|
|
||||||
The fragments are NEVER processed by configure, so if you make changes to
|
|
||||||
them they will have an immediate effect.
|
|
||||||
|
|
||||||
Autoconf
|
|
||||||
~~~~~~~~
|
|
||||||
Straight out of CVS you have to initialize autoconf. This requires
|
|
||||||
automake (I really don't know why) and autoconf and requires doing
|
|
||||||
aclocal -I buidlib
|
|
||||||
autoconf
|
|
||||||
[Altertatively you can run make startup in the top level build dir]
|
|
||||||
|
|
||||||
Autoconf is configured to do some basic system probes for optional and
|
|
||||||
required functionality and generate an environment.mak and include/config.h
|
|
||||||
from it's findings. It will then write a 'makefile' and run make dirs to
|
|
||||||
create the output directory tree.
|
|
||||||
|
|
||||||
It is not my belief that autoconf should be used to generate substantial
|
|
||||||
source code markup to escape OS problems. If an OS problem does crop up
|
|
||||||
it can likely be corrected by installing the correct files into the
|
|
||||||
build include/ dir and perhaps writing some replacement code and
|
|
||||||
linking it in. To the fullest extent possible the source code should conform
|
|
||||||
to standards and not cater to broken systems.
|
|
||||||
|
|
||||||
Autoconf will also wite a makefile into the top level of the build dir,
|
|
||||||
this simply acts as a wrapper to the main top level make in the source tree.
|
|
||||||
There is one big warning, you can't use both this make file and the
|
|
||||||
ones in the top level tree. Make is not able to resolve rules that
|
|
||||||
go to the same file through different paths and this will confuse the
|
|
||||||
depends mechanism. I recommend always using the makefiles in the
|
|
||||||
source directory and exporting BUILD.
|
|
3
apt/TODO
3
apt/TODO
@ -1,3 +1,6 @@
|
|||||||
- Implement hashing in file method.
|
- Implement hashing in file method.
|
||||||
- Build program to check for dependencies between repositories.
|
- Build program to check for dependencies between repositories.
|
||||||
- Implement apt-cache provides/whatprovides
|
- Implement apt-cache provides/whatprovides
|
||||||
|
- Implement Minimize
|
||||||
|
- Implement depends/provides support in Lua API.
|
||||||
|
- Implement build options for source -b command.
|
||||||
|
4148
apt/aclocal.m4
vendored
4148
apt/aclocal.m4
vendored
File diff suppressed because it is too large
Load Diff
@ -1,155 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: arfile.cc,v 1.5 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
AR File - Handle an 'AR' archive
|
|
||||||
|
|
||||||
AR Archives have plain text headers at the start of each file
|
|
||||||
section. The headers are aligned on a 2 byte boundry.
|
|
||||||
|
|
||||||
Information about the structure of AR files can be found in ar(5)
|
|
||||||
on a BSD system, or in the binutils source.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/arfile.h"
|
|
||||||
#endif
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/arfile.h>
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
struct ARArchive::MemberHeader
|
|
||||||
{
|
|
||||||
char Name[16];
|
|
||||||
char MTime[12];
|
|
||||||
char UID[6];
|
|
||||||
char GID[6];
|
|
||||||
char Mode[8];
|
|
||||||
char Size[10];
|
|
||||||
char Magic[2];
|
|
||||||
};
|
|
||||||
|
|
||||||
// ARArchive::ARArchive - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
ARArchive::ARArchive(FileFd &File) : List(0), File(File)
|
|
||||||
{
|
|
||||||
LoadHeaders();
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ARArchive::~ARArchive - Destructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
ARArchive::~ARArchive()
|
|
||||||
{
|
|
||||||
while (List != 0)
|
|
||||||
{
|
|
||||||
Member *Tmp = List;
|
|
||||||
List = List->Next;
|
|
||||||
delete Tmp;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ARArchive::LoadHeaders - Load the headers from each file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* AR files are structured with a 8 byte magic string followed by a 60
|
|
||||||
byte plain text header then the file data, another header, data, etc */
|
|
||||||
bool ARArchive::LoadHeaders()
|
|
||||||
{
|
|
||||||
signed long Left = File.Size();
|
|
||||||
|
|
||||||
// Check the magic byte
|
|
||||||
char Magic[8];
|
|
||||||
if (File.Read(Magic,sizeof(Magic)) == false)
|
|
||||||
return false;
|
|
||||||
if (memcmp(Magic,"!<arch>\012",sizeof(Magic)) != 0)
|
|
||||||
return _error->Error(_("Invalid archive signature"));
|
|
||||||
Left -= sizeof(Magic);
|
|
||||||
|
|
||||||
// Read the member list
|
|
||||||
while (Left > 0)
|
|
||||||
{
|
|
||||||
MemberHeader Head;
|
|
||||||
if (File.Read(&Head,sizeof(Head)) == false)
|
|
||||||
return _error->Error(_("Error reading archive member header"));
|
|
||||||
Left -= sizeof(Head);
|
|
||||||
|
|
||||||
// Convert all of the integer members
|
|
||||||
Member *Memb = new Member();
|
|
||||||
if (StrToNum(Head.MTime,Memb->MTime,sizeof(Head.MTime)) == false ||
|
|
||||||
StrToNum(Head.UID,Memb->UID,sizeof(Head.UID)) == false ||
|
|
||||||
StrToNum(Head.GID,Memb->GID,sizeof(Head.GID)) == false ||
|
|
||||||
StrToNum(Head.Mode,Memb->Mode,sizeof(Head.Mode),8) == false ||
|
|
||||||
StrToNum(Head.Size,Memb->Size,sizeof(Head.Size)) == false)
|
|
||||||
{
|
|
||||||
delete Memb;
|
|
||||||
return _error->Error(_("Invalid archive member header"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check for an extra long name string
|
|
||||||
if (memcmp(Head.Name,"#1/",3) == 0)
|
|
||||||
{
|
|
||||||
char S[300];
|
|
||||||
unsigned long Len;
|
|
||||||
if (StrToNum(Head.Name+3,Len,sizeof(Head.Size)-3) == false ||
|
|
||||||
Len >= strlen(S))
|
|
||||||
{
|
|
||||||
delete Memb;
|
|
||||||
return _error->Error(_("Invalid archive member header"));
|
|
||||||
}
|
|
||||||
if (File.Read(S,Len) == false)
|
|
||||||
return false;
|
|
||||||
S[Len] = 0;
|
|
||||||
Memb->Name = S;
|
|
||||||
Memb->Size -= Len;
|
|
||||||
Left -= Len;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
unsigned int I = sizeof(Head.Name) - 1;
|
|
||||||
for (; Head.Name[I] == ' '; I--);
|
|
||||||
Memb->Name = string(Head.Name,0,I+1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Account for the AR header alignment
|
|
||||||
unsigned Skip = Memb->Size % 2;
|
|
||||||
|
|
||||||
// Add it to the list
|
|
||||||
Memb->Next = List;
|
|
||||||
List = Memb;
|
|
||||||
Memb->Start = File.Tell();
|
|
||||||
if (File.Skip(Memb->Size + Skip) == false)
|
|
||||||
return false;
|
|
||||||
if (Left < (signed)(Memb->Size + Skip))
|
|
||||||
return _error->Error(_("Archive is too short"));
|
|
||||||
Left -= Memb->Size + Skip;
|
|
||||||
}
|
|
||||||
if (Left != 0)
|
|
||||||
return _error->Error(_("Failed to read the archive headers"));
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ARArchive::FindMember - Find a name in the member list /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Find a member with the given name */
|
|
||||||
const ARArchive::Member *ARArchive::FindMember(const char *Name) const
|
|
||||||
{
|
|
||||||
const Member *Res = List;
|
|
||||||
while (Res != 0)
|
|
||||||
{
|
|
||||||
if (Res->Name == Name)
|
|
||||||
return Res;
|
|
||||||
Res = Res->Next;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,68 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: arfile.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
AR File - Handle an 'AR' archive
|
|
||||||
|
|
||||||
This is a reader for the usual 4.4 BSD AR format. It allows raw
|
|
||||||
stream access to a single member at a time. Basically all this class
|
|
||||||
provides is header parsing and verification. It is up to the client
|
|
||||||
to correctly make use of the stream start/stop points.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_ARFILE_H
|
|
||||||
#define PKGLIB_ARFILE_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/arfile.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include <apt-pkg/fileutl.h>
|
|
||||||
|
|
||||||
class ARArchive
|
|
||||||
{
|
|
||||||
struct MemberHeader;
|
|
||||||
public:
|
|
||||||
struct Member;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
|
|
||||||
// Linked list of members
|
|
||||||
Member *List;
|
|
||||||
|
|
||||||
bool LoadHeaders();
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// The stream file
|
|
||||||
FileFd &File;
|
|
||||||
|
|
||||||
// Locate a member by name
|
|
||||||
const Member *FindMember(const char *Name) const;
|
|
||||||
|
|
||||||
ARArchive(FileFd &File);
|
|
||||||
~ARArchive();
|
|
||||||
};
|
|
||||||
|
|
||||||
// A member of the archive
|
|
||||||
struct ARArchive::Member
|
|
||||||
{
|
|
||||||
// Fields from the header
|
|
||||||
string Name;
|
|
||||||
unsigned long MTime;
|
|
||||||
unsigned long UID;
|
|
||||||
unsigned long GID;
|
|
||||||
unsigned long Mode;
|
|
||||||
unsigned long Size;
|
|
||||||
|
|
||||||
// Location of the data.
|
|
||||||
unsigned long Start;
|
|
||||||
Member *Next;
|
|
||||||
|
|
||||||
Member() : Start(0), Next(0) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,344 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: extracttar.cc,v 1.7 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Extract a Tar - Tar Extractor
|
|
||||||
|
|
||||||
Some performance measurements showed that zlib performed quite poorly
|
|
||||||
in comparision to a forked gzip process. This tar extractor makes use
|
|
||||||
of the fact that dup'd file descriptors have the same seek pointer
|
|
||||||
and that gzip will not read past the end of a compressed stream,
|
|
||||||
even if there is more data. We use the dup property to track extraction
|
|
||||||
progress and the gzip feature to just feed gzip a fd in the middle
|
|
||||||
of an AR file.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/extracttar.h"
|
|
||||||
#endif
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/extracttar.h>
|
|
||||||
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
#include <apt-pkg/configuration.h>
|
|
||||||
#include <system.h>
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <signal.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <iostream>
|
|
||||||
/*}}}*/
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
// The on disk header for a tar file.
|
|
||||||
struct ExtractTar::TarHeader
|
|
||||||
{
|
|
||||||
char Name[100];
|
|
||||||
char Mode[8];
|
|
||||||
char UserID[8];
|
|
||||||
char GroupID[8];
|
|
||||||
char Size[12];
|
|
||||||
char MTime[12];
|
|
||||||
char Checksum[8];
|
|
||||||
char LinkFlag;
|
|
||||||
char LinkName[100];
|
|
||||||
char MagicNumber[8];
|
|
||||||
char UserName[32];
|
|
||||||
char GroupName[32];
|
|
||||||
char Major[8];
|
|
||||||
char Minor[8];
|
|
||||||
};
|
|
||||||
|
|
||||||
// ExtractTar::ExtractTar - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
ExtractTar::ExtractTar(FileFd &Fd,unsigned long Max) : File(Fd),
|
|
||||||
MaxInSize(Max)
|
|
||||||
|
|
||||||
{
|
|
||||||
GZPid = -1;
|
|
||||||
InFd = -1;
|
|
||||||
Eof = false;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ExtractTar::ExtractTar - Destructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
ExtractTar::~ExtractTar()
|
|
||||||
{
|
|
||||||
// Error close
|
|
||||||
Done(true);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ExtractTar::Done - Reap the gzip sub process /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* If the force flag is given then error messages are suppressed - this
|
|
||||||
means we hit the end of the tar file but there was still gzip data. */
|
|
||||||
bool ExtractTar::Done(bool Force)
|
|
||||||
{
|
|
||||||
InFd.Close();
|
|
||||||
if (GZPid <= 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
/* If there is a pending error then we are cleaning up gzip and are
|
|
||||||
not interested in it's failures */
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
Force = true;
|
|
||||||
|
|
||||||
// Make sure we clean it up!
|
|
||||||
kill(GZPid,SIGINT);
|
|
||||||
if (ExecWait(GZPid,_config->Find("dir::bin::gzip","/bin/gzip").c_str(),
|
|
||||||
Force) == false)
|
|
||||||
{
|
|
||||||
GZPid = -1;
|
|
||||||
return Force;
|
|
||||||
}
|
|
||||||
|
|
||||||
GZPid = -1;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ExtractTar::StartGzip - Startup gzip /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This creates a gzip sub process that has its input as the file itself.
|
|
||||||
If this tar file is embedded into something like an ar file then
|
|
||||||
gzip will efficiently ignore the extra bits. */
|
|
||||||
bool ExtractTar::StartGzip()
|
|
||||||
{
|
|
||||||
int Pipes[2];
|
|
||||||
if (pipe(Pipes) != 0)
|
|
||||||
return _error->Errno("pipe",_("Failed to create pipes"));
|
|
||||||
|
|
||||||
// Fork off the process
|
|
||||||
GZPid = ExecFork();
|
|
||||||
|
|
||||||
// Spawn the subprocess
|
|
||||||
if (GZPid == 0)
|
|
||||||
{
|
|
||||||
// Setup the FDs
|
|
||||||
dup2(Pipes[1],STDOUT_FILENO);
|
|
||||||
dup2(File.Fd(),STDIN_FILENO);
|
|
||||||
int Fd = open("/dev/null",O_RDWR);
|
|
||||||
if (Fd == -1)
|
|
||||||
_exit(101);
|
|
||||||
dup2(Fd,STDERR_FILENO);
|
|
||||||
close(Fd);
|
|
||||||
SetCloseExec(STDOUT_FILENO,false);
|
|
||||||
SetCloseExec(STDIN_FILENO,false);
|
|
||||||
SetCloseExec(STDERR_FILENO,false);
|
|
||||||
|
|
||||||
const char *Args[3];
|
|
||||||
Args[0] = _config->Find("dir::bin::gzip","/bin/gzip").c_str();
|
|
||||||
Args[1] = "-d";
|
|
||||||
Args[2] = 0;
|
|
||||||
execv(Args[0],(char **)Args);
|
|
||||||
cerr << _("Failed to exec gzip ") << Args[0] << endl;
|
|
||||||
_exit(100);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fix up our FDs
|
|
||||||
InFd.Fd(Pipes[0]);
|
|
||||||
close(Pipes[1]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// ExtractTar::Go - Perform extraction /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This reads each 512 byte block from the archive and extracts the header
|
|
||||||
information into the Item structure. Then it resolves the UID/GID and
|
|
||||||
invokes the correct processing function. */
|
|
||||||
bool ExtractTar::Go(pkgDirStream &Stream)
|
|
||||||
{
|
|
||||||
if (StartGzip() == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Loop over all blocks
|
|
||||||
string LastLongLink;
|
|
||||||
string LastLongName;
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
bool BadRecord = false;
|
|
||||||
unsigned char Block[512];
|
|
||||||
if (InFd.Read(Block,sizeof(Block),true) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (InFd.Eof() == true)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Get the checksum
|
|
||||||
TarHeader *Tar = (TarHeader *)Block;
|
|
||||||
unsigned long CheckSum;
|
|
||||||
if (StrToNum(Tar->Checksum,CheckSum,sizeof(Tar->Checksum),8) == false)
|
|
||||||
return _error->Error(_("Corrupted archive"));
|
|
||||||
|
|
||||||
/* Compute the checksum field. The actual checksum is blanked out
|
|
||||||
with spaces so it is not included in the computation */
|
|
||||||
unsigned long NewSum = 0;
|
|
||||||
memset(Tar->Checksum,' ',sizeof(Tar->Checksum));
|
|
||||||
for (int I = 0; I != sizeof(Block); I++)
|
|
||||||
NewSum += Block[I];
|
|
||||||
|
|
||||||
/* Check for a block of nulls - in this case we kill gzip, GNU tar
|
|
||||||
does this.. */
|
|
||||||
if (NewSum == ' '*sizeof(Tar->Checksum))
|
|
||||||
return Done(true);
|
|
||||||
|
|
||||||
if (NewSum != CheckSum)
|
|
||||||
return _error->Error(_("Tar Checksum failed, archive corrupted"));
|
|
||||||
|
|
||||||
// Decode all of the fields
|
|
||||||
pkgDirStream::Item Itm;
|
|
||||||
if (StrToNum(Tar->Mode,Itm.Mode,sizeof(Tar->Mode),8) == false ||
|
|
||||||
StrToNum(Tar->UserID,Itm.UID,sizeof(Tar->UserID),8) == false ||
|
|
||||||
StrToNum(Tar->GroupID,Itm.GID,sizeof(Tar->GroupID),8) == false ||
|
|
||||||
StrToNum(Tar->Size,Itm.Size,sizeof(Tar->Size),8) == false ||
|
|
||||||
StrToNum(Tar->MTime,Itm.MTime,sizeof(Tar->MTime),8) == false ||
|
|
||||||
StrToNum(Tar->Major,Itm.Major,sizeof(Tar->Major),8) == false ||
|
|
||||||
StrToNum(Tar->Minor,Itm.Minor,sizeof(Tar->Minor),8) == false)
|
|
||||||
return _error->Error(_("Corrupted archive"));
|
|
||||||
|
|
||||||
// Grab the filename
|
|
||||||
if (LastLongName.empty() == false)
|
|
||||||
Itm.Name = (char *)LastLongName.c_str();
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Tar->Name[sizeof(Tar->Name)] = 0;
|
|
||||||
Itm.Name = Tar->Name;
|
|
||||||
}
|
|
||||||
if (Itm.Name[0] == '.' && Itm.Name[1] == '/' && Itm.Name[2] != 0)
|
|
||||||
Itm.Name += 2;
|
|
||||||
|
|
||||||
// Grab the link target
|
|
||||||
Tar->Name[sizeof(Tar->LinkName)] = 0;
|
|
||||||
Itm.LinkTarget = Tar->LinkName;
|
|
||||||
|
|
||||||
if (LastLongLink.empty() == false)
|
|
||||||
Itm.LinkTarget = (char *)LastLongLink.c_str();
|
|
||||||
|
|
||||||
// Convert the type over
|
|
||||||
switch (Tar->LinkFlag)
|
|
||||||
{
|
|
||||||
case NormalFile0:
|
|
||||||
case NormalFile:
|
|
||||||
Itm.Type = pkgDirStream::Item::File;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case HardLink:
|
|
||||||
Itm.Type = pkgDirStream::Item::HardLink;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SymbolicLink:
|
|
||||||
Itm.Type = pkgDirStream::Item::SymbolicLink;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CharacterDevice:
|
|
||||||
Itm.Type = pkgDirStream::Item::CharDevice;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case BlockDevice:
|
|
||||||
Itm.Type = pkgDirStream::Item::BlockDevice;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Directory:
|
|
||||||
Itm.Type = pkgDirStream::Item::Directory;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case FIFO:
|
|
||||||
Itm.Type = pkgDirStream::Item::FIFO;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case GNU_LongLink:
|
|
||||||
{
|
|
||||||
unsigned long Length = Itm.Size;
|
|
||||||
unsigned char Block[512];
|
|
||||||
while (Length > 0)
|
|
||||||
{
|
|
||||||
if (InFd.Read(Block,sizeof(Block),true) == false)
|
|
||||||
return false;
|
|
||||||
if (Length <= sizeof(Block))
|
|
||||||
{
|
|
||||||
LastLongLink.append(Block,Block+sizeof(Block));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
LastLongLink.append(Block,Block+sizeof(Block));
|
|
||||||
Length -= sizeof(Block);
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
case GNU_LongName:
|
|
||||||
{
|
|
||||||
unsigned long Length = Itm.Size;
|
|
||||||
unsigned char Block[512];
|
|
||||||
while (Length > 0)
|
|
||||||
{
|
|
||||||
if (InFd.Read(Block,sizeof(Block),true) == false)
|
|
||||||
return false;
|
|
||||||
if (Length < sizeof(Block))
|
|
||||||
{
|
|
||||||
LastLongName.append(Block,Block+sizeof(Block));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
LastLongName.append(Block,Block+sizeof(Block));
|
|
||||||
Length -= sizeof(Block);
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
BadRecord = true;
|
|
||||||
_error->Warning(_("Unkown TAR header type %u, member %s"),(unsigned)Tar->LinkFlag,Tar->Name);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
int Fd = -1;
|
|
||||||
if (BadRecord == false)
|
|
||||||
if (Stream.DoItem(Itm,Fd) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Copy the file over the FD
|
|
||||||
unsigned long Size = Itm.Size;
|
|
||||||
while (Size != 0)
|
|
||||||
{
|
|
||||||
unsigned char Junk[32*1024];
|
|
||||||
unsigned long Read = MIN(Size,sizeof(Junk));
|
|
||||||
if (InFd.Read(Junk,((Read+511)/512)*512) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (BadRecord == false)
|
|
||||||
{
|
|
||||||
if (Fd > 0)
|
|
||||||
{
|
|
||||||
if (write(Fd,Junk,Read) != (signed)Read)
|
|
||||||
return Stream.Fail(Itm,Fd);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* An Fd of -2 means to send to a special processing
|
|
||||||
function */
|
|
||||||
if (Fd == -2)
|
|
||||||
if (Stream.Process(Itm,Junk,Read,Itm.Size - Size) == false)
|
|
||||||
return Stream.Fail(Itm,Fd);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Size -= Read;
|
|
||||||
}
|
|
||||||
|
|
||||||
// And finish up
|
|
||||||
if (Itm.Size != 0 && BadRecord == false)
|
|
||||||
if (Stream.FinishedFile(Itm,Fd) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
LastLongName.erase();
|
|
||||||
LastLongLink.erase();
|
|
||||||
}
|
|
||||||
|
|
||||||
return Done(false);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,54 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: extracttar.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Extract a Tar - Tar Extractor
|
|
||||||
|
|
||||||
The tar extractor takes an ordinary gzip compressed tar stream from
|
|
||||||
the given file and explodes it, passing the individual items to the
|
|
||||||
given Directory Stream for processing.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_EXTRACTTAR_H
|
|
||||||
#define PKGLIB_EXTRACTTAR_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/extracttar.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/fileutl.h>
|
|
||||||
#include <apt-pkg/dirstream.h>
|
|
||||||
|
|
||||||
class ExtractTar
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
struct TarHeader;
|
|
||||||
|
|
||||||
// The varios types items can be
|
|
||||||
enum ItemType {NormalFile0 = '\0',NormalFile = '0',HardLink = '1',
|
|
||||||
SymbolicLink = '2',CharacterDevice = '3',
|
|
||||||
BlockDevice = '4',Directory = '5',FIFO = '6',
|
|
||||||
GNU_LongLink = 'K',GNU_LongName = 'L'};
|
|
||||||
|
|
||||||
FileFd &File;
|
|
||||||
unsigned long MaxInSize;
|
|
||||||
int GZPid;
|
|
||||||
FileFd InFd;
|
|
||||||
bool Eof;
|
|
||||||
|
|
||||||
// Fork and reap gzip
|
|
||||||
bool StartGzip();
|
|
||||||
bool Done(bool Force);
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
bool Go(pkgDirStream &Stream);
|
|
||||||
|
|
||||||
ExtractTar(FileFd &Fd,unsigned long Max);
|
|
||||||
virtual ~ExtractTar();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,30 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: database.cc,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Data Base Abstraction
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/database.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/database.h>
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// DataBase::GetMetaTmp - Get the temp dir /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This re-initializes the meta temporary directory if it hasn't yet
|
|
||||||
been inited for this cycle. The flag is the emptyness of MetaDir */
|
|
||||||
bool pkgDataBase::GetMetaTmp(string &Dir)
|
|
||||||
{
|
|
||||||
if (MetaDir.empty() == true)
|
|
||||||
if (InitMetaTmp(MetaDir) == false)
|
|
||||||
return false;
|
|
||||||
Dir = MetaDir;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,56 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: database.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Data Base Abstraction
|
|
||||||
|
|
||||||
This class provides a simple interface to an abstract notion of a
|
|
||||||
database directory for storing state information about the system.
|
|
||||||
|
|
||||||
The 'Meta' information for a package is the control information and
|
|
||||||
setup scripts stored inside the archive. GetMetaTmp returns the name of
|
|
||||||
a directory that is used to store named files containing the control
|
|
||||||
information.
|
|
||||||
|
|
||||||
The File Listing is the database of installed files. It is loaded
|
|
||||||
into the memory/persistent cache structure by the ReadFileList method.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_DATABASE_H
|
|
||||||
#define PKGLIB_DATABASE_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/database.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/filelist.h>
|
|
||||||
#include <apt-pkg/pkgcachegen.h>
|
|
||||||
|
|
||||||
class pkgDataBase
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
pkgCacheGenerator *Cache;
|
|
||||||
pkgFLCache *FList;
|
|
||||||
string MetaDir;
|
|
||||||
virtual bool InitMetaTmp(string &Dir) = 0;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Some manipulators for the cache and generator
|
|
||||||
inline pkgCache &GetCache() {return Cache->GetCache();};
|
|
||||||
inline pkgFLCache &GetFLCache() {return *FList;};
|
|
||||||
inline pkgCacheGenerator &GetGenerator() {return *Cache;};
|
|
||||||
|
|
||||||
bool GetMetaTmp(string &Dir);
|
|
||||||
virtual bool ReadyFileList(OpProgress &Progress) = 0;
|
|
||||||
virtual bool ReadyPkgCache(OpProgress &Progress) = 0;
|
|
||||||
virtual bool LoadChanges() = 0;
|
|
||||||
|
|
||||||
pkgDataBase() : Cache(0), FList(0) {};
|
|
||||||
virtual ~pkgDataBase() {delete Cache; delete FList;};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,263 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: debfile.cc,v 1.3 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Debian Archive File (.deb)
|
|
||||||
|
|
||||||
.DEB archives are AR files containing two tars and an empty marker
|
|
||||||
member called 'debian-binary'. The two tars contain the meta data and
|
|
||||||
the actual archive contents. Thus this class is a very simple wrapper
|
|
||||||
around ar/tar to simply extract the right tar files.
|
|
||||||
|
|
||||||
It also uses the deb package list parser to parse the control file
|
|
||||||
into the cache.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/debfile.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/debfile.h>
|
|
||||||
#include <apt-pkg/extracttar.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
#include <apt-pkg/deblistparser.h>
|
|
||||||
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// DebFile::debDebFile - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Open the AR file and check for consistency */
|
|
||||||
debDebFile::debDebFile(FileFd &File) : File(File), AR(File)
|
|
||||||
{
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Check the members for validity
|
|
||||||
if (CheckMember("debian-binary") == false ||
|
|
||||||
CheckMember("control.tar.gz") == false ||
|
|
||||||
CheckMember("data.tar.gz") == false)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DebFile::CheckMember - Check if a named member is in the archive /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is used to check for a correct deb and to give nicer error messages
|
|
||||||
for people playing around. */
|
|
||||||
bool debDebFile::CheckMember(const char *Name)
|
|
||||||
{
|
|
||||||
if (AR.FindMember(Name) == 0)
|
|
||||||
return _error->Error(_("This is not a valid DEB archive, missing '%s' member"),Name);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DebFile::GotoMember - Jump to a Member /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Jump in the file to the start of a named member and return the information
|
|
||||||
about that member. The caller can then read from the file up to the
|
|
||||||
returned size. Note, since this relies on the file position this is
|
|
||||||
a destructive operation, it also changes the last returned Member
|
|
||||||
structure - so don't nest them! */
|
|
||||||
const ARArchive::Member *debDebFile::GotoMember(const char *Name)
|
|
||||||
{
|
|
||||||
// Get the archive member and positition the file
|
|
||||||
const ARArchive::Member *Member = AR.FindMember(Name);
|
|
||||||
if (Member == 0)
|
|
||||||
{
|
|
||||||
_error->Error(_("Internal Error, could not locate member %s"),Name);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (File.Seek(Member->Start) == false)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return Member;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DebFile::ExtractControl - Extract Control information /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Extract the control information into the Database's temporary
|
|
||||||
directory. */
|
|
||||||
bool debDebFile::ExtractControl(pkgDataBase &DB)
|
|
||||||
{
|
|
||||||
// Get the archive member and positition the file
|
|
||||||
const ARArchive::Member *Member = GotoMember("control.tar.gz");
|
|
||||||
if (Member == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Prepare Tar
|
|
||||||
ControlExtract Extract;
|
|
||||||
ExtractTar Tar(File,Member->Size);
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Get into the temporary directory
|
|
||||||
string Cwd = SafeGetCWD();
|
|
||||||
string Tmp;
|
|
||||||
if (DB.GetMetaTmp(Tmp) == false)
|
|
||||||
return false;
|
|
||||||
if (chdir(Tmp.c_str()) != 0)
|
|
||||||
return _error->Errno("chdir",_("Couldn't change to %s"),Tmp.c_str());
|
|
||||||
|
|
||||||
// Do extraction
|
|
||||||
if (Tar.Go(Extract) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Switch out of the tmp directory.
|
|
||||||
if (chdir(Cwd.c_str()) != 0)
|
|
||||||
chdir("/");
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DebFile::ExtractArchive - Extract the archive data itself /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Simple wrapper around tar.. */
|
|
||||||
bool debDebFile::ExtractArchive(pkgDirStream &Stream)
|
|
||||||
{
|
|
||||||
// Get the archive member and positition the file
|
|
||||||
const ARArchive::Member *Member = AR.FindMember("data.tar.gz");
|
|
||||||
if (Member == 0)
|
|
||||||
return _error->Error(_("Internal Error, could not locate member"));
|
|
||||||
if (File.Seek(Member->Start) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Prepare Tar
|
|
||||||
ExtractTar Tar(File,Member->Size);
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return false;
|
|
||||||
return Tar.Go(Stream);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DebFile::MergeControl - Merge the control information /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This reads the extracted control file into the cache and returns the
|
|
||||||
version that was parsed. All this really does is select the correct
|
|
||||||
parser and correct file to parse. */
|
|
||||||
pkgCache::VerIterator debDebFile::MergeControl(pkgDataBase &DB)
|
|
||||||
{
|
|
||||||
// Open the control file
|
|
||||||
string Tmp;
|
|
||||||
if (DB.GetMetaTmp(Tmp) == false)
|
|
||||||
return pkgCache::VerIterator(DB.GetCache());
|
|
||||||
FileFd Fd(Tmp + "control",FileFd::ReadOnly);
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return pkgCache::VerIterator(DB.GetCache());
|
|
||||||
|
|
||||||
// Parse it
|
|
||||||
debListParser Parse(&Fd);
|
|
||||||
pkgCache::VerIterator Ver(DB.GetCache());
|
|
||||||
if (DB.GetGenerator().MergeList(Parse,&Ver) == false)
|
|
||||||
return pkgCache::VerIterator(DB.GetCache());
|
|
||||||
|
|
||||||
if (Ver.end() == true)
|
|
||||||
_error->Error(_("Failed to locate a valid control file"));
|
|
||||||
return Ver;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// DebFile::ControlExtract::DoItem - Control Tar Extraction /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This directory stream handler for the control tar handles extracting
|
|
||||||
it into the temporary meta directory. It only extracts files, it does
|
|
||||||
not create directories, links or anything else. */
|
|
||||||
bool debDebFile::ControlExtract::DoItem(Item &Itm,int &Fd)
|
|
||||||
{
|
|
||||||
if (Itm.Type != Item::File)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
/* Cleanse the file name, prevent people from trying to unpack into
|
|
||||||
absolute paths, .., etc */
|
|
||||||
for (char *I = Itm.Name; *I != 0; I++)
|
|
||||||
if (*I == '/')
|
|
||||||
*I = '_';
|
|
||||||
|
|
||||||
/* Force the ownership to be root and ensure correct permissions,
|
|
||||||
go-w, the rest are left untouched */
|
|
||||||
Itm.UID = 0;
|
|
||||||
Itm.GID = 0;
|
|
||||||
Itm.Mode &= ~(S_IWGRP | S_IWOTH);
|
|
||||||
|
|
||||||
return pkgDirStream::DoItem(Itm,Fd);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// MemControlExtract::DoItem - Check if it is the control file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This sets up to extract the control block member file into a memory
|
|
||||||
block of just the right size. All other files go into the bit bucket. */
|
|
||||||
bool debDebFile::MemControlExtract::DoItem(Item &Itm,int &Fd)
|
|
||||||
{
|
|
||||||
// At the control file, allocate buffer memory.
|
|
||||||
if (Member == Itm.Name)
|
|
||||||
{
|
|
||||||
delete [] Control;
|
|
||||||
Control = new char[Itm.Size+2];
|
|
||||||
IsControl = true;
|
|
||||||
Fd = -2; // Signal to pass to Process
|
|
||||||
Length = Itm.Size;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
IsControl = false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// MemControlExtract::Process - Process extracting the control file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Just memcopy the block from the tar extractor and put it in the right
|
|
||||||
place in the pre-allocated memory block. */
|
|
||||||
bool debDebFile::MemControlExtract::Process(Item &Itm,const unsigned char *Data,
|
|
||||||
unsigned long Size,unsigned long Pos)
|
|
||||||
{
|
|
||||||
memcpy(Control + Pos, Data,Size);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// MemControlExtract::Read - Read the control information from the deb /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This uses the internal tar extractor to fetch the control file, and then
|
|
||||||
it parses it into a tag section parser. */
|
|
||||||
bool debDebFile::MemControlExtract::Read(debDebFile &Deb)
|
|
||||||
{
|
|
||||||
// Get the archive member and positition the file
|
|
||||||
const ARArchive::Member *Member = Deb.GotoMember("control.tar.gz");
|
|
||||||
if (Member == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
// Extract it.
|
|
||||||
ExtractTar Tar(Deb.GetFile(),Member->Size);
|
|
||||||
if (Tar.Go(*this) == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (Control == 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
Control[Length] = '\n';
|
|
||||||
Control[Length+1] = '\n';
|
|
||||||
if (Section.Scan(Control,Length+2) == false)
|
|
||||||
return _error->Error(_("Unparsible control file"));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// MemControlExtract::TakeControl - Parse a memory block /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* The given memory block is loaded into the parser and parsed as a control
|
|
||||||
record. */
|
|
||||||
bool debDebFile::MemControlExtract::TakeControl(const void *Data,unsigned long Size)
|
|
||||||
{
|
|
||||||
delete [] Control;
|
|
||||||
Control = new char[Size+2];
|
|
||||||
Length = Size;
|
|
||||||
memcpy(Control,Data,Size);
|
|
||||||
|
|
||||||
Control[Length] = '\n';
|
|
||||||
Control[Length+1] = '\n';
|
|
||||||
return Section.Scan(Control,Length+2);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
|
|
@ -1,92 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: debfile.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Debian Archive File (.deb)
|
|
||||||
|
|
||||||
This Class handles all the operations performed directly on .deb
|
|
||||||
files. It makes use of the AR and TAR classes to give the necessary
|
|
||||||
external interface.
|
|
||||||
|
|
||||||
There are only two things that can be done with a raw package,
|
|
||||||
extract it's control information and extract the contents itself.
|
|
||||||
|
|
||||||
This should probably subclass an as-yet unwritten super class to
|
|
||||||
produce a generic archive mechanism.
|
|
||||||
|
|
||||||
The memory control file extractor is useful to extract a single file
|
|
||||||
into memory from the control.tar.gz
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_DEBFILE_H
|
|
||||||
#define PKGLIB_DEBFILE_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/debfile.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/arfile.h>
|
|
||||||
#include <apt-pkg/database.h>
|
|
||||||
#include <apt-pkg/dirstream.h>
|
|
||||||
#include <apt-pkg/tagfile.h>
|
|
||||||
|
|
||||||
class debDebFile
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
FileFd &File;
|
|
||||||
ARArchive AR;
|
|
||||||
|
|
||||||
bool CheckMember(const char *Name);
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
class ControlExtract;
|
|
||||||
class MemControlExtract;
|
|
||||||
|
|
||||||
bool ExtractControl(pkgDataBase &DB);
|
|
||||||
bool ExtractArchive(pkgDirStream &Stream);
|
|
||||||
pkgCache::VerIterator MergeControl(pkgDataBase &DB);
|
|
||||||
const ARArchive::Member *GotoMember(const char *Name);
|
|
||||||
inline FileFd &GetFile() {return File;};
|
|
||||||
|
|
||||||
debDebFile(FileFd &File);
|
|
||||||
};
|
|
||||||
|
|
||||||
class debDebFile::ControlExtract : public pkgDirStream
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
virtual bool DoItem(Item &Itm,int &Fd);
|
|
||||||
};
|
|
||||||
|
|
||||||
class debDebFile::MemControlExtract : public pkgDirStream
|
|
||||||
{
|
|
||||||
bool IsControl;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
char *Control;
|
|
||||||
pkgTagSection Section;
|
|
||||||
unsigned long Length;
|
|
||||||
string Member;
|
|
||||||
|
|
||||||
// Members from DirStream
|
|
||||||
virtual bool DoItem(Item &Itm,int &Fd);
|
|
||||||
virtual bool Process(Item &Itm,const unsigned char *Data,
|
|
||||||
unsigned long Size,unsigned long Pos);
|
|
||||||
|
|
||||||
|
|
||||||
// Helpers
|
|
||||||
bool Read(debDebFile &Deb);
|
|
||||||
bool TakeControl(const void *Data,unsigned long Size);
|
|
||||||
|
|
||||||
MemControlExtract() : IsControl(false), Control(0), Length(0), Member("control") {};
|
|
||||||
MemControlExtract(string Member) : IsControl(false), Control(0), Length(0), Member(Member) {};
|
|
||||||
~MemControlExtract() {delete [] Control;};
|
|
||||||
};
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,494 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: dpkgdb.cc,v 1.7 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
DPKGv1 Database Implemenation
|
|
||||||
|
|
||||||
This class provides parsers and other implementations for the DPKGv1
|
|
||||||
database. It reads the diversion file, the list files and the status
|
|
||||||
file to build both the list of currently installed files and the
|
|
||||||
currently installed package list.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/dpkgdb.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/dpkgdb.h>
|
|
||||||
#include <apt-pkg/configuration.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
#include <apt-pkg/progress.h>
|
|
||||||
#include <apt-pkg/tagfile.h>
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <sys/mman.h>
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <ctype.h>
|
|
||||||
#include <iostream>
|
|
||||||
/*}}}*/
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
// EraseDir - Erase A Directory /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is necessary to create a new empty sub directory. The caller should
|
|
||||||
invoke mkdir after this with the proper permissions and check for
|
|
||||||
error. Maybe stick this in fileutils */
|
|
||||||
static bool EraseDir(const char *Dir)
|
|
||||||
{
|
|
||||||
// First we try a simple RM
|
|
||||||
if (rmdir(Dir) == 0 ||
|
|
||||||
errno == ENOENT)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// A file? Easy enough..
|
|
||||||
if (errno == ENOTDIR)
|
|
||||||
{
|
|
||||||
if (unlink(Dir) != 0)
|
|
||||||
return _error->Errno("unlink",_("Failed to remove %s"),Dir);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Should not happen
|
|
||||||
if (errno != ENOTEMPTY)
|
|
||||||
return _error->Errno("rmdir",_("Failed to remove %s"),Dir);
|
|
||||||
|
|
||||||
// Purge it using rm
|
|
||||||
int Pid = ExecFork();
|
|
||||||
|
|
||||||
// Spawn the subprocess
|
|
||||||
if (Pid == 0)
|
|
||||||
{
|
|
||||||
execlp(_config->Find("Dir::Bin::rm","/bin/rm").c_str(),
|
|
||||||
"rm","-rf","--",Dir,0);
|
|
||||||
_exit(100);
|
|
||||||
}
|
|
||||||
return ExecWait(Pid,_config->Find("dir::bin::rm","/bin/rm").c_str());
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::debDpkgDB - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
debDpkgDB::debDpkgDB() : CacheMap(0), FileMap(0)
|
|
||||||
{
|
|
||||||
AdminDir = flNotFile(_config->Find("Dir::State::status"));
|
|
||||||
DiverInode = 0;
|
|
||||||
DiverTime = 0;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::~debDpkgDB - Destructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
debDpkgDB::~debDpkgDB()
|
|
||||||
{
|
|
||||||
delete Cache;
|
|
||||||
Cache = 0;
|
|
||||||
delete CacheMap;
|
|
||||||
CacheMap = 0;
|
|
||||||
|
|
||||||
delete FList;
|
|
||||||
FList = 0;
|
|
||||||
delete FileMap;
|
|
||||||
FileMap = 0;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::InitMetaTmp - Get the temp dir for meta information /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This creats+empties the meta temporary directory /var/lib/dpkg/tmp.ci
|
|
||||||
Only one package at a time can be using the returned meta directory. */
|
|
||||||
bool debDpkgDB::InitMetaTmp(string &Dir)
|
|
||||||
{
|
|
||||||
string Tmp = AdminDir + "tmp.ci/";
|
|
||||||
if (EraseDir(Tmp.c_str()) == false)
|
|
||||||
return _error->Error(_("Unable to create %s"),Tmp.c_str());
|
|
||||||
if (mkdir(Tmp.c_str(),0755) != 0)
|
|
||||||
return _error->Errno("mkdir",_("Unable to create %s"),Tmp.c_str());
|
|
||||||
|
|
||||||
// Verify it is on the same filesystem as the main info directory
|
|
||||||
dev_t Dev;
|
|
||||||
struct stat St;
|
|
||||||
if (stat((AdminDir + "info").c_str(),&St) != 0)
|
|
||||||
return _error->Errno("stat",_("Failed to stat %sinfo"),AdminDir.c_str());
|
|
||||||
Dev = St.st_dev;
|
|
||||||
if (stat(Tmp.c_str(),&St) != 0)
|
|
||||||
return _error->Errno("stat",_("Failed to stat %s"),Tmp.c_str());
|
|
||||||
if (Dev != St.st_dev)
|
|
||||||
return _error->Error(_("The info and temp directories need to be on the same filesystem"));
|
|
||||||
|
|
||||||
// Done
|
|
||||||
Dir = Tmp;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::ReadyPkgCache - Prepare the cache with the current status /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This reads in the status file into an empty cache. This really needs
|
|
||||||
to be somehow unified with the high level APT notion of the Database
|
|
||||||
directory, but there is no clear way on how to do that yet. */
|
|
||||||
bool debDpkgDB::ReadyPkgCache(OpProgress &Progress)
|
|
||||||
{
|
|
||||||
if (Cache != 0)
|
|
||||||
{
|
|
||||||
Progress.OverallProgress(1,1,1,_("Reading Package Lists"));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (CacheMap != 0)
|
|
||||||
{
|
|
||||||
delete CacheMap;
|
|
||||||
CacheMap = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pkgMakeOnlyStatusCache(Progress,&CacheMap) == false)
|
|
||||||
return false;
|
|
||||||
Cache->DropProgress();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::ReadFList - Read the File Listings in /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This reads the file listing in from the state directory. This is a
|
|
||||||
performance critical routine, as it needs to parse about 50k lines of
|
|
||||||
text spread over a hundred or more files. For an initial cold start
|
|
||||||
most of the time is spent in reading file inodes and so on, not
|
|
||||||
actually parsing. */
|
|
||||||
bool debDpkgDB::ReadFList(OpProgress &Progress)
|
|
||||||
{
|
|
||||||
// Count the number of packages we need to read information for
|
|
||||||
unsigned long Total = 0;
|
|
||||||
pkgCache &Cache = this->Cache->GetCache();
|
|
||||||
for (pkgCache::PkgIterator I = Cache.PkgBegin(); I.end() == false; I++)
|
|
||||||
{
|
|
||||||
// Only not installed packages have no files.
|
|
||||||
if (I->CurrentState == pkgCache::State::NotInstalled)
|
|
||||||
continue;
|
|
||||||
Total++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Switch into the admin dir, this prevents useless lookups for the
|
|
||||||
path components */
|
|
||||||
string Cwd = SafeGetCWD();
|
|
||||||
if (chdir((AdminDir + "info/").c_str()) != 0)
|
|
||||||
return _error->Errno("chdir",_("Failed to change to the admin dir %sinfo"),AdminDir.c_str());
|
|
||||||
|
|
||||||
// Allocate a buffer. Anything larger than this buffer will be mmaped
|
|
||||||
unsigned long BufSize = 32*1024;
|
|
||||||
char *Buffer = new char[BufSize];
|
|
||||||
|
|
||||||
// Begin Loading them
|
|
||||||
unsigned long Count = 0;
|
|
||||||
char Name[300];
|
|
||||||
for (pkgCache::PkgIterator I = Cache.PkgBegin(); I.end() == false; I++)
|
|
||||||
{
|
|
||||||
/* Only not installed packages have no files. ConfFile packages have
|
|
||||||
file lists but we don't want to read them in */
|
|
||||||
if (I->CurrentState == pkgCache::State::NotInstalled ||
|
|
||||||
I->CurrentState == pkgCache::State::ConfigFiles)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Fetch a package handle to associate with the file
|
|
||||||
pkgFLCache::PkgIterator FlPkg = FList->GetPkg(I.Name(),0,true);
|
|
||||||
if (FlPkg.end() == true)
|
|
||||||
{
|
|
||||||
_error->Error(_("Internal Error getting a Package Name"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
Progress.OverallProgress(Count,Total,1,_("Reading File Listing"));
|
|
||||||
|
|
||||||
// Open the list file
|
|
||||||
snprintf(Name,sizeof(Name),"%s.list",I.Name());
|
|
||||||
int Fd = open(Name,O_RDONLY);
|
|
||||||
|
|
||||||
/* Okay this is very strange and bad.. Best thing is to bail and
|
|
||||||
instruct the user to look into it. */
|
|
||||||
struct stat Stat;
|
|
||||||
if (Fd == -1 || fstat(Fd,&Stat) != 0)
|
|
||||||
{
|
|
||||||
_error->Errno("open",_("Failed to open the list file '%sinfo/%s'. If you "
|
|
||||||
"cannot restore this file then make it empty "
|
|
||||||
"and immediately re-install the same version of the package!"),
|
|
||||||
AdminDir.c_str(),Name);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set File to be a memory buffer containing the whole file
|
|
||||||
char *File;
|
|
||||||
if ((unsigned)Stat.st_size < BufSize)
|
|
||||||
{
|
|
||||||
if (read(Fd,Buffer,Stat.st_size) != Stat.st_size)
|
|
||||||
{
|
|
||||||
_error->Errno("read",_("Failed reading the list file %sinfo/%s"),
|
|
||||||
AdminDir.c_str(),Name);
|
|
||||||
close(Fd);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
File = Buffer;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// Use mmap
|
|
||||||
File = (char *)mmap(0,Stat.st_size,PROT_READ,MAP_PRIVATE,Fd,0);
|
|
||||||
if (File == (char *)(-1))
|
|
||||||
{
|
|
||||||
_error->Errno("mmap",_("Failed reading the list file %sinfo/%s"),
|
|
||||||
AdminDir.c_str(),Name);
|
|
||||||
close(Fd);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parse it
|
|
||||||
const char *Start = File;
|
|
||||||
const char *End = File;
|
|
||||||
const char *Finish = File + Stat.st_size;
|
|
||||||
for (; End < Finish; End++)
|
|
||||||
{
|
|
||||||
// Not an end of line
|
|
||||||
if (*End != '\n' && End + 1 < Finish)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Skip blank lines
|
|
||||||
if (End - Start > 1)
|
|
||||||
{
|
|
||||||
pkgFLCache::NodeIterator Node = FList->GetNode(Start,End,
|
|
||||||
FlPkg.Offset(),true,false);
|
|
||||||
if (Node.end() == true)
|
|
||||||
{
|
|
||||||
_error->Error(_("Internal Error getting a Node"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Skip past the end of line
|
|
||||||
for (; *End == '\n' && End < Finish; End++);
|
|
||||||
Start = End;
|
|
||||||
}
|
|
||||||
|
|
||||||
close(Fd);
|
|
||||||
if ((unsigned)Stat.st_size >= BufSize)
|
|
||||||
munmap((caddr_t)File,Stat.st_size);
|
|
||||||
|
|
||||||
// Failed
|
|
||||||
if (End < Finish)
|
|
||||||
break;
|
|
||||||
|
|
||||||
Count++;
|
|
||||||
}
|
|
||||||
|
|
||||||
delete [] Buffer;
|
|
||||||
if (chdir(Cwd.c_str()) != 0)
|
|
||||||
chdir("/");
|
|
||||||
|
|
||||||
return !_error->PendingError();
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::ReadDiversions - Load the diversions file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Read the diversion file in from disk. This is usually invoked by
|
|
||||||
LoadChanges before performing an operation that uses the FLCache. */
|
|
||||||
bool debDpkgDB::ReadDiversions()
|
|
||||||
{
|
|
||||||
struct stat Stat;
|
|
||||||
if (stat((AdminDir + "diversions").c_str(),&Stat) != 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
FILE *Fd = fopen((AdminDir + "diversions").c_str(),"r");
|
|
||||||
if (Fd == 0)
|
|
||||||
return _error->Errno("fopen",_("Failed to open the diversions file %sdiversions"),AdminDir.c_str());
|
|
||||||
|
|
||||||
FList->BeginDiverLoad();
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
char From[300];
|
|
||||||
char To[300];
|
|
||||||
char Package[100];
|
|
||||||
|
|
||||||
// Read the three lines in
|
|
||||||
if (fgets(From,sizeof(From),Fd) == 0)
|
|
||||||
break;
|
|
||||||
if (fgets(To,sizeof(To),Fd) == 0 ||
|
|
||||||
fgets(Package,sizeof(Package),Fd) == 0)
|
|
||||||
{
|
|
||||||
_error->Error(_("The diversion file is corrupted"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Strip the \ns
|
|
||||||
unsigned long Len = strlen(From);
|
|
||||||
if (Len < 2 || From[Len-1] != '\n')
|
|
||||||
_error->Error(_("Invalid line in the diversion file: %s"),From);
|
|
||||||
else
|
|
||||||
From[Len-1] = 0;
|
|
||||||
Len = strlen(To);
|
|
||||||
if (Len < 2 || To[Len-1] != '\n')
|
|
||||||
_error->Error(_("Invalid line in the diversion file: %s"),To);
|
|
||||||
else
|
|
||||||
To[Len-1] = 0;
|
|
||||||
Len = strlen(Package);
|
|
||||||
if (Len < 2 || Package[Len-1] != '\n')
|
|
||||||
_error->Error(_("Invalid line in the diversion file: %s"),Package);
|
|
||||||
else
|
|
||||||
Package[Len-1] = 0;
|
|
||||||
|
|
||||||
// Make sure the lines were parsed OK
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Fetch a package
|
|
||||||
if (strcmp(Package,":") == 0)
|
|
||||||
Package[0] = 0;
|
|
||||||
pkgFLCache::PkgIterator FlPkg = FList->GetPkg(Package,0,true);
|
|
||||||
if (FlPkg.end() == true)
|
|
||||||
{
|
|
||||||
_error->Error(_("Internal Error getting a Package Name"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Install the diversion
|
|
||||||
if (FList->AddDiversion(FlPkg,From,To) == false)
|
|
||||||
{
|
|
||||||
_error->Error(_("Internal Error adding a diversion"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (_error->PendingError() == false)
|
|
||||||
FList->FinishDiverLoad();
|
|
||||||
|
|
||||||
DiverInode = Stat.st_ino;
|
|
||||||
DiverTime = Stat.st_mtime;
|
|
||||||
|
|
||||||
fclose(Fd);
|
|
||||||
return !_error->PendingError();
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::ReadFileList - Read the file listing /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Read in the file listing. The file listing is created from three
|
|
||||||
sources, *.list, Conffile sections and the Diversion table. */
|
|
||||||
bool debDpkgDB::ReadyFileList(OpProgress &Progress)
|
|
||||||
{
|
|
||||||
if (Cache == 0)
|
|
||||||
return _error->Error(_("The pkg cache must be initialize first"));
|
|
||||||
if (FList != 0)
|
|
||||||
{
|
|
||||||
Progress.OverallProgress(1,1,1,_("Reading File List"));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the cache and read in the file listing
|
|
||||||
FileMap = new DynamicMMap(MMap::Public);
|
|
||||||
FList = new pkgFLCache(*FileMap);
|
|
||||||
if (_error->PendingError() == true ||
|
|
||||||
ReadFList(Progress) == false ||
|
|
||||||
ReadConfFiles() == false ||
|
|
||||||
ReadDiversions() == false)
|
|
||||||
{
|
|
||||||
delete FList;
|
|
||||||
delete FileMap;
|
|
||||||
FileMap = 0;
|
|
||||||
FList = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
cout << "Node: " << FList->HeaderP->NodeCount << ',' << FList->HeaderP->UniqNodes << endl;
|
|
||||||
cout << "Dir: " << FList->HeaderP->DirCount << endl;
|
|
||||||
cout << "Package: " << FList->HeaderP->PackageCount << endl;
|
|
||||||
cout << "HashSize: " << FList->HeaderP->HashSize << endl;
|
|
||||||
cout << "Size: " << FileMap->Size() << endl;
|
|
||||||
cout << endl;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::ReadConfFiles - Read the conf file sections from the s-file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Reading the conf files is done by reparsing the status file. This is
|
|
||||||
actually rather fast so it is no big deal. */
|
|
||||||
bool debDpkgDB::ReadConfFiles()
|
|
||||||
{
|
|
||||||
FileFd File(_config->FindFile("Dir::State::status"),FileFd::ReadOnly);
|
|
||||||
pkgTagFile Tags(&File);
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
pkgTagSection Section;
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
// Skip to the next section
|
|
||||||
unsigned long Offset = Tags.Offset();
|
|
||||||
if (Tags.Step(Section) == false)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Parse the line
|
|
||||||
const char *Start;
|
|
||||||
const char *Stop;
|
|
||||||
if (Section.Find("Conffiles",Start,Stop) == false)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
const char *PkgStart;
|
|
||||||
const char *PkgEnd;
|
|
||||||
if (Section.Find("Package",PkgStart,PkgEnd) == false)
|
|
||||||
return _error->Error(_("Failed to find a Package: Header, offset %lu"),Offset);
|
|
||||||
|
|
||||||
// Snag a package record for it
|
|
||||||
pkgFLCache::PkgIterator FlPkg = FList->GetPkg(PkgStart,PkgEnd,true);
|
|
||||||
if (FlPkg.end() == true)
|
|
||||||
return _error->Error(_("Internal Error getting a Package Name"));
|
|
||||||
|
|
||||||
// Parse the conf file lines
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
for (; isspace(*Start) != 0 && Start < Stop; Start++);
|
|
||||||
if (Start == Stop)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Split it into words
|
|
||||||
const char *End = Start;
|
|
||||||
for (; isspace(*End) == 0 && End < Stop; End++);
|
|
||||||
const char *StartMd5 = End;
|
|
||||||
for (; isspace(*StartMd5) != 0 && StartMd5 < Stop; StartMd5++);
|
|
||||||
const char *EndMd5 = StartMd5;
|
|
||||||
for (; isspace(*EndMd5) == 0 && EndMd5 < Stop; EndMd5++);
|
|
||||||
if (StartMd5 == EndMd5 || Start == End)
|
|
||||||
return _error->Error(_("Bad ConfFile section in the status file. Offset %lu"),Offset);
|
|
||||||
|
|
||||||
// Insert a new entry
|
|
||||||
unsigned char MD5[16];
|
|
||||||
if (Hex2Num(string(StartMd5,EndMd5-StartMd5),MD5,16) == false)
|
|
||||||
return _error->Error(_("Error parsing MD5. Offset %lu"),Offset);
|
|
||||||
|
|
||||||
if (FList->AddConfFile(Start,End,FlPkg,MD5) == false)
|
|
||||||
return false;
|
|
||||||
Start = EndMd5;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DpkgDB::LoadChanges - Read in any changed state files /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* The only file in the dpkg system that can change while packages are
|
|
||||||
unpacking is the diversions file. */
|
|
||||||
bool debDpkgDB::LoadChanges()
|
|
||||||
{
|
|
||||||
struct stat Stat;
|
|
||||||
if (stat((AdminDir + "diversions").c_str(),&Stat) != 0)
|
|
||||||
return true;
|
|
||||||
if (DiverInode == Stat.st_ino && DiverTime == Stat.st_mtime)
|
|
||||||
return true;
|
|
||||||
return ReadDiversions();
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,53 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: dpkgdb.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
DPKGv1 Data Base Implemenation
|
|
||||||
|
|
||||||
The DPKGv1 database is typically stored in /var/lib/dpkg/. For
|
|
||||||
DPKGv1 the 'meta' information is the contents of the .deb control.tar.gz
|
|
||||||
member prepended by the package name. The meta information is unpacked
|
|
||||||
in its temporary directory and then migrated into the main list dir
|
|
||||||
at a checkpoint.
|
|
||||||
|
|
||||||
Journaling is providing by syncronized file writes to the updates sub
|
|
||||||
directory.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_DPKGDB_H
|
|
||||||
#define PKGLIB_DPKGDB_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/dpkgdb.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/database.h>
|
|
||||||
|
|
||||||
class debDpkgDB : public pkgDataBase
|
|
||||||
{
|
|
||||||
protected:
|
|
||||||
|
|
||||||
string AdminDir;
|
|
||||||
DynamicMMap *CacheMap;
|
|
||||||
DynamicMMap *FileMap;
|
|
||||||
unsigned long DiverInode;
|
|
||||||
signed long DiverTime;
|
|
||||||
|
|
||||||
virtual bool InitMetaTmp(string &Dir);
|
|
||||||
bool ReadFList(OpProgress &Progress);
|
|
||||||
bool ReadDiversions();
|
|
||||||
bool ReadConfFiles();
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
virtual bool ReadyFileList(OpProgress &Progress);
|
|
||||||
virtual bool ReadyPkgCache(OpProgress &Progress);
|
|
||||||
virtual bool LoadChanges();
|
|
||||||
|
|
||||||
debDpkgDB();
|
|
||||||
virtual ~debDpkgDB();
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,104 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: dirstream.cc,v 1.3 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Directory Stream
|
|
||||||
|
|
||||||
This class provides a simple basic extractor that can be used for
|
|
||||||
a number of purposes.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/dirstream.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/dirstream.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <utime.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// DirStream::DoItem - Process an item /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is a very simple extractor, it does not deal with things like
|
|
||||||
overwriting directories with files and so on. */
|
|
||||||
bool pkgDirStream::DoItem(Item &Itm,int &Fd)
|
|
||||||
{
|
|
||||||
switch (Itm.Type)
|
|
||||||
{
|
|
||||||
case Item::File:
|
|
||||||
{
|
|
||||||
/* Open the output file, NDELAY is used to prevent this from
|
|
||||||
blowing up on device special files.. */
|
|
||||||
int iFd = open(Itm.Name,O_NDELAY|O_WRONLY|O_CREAT|O_TRUNC|O_APPEND,
|
|
||||||
Itm.Mode);
|
|
||||||
if (iFd < 0)
|
|
||||||
return _error->Errno("open",_("Failed write file %s"),
|
|
||||||
Itm.Name);
|
|
||||||
|
|
||||||
// fchmod deals with umask and fchown sets the ownership
|
|
||||||
if (fchmod(iFd,Itm.Mode) != 0)
|
|
||||||
return _error->Errno("fchmod",_("Failed write file %s"),
|
|
||||||
Itm.Name);
|
|
||||||
if (fchown(iFd,Itm.UID,Itm.GID) != 0 && errno != EPERM)
|
|
||||||
return _error->Errno("fchown",_("Failed write file %s"),
|
|
||||||
Itm.Name);
|
|
||||||
Fd = iFd;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case Item::HardLink:
|
|
||||||
case Item::SymbolicLink:
|
|
||||||
case Item::CharDevice:
|
|
||||||
case Item::BlockDevice:
|
|
||||||
case Item::Directory:
|
|
||||||
case Item::FIFO:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DirStream::FinishedFile - Finished processing a file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool pkgDirStream::FinishedFile(Item &Itm,int Fd)
|
|
||||||
{
|
|
||||||
if (Fd < 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
if (close(Fd) != 0)
|
|
||||||
return _error->Errno("close",_("Failed to close file %s"),Itm.Name);
|
|
||||||
|
|
||||||
/* Set the modification times. The only way it can fail is if someone
|
|
||||||
has futzed with our file, which is intolerable :> */
|
|
||||||
struct utimbuf Time;
|
|
||||||
Time.actime = Itm.MTime;
|
|
||||||
Time.modtime = Itm.MTime;
|
|
||||||
if (utime(Itm.Name,&Time) != 0)
|
|
||||||
_error->Errno("utime",_("Failed to close file %s"),Itm.Name);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// DirStream::Fail - Failed processing a file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool pkgDirStream::Fail(Item &Itm,int Fd)
|
|
||||||
{
|
|
||||||
if (Fd < 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
close(Fd);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,61 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: dirstream.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Directory Stream
|
|
||||||
|
|
||||||
When unpacking the contents of the archive are passed into a directory
|
|
||||||
stream class for analysis and processing. The class controls all aspects
|
|
||||||
of actually writing the directory stream from disk. The low level
|
|
||||||
archive handlers are only responsible for decoding the archive format
|
|
||||||
and sending events (via method calls) to the specified directory
|
|
||||||
stream.
|
|
||||||
|
|
||||||
When unpacking a real file the archive handler is passed back a file
|
|
||||||
handle to write the data to, this is to support strange
|
|
||||||
archives+unpacking methods. If that fd is -1 then the file data is
|
|
||||||
simply ignored.
|
|
||||||
|
|
||||||
The provided defaults do the 'Right Thing' for a normal unpacking
|
|
||||||
process (ie 'tar')
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_DIRSTREAM_H
|
|
||||||
#define PKGLIB_DIRSTREAM_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/dirstream.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
class pkgDirStream
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
// All possible information about a component
|
|
||||||
struct Item
|
|
||||||
{
|
|
||||||
enum Type_t {File, HardLink, SymbolicLink, CharDevice, BlockDevice,
|
|
||||||
Directory, FIFO} Type;
|
|
||||||
char *Name;
|
|
||||||
char *LinkTarget;
|
|
||||||
unsigned long Mode;
|
|
||||||
unsigned long UID;
|
|
||||||
unsigned long GID;
|
|
||||||
unsigned long Size;
|
|
||||||
unsigned long MTime;
|
|
||||||
unsigned long Major;
|
|
||||||
unsigned long Minor;
|
|
||||||
};
|
|
||||||
|
|
||||||
virtual bool DoItem(Item &Itm,int &Fd);
|
|
||||||
virtual bool Fail(Item &Itm,int Fd);
|
|
||||||
virtual bool FinishedFile(Item &Itm,int Fd);
|
|
||||||
virtual bool Process(Item &Itm,const unsigned char *Data,
|
|
||||||
unsigned long Size,unsigned long Pos) {return true;};
|
|
||||||
|
|
||||||
virtual ~pkgDirStream() {};
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,5 +0,0 @@
|
|||||||
- Replacing directories with files
|
|
||||||
dpkg permits this with the weak condition that the directory is owned only
|
|
||||||
by the package. APT requires that the directory have no files that are not
|
|
||||||
owned by the package. Replaces are specifically not checked to prevent
|
|
||||||
file list corruption.
|
|
@ -1,512 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: extract.cc,v 1.6 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Archive Extraction Directory Stream
|
|
||||||
|
|
||||||
Extraction for each file is a bit of an involved process. Each object
|
|
||||||
undergoes an atomic backup, overwrite, erase sequence. First the
|
|
||||||
object is unpacked to '.dpkg.new' then the original is hardlinked to
|
|
||||||
'.dpkg.tmp' and finally the new object is renamed to overwrite the old
|
|
||||||
one. From an external perspective the file never ceased to exist.
|
|
||||||
After the archive has been sucessfully unpacked the .dpkg.tmp files
|
|
||||||
are erased. A failure causes all the .dpkg.tmp files to be restored.
|
|
||||||
|
|
||||||
Decisions about unpacking go like this:
|
|
||||||
- Store the original filename in the file listing
|
|
||||||
- Resolve any diversions that would effect this file, all checks
|
|
||||||
below apply to the diverted name, not the real one.
|
|
||||||
- Resolve any symlinked configuration files.
|
|
||||||
- If the existing file does not exist then .dpkg-tmp is checked for.
|
|
||||||
[Note, this is reduced to only check if a file was expected to be
|
|
||||||
there]
|
|
||||||
- If the existing link/file is not a directory then it is replaced
|
|
||||||
irregardless
|
|
||||||
- If the existing link/directory is being replaced by a directory then
|
|
||||||
absolutely nothing happens.
|
|
||||||
- If the existing link/directory is being replaced by a link then
|
|
||||||
absolutely nothing happens.
|
|
||||||
- If the existing link/directory is being replaced by a non-directory
|
|
||||||
then this will abort if the package is not the sole owner of the
|
|
||||||
directory. [Note, this is changed to not happen if the directory
|
|
||||||
non-empty - that is, it only includes files that are part of this
|
|
||||||
package - prevents removing user files accidentally.]
|
|
||||||
- If the non-directory exists in the listing database and it
|
|
||||||
does not belong to the current package then an overwrite condition
|
|
||||||
is invoked.
|
|
||||||
|
|
||||||
As we unpack we record the file list differences in the FL cache. If
|
|
||||||
we need to unroll the the FL cache knows which files have been unpacked
|
|
||||||
and can undo. When we need to erase then it knows which files have not
|
|
||||||
been unpacked.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/extract.h"
|
|
||||||
#endif
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/extract.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
#include <apt-pkg/debversion.h>
|
|
||||||
|
|
||||||
#include <sys/stat.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <dirent.h>
|
|
||||||
#include <iostream>
|
|
||||||
/*}}}*/
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
static const char *TempExt = "dpkg-tmp";
|
|
||||||
//static const char *NewExt = "dpkg-new";
|
|
||||||
|
|
||||||
// Extract::pkgExtract - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
pkgExtract::pkgExtract(pkgFLCache &FLCache,pkgCache::VerIterator Ver) :
|
|
||||||
FLCache(FLCache), Ver(Ver)
|
|
||||||
{
|
|
||||||
FLPkg = FLCache.GetPkg(Ver.ParentPkg().Name(),true);
|
|
||||||
if (FLPkg.end() == true)
|
|
||||||
return;
|
|
||||||
Debug = true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::DoItem - Handle a single item from the stream /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This performs the setup for the extraction.. */
|
|
||||||
bool pkgExtract::DoItem(Item &Itm,int &Fd)
|
|
||||||
{
|
|
||||||
char Temp[sizeof(FileName)];
|
|
||||||
|
|
||||||
/* Strip any leading/trailing /s from the filename, then copy it to the
|
|
||||||
temp buffer and re-apply the leading / We use a class variable
|
|
||||||
to store the new filename for use by the three extraction funcs */
|
|
||||||
char *End = FileName+1;
|
|
||||||
const char *I = Itm.Name;
|
|
||||||
for (; *I != 0 && *I == '/'; I++);
|
|
||||||
*FileName = '/';
|
|
||||||
for (; *I != 0 && End < FileName + sizeof(FileName); I++, End++)
|
|
||||||
*End = *I;
|
|
||||||
if (End + 20 >= FileName + sizeof(FileName))
|
|
||||||
return _error->Error(_("The path %s is too long"),Itm.Name);
|
|
||||||
for (; End > FileName && End[-1] == '/'; End--);
|
|
||||||
*End = 0;
|
|
||||||
Itm.Name = FileName;
|
|
||||||
|
|
||||||
/* Lookup the file. Nde is the file [group] we are going to write to and
|
|
||||||
RealNde is the actual node we are manipulating. Due to diversions
|
|
||||||
they may be entirely different. */
|
|
||||||
pkgFLCache::NodeIterator Nde = FLCache.GetNode(Itm.Name,End,0,false,false);
|
|
||||||
pkgFLCache::NodeIterator RealNde = Nde;
|
|
||||||
|
|
||||||
// See if the file is already in the file listing
|
|
||||||
unsigned long FileGroup = RealNde->File;
|
|
||||||
for (; RealNde.end() == false && FileGroup == RealNde->File; RealNde++)
|
|
||||||
if (RealNde.RealPackage() == FLPkg)
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Nope, create an entry
|
|
||||||
if (RealNde.end() == true)
|
|
||||||
{
|
|
||||||
RealNde = FLCache.GetNode(Itm.Name,End,FLPkg.Offset(),true,false);
|
|
||||||
if (RealNde.end() == true)
|
|
||||||
return false;
|
|
||||||
RealNde->Flags |= pkgFLCache::Node::NewFile;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Check if this entry already was unpacked. The only time this should
|
|
||||||
ever happen is if someone has hacked tar to support capabilities, in
|
|
||||||
which case this needs to be modified anyhow.. */
|
|
||||||
if ((RealNde->Flags & pkgFLCache::Node::Unpacked) ==
|
|
||||||
pkgFLCache::Node::Unpacked)
|
|
||||||
return _error->Error(_("Unpacking %s more than once"),Itm.Name);
|
|
||||||
|
|
||||||
if (Nde.end() == true)
|
|
||||||
Nde = RealNde;
|
|
||||||
|
|
||||||
/* Consider a diverted file - We are not permitted to divert directories,
|
|
||||||
but everything else is fair game (including conf files!) */
|
|
||||||
if ((Nde->Flags & pkgFLCache::Node::Diversion) != 0)
|
|
||||||
{
|
|
||||||
if (Itm.Type == Item::Directory)
|
|
||||||
return _error->Error(_("The directory %s is diverted"),Itm.Name);
|
|
||||||
|
|
||||||
/* A package overwriting a diversion target is just the same as
|
|
||||||
overwriting a normally owned file and is checked for below in
|
|
||||||
the overwrites mechanism */
|
|
||||||
|
|
||||||
/* If this package is trying to overwrite the target of a diversion,
|
|
||||||
that is never, ever permitted */
|
|
||||||
pkgFLCache::DiverIterator Div = Nde.Diversion();
|
|
||||||
if (Div.DivertTo() == Nde)
|
|
||||||
return _error->Error(_("The package is trying to write to the "
|
|
||||||
"diversion target %s/%s"),Nde.DirN(),Nde.File());
|
|
||||||
|
|
||||||
// See if it is us and we are following it in the right direction
|
|
||||||
if (Div->OwnerPkg != FLPkg.Offset() && Div.DivertFrom() == Nde)
|
|
||||||
{
|
|
||||||
Nde = Div.DivertTo();
|
|
||||||
End = FileName + snprintf(FileName,sizeof(FileName)-20,"%s/%s",
|
|
||||||
Nde.DirN(),Nde.File());
|
|
||||||
if (End <= FileName)
|
|
||||||
return _error->Error(_("The diversion path is too long"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Deal with symlinks and conf files
|
|
||||||
if ((RealNde->Flags & pkgFLCache::Node::NewConfFile) ==
|
|
||||||
pkgFLCache::Node::NewConfFile)
|
|
||||||
{
|
|
||||||
string Res = flNoLink(Itm.Name);
|
|
||||||
if (Res.length() > sizeof(FileName))
|
|
||||||
return _error->Error(_("The path %s is too long"),Res.c_str());
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "Followed conf file from " << FileName << " to " << Res << endl;
|
|
||||||
Itm.Name = strcpy(FileName,Res.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Get information about the existing file, and attempt to restore
|
|
||||||
a backup if it does not exist */
|
|
||||||
struct stat LExisting;
|
|
||||||
bool EValid = false;
|
|
||||||
if (lstat(Itm.Name,&LExisting) != 0)
|
|
||||||
{
|
|
||||||
// This is bad news.
|
|
||||||
if (errno != ENOENT)
|
|
||||||
return _error->Errno("stat",_("Failed to stat %s"),Itm.Name);
|
|
||||||
|
|
||||||
// See if we can recover the backup file
|
|
||||||
if (Nde.end() == false)
|
|
||||||
{
|
|
||||||
snprintf(Temp,sizeof(Temp),"%s.%s",Itm.Name,TempExt);
|
|
||||||
if (rename(Temp,Itm.Name) != 0 && errno != ENOENT)
|
|
||||||
return _error->Errno("rename",_("Failed to rename %s to %s"),
|
|
||||||
Temp,Itm.Name);
|
|
||||||
if (stat(Itm.Name,&LExisting) != 0)
|
|
||||||
{
|
|
||||||
if (errno != ENOENT)
|
|
||||||
return _error->Errno("stat",_("Failed to stat %s"),Itm.Name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
EValid = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
EValid = true;
|
|
||||||
|
|
||||||
/* If the file is a link we need to stat its destination, get the
|
|
||||||
existing file modes */
|
|
||||||
struct stat Existing = LExisting;
|
|
||||||
if (EValid == true && S_ISLNK(Existing.st_mode))
|
|
||||||
{
|
|
||||||
if (stat(Itm.Name,&Existing) != 0)
|
|
||||||
{
|
|
||||||
if (errno != ENOENT)
|
|
||||||
return _error->Errno("stat",_("Failed to stat %s"),Itm.Name);
|
|
||||||
Existing = LExisting;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// We pretend a non-existing file looks like it is a normal file
|
|
||||||
if (EValid == false)
|
|
||||||
Existing.st_mode = S_IFREG;
|
|
||||||
|
|
||||||
/* Okay, at this point 'Existing' is the stat information for the
|
|
||||||
real non-link file */
|
|
||||||
|
|
||||||
/* The only way this can be a no-op is if a directory is being
|
|
||||||
replaced by a directory or by a link */
|
|
||||||
if (S_ISDIR(Existing.st_mode) != 0 &&
|
|
||||||
(Itm.Type == Item::Directory || Itm.Type == Item::SymbolicLink))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
/* Non-Directory being replaced by non-directory. We check for over
|
|
||||||
writes here. */
|
|
||||||
if (Nde.end() == false)
|
|
||||||
{
|
|
||||||
if (HandleOverwrites(Nde) == false)
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Directory being replaced by a non-directory - this needs to see if
|
|
||||||
the package is the owner and then see if the directory would be
|
|
||||||
empty after the package is removed [ie no user files will be
|
|
||||||
erased] */
|
|
||||||
if (S_ISDIR(Existing.st_mode) != 0)
|
|
||||||
{
|
|
||||||
if (CheckDirReplace(Itm.Name) == false)
|
|
||||||
return _error->Error(_("The directory %s is being replaced by a non-directory"),Itm.Name);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "Extract " << string(Itm.Name,End) << endl;
|
|
||||||
/* if (Count != 0)
|
|
||||||
return _error->Error(_("Done"));*/
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::Finished - Sequence finished, erase the temp files /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool pkgExtract::Finished()
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::Aborted - Sequence aborted, undo all our unpacking /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This undoes everything that was done by all calls to the DoItem method
|
|
||||||
and restores the File Listing cache to its original form. It bases its
|
|
||||||
actions on the flags value for each node in the cache. */
|
|
||||||
bool pkgExtract::Aborted()
|
|
||||||
{
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "Aborted, backing out" << endl;
|
|
||||||
|
|
||||||
pkgFLCache::NodeIterator Files = FLPkg.Files();
|
|
||||||
map_ptrloc *Last = &FLPkg->Files;
|
|
||||||
|
|
||||||
/* Loop over all files, restore those that have been unpacked from their
|
|
||||||
dpkg-tmp entires */
|
|
||||||
while (Files.end() == false)
|
|
||||||
{
|
|
||||||
// Locate the hash bucket for the node and locate its group head
|
|
||||||
pkgFLCache::NodeIterator Nde(FLCache,FLCache.HashNode(Files));
|
|
||||||
for (; Nde.end() == false && Files->File != Nde->File; Nde++);
|
|
||||||
if (Nde.end() == true)
|
|
||||||
return _error->Error(_("Failed to locate node in its hash bucket"));
|
|
||||||
|
|
||||||
if (snprintf(FileName,sizeof(FileName)-20,"%s/%s",
|
|
||||||
Nde.DirN(),Nde.File()) <= 0)
|
|
||||||
return _error->Error(_("The path is too long"));
|
|
||||||
|
|
||||||
// Deal with diversions
|
|
||||||
if ((Nde->Flags & pkgFLCache::Node::Diversion) != 0)
|
|
||||||
{
|
|
||||||
pkgFLCache::DiverIterator Div = Nde.Diversion();
|
|
||||||
|
|
||||||
// See if it is us and we are following it in the right direction
|
|
||||||
if (Div->OwnerPkg != FLPkg.Offset() && Div.DivertFrom() == Nde)
|
|
||||||
{
|
|
||||||
Nde = Div.DivertTo();
|
|
||||||
if (snprintf(FileName,sizeof(FileName)-20,"%s/%s",
|
|
||||||
Nde.DirN(),Nde.File()) <= 0)
|
|
||||||
return _error->Error(_("The diversion path is too long"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Deal with overwrites+replaces
|
|
||||||
for (; Nde.end() == false && Files->File == Nde->File; Nde++)
|
|
||||||
{
|
|
||||||
if ((Nde->Flags & pkgFLCache::Node::Replaced) ==
|
|
||||||
pkgFLCache::Node::Replaced)
|
|
||||||
{
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "De-replaced " << FileName << " from " << Nde.RealPackage()->Name << endl;
|
|
||||||
Nde->Flags &= ~pkgFLCache::Node::Replaced;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Undo the change in the filesystem
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "Backing out " << FileName;
|
|
||||||
|
|
||||||
// Remove a new node
|
|
||||||
if ((Files->Flags & pkgFLCache::Node::NewFile) ==
|
|
||||||
pkgFLCache::Node::NewFile)
|
|
||||||
{
|
|
||||||
if (Debug == true)
|
|
||||||
clog << " [new node]" << endl;
|
|
||||||
pkgFLCache::Node *Tmp = Files;
|
|
||||||
Files++;
|
|
||||||
*Last = Tmp->NextPkg;
|
|
||||||
Tmp->NextPkg = 0;
|
|
||||||
|
|
||||||
FLCache.DropNode(Tmp - FLCache.NodeP);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (Debug == true)
|
|
||||||
clog << endl;
|
|
||||||
|
|
||||||
Last = &Files->NextPkg;
|
|
||||||
Files++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::Fail - Extraction of a file Failed /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool pkgExtract::Fail(Item &Itm,int Fd)
|
|
||||||
{
|
|
||||||
return pkgDirStream::Fail(Itm,Fd);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::FinishedFile - Finished a file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* */
|
|
||||||
bool pkgExtract::FinishedFile(Item &Itm,int Fd)
|
|
||||||
{
|
|
||||||
return pkgDirStream::FinishedFile(Itm,Fd);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::HandleOverwrites - See if a replaces covers this overwrite /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Check if the file is in a package that is being replaced by this
|
|
||||||
package or if the file is being overwritten. Note that if the file
|
|
||||||
is really a directory but it has been erased from the filesystem
|
|
||||||
this will fail with an overwrite message. This is a limitation of the
|
|
||||||
dpkg file information format.
|
|
||||||
|
|
||||||
XX If a new package installs and another package replaces files in this
|
|
||||||
package what should we do? */
|
|
||||||
bool pkgExtract::HandleOverwrites(pkgFLCache::NodeIterator Nde,
|
|
||||||
bool DiverCheck)
|
|
||||||
{
|
|
||||||
pkgFLCache::NodeIterator TmpNde = Nde;
|
|
||||||
unsigned long DiverOwner = 0;
|
|
||||||
unsigned long FileGroup = Nde->File;
|
|
||||||
const char *FirstOwner = 0;
|
|
||||||
for (; Nde.end() == false && FileGroup == Nde->File; Nde++)
|
|
||||||
{
|
|
||||||
if ((Nde->Flags & pkgFLCache::Node::Diversion) != 0)
|
|
||||||
{
|
|
||||||
/* Store the diversion owner if this is the forward direction
|
|
||||||
of the diversion */
|
|
||||||
if (DiverCheck == true)
|
|
||||||
DiverOwner = Nde.Diversion()->OwnerPkg;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
pkgFLCache::PkgIterator FPkg(FLCache,Nde.RealPackage());
|
|
||||||
if (FPkg.end() == true || FPkg == FLPkg)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* This tests trips when we are checking a diversion to see
|
|
||||||
if something has already been diverted by this diversion */
|
|
||||||
if (FPkg.Offset() == DiverOwner)
|
|
||||||
continue;
|
|
||||||
FirstOwner = FPkg.Name();
|
|
||||||
|
|
||||||
// Now see if this package matches one in a replace depends
|
|
||||||
pkgCache::DepIterator Dep = Ver.DependsList();
|
|
||||||
bool Ok = false;
|
|
||||||
for (; Dep.end() == false; Dep++)
|
|
||||||
{
|
|
||||||
if (Dep->Type != pkgCache::Dep::Replaces)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Does the replaces apply to this package?
|
|
||||||
if (strcmp(Dep.TargetPkg().Name(),FPkg.Name()) != 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* Check the version for match. I do not think CurrentVer can be
|
|
||||||
0 if we are here.. */
|
|
||||||
pkgCache::PkgIterator Pkg = Dep.TargetPkg();
|
|
||||||
if (Pkg->CurrentVer == 0)
|
|
||||||
{
|
|
||||||
_error->Warning(_("Overwrite package match with no version for %s"),Pkg.Name());
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Replaces is met
|
|
||||||
if (debVS.CheckDep(Pkg.CurrentVer().VerStr(),Dep->CompareOp,Dep.TargetVer()) == true)
|
|
||||||
{
|
|
||||||
if (Debug == true)
|
|
||||||
clog << "Replaced file " << Nde.DirN() << '/' << Nde.File() << " from " << Pkg.Name() << endl;
|
|
||||||
Nde->Flags |= pkgFLCache::Node::Replaced;
|
|
||||||
Ok = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Negative Hit
|
|
||||||
if (Ok == false)
|
|
||||||
return _error->Error(_("File %s/%s overwrites the one in the package %s"),
|
|
||||||
Nde.DirN(),Nde.File(),FPkg.Name());
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If this is a diversion we might have to recurse to process
|
|
||||||
the other side of it */
|
|
||||||
if ((TmpNde->Flags & pkgFLCache::Node::Diversion) != 0)
|
|
||||||
{
|
|
||||||
pkgFLCache::DiverIterator Div = TmpNde.Diversion();
|
|
||||||
if (Div.DivertTo() == TmpNde)
|
|
||||||
return HandleOverwrites(Div.DivertFrom(),true);
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// Extract::CheckDirReplace - See if this directory can be erased /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* If this directory is owned by a single package and that package is
|
|
||||||
replacing it with something non-directoryish then dpkg allows this.
|
|
||||||
We increase the requirement to be that the directory is non-empty after
|
|
||||||
the package is removed */
|
|
||||||
bool pkgExtract::CheckDirReplace(string Dir,unsigned int Depth)
|
|
||||||
{
|
|
||||||
// Looping?
|
|
||||||
if (Depth > 40)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (Dir[Dir.size() - 1] != '/')
|
|
||||||
Dir += '/';
|
|
||||||
|
|
||||||
DIR *D = opendir(Dir.c_str());
|
|
||||||
if (D == 0)
|
|
||||||
return _error->Errno("opendir",_("Unable to read %s"),Dir.c_str());
|
|
||||||
|
|
||||||
string File;
|
|
||||||
for (struct dirent *Dent = readdir(D); Dent != 0; Dent = readdir(D))
|
|
||||||
{
|
|
||||||
// Skip some files
|
|
||||||
if (strcmp(Dent->d_name,".") == 0 ||
|
|
||||||
strcmp(Dent->d_name,"..") == 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Look up the node
|
|
||||||
File = Dir + Dent->d_name;
|
|
||||||
pkgFLCache::NodeIterator Nde = FLCache.GetNode(File.c_str(),
|
|
||||||
File.c_str() + File.length(),0,false,false);
|
|
||||||
|
|
||||||
// The file is not owned by this package
|
|
||||||
if (Nde.end() != false || Nde.RealPackage() != FLPkg)
|
|
||||||
{
|
|
||||||
closedir(D);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// See if it is a directory
|
|
||||||
struct stat St;
|
|
||||||
if (lstat(File.c_str(),&St) != 0)
|
|
||||||
{
|
|
||||||
closedir(D);
|
|
||||||
return _error->Errno("lstat",_("Unable to stat %s"),File.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Recurse down directories
|
|
||||||
if (S_ISDIR(St.st_mode) != 0)
|
|
||||||
{
|
|
||||||
if (CheckDirReplace(File,Depth + 1) == false)
|
|
||||||
{
|
|
||||||
closedir(D);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// No conflicts
|
|
||||||
closedir(D);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,52 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: extract.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
Archive Extraction Directory Stream
|
|
||||||
|
|
||||||
This Directory Stream implements extraction of an archive into the
|
|
||||||
filesystem. It makes the choices on what files should be unpacked and
|
|
||||||
replaces as well as guiding the actual unpacking.
|
|
||||||
|
|
||||||
When the unpacking sequence is completed one of the two functions,
|
|
||||||
Finished or Aborted must be called.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_EXTRACT_H
|
|
||||||
#define PKGLIB_EXTRACT_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/extract.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/dirstream.h>
|
|
||||||
#include <apt-pkg/filelist.h>
|
|
||||||
#include <apt-pkg/pkgcache.h>
|
|
||||||
|
|
||||||
class pkgExtract : public pkgDirStream
|
|
||||||
{
|
|
||||||
pkgFLCache &FLCache;
|
|
||||||
pkgCache::VerIterator Ver;
|
|
||||||
pkgFLCache::PkgIterator FLPkg;
|
|
||||||
char FileName[1024];
|
|
||||||
bool Debug;
|
|
||||||
|
|
||||||
bool HandleOverwrites(pkgFLCache::NodeIterator Nde,
|
|
||||||
bool DiverCheck = false);
|
|
||||||
bool CheckDirReplace(string Dir,unsigned int Depth = 0);
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
virtual bool DoItem(Item &Itm,int &Fd);
|
|
||||||
virtual bool Fail(Item &Itm,int Fd);
|
|
||||||
virtual bool FinishedFile(Item &Itm,int Fd);
|
|
||||||
|
|
||||||
bool Finished();
|
|
||||||
bool Aborted();
|
|
||||||
|
|
||||||
pkgExtract(pkgFLCache &FLCache,pkgCache::VerIterator Ver);
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,591 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: filelist.cc,v 1.4 2003/02/10 00:36:12 doogie Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
File Listing - Manages a Cache of File -> Package names.
|
|
||||||
|
|
||||||
Diversions add some signficant complexity to the system. To keep
|
|
||||||
storage space down in the very special case of a diverted file no
|
|
||||||
extra bytes are allocated in the Node structure. Instead a diversion
|
|
||||||
is inserted directly into the hash table and its flag bit set. Every
|
|
||||||
lookup for that filename will always return the diversion.
|
|
||||||
|
|
||||||
The hash buckets are stored in sorted form, with diversions having
|
|
||||||
the higest sort order. Identical files are assigned the same file
|
|
||||||
pointer, thus after a search all of the nodes owning that file can be
|
|
||||||
found by iterating down the bucket.
|
|
||||||
|
|
||||||
Re-updates of diversions (another extremely special case) are done by
|
|
||||||
marking all diversions as untouched, then loading the entire diversion
|
|
||||||
list again, touching each diversion and then finally going back and
|
|
||||||
releasing all untouched diversions. It is assumed that the diversion
|
|
||||||
table will always be quite small and be a very irregular case.
|
|
||||||
|
|
||||||
Diversions that are user-installed are represented by a package with
|
|
||||||
an empty name string.
|
|
||||||
|
|
||||||
Conf files are handled like diversions by changing the meaning of the
|
|
||||||
Pointer field to point to a conf file entry - again to reduce over
|
|
||||||
head for a special case.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
// Include Files /*{{{*/
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma implementation "apt-pkg/filelist.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apti18n.h>
|
|
||||||
#include <apt-pkg/filelist.h>
|
|
||||||
#include <apt-pkg/mmap.h>
|
|
||||||
#include <apt-pkg/error.h>
|
|
||||||
#include <apt-pkg/strutl.h>
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <iostream>
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
// FlCache::Header::Header - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Initialize the header variables. These are the defaults used when
|
|
||||||
creating new caches */
|
|
||||||
pkgFLCache::Header::Header()
|
|
||||||
{
|
|
||||||
Signature = 0xEA3F1295;
|
|
||||||
|
|
||||||
/* Whenever the structures change the major version should be bumped,
|
|
||||||
whenever the generator changes the minor version should be bumped. */
|
|
||||||
MajorVersion = 1;
|
|
||||||
MinorVersion = 0;
|
|
||||||
Dirty = true;
|
|
||||||
|
|
||||||
HeaderSz = sizeof(pkgFLCache::Header);
|
|
||||||
NodeSz = sizeof(pkgFLCache::Node);
|
|
||||||
DirSz = sizeof(pkgFLCache::Directory);
|
|
||||||
PackageSz = sizeof(pkgFLCache::Package);
|
|
||||||
DiversionSz = sizeof(pkgFLCache::Diversion);
|
|
||||||
ConfFileSz = sizeof(pkgFLCache::ConfFile);
|
|
||||||
|
|
||||||
NodeCount = 0;
|
|
||||||
DirCount = 0;
|
|
||||||
PackageCount = 0;
|
|
||||||
DiversionCount = 0;
|
|
||||||
ConfFileCount = 0;
|
|
||||||
HashSize = 1 << 14;
|
|
||||||
|
|
||||||
FileHash = 0;
|
|
||||||
DirTree = 0;
|
|
||||||
Packages = 0;
|
|
||||||
Diversions = 0;
|
|
||||||
UniqNodes = 0;
|
|
||||||
memset(Pools,0,sizeof(Pools));
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::Header::CheckSizes - Check if the two headers have same *sz /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Compare to make sure we are matching versions */
|
|
||||||
bool pkgFLCache::Header::CheckSizes(Header &Against) const
|
|
||||||
{
|
|
||||||
if (HeaderSz == Against.HeaderSz &&
|
|
||||||
NodeSz == Against.NodeSz &&
|
|
||||||
DirSz == Against.DirSz &&
|
|
||||||
DiversionSz == Against.DiversionSz &&
|
|
||||||
PackageSz == Against.PackageSz &&
|
|
||||||
ConfFileSz == Against.ConfFileSz)
|
|
||||||
return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// FLCache::pkgFLCache - Constructor /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* If this is a new cache then a new header and hash table are instantaited
|
|
||||||
otherwise the existing ones are mearly attached */
|
|
||||||
pkgFLCache::pkgFLCache(DynamicMMap &Map) : Map(Map)
|
|
||||||
{
|
|
||||||
if (_error->PendingError() == true)
|
|
||||||
return;
|
|
||||||
|
|
||||||
LastTreeLookup = 0;
|
|
||||||
LastLookupSize = 0;
|
|
||||||
|
|
||||||
// Apply the typecasts
|
|
||||||
HeaderP = (Header *)Map.Data();
|
|
||||||
NodeP = (Node *)Map.Data();
|
|
||||||
DirP = (Directory *)Map.Data();
|
|
||||||
DiverP = (Diversion *)Map.Data();
|
|
||||||
PkgP = (Package *)Map.Data();
|
|
||||||
ConfP = (ConfFile *)Map.Data();
|
|
||||||
StrP = (char *)Map.Data();
|
|
||||||
AnyP = (unsigned char *)Map.Data();
|
|
||||||
|
|
||||||
// New mapping, create the basic cache structures
|
|
||||||
if (Map.Size() == 0)
|
|
||||||
{
|
|
||||||
Map.RawAllocate(sizeof(pkgFLCache::Header));
|
|
||||||
*HeaderP = pkgFLCache::Header();
|
|
||||||
HeaderP->FileHash = Map.RawAllocate(sizeof(pkgFLCache::Node)*HeaderP->HashSize,
|
|
||||||
sizeof(pkgFLCache::Node))/sizeof(pkgFLCache::Node);
|
|
||||||
}
|
|
||||||
|
|
||||||
FileHash = NodeP + HeaderP->FileHash;
|
|
||||||
|
|
||||||
// Setup the dynamic map manager
|
|
||||||
HeaderP->Dirty = true;
|
|
||||||
Map.Sync(0,sizeof(pkgFLCache::Header));
|
|
||||||
Map.UsePools(*HeaderP->Pools,sizeof(HeaderP->Pools)/sizeof(HeaderP->Pools[0]));
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::TreeLookup - Perform a lookup in a generic tree /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is a simple generic tree lookup. The first three entries of
|
|
||||||
the Directory structure are used as a template, but any other similar
|
|
||||||
structure could be used in it's place. */
|
|
||||||
map_ptrloc pkgFLCache::TreeLookup(map_ptrloc *Base,const char *Text,
|
|
||||||
const char *TextEnd,unsigned long Size,
|
|
||||||
unsigned int *Count,bool Insert)
|
|
||||||
{
|
|
||||||
pkgFLCache::Directory *Dir;
|
|
||||||
|
|
||||||
// Check our last entry cache
|
|
||||||
if (LastTreeLookup != 0 && LastLookupSize == Size)
|
|
||||||
{
|
|
||||||
Dir = (pkgFLCache::Directory *)(AnyP + LastTreeLookup*Size);
|
|
||||||
if (stringcmp(Text,TextEnd,StrP + Dir->Name) == 0)
|
|
||||||
return LastTreeLookup;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (1)
|
|
||||||
{
|
|
||||||
// Allocate a new one
|
|
||||||
if (*Base == 0)
|
|
||||||
{
|
|
||||||
if (Insert == false)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
*Base = Map.Allocate(Size);
|
|
||||||
if (*Base == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
(*Count)++;
|
|
||||||
Dir = (pkgFLCache::Directory *)(AnyP + *Base*Size);
|
|
||||||
Dir->Name = Map.WriteString(Text,TextEnd - Text);
|
|
||||||
LastTreeLookup = *Base;
|
|
||||||
LastLookupSize = Size;
|
|
||||||
return *Base;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Compare this node
|
|
||||||
Dir = (pkgFLCache::Directory *)(AnyP + *Base*Size);
|
|
||||||
int Res = stringcmp(Text,TextEnd,StrP + Dir->Name);
|
|
||||||
if (Res == 0)
|
|
||||||
{
|
|
||||||
LastTreeLookup = *Base;
|
|
||||||
LastLookupSize = Size;
|
|
||||||
return *Base;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Res > 0)
|
|
||||||
Base = &Dir->Left;
|
|
||||||
if (Res < 0)
|
|
||||||
Base = &Dir->Right;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::PrintTree - Print out a tree /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is a simple generic tree dumper, ment for debugging. */
|
|
||||||
void pkgFLCache::PrintTree(map_ptrloc Base,unsigned long Size)
|
|
||||||
{
|
|
||||||
if (Base == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
pkgFLCache::Directory *Dir = (pkgFLCache::Directory *)(AnyP + Base*Size);
|
|
||||||
PrintTree(Dir->Left,Size);
|
|
||||||
cout << (StrP + Dir->Name) << endl;
|
|
||||||
PrintTree(Dir->Right,Size);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::GetPkg - Get a package pointer /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Locate a package by name in it's tree, this is just a wrapper for
|
|
||||||
TreeLookup */
|
|
||||||
pkgFLCache::PkgIterator pkgFLCache::GetPkg(const char *Name,const char *NameEnd,
|
|
||||||
bool Insert)
|
|
||||||
{
|
|
||||||
if (NameEnd == 0)
|
|
||||||
NameEnd = Name + strlen(Name);
|
|
||||||
|
|
||||||
map_ptrloc Pos = TreeLookup(&HeaderP->Packages,Name,NameEnd,
|
|
||||||
sizeof(pkgFLCache::Package),
|
|
||||||
&HeaderP->PackageCount,Insert);
|
|
||||||
if (Pos == 0)
|
|
||||||
return pkgFLCache::PkgIterator();
|
|
||||||
return pkgFLCache::PkgIterator(*this,PkgP + Pos);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::GetNode - Get the node associated with the filename /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Lookup a node in the hash table. If Insert is true then a new node is
|
|
||||||
always inserted. The hash table can have multiple instances of a
|
|
||||||
single name available. A search returns the first. It is important
|
|
||||||
that additions for the same name insert after the first entry of
|
|
||||||
the name group. */
|
|
||||||
pkgFLCache::NodeIterator pkgFLCache::GetNode(const char *Name,
|
|
||||||
const char *NameEnd,
|
|
||||||
map_ptrloc Loc,
|
|
||||||
bool Insert,bool Divert)
|
|
||||||
{
|
|
||||||
// Split the name into file and directory, hashing as it is copied
|
|
||||||
const char *File = Name;
|
|
||||||
unsigned long HashPos = 0;
|
|
||||||
for (const char *I = Name; I < NameEnd; I++)
|
|
||||||
{
|
|
||||||
HashPos = 1637*HashPos + *I;
|
|
||||||
if (*I == '/')
|
|
||||||
File = I;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Search for it
|
|
||||||
Node *Hash = NodeP + HeaderP->FileHash + (HashPos % HeaderP->HashSize);
|
|
||||||
int Res = 0;
|
|
||||||
map_ptrloc FilePtr = 0;
|
|
||||||
while (Hash->Pointer != 0)
|
|
||||||
{
|
|
||||||
// Compare
|
|
||||||
Res = stringcmp(File+1,NameEnd,StrP + Hash->File);
|
|
||||||
if (Res == 0)
|
|
||||||
Res = stringcmp(Name,File,StrP + DirP[Hash->Dir].Name);
|
|
||||||
|
|
||||||
// Diversion?
|
|
||||||
if (Res == 0 && Insert == true)
|
|
||||||
{
|
|
||||||
/* Dir and File match exactly, we need to reuse the file name
|
|
||||||
when we link it in */
|
|
||||||
FilePtr = Hash->File;
|
|
||||||
Res = Divert - ((Hash->Flags & Node::Diversion) == Node::Diversion);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Is a match
|
|
||||||
if (Res == 0)
|
|
||||||
{
|
|
||||||
if (Insert == false)
|
|
||||||
return NodeIterator(*this,Hash);
|
|
||||||
|
|
||||||
// Only one diversion per name!
|
|
||||||
if (Divert == true)
|
|
||||||
return NodeIterator(*this,Hash);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Out of sort order
|
|
||||||
if (Res > 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (Hash->Next != 0)
|
|
||||||
Hash = NodeP + Hash->Next;
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fail, not found
|
|
||||||
if (Insert == false)
|
|
||||||
return NodeIterator(*this);
|
|
||||||
|
|
||||||
// Find a directory node
|
|
||||||
map_ptrloc Dir = TreeLookup(&HeaderP->DirTree,Name,File,
|
|
||||||
sizeof(pkgFLCache::Directory),
|
|
||||||
&HeaderP->DirCount,true);
|
|
||||||
if (Dir == 0)
|
|
||||||
return NodeIterator(*this);
|
|
||||||
|
|
||||||
// Allocate a new node
|
|
||||||
if (Hash->Pointer != 0)
|
|
||||||
{
|
|
||||||
// Overwrite or append
|
|
||||||
if (Res > 0)
|
|
||||||
{
|
|
||||||
Node *Next = NodeP + Map.Allocate(sizeof(*Hash));
|
|
||||||
if (Next == NodeP)
|
|
||||||
return NodeIterator(*this);
|
|
||||||
*Next = *Hash;
|
|
||||||
Hash->Next = Next - NodeP;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
unsigned long NewNext = Map.Allocate(sizeof(*Hash));
|
|
||||||
if (NewNext == 0)
|
|
||||||
return NodeIterator(*this);
|
|
||||||
NodeP[NewNext].Next = Hash->Next;
|
|
||||||
Hash->Next = NewNext;
|
|
||||||
Hash = NodeP + Hash->Next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Insert into the new item
|
|
||||||
Hash->Dir = Dir;
|
|
||||||
Hash->Pointer = Loc;
|
|
||||||
Hash->Flags = 0;
|
|
||||||
if (Divert == true)
|
|
||||||
Hash->Flags |= Node::Diversion;
|
|
||||||
|
|
||||||
if (FilePtr != 0)
|
|
||||||
Hash->File = FilePtr;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
HeaderP->UniqNodes++;
|
|
||||||
Hash->File = Map.WriteString(File+1,NameEnd - File-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Link the node to the package list
|
|
||||||
if (Divert == false && Loc == 0)
|
|
||||||
{
|
|
||||||
Hash->Next = PkgP[Loc].Files;
|
|
||||||
PkgP[Loc].Files = Hash - NodeP;
|
|
||||||
}
|
|
||||||
|
|
||||||
HeaderP->NodeCount++;
|
|
||||||
return NodeIterator(*this,Hash);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::HashNode - Return the hash bucket for the node /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This is one of two hashing functions. The other is inlined into the
|
|
||||||
GetNode routine. */
|
|
||||||
pkgFLCache::Node *pkgFLCache::HashNode(NodeIterator const &Nde)
|
|
||||||
{
|
|
||||||
// Hash the node
|
|
||||||
unsigned long HashPos = 0;
|
|
||||||
for (const char *I = Nde.DirN(); *I != 0; I++)
|
|
||||||
HashPos = 1637*HashPos + *I;
|
|
||||||
HashPos = 1637*HashPos + '/';
|
|
||||||
for (const char *I = Nde.File(); *I != 0; I++)
|
|
||||||
HashPos = 1637*HashPos + *I;
|
|
||||||
return NodeP + HeaderP->FileHash + (HashPos % HeaderP->HashSize);
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::DropNode - Drop a node from the hash table /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This erases a node from the hash table. Note that this does not unlink
|
|
||||||
the node from the package linked list. */
|
|
||||||
void pkgFLCache::DropNode(map_ptrloc N)
|
|
||||||
{
|
|
||||||
if (N == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
NodeIterator Nde(*this,NodeP + N);
|
|
||||||
|
|
||||||
if (Nde->NextPkg != 0)
|
|
||||||
_error->Warning(_("DropNode called on still linked node"));
|
|
||||||
|
|
||||||
// Locate it in the hash table
|
|
||||||
Node *Last = 0;
|
|
||||||
Node *Hash = HashNode(Nde);
|
|
||||||
while (Hash->Pointer != 0)
|
|
||||||
{
|
|
||||||
// Got it
|
|
||||||
if (Hash == Nde)
|
|
||||||
{
|
|
||||||
// Top of the bucket..
|
|
||||||
if (Last == 0)
|
|
||||||
{
|
|
||||||
Hash->Pointer = 0;
|
|
||||||
if (Hash->Next == 0)
|
|
||||||
return;
|
|
||||||
*Hash = NodeP[Hash->Next];
|
|
||||||
// Release Hash->Next
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Last->Next = Hash->Next;
|
|
||||||
// Release Hash
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Last = Hash;
|
|
||||||
if (Hash->Next != 0)
|
|
||||||
Hash = NodeP + Hash->Next;
|
|
||||||
else
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
_error->Error(_("Failed to locate the hash element!"));
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::BeginDiverLoad - Start reading new diversions /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Tag all the diversions as untouched */
|
|
||||||
void pkgFLCache::BeginDiverLoad()
|
|
||||||
{
|
|
||||||
for (DiverIterator I = DiverBegin(); I.end() == false; I++)
|
|
||||||
I->Flags = 0;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::FinishDiverLoad - Finish up a new diversion load /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This drops any untouched diversions. In effect removing any diversions
|
|
||||||
that where not loaded (ie missing from the diversion file) */
|
|
||||||
void pkgFLCache::FinishDiverLoad()
|
|
||||||
{
|
|
||||||
map_ptrloc *Cur = &HeaderP->Diversions;
|
|
||||||
while (*Cur != 0)
|
|
||||||
{
|
|
||||||
Diversion *Div = DiverP + *Cur;
|
|
||||||
if ((Div->Flags & Diversion::Touched) == Diversion::Touched)
|
|
||||||
{
|
|
||||||
Cur = &Div->Next;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Purge!
|
|
||||||
DropNode(Div->DivertTo);
|
|
||||||
DropNode(Div->DivertFrom);
|
|
||||||
*Cur = Div->Next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::AddDiversion - Add a new diversion /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Add a new diversion to the diverion tables and make sure that it is
|
|
||||||
unique and non-chaining. */
|
|
||||||
bool pkgFLCache::AddDiversion(PkgIterator const &Owner,
|
|
||||||
const char *From,const char *To)
|
|
||||||
{
|
|
||||||
/* Locate the two hash nodes we are going to manipulate. If there
|
|
||||||
are pre-existing diversions then they will be returned */
|
|
||||||
NodeIterator FromN = GetNode(From,From+strlen(From),0,true,true);
|
|
||||||
NodeIterator ToN = GetNode(To,To+strlen(To),0,true,true);
|
|
||||||
if (FromN.end() == true || ToN.end() == true)
|
|
||||||
return _error->Error(_("Failed to allocate diversion"));
|
|
||||||
|
|
||||||
// Should never happen
|
|
||||||
if ((FromN->Flags & Node::Diversion) != Node::Diversion ||
|
|
||||||
(ToN->Flags & Node::Diversion) != Node::Diversion)
|
|
||||||
return _error->Error(_("Internal Error in AddDiversion"));
|
|
||||||
|
|
||||||
// Now, try to reclaim an existing diversion..
|
|
||||||
map_ptrloc Diver = 0;
|
|
||||||
if (FromN->Pointer != 0)
|
|
||||||
Diver = FromN->Pointer;
|
|
||||||
|
|
||||||
/* Make sure from and to point to the same diversion, if they dont
|
|
||||||
then we are trying to intermix diversions - very bad */
|
|
||||||
if (ToN->Pointer != 0 && ToN->Pointer != Diver)
|
|
||||||
{
|
|
||||||
// It could be that the other diversion is no longer in use
|
|
||||||
if ((DiverP[ToN->Pointer].Flags & Diversion::Touched) == Diversion::Touched)
|
|
||||||
return _error->Error(_("Trying to overwrite a diversion, %s -> %s and %s/%s"),
|
|
||||||
From,To,ToN.File(),ToN.Dir().Name());
|
|
||||||
|
|
||||||
// We can erase it.
|
|
||||||
Diversion *Div = DiverP + ToN->Pointer;
|
|
||||||
ToN->Pointer = 0;
|
|
||||||
|
|
||||||
if (Div->DivertTo == ToN.Offset())
|
|
||||||
Div->DivertTo = 0;
|
|
||||||
if (Div->DivertFrom == ToN.Offset())
|
|
||||||
Div->DivertFrom = 0;
|
|
||||||
|
|
||||||
// This diversion will be cleaned up by FinishDiverLoad
|
|
||||||
}
|
|
||||||
|
|
||||||
// Allocate a new diversion
|
|
||||||
if (Diver == 0)
|
|
||||||
{
|
|
||||||
Diver = Map.Allocate(sizeof(Diversion));
|
|
||||||
if (Diver == 0)
|
|
||||||
return false;
|
|
||||||
DiverP[Diver].Next = HeaderP->Diversions;
|
|
||||||
HeaderP->Diversions = Diver;
|
|
||||||
HeaderP->DiversionCount++;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Can only have one diversion of the same files
|
|
||||||
Diversion *Div = DiverP + Diver;
|
|
||||||
if ((Div->Flags & Diversion::Touched) == Diversion::Touched)
|
|
||||||
return _error->Error(_("Double add of diversion %s -> %s"),From,To);
|
|
||||||
|
|
||||||
// Setup the From/To links
|
|
||||||
if (Div->DivertFrom != FromN.Offset() && Div->DivertFrom != ToN.Offset())
|
|
||||||
DropNode(Div->DivertFrom);
|
|
||||||
Div->DivertFrom = FromN.Offset();
|
|
||||||
if (Div->DivertTo != FromN.Offset() && Div->DivertTo != ToN.Offset())
|
|
||||||
DropNode(Div->DivertTo);
|
|
||||||
Div->DivertTo = ToN.Offset();
|
|
||||||
|
|
||||||
// Link it to the two nodes
|
|
||||||
FromN->Pointer = Diver;
|
|
||||||
ToN->Pointer = Diver;
|
|
||||||
|
|
||||||
// And the package
|
|
||||||
Div->OwnerPkg = Owner.Offset();
|
|
||||||
Div->Flags |= Diversion::Touched;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// FLCache::AddConfFile - Add a new configuration file /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This simply adds a new conf file node to the hash table. This is only
|
|
||||||
used by the status file reader. It associates a hash with each conf
|
|
||||||
file entry that exists in the status file and the list file for
|
|
||||||
the proper package. Duplicate conf files (across packages) are left
|
|
||||||
up to other routines to deal with. */
|
|
||||||
bool pkgFLCache::AddConfFile(const char *Name,const char *NameEnd,
|
|
||||||
PkgIterator const &Owner,
|
|
||||||
const unsigned char *Sum)
|
|
||||||
{
|
|
||||||
NodeIterator Nde = GetNode(Name,NameEnd,0,false,false);
|
|
||||||
if (Nde.end() == true)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
unsigned long File = Nde->File;
|
|
||||||
for (; Nde->File == File && Nde.end() == false; Nde++)
|
|
||||||
{
|
|
||||||
if (Nde.RealPackage() != Owner)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if ((Nde->Flags & Node::ConfFile) == Node::ConfFile)
|
|
||||||
return _error->Error(_("Duplicate conf file %s/%s"),Nde.DirN(),Nde.File());
|
|
||||||
|
|
||||||
// Allocate a new conf file structure
|
|
||||||
map_ptrloc Conf = Map.Allocate(sizeof(ConfFile));
|
|
||||||
if (Conf == 0)
|
|
||||||
return false;
|
|
||||||
ConfP[Conf].OwnerPkg = Owner.Offset();
|
|
||||||
memcpy(ConfP[Conf].MD5,Sum,sizeof(ConfP[Conf].MD5));
|
|
||||||
|
|
||||||
Nde->Pointer = Conf;
|
|
||||||
Nde->Flags |= Node::ConfFile;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* This means the conf file has been replaced, but the entry in the
|
|
||||||
status file was not updated */
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
|
|
||||||
// NodeIterator::RealPackage - Return the package for this node /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* Since the package pointer is indirected in all sorts of interesting ways
|
|
||||||
this is used to get a pointer to the owning package */
|
|
||||||
pkgFLCache::Package *pkgFLCache::NodeIterator::RealPackage() const
|
|
||||||
{
|
|
||||||
if (Nde->Pointer == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if ((Nde->Flags & Node::ConfFile) == Node::ConfFile)
|
|
||||||
return Owner->PkgP + Owner->ConfP[Nde->Pointer].OwnerPkg;
|
|
||||||
|
|
||||||
// Diversions are ignored
|
|
||||||
if ((Nde->Flags & Node::Diversion) == Node::Diversion)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return Owner->PkgP + Nde->Pointer;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
@ -1,314 +0,0 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
|
||||||
// Description /*{{{*/
|
|
||||||
// $Id: filelist.h,v 1.2 2002/07/25 18:07:17 niemeyer Exp $
|
|
||||||
/* ######################################################################
|
|
||||||
|
|
||||||
File Listing - Manages a Cache of File -> Package names.
|
|
||||||
|
|
||||||
This is identical to the Package cache, except that the generator
|
|
||||||
(which is much simpler) is integrated directly into the main class,
|
|
||||||
and it has been designed to handle live updates.
|
|
||||||
|
|
||||||
The storage content of the class is maintained in a memory map and is
|
|
||||||
written directly to the file system. Performance is traded against
|
|
||||||
space to give something that performs well and remains small.
|
|
||||||
The average per file usage is 32 bytes which yeilds about a meg every
|
|
||||||
36k files. Directory paths are collected into a binary tree and stored
|
|
||||||
only once, this offsets the cost of the hash nodes enough to keep
|
|
||||||
memory usage slightly less than the sum of the filenames.
|
|
||||||
|
|
||||||
The file names are stored into a fixed size chained hash table that is
|
|
||||||
linked to the package name and to the directory component.
|
|
||||||
|
|
||||||
Each file node has a set of associated flags that indicate the current
|
|
||||||
state of the file.
|
|
||||||
|
|
||||||
##################################################################### */
|
|
||||||
/*}}}*/
|
|
||||||
#ifndef PKGLIB_FILELIST_H
|
|
||||||
#define PKGLIB_FILELIST_H
|
|
||||||
|
|
||||||
#ifdef __GNUG__
|
|
||||||
#pragma interface "apt-pkg/filelist.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <apt-pkg/mmap.h>
|
|
||||||
|
|
||||||
class pkgFLCache
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
struct Header;
|
|
||||||
struct Node;
|
|
||||||
struct Directory;
|
|
||||||
struct Package;
|
|
||||||
struct Diversion;
|
|
||||||
struct ConfFile;
|
|
||||||
|
|
||||||
class NodeIterator;
|
|
||||||
class DirIterator;
|
|
||||||
class PkgIterator;
|
|
||||||
class DiverIterator;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
string CacheFile;
|
|
||||||
DynamicMMap ⤅
|
|
||||||
map_ptrloc LastTreeLookup;
|
|
||||||
unsigned long LastLookupSize;
|
|
||||||
|
|
||||||
// Helpers for the addition algorithms
|
|
||||||
map_ptrloc TreeLookup(map_ptrloc *Base,const char *Text,const char *TextEnd,
|
|
||||||
unsigned long Size,unsigned int *Count = 0,
|
|
||||||
bool Insert = false);
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Pointers to the arrays of items
|
|
||||||
Header *HeaderP;
|
|
||||||
Node *NodeP;
|
|
||||||
Directory *DirP;
|
|
||||||
Package *PkgP;
|
|
||||||
Diversion *DiverP;
|
|
||||||
ConfFile *ConfP;
|
|
||||||
char *StrP;
|
|
||||||
unsigned char *AnyP;
|
|
||||||
|
|
||||||
// Quick accessors
|
|
||||||
Node *FileHash;
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
Header &Head() {return *HeaderP;};
|
|
||||||
void PrintTree(map_ptrloc Base,unsigned long Size);
|
|
||||||
|
|
||||||
// Add/Find things
|
|
||||||
PkgIterator GetPkg(const char *Name,const char *End,bool Insert);
|
|
||||||
inline PkgIterator GetPkg(const char *Name,bool Insert);
|
|
||||||
NodeIterator GetNode(const char *Name,
|
|
||||||
const char *NameEnd,
|
|
||||||
map_ptrloc Loc,
|
|
||||||
bool Insert,bool Divert);
|
|
||||||
Node *HashNode(NodeIterator const &N);
|
|
||||||
void DropNode(map_ptrloc Node);
|
|
||||||
|
|
||||||
inline DiverIterator DiverBegin();
|
|
||||||
|
|
||||||
// Diversion control
|
|
||||||
void BeginDiverLoad();
|
|
||||||
void FinishDiverLoad();
|
|
||||||
bool AddDiversion(PkgIterator const &Owner,const char *From,
|
|
||||||
const char *To);
|
|
||||||
bool AddConfFile(const char *Name,const char *NameEnd,
|
|
||||||
PkgIterator const &Owner,const unsigned char *Sum);
|
|
||||||
|
|
||||||
pkgFLCache(DynamicMMap &Map);
|
|
||||||
// ~pkgFLCache();
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pkgFLCache::Header
|
|
||||||
{
|
|
||||||
// Signature information
|
|
||||||
unsigned long Signature;
|
|
||||||
short MajorVersion;
|
|
||||||
short MinorVersion;
|
|
||||||
bool Dirty;
|
|
||||||
|
|
||||||
// Size of structure values
|
|
||||||
unsigned HeaderSz;
|
|
||||||
unsigned NodeSz;
|
|
||||||
unsigned DirSz;
|
|
||||||
unsigned PackageSz;
|
|
||||||
unsigned DiversionSz;
|
|
||||||
unsigned ConfFileSz;
|
|
||||||
|
|
||||||
// Structure Counts;
|
|
||||||
unsigned int NodeCount;
|
|
||||||
unsigned int DirCount;
|
|
||||||
unsigned int PackageCount;
|
|
||||||
unsigned int DiversionCount;
|
|
||||||
unsigned int ConfFileCount;
|
|
||||||
unsigned int HashSize;
|
|
||||||
unsigned long UniqNodes;
|
|
||||||
|
|
||||||
// Offsets
|
|
||||||
map_ptrloc FileHash;
|
|
||||||
map_ptrloc DirTree;
|
|
||||||
map_ptrloc Packages;
|
|
||||||
map_ptrloc Diversions;
|
|
||||||
|
|
||||||
/* Allocation pools, there should be one of these for each structure
|
|
||||||
excluding the header */
|
|
||||||
DynamicMMap::Pool Pools[5];
|
|
||||||
|
|
||||||
bool CheckSizes(Header &Against) const;
|
|
||||||
Header();
|
|
||||||
};
|
|
||||||
|
|
||||||
/* The bit field is used to advoid incurring an extra 4 bytes x 40000,
|
|
||||||
Pointer is the most infrequently used member of the structure */
|
|
||||||
struct pkgFLCache::Node
|
|
||||||
{
|
|
||||||
map_ptrloc Dir; // Dir
|
|
||||||
map_ptrloc File; // String
|
|
||||||
unsigned Pointer:24; // Package/Diversion/ConfFile
|
|
||||||
unsigned Flags:8; // Package
|
|
||||||
map_ptrloc Next; // Node
|
|
||||||
map_ptrloc NextPkg; // Node
|
|
||||||
|
|
||||||
enum Flags {Diversion = (1<<0),ConfFile = (1<<1),
|
|
||||||
NewConfFile = (1<<2),NewFile = (1<<3),
|
|
||||||
Unpacked = (1<<4),Replaced = (1<<5)};
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pkgFLCache::Directory
|
|
||||||
{
|
|
||||||
map_ptrloc Left; // Directory
|
|
||||||
map_ptrloc Right; // Directory
|
|
||||||
map_ptrloc Name; // String
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pkgFLCache::Package
|
|
||||||
{
|
|
||||||
map_ptrloc Left; // Package
|
|
||||||
map_ptrloc Right; // Package
|
|
||||||
map_ptrloc Name; // String
|
|
||||||
map_ptrloc Files; // Node
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pkgFLCache::Diversion
|
|
||||||
{
|
|
||||||
map_ptrloc OwnerPkg; // Package
|
|
||||||
map_ptrloc DivertFrom; // Node
|
|
||||||
map_ptrloc DivertTo; // String
|
|
||||||
|
|
||||||
map_ptrloc Next; // Diversion
|
|
||||||
unsigned long Flags;
|
|
||||||
|
|
||||||
enum Flags {Touched = (1<<0)};
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pkgFLCache::ConfFile
|
|
||||||
{
|
|
||||||
map_ptrloc OwnerPkg; // Package
|
|
||||||
unsigned char MD5[16];
|
|
||||||
};
|
|
||||||
|
|
||||||
class pkgFLCache::PkgIterator
|
|
||||||
{
|
|
||||||
Package *Pkg;
|
|
||||||
pkgFLCache *Owner;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
inline bool end() const {return Owner == 0 || Pkg == Owner->PkgP?true:false;}
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
inline Package *operator ->() {return Pkg;};
|
|
||||||
inline Package const *operator ->() const {return Pkg;};
|
|
||||||
inline Package const &operator *() const {return *Pkg;};
|
|
||||||
inline operator Package *() {return Pkg == Owner->PkgP?0:Pkg;};
|
|
||||||
inline operator Package const *() const {return Pkg == Owner->PkgP?0:Pkg;};
|
|
||||||
|
|
||||||
inline unsigned long Offset() const {return Pkg - Owner->PkgP;};
|
|
||||||
inline const char *Name() const {return Pkg->Name == 0?0:Owner->StrP + Pkg->Name;};
|
|
||||||
inline pkgFLCache::NodeIterator Files() const;
|
|
||||||
|
|
||||||
PkgIterator() : Pkg(0), Owner(0) {};
|
|
||||||
PkgIterator(pkgFLCache &Owner,Package *Trg) : Pkg(Trg), Owner(&Owner) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
class pkgFLCache::DirIterator
|
|
||||||
{
|
|
||||||
Directory *Dir;
|
|
||||||
pkgFLCache *Owner;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
inline Directory *operator ->() {return Dir;};
|
|
||||||
inline Directory const *operator ->() const {return Dir;};
|
|
||||||
inline Directory const &operator *() const {return *Dir;};
|
|
||||||
inline operator Directory *() {return Dir == Owner->DirP?0:Dir;};
|
|
||||||
inline operator Directory const *() const {return Dir == Owner->DirP?0:Dir;};
|
|
||||||
|
|
||||||
inline const char *Name() const {return Dir->Name == 0?0:Owner->StrP + Dir->Name;};
|
|
||||||
|
|
||||||
DirIterator() : Dir(0), Owner(0) {};
|
|
||||||
DirIterator(pkgFLCache &Owner,Directory *Trg) : Dir(Trg), Owner(&Owner) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
class pkgFLCache::DiverIterator
|
|
||||||
{
|
|
||||||
Diversion *Diver;
|
|
||||||
pkgFLCache *Owner;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Iteration
|
|
||||||
void operator ++(int) {if (Diver != Owner->DiverP) Diver = Owner->DiverP + Diver->Next;};
|
|
||||||
inline void operator ++() {operator ++(0);};
|
|
||||||
inline bool end() const {return Owner == 0 || Diver == Owner->DiverP;};
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
inline Diversion *operator ->() {return Diver;};
|
|
||||||
inline Diversion const *operator ->() const {return Diver;};
|
|
||||||
inline Diversion const &operator *() const {return *Diver;};
|
|
||||||
inline operator Diversion *() {return Diver == Owner->DiverP?0:Diver;};
|
|
||||||
inline operator Diversion const *() const {return Diver == Owner->DiverP?0:Diver;};
|
|
||||||
|
|
||||||
inline PkgIterator OwnerPkg() const {return PkgIterator(*Owner,Owner->PkgP + Diver->OwnerPkg);};
|
|
||||||
inline NodeIterator DivertFrom() const;
|
|
||||||
inline NodeIterator DivertTo() const;
|
|
||||||
|
|
||||||
DiverIterator() : Diver(0), Owner(0) {};
|
|
||||||
DiverIterator(pkgFLCache &Owner,Diversion *Trg) : Diver(Trg), Owner(&Owner) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
class pkgFLCache::NodeIterator
|
|
||||||
{
|
|
||||||
Node *Nde;
|
|
||||||
enum {NdePkg, NdeHash} Type;
|
|
||||||
pkgFLCache *Owner;
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Iteration
|
|
||||||
void operator ++(int) {if (Nde != Owner->NodeP) Nde = Owner->NodeP +
|
|
||||||
(Type == NdePkg?Nde->NextPkg:Nde->Next);};
|
|
||||||
inline void operator ++() {operator ++(0);};
|
|
||||||
inline bool end() const {return Owner == 0 || Nde == Owner->NodeP;};
|
|
||||||
|
|
||||||
// Accessors
|
|
||||||
inline Node *operator ->() {return Nde;};
|
|
||||||
inline Node const *operator ->() const {return Nde;};
|
|
||||||
inline Node const &operator *() const {return *Nde;};
|
|
||||||
inline operator Node *() {return Nde == Owner->NodeP?0:Nde;};
|
|
||||||
inline operator Node const *() const {return Nde == Owner->NodeP?0:Nde;};
|
|
||||||
inline unsigned long Offset() const {return Nde - Owner->NodeP;};
|
|
||||||
inline DirIterator Dir() const {return DirIterator(*Owner,Owner->DirP + Nde->Dir);};
|
|
||||||
inline DiverIterator Diversion() const {return DiverIterator(*Owner,Owner->DiverP + Nde->Pointer);};
|
|
||||||
inline const char *File() const {return Nde->File == 0?0:Owner->StrP + Nde->File;};
|
|
||||||
inline const char *DirN() const {return Owner->StrP + Owner->DirP[Nde->Dir].Name;};
|
|
||||||
Package *RealPackage() const;
|
|
||||||
|
|
||||||
NodeIterator() : Nde(0), Type(NdeHash), Owner(0) {};
|
|
||||||
NodeIterator(pkgFLCache &Owner) : Nde(Owner.NodeP), Type(NdeHash), Owner(&Owner) {};
|
|
||||||
NodeIterator(pkgFLCache &Owner,Node *Trg) : Nde(Trg), Type(NdeHash), Owner(&Owner) {};
|
|
||||||
NodeIterator(pkgFLCache &Owner,Node *Trg,Package *) : Nde(Trg), Type(NdePkg), Owner(&Owner) {};
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Inlines with forward references that cannot be included directly in their
|
|
||||||
respsective classes */
|
|
||||||
inline pkgFLCache::NodeIterator pkgFLCache::DiverIterator::DivertFrom() const
|
|
||||||
{return NodeIterator(*Owner,Owner->NodeP + Diver->DivertFrom);};
|
|
||||||
inline pkgFLCache::NodeIterator pkgFLCache::DiverIterator::DivertTo() const
|
|
||||||
{return NodeIterator(*Owner,Owner->NodeP + Diver->DivertTo);};
|
|
||||||
|
|
||||||
inline pkgFLCache::NodeIterator pkgFLCache::PkgIterator::Files() const
|
|
||||||
{return NodeIterator(*Owner,Owner->NodeP + Pkg->Files,Pkg);};
|
|
||||||
|
|
||||||
inline pkgFLCache::DiverIterator pkgFLCache::DiverBegin()
|
|
||||||
{return DiverIterator(*this,DiverP + HeaderP->Diversions);};
|
|
||||||
|
|
||||||
inline pkgFLCache::PkgIterator pkgFLCache::GetPkg(const char *Name,bool Insert)
|
|
||||||
{return GetPkg(Name,Name+strlen(Name),Insert);};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,32 +0,0 @@
|
|||||||
# -*- make -*-
|
|
||||||
BASE=..
|
|
||||||
SUBDIR=apt-inst
|
|
||||||
|
|
||||||
# Header location
|
|
||||||
SUBDIRS = contrib deb
|
|
||||||
HEADER_TARGETDIRS = apt-pkg
|
|
||||||
|
|
||||||
# Bring in the default rules
|
|
||||||
include ../buildlib/defaults.mak
|
|
||||||
|
|
||||||
# The library name
|
|
||||||
LIBRARY=apt-inst
|
|
||||||
LIBEXT=$(GLIBC_VER)$(LIBSTDCPP_VER)
|
|
||||||
MAJOR=1.0
|
|
||||||
MINOR=0
|
|
||||||
SLIBS=$(PTHREADLIB) -lapt-pkg
|
|
||||||
APT_DOMAIN:=libapt-inst$(MAJOR)
|
|
||||||
|
|
||||||
# Source code for the contributed non-core things
|
|
||||||
SOURCE = contrib/extracttar.cc contrib/arfile.cc
|
|
||||||
|
|
||||||
# Source code for the main library
|
|
||||||
SOURCE+= filelist.cc database.cc dirstream.cc extract.cc \
|
|
||||||
deb/dpkgdb.cc deb/debfile.cc
|
|
||||||
|
|
||||||
# Public header files
|
|
||||||
HEADERS = extracttar.h arfile.h filelist.h database.h extract.h \
|
|
||||||
dpkgdb.h dirstream.h debfile.h
|
|
||||||
|
|
||||||
HEADERS := $(addprefix apt-pkg/,$(HEADERS))
|
|
||||||
include $(LIBRARY_H)
|
|
157
apt/apt-pkg/Makefile.am
Normal file
157
apt/apt-pkg/Makefile.am
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
|
||||||
|
lib_LTLIBRARIES = libapt-pkg.la
|
||||||
|
|
||||||
|
libapt_pkg_la_LIBADD = @RPMLIBS@
|
||||||
|
libapt_pkg_la_LDFLAGS = -version-info 1:1:1 -release @GLIBC_VER@-@LIBSTDCPP_VER@
|
||||||
|
|
||||||
|
AM_CPPFLAGS = -DLIBDIR=\"$(libdir)\"
|
||||||
|
|
||||||
|
INCLUDES = -I$(top_srcdir)/lua/include -I$(top_srcdir)/lua/local
|
||||||
|
|
||||||
|
if WITH_LUA
|
||||||
|
libapt_pkg_la_LIBADD += $(top_builddir)/lua/liblua.la
|
||||||
|
endif
|
||||||
|
|
||||||
|
libapt_pkg_la_SOURCES = \
|
||||||
|
contrib/cdromutl.cc \
|
||||||
|
contrib/cdromutl.h \
|
||||||
|
contrib/cmndline.cc \
|
||||||
|
contrib/cmndline.h \
|
||||||
|
contrib/configuration.cc \
|
||||||
|
contrib/configuration.h \
|
||||||
|
contrib/crc-16.cc \
|
||||||
|
contrib/crc-16.h \
|
||||||
|
contrib/error.cc \
|
||||||
|
contrib/error.h \
|
||||||
|
contrib/fileutl.cc \
|
||||||
|
contrib/fileutl.h \
|
||||||
|
contrib/hashes.cc \
|
||||||
|
contrib/hashes.h \
|
||||||
|
contrib/md5.cc \
|
||||||
|
contrib/md5.h \
|
||||||
|
contrib/mmap.cc \
|
||||||
|
contrib/mmap.h \
|
||||||
|
contrib/progress.cc \
|
||||||
|
contrib/progress.h \
|
||||||
|
contrib/sha1.cc \
|
||||||
|
contrib/sha1.h \
|
||||||
|
contrib/sptr.h \
|
||||||
|
contrib/strutl.cc \
|
||||||
|
contrib/strutl.h \
|
||||||
|
contrib/system.h \
|
||||||
|
rpm/rpmhandler.cc \
|
||||||
|
rpm/rpmhandler.h \
|
||||||
|
rpm/rpmindexfile.cc \
|
||||||
|
rpm/rpmindexfile.h \
|
||||||
|
rpm/rpmlistparser.cc \
|
||||||
|
rpm/rpmlistparser.h \
|
||||||
|
rpm/rpmmisc.h \
|
||||||
|
rpm/rpmpackagedata.cc \
|
||||||
|
rpm/rpmpackagedata.h \
|
||||||
|
rpm/rpmpm.cc \
|
||||||
|
rpm/rpmpm.h \
|
||||||
|
rpm/rpmshowprogress.h \
|
||||||
|
rpm/rpmrecords.cc \
|
||||||
|
rpm/rpmrecords.h \
|
||||||
|
rpm/rpmsrcrecords.cc \
|
||||||
|
rpm/rpmsrcrecords.h \
|
||||||
|
rpm/rpmsystem.cc \
|
||||||
|
rpm/rpmsystem.h \
|
||||||
|
rpm/rpmversion.cc \
|
||||||
|
rpm/rpmversion.h \
|
||||||
|
acquire.cc \
|
||||||
|
acquire.h \
|
||||||
|
acquire-item.cc \
|
||||||
|
acquire-item.h \
|
||||||
|
acquire-method.cc \
|
||||||
|
acquire-method.h \
|
||||||
|
acquire-worker.cc \
|
||||||
|
acquire-worker.h \
|
||||||
|
algorithms.cc \
|
||||||
|
algorithms.h \
|
||||||
|
cachefile.cc \
|
||||||
|
cachefile.h \
|
||||||
|
cacheiterators.h \
|
||||||
|
clean.cc \
|
||||||
|
clean.h \
|
||||||
|
depcache.cc \
|
||||||
|
depcache.h \
|
||||||
|
indexfile.cc \
|
||||||
|
indexfile.h \
|
||||||
|
init.cc \
|
||||||
|
init.h \
|
||||||
|
luaiface.cc \
|
||||||
|
luaiface.h \
|
||||||
|
orderlist.cc \
|
||||||
|
orderlist.h \
|
||||||
|
packagemanager.cc \
|
||||||
|
packagemanager.h \
|
||||||
|
pkgcache.cc \
|
||||||
|
pkgcachegen.cc \
|
||||||
|
pkgcachegen.h \
|
||||||
|
pkgcache.h \
|
||||||
|
pkgrecords.cc \
|
||||||
|
pkgrecords.h \
|
||||||
|
pkgsystem.cc \
|
||||||
|
pkgsystem.h \
|
||||||
|
policy.cc \
|
||||||
|
policy.h \
|
||||||
|
repository.cc \
|
||||||
|
repository.h \
|
||||||
|
sourcelist.cc \
|
||||||
|
sourcelist.h \
|
||||||
|
srcrecords.cc \
|
||||||
|
srcrecords.h \
|
||||||
|
tagfile.cc \
|
||||||
|
tagfile.h \
|
||||||
|
version.cc \
|
||||||
|
version.h \
|
||||||
|
versionmatch.cc \
|
||||||
|
versionmatch.h
|
||||||
|
|
||||||
|
PRIVATEHEADERS = contrib/system.h
|
||||||
|
|
||||||
|
includedir=${prefix}/include/apt-pkg
|
||||||
|
include_HEADERS = $(filter-out \
|
||||||
|
$(PRIVATEHEADERS), \
|
||||||
|
$(filter %.h,$(libapt_pkg_la_SOURCES)))
|
||||||
|
|
||||||
|
# This is a hack to allow us to maintain the original
|
||||||
|
# APT system of a a flat apt-pkg/ header directory.
|
||||||
|
PRIVREALHEADERS = $(PRIVATEHEADERS)
|
||||||
|
PRIVCOPYHEADERS = $(patsubst %.h, \
|
||||||
|
$(top_builddir)/include/%.h, \
|
||||||
|
$(notdir $(PRIVREALHEADERS)))
|
||||||
|
REALHEADERS = $(filter-out \
|
||||||
|
$(PRIVREALHEADERS), \
|
||||||
|
$(filter %.h,$(libapt_pkg_la_SOURCES)))
|
||||||
|
COPYHEADERS = $(patsubst %.h, \
|
||||||
|
$(top_builddir)/include/apt-pkg/%.h, \
|
||||||
|
$(notdir $(REALHEADERS)))
|
||||||
|
REALOBJECTS = $(patsubst %.cc,%.lo,\
|
||||||
|
$(filter %.cc,$(libapt_pkg_la_SOURCES)))
|
||||||
|
$(REALOBJECTS): $(COPYHEADERS) $(PRIVCOPYHEADERS)
|
||||||
|
|
||||||
|
$(top_builddir)/include/apt-pkg/%: %
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
$(top_builddir)/include/apt-pkg/%: contrib/%
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
$(top_builddir)/include/apt-pkg/%: rpm/%
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
$(top_builddir)/include/%: %
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
$(top_builddir)/include/%: contrib/%
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
$(top_builddir)/include/%: rpm/%
|
||||||
|
@$(mkinstalldirs) $(top_builddir)/include/apt-pkg
|
||||||
|
cp -f -p $< $@
|
||||||
|
|
||||||
|
clean-local:
|
||||||
|
rm -f $(PRIVCOPYHEADERS)
|
||||||
|
rm -rf $(top_builddir)/include/apt-pkg
|
||||||
|
|
1540
apt/apt-pkg/Makefile.in
Normal file
1540
apt/apt-pkg/Makefile.in
Normal file
File diff suppressed because it is too large
Load Diff
@ -26,7 +26,10 @@
|
|||||||
// CNC:2002-07-03
|
// CNC:2002-07-03
|
||||||
#include <apt-pkg/repository.h>
|
#include <apt-pkg/repository.h>
|
||||||
#include <apt-pkg/md5.h>
|
#include <apt-pkg/md5.h>
|
||||||
|
#include <config.h>
|
||||||
|
#include <apt-pkg/luaiface.h>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include <assert.h>
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
#include <apti18n.h>
|
#include <apti18n.h>
|
||||||
@ -188,7 +191,7 @@ pkgAcqIndex::pkgAcqIndex(pkgAcquire *Owner,pkgRepository *Repository,
|
|||||||
|
|
||||||
// Create the item
|
// Create the item
|
||||||
// CNC:2002-07-03
|
// CNC:2002-07-03
|
||||||
Desc.URI = URI + ".bz2";
|
Desc.URI = URI + _config->Find("Acquire::ComprExtension", ".bz2");
|
||||||
Desc.Description = URIDesc;
|
Desc.Description = URIDesc;
|
||||||
Desc.Owner = this;
|
Desc.Owner = this;
|
||||||
Desc.ShortDesc = ShortDesc;
|
Desc.ShortDesc = ShortDesc;
|
||||||
@ -773,6 +776,33 @@ bool pkgAcqArchive::QueueNext()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
|
// CNC:2003-03-19
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
// ScriptsAcquireDone - Script trigger. /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
template<class T>
|
||||||
|
static void ScriptsAcquireDone(const char *ConfKey,
|
||||||
|
string &StoreFilename,
|
||||||
|
string &ErrorText,
|
||||||
|
T &Status)
|
||||||
|
{
|
||||||
|
if (_lua->HasScripts(ConfKey) == true) {
|
||||||
|
_lua->SetGlobal("acquire_filename", StoreFilename.c_str());
|
||||||
|
_lua->SetGlobal("acquire_error", (const char *)NULL);
|
||||||
|
_lua->RunScripts(ConfKey, true);
|
||||||
|
const char *Error = _lua->GetGlobal("acquire_error");
|
||||||
|
if (Error != NULL && *Error != 0) {
|
||||||
|
Status = pkgAcquire::Item::StatError;
|
||||||
|
ErrorText = Error;
|
||||||
|
}
|
||||||
|
_lua->ResetGlobals();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
#endif
|
||||||
|
|
||||||
// AcqArchive::Done - Finished fetching /*{{{*/
|
// AcqArchive::Done - Finished fetching /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
@ -817,6 +847,13 @@ void pkgAcqArchive::Done(string Message,unsigned long Size,string Md5Hash,
|
|||||||
{
|
{
|
||||||
StoreFilename = DestFile = FileName;
|
StoreFilename = DestFile = FileName;
|
||||||
Local = true;
|
Local = true;
|
||||||
|
|
||||||
|
// CNC:2003-03-19
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
ScriptsAcquireDone("Scripts::Acquire::Archive::Done",
|
||||||
|
StoreFilename, ErrorText, Status);
|
||||||
|
#endif
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -827,6 +864,13 @@ void pkgAcqArchive::Done(string Message,unsigned long Size,string Md5Hash,
|
|||||||
|
|
||||||
StoreFilename = DestFile = FinalFile;
|
StoreFilename = DestFile = FinalFile;
|
||||||
Complete = true;
|
Complete = true;
|
||||||
|
|
||||||
|
// CNC:2003-03-19
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
ScriptsAcquireDone("Scripts::Acquire::Archive::Done",
|
||||||
|
StoreFilename, ErrorText, Status);
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
// AcqArchive::Failed - Failure handler /*{{{*/
|
// AcqArchive::Failed - Failure handler /*{{{*/
|
||||||
@ -965,6 +1009,13 @@ void pkgAcqFile::Done(string Message,unsigned long Size,string MD5,
|
|||||||
{
|
{
|
||||||
if (S_ISLNK(St.st_mode) != 0)
|
if (S_ISLNK(St.st_mode) != 0)
|
||||||
unlink(DestFile.c_str());
|
unlink(DestFile.c_str());
|
||||||
|
// CNC:2003-12-11 - Check if FileName == DestFile
|
||||||
|
else {
|
||||||
|
struct stat St2;
|
||||||
|
if (stat(FileName.c_str(), &St2) == 0
|
||||||
|
&& St.st_ino == St2.st_ino)
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Symlink the file
|
// Symlink the file
|
||||||
|
@ -46,7 +46,7 @@ class pkgAcquire::Item
|
|||||||
|
|
||||||
// State of the item
|
// State of the item
|
||||||
/* CNC:2002-11-22
|
/* CNC:2002-11-22
|
||||||
* Do not use anonyomus enums, as this breaks swig in some cases */
|
* Do not use anonyomus enums, as this breaks SWIG in some cases */
|
||||||
enum StatusFlags {StatIdle, StatFetching, StatDone, StatError} Status;
|
enum StatusFlags {StatIdle, StatFetching, StatDone, StatError} Status;
|
||||||
string ErrorText;
|
string ErrorText;
|
||||||
unsigned long FileSize;
|
unsigned long FileSize;
|
||||||
|
@ -419,7 +419,8 @@ bool pkgDistUpgrade(pkgDepCache &Cache)
|
|||||||
if (_config->FindB("APT::Remove-Depends",false) == true)
|
if (_config->FindB("APT::Remove-Depends",false) == true)
|
||||||
Fix.RemoveDepends();
|
Fix.RemoveDepends();
|
||||||
|
|
||||||
return Fix.Resolve();
|
// CNC:2003-03-22
|
||||||
|
return Fix.Resolve(true);
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
// AllUpgrade - Upgrade as many packages as possible /*{{{*/
|
// AllUpgrade - Upgrade as many packages as possible /*{{{*/
|
||||||
@ -1029,6 +1030,22 @@ bool pkgProblemResolver::Resolve(bool BrokenFix)
|
|||||||
if ((Flags[Pkg->ID] & Protected) != 0)
|
if ((Flags[Pkg->ID] & Protected) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
// CNC:2003-03-22
|
||||||
|
pkgDepCache::State State(&Cache);
|
||||||
|
if (BrokenFix == true && DoUpgrade(Pkg) == true)
|
||||||
|
{
|
||||||
|
if (Cache[I].InstBroken() == false &&
|
||||||
|
State.BrokenCount() >= Cache.BrokenCount())
|
||||||
|
{
|
||||||
|
if (Debug == true)
|
||||||
|
clog << " Installing " << Pkg.Name() << endl;
|
||||||
|
Change = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
State.Restore();
|
||||||
|
}
|
||||||
|
|
||||||
if (Debug == true)
|
if (Debug == true)
|
||||||
clog << " Added " << Pkg.Name() << " to the remove list" << endl;
|
clog << " Added " << Pkg.Name() << " to the remove list" << endl;
|
||||||
|
|
||||||
@ -1405,7 +1422,7 @@ static int PrioComp(const void *A,const void *B)
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (L->Priority != R->Priority)
|
if (L->Priority != R->Priority)
|
||||||
return R->Priority - L->Priority;
|
return L->Priority - R->Priority;
|
||||||
return strcmp(L.ParentPkg().Name(),R.ParentPkg().Name());
|
return strcmp(L.ParentPkg().Name(),R.ParentPkg().Name());
|
||||||
}
|
}
|
||||||
void pkgPrioSortList(pkgCache &Cache,pkgCache::Version **List)
|
void pkgPrioSortList(pkgCache &Cache,pkgCache::Version **List)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: cacheiterators.h,v 1.1 2002/07/23 17:54:50 niemeyer Exp $
|
// $Id: cacheiterators.h,v 1.18 2003/10/09 23:15:25 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Cache Iterators - Iterators for navigating the cache structure
|
Cache Iterators - Iterators for navigating the cache structure
|
||||||
@ -302,7 +302,7 @@ class pkgCache::PkgFileIterator
|
|||||||
inline const char *Component() const {return File->Component == 0?0:Owner->StrP + File->Component;};
|
inline const char *Component() const {return File->Component == 0?0:Owner->StrP + File->Component;};
|
||||||
inline const char *Version() const {return File->Version == 0?0:Owner->StrP + File->Version;};
|
inline const char *Version() const {return File->Version == 0?0:Owner->StrP + File->Version;};
|
||||||
inline const char *Origin() const {return File->Origin == 0?0:Owner->StrP + File->Origin;};
|
inline const char *Origin() const {return File->Origin == 0?0:Owner->StrP + File->Origin;};
|
||||||
inline const char *Label() const {return File->Origin == 0?0:Owner->StrP + File->Label;};
|
inline const char *Label() const {return File->Label == 0?0:Owner->StrP + File->Label;};
|
||||||
inline const char *Site() const {return File->Site == 0?0:Owner->StrP + File->Site;};
|
inline const char *Site() const {return File->Site == 0?0:Owner->StrP + File->Site;};
|
||||||
inline const char *Architecture() const {return File->Architecture == 0?0:Owner->StrP + File->Architecture;};
|
inline const char *Architecture() const {return File->Architecture == 0?0:Owner->StrP + File->Architecture;};
|
||||||
inline const char *IndexType() const {return File->IndexType == 0?0:Owner->StrP + File->IndexType;};
|
inline const char *IndexType() const {return File->IndexType == 0?0:Owner->StrP + File->IndexType;};
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: configuration.cc,v 1.4 2003/01/29 18:43:48 niemeyer Exp $
|
// $Id: configuration.cc,v 1.27 2003/07/26 00:27:36 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Configuration Class
|
Configuration Class
|
||||||
@ -305,7 +305,8 @@ string Configuration::FindAny(const char *Name,const char *Default) const
|
|||||||
|
|
||||||
// bool
|
// bool
|
||||||
case 'b':
|
case 'b':
|
||||||
return FindB(key, Default) ? "true" : "false";
|
// CNC:2003-11-23
|
||||||
|
return FindB(key, StringToBool(Default)) ? "true" : "false";
|
||||||
|
|
||||||
// int
|
// int
|
||||||
case 'i':
|
case 'i':
|
||||||
@ -412,13 +413,17 @@ bool Configuration::ExistsAny(const char *Name) const
|
|||||||
{
|
{
|
||||||
string key = Name;
|
string key = Name;
|
||||||
|
|
||||||
if (key.size() > 2 && key.end()[-2] == '/' &&
|
if (key.size() > 2 && key.end()[-2] == '/')
|
||||||
key.find_first_of("fdbi",key.size()-1) < key.size())
|
if (key.find_first_of("fdbi",key.size()-1) < key.size())
|
||||||
{
|
{
|
||||||
key.resize(key.size() - 2);
|
key.resize(key.size() - 2);
|
||||||
if (Exists(key.c_str()))
|
if (Exists(key.c_str()))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_error->Warning(_("Unrecognized type abbreviation: '%c'"), key.end()[-3]);
|
||||||
|
}
|
||||||
|
|
||||||
return Exists(Name);
|
return Exists(Name);
|
||||||
}
|
}
|
||||||
@ -735,6 +740,11 @@ bool ReadConfigDir(Configuration &Conf,string Dir,bool AsSectional,
|
|||||||
{
|
{
|
||||||
if (Ent->d_name[0] == '.')
|
if (Ent->d_name[0] == '.')
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
// CNC:2003-12-02 Only accept .list & .conf files as valid config parts
|
||||||
|
if ((flExtension(Ent->d_name) != "list") &&
|
||||||
|
(flExtension(Ent->d_name) != "conf"))
|
||||||
|
continue;
|
||||||
|
|
||||||
// Skip bad file names ala run-parts
|
// Skip bad file names ala run-parts
|
||||||
const char *C = Ent->d_name;
|
const char *C = Ent->d_name;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: strutl.cc,v 1.47 2003/02/02 22:20:27 jgg Exp $
|
// $Id: strutl.cc,v 1.48 2003/07/18 14:15:11 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
String Util - Some useful string functions.
|
String Util - Some useful string functions.
|
||||||
@ -652,7 +652,7 @@ bool ReadMessages(int Fd, vector<string> &List)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Pull the message out
|
// Pull the message out
|
||||||
string Message(Buffer,0,I-Buffer);
|
string Message(Buffer,I-Buffer);
|
||||||
|
|
||||||
// Fix up the buffer
|
// Fix up the buffer
|
||||||
for (; I < End && *I == '\n'; I++);
|
for (; I < End && *I == '\n'; I++);
|
||||||
@ -1045,7 +1045,7 @@ void URI::CopyFrom(string U)
|
|||||||
Path = "/";
|
Path = "/";
|
||||||
|
|
||||||
// Now we attempt to locate a user:pass@host fragment
|
// Now we attempt to locate a user:pass@host fragment
|
||||||
if (FirstColon[1] == '/' && FirstColon[2] == '/')
|
if (FirstColon + 2 <= U.end() && FirstColon[1] == '/' && FirstColon[2] == '/')
|
||||||
FirstColon += 3;
|
FirstColon += 3;
|
||||||
else
|
else
|
||||||
FirstColon += 1;
|
FirstColon += 1;
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: deblistparser.cc,v 1.2 2002/07/25 18:07:18 niemeyer Exp $
|
// $Id: deblistparser.cc,v 1.29 2003/09/22 04:16:26 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Package Cache Generator - Generator for the cache structure.
|
Package Cache Generator - Generator for the cache structure.
|
||||||
@ -268,11 +268,7 @@ bool debListParser::ParseStatus(pkgCache::PkgIterator Pkg,
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
/*}}}*/
|
|
||||||
// ListParser::ParseDepends - Parse a dependency element /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This parses the dependency elements out of a standard string in place,
|
|
||||||
bit by bit. */
|
|
||||||
const char *debListParser::ConvertRelation(const char *I,unsigned int &Op)
|
const char *debListParser::ConvertRelation(const char *I,unsigned int &Op)
|
||||||
{
|
{
|
||||||
// Determine the operator
|
// Determine the operator
|
||||||
@ -331,6 +327,11 @@ const char *debListParser::ConvertRelation(const char *I,unsigned int &Op)
|
|||||||
return I;
|
return I;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*}}}*/
|
||||||
|
// ListParser::ParseDepends - Parse a dependency element /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* This parses the dependency elements out of a standard string in place,
|
||||||
|
bit by bit. */
|
||||||
const char *debListParser::ParseDepends(const char *Start,const char *Stop,
|
const char *debListParser::ParseDepends(const char *Start,const char *Stop,
|
||||||
string &Package,string &Ver,
|
string &Package,string &Ver,
|
||||||
unsigned int &Op, bool ParseArchFlags)
|
unsigned int &Op, bool ParseArchFlags)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: debversion.cc,v 1.2 2003/01/29 18:43:48 niemeyer Exp $
|
// $Id: debversion.cc,v 1.8 2003/09/10 23:39:49 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Debian Version - Versioning system for Debian
|
Debian Version - Versioning system for Debian
|
||||||
@ -48,9 +48,15 @@ int debVersioningSystem::CmpFragment(const char *A,const char *AEnd,
|
|||||||
if (A >= AEnd && B >= BEnd)
|
if (A >= AEnd && B >= BEnd)
|
||||||
return 0;
|
return 0;
|
||||||
if (A >= AEnd)
|
if (A >= AEnd)
|
||||||
|
{
|
||||||
|
if (*B == '~') return 1;
|
||||||
return -1;
|
return -1;
|
||||||
|
}
|
||||||
if (B >= BEnd)
|
if (B >= BEnd)
|
||||||
|
{
|
||||||
|
if (*A == '~') return -1;
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* Iterate over the whole string
|
/* Iterate over the whole string
|
||||||
What this does is to spilt the whole string into groups of
|
What this does is to spilt the whole string into groups of
|
||||||
@ -65,8 +71,8 @@ int debVersioningSystem::CmpFragment(const char *A,const char *AEnd,
|
|||||||
{
|
{
|
||||||
int first_diff = 0;
|
int first_diff = 0;
|
||||||
|
|
||||||
while ((lhs != AEnd && !isdigit(*lhs)) ||
|
while (lhs != AEnd && rhs != BEnd &&
|
||||||
(rhs != BEnd && !isdigit(*rhs)) )
|
(!isdigit(*lhs) || !isdigit(*rhs)))
|
||||||
{
|
{
|
||||||
int vc = order(*lhs);
|
int vc = order(*lhs);
|
||||||
int rc = order(*rhs);
|
int rc = order(*rhs);
|
||||||
@ -101,11 +107,17 @@ int debVersioningSystem::CmpFragment(const char *A,const char *AEnd,
|
|||||||
|
|
||||||
// lhs is shorter
|
// lhs is shorter
|
||||||
if (lhs == AEnd)
|
if (lhs == AEnd)
|
||||||
|
{
|
||||||
|
if (*rhs == '~') return 1;
|
||||||
return -1;
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
// rhs is shorter
|
// rhs is shorter
|
||||||
if (rhs == BEnd)
|
if (rhs == BEnd)
|
||||||
|
{
|
||||||
|
if (*lhs == '~') return -1;
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
// Shouldnt happen
|
// Shouldnt happen
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: dpkgpm.cc,v 1.2 2002/07/25 18:07:18 niemeyer Exp $
|
// $Id: dpkgpm.cc,v 1.27 2003/07/26 00:25:44 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
DPKG Package Manager - Provide an interface to dpkg
|
DPKG Package Manager - Provide an interface to dpkg
|
||||||
@ -328,7 +328,7 @@ bool pkgDPkgPM::RunScriptsWithPkgs(const char *Cnf)
|
|||||||
bool pkgDPkgPM::Go()
|
bool pkgDPkgPM::Go()
|
||||||
{
|
{
|
||||||
unsigned int MaxArgs = _config->FindI("Dpkg::MaxArgs",350);
|
unsigned int MaxArgs = _config->FindI("Dpkg::MaxArgs",350);
|
||||||
unsigned int MaxArgBytes = _config->FindI("Dpkg::MaxArgBytes",1024);
|
unsigned int MaxArgBytes = _config->FindI("Dpkg::MaxArgBytes",8192);
|
||||||
|
|
||||||
if (RunScripts("DPkg::Pre-Invoke") == false)
|
if (RunScripts("DPkg::Pre-Invoke") == false)
|
||||||
return false;
|
return false;
|
||||||
@ -447,7 +447,7 @@ bool pkgDPkgPM::Go()
|
|||||||
if (chdir(_config->FindDir("DPkg::Run-Directory","/").c_str()) != 0)
|
if (chdir(_config->FindDir("DPkg::Run-Directory","/").c_str()) != 0)
|
||||||
_exit(100);
|
_exit(100);
|
||||||
|
|
||||||
if (_config->FindB("DPkg::FlushSTDIN",true) == true)
|
if (_config->FindB("DPkg::FlushSTDIN",true) == true && isatty(STDIN_FILENO))
|
||||||
{
|
{
|
||||||
int Flags,dummy;
|
int Flags,dummy;
|
||||||
if ((Flags = fcntl(STDIN_FILENO,F_GETFL,dummy)) < 0)
|
if ((Flags = fcntl(STDIN_FILENO,F_GETFL,dummy)) < 0)
|
||||||
|
@ -19,6 +19,10 @@
|
|||||||
|
|
||||||
// CNC:2002-07-05
|
// CNC:2002-07-05
|
||||||
#include <apt-pkg/pkgsystem.h>
|
#include <apt-pkg/pkgsystem.h>
|
||||||
|
|
||||||
|
// CNC:2003-03-17
|
||||||
|
#include <config.h>
|
||||||
|
#include <apt-pkg/luaiface.h>
|
||||||
|
|
||||||
#include <apti18n.h>
|
#include <apti18n.h>
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
@ -94,6 +98,13 @@ bool pkgDepCache::Init(OpProgress *Prog)
|
|||||||
}
|
}
|
||||||
|
|
||||||
Update(Prog);
|
Update(Prog);
|
||||||
|
|
||||||
|
// CNC:2003-03-17
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
_lua->SetDepCache(this);
|
||||||
|
_lua->RunScripts("Scripts::Cache::Init", true);
|
||||||
|
_lua->ResetCaches();
|
||||||
|
#endif
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1015,19 +1026,33 @@ bool pkgDepCache::Policy::IsImportantDep(DepIterator Dep)
|
|||||||
// pkgDepCache::State::* - Routines to work on the state of a DepCache. /*{{{*/
|
// pkgDepCache::State::* - Routines to work on the state of a DepCache. /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
|
void pkgDepCache::State::Copy(pkgDepCache::State const &Other)
|
||||||
|
{
|
||||||
|
memcpy(this, &Other, sizeof(*this));
|
||||||
|
int Size = Dep->Head().PackageCount;
|
||||||
|
int DepSize = Dep->Head().DependsCount;
|
||||||
|
PkgState = new StateCache[Size];
|
||||||
|
PkgIgnore = new bool[Size];
|
||||||
|
DepState = new unsigned char[DepSize];
|
||||||
|
memcpy(PkgState, Other.PkgState, Size*sizeof(*PkgState));
|
||||||
|
memcpy(PkgIgnore, Other.PkgIgnore, Size*sizeof(*PkgIgnore));
|
||||||
|
memcpy(DepState, Other.DepState, DepSize*sizeof(*DepState));
|
||||||
|
}
|
||||||
|
|
||||||
void pkgDepCache::State::Save(pkgDepCache *dep)
|
void pkgDepCache::State::Save(pkgDepCache *dep)
|
||||||
{
|
{
|
||||||
Dep = dep;
|
Dep = dep;
|
||||||
delete [] PkgState;
|
delete[] PkgState;
|
||||||
delete [] DepState;
|
delete[] DepState;
|
||||||
delete [] PkgIgnore;
|
delete[] PkgIgnore;
|
||||||
int Size = Dep->Head().PackageCount;
|
int Size = Dep->Head().PackageCount;
|
||||||
|
int DepSize = Dep->Head().DependsCount;
|
||||||
PkgState = new StateCache[Size];
|
PkgState = new StateCache[Size];
|
||||||
PkgIgnore = new bool[Size];
|
PkgIgnore = new bool[Size];
|
||||||
DepState = new unsigned char[Dep->Head().DependsCount];
|
DepState = new unsigned char[DepSize];
|
||||||
memcpy(PkgState, Dep->PkgState, Size*sizeof(*PkgState));
|
memcpy(PkgState, Dep->PkgState, Size*sizeof(*PkgState));
|
||||||
memset(PkgIgnore, 0, Size*sizeof(*PkgIgnore));
|
memset(PkgIgnore, 0, Size*sizeof(*PkgIgnore));
|
||||||
memcpy(DepState, Dep->DepState, Dep->Head().DependsCount*sizeof(*DepState));
|
memcpy(DepState, Dep->DepState, DepSize*sizeof(*DepState));
|
||||||
iUsrSize = Dep->iUsrSize;
|
iUsrSize = Dep->iUsrSize;
|
||||||
iDownloadSize= Dep->iDownloadSize;
|
iDownloadSize= Dep->iDownloadSize;
|
||||||
iInstCount = Dep->iInstCount;
|
iInstCount = Dep->iInstCount;
|
||||||
@ -1039,8 +1064,7 @@ void pkgDepCache::State::Save(pkgDepCache *dep)
|
|||||||
|
|
||||||
void pkgDepCache::State::Restore()
|
void pkgDepCache::State::Restore()
|
||||||
{
|
{
|
||||||
int Size = Dep->Head().PackageCount;
|
memcpy(Dep->PkgState, PkgState, Dep->Head().PackageCount*sizeof(*PkgState));
|
||||||
memcpy(Dep->PkgState, PkgState, Size*sizeof(*PkgState));
|
|
||||||
memcpy(Dep->DepState, DepState, Dep->Head().DependsCount*sizeof(*DepState));
|
memcpy(Dep->DepState, DepState, Dep->Head().DependsCount*sizeof(*DepState));
|
||||||
Dep->iUsrSize = iUsrSize;
|
Dep->iUsrSize = iUsrSize;
|
||||||
Dep->iDownloadSize= iDownloadSize;
|
Dep->iDownloadSize= iDownloadSize;
|
||||||
@ -1063,6 +1087,12 @@ bool pkgDepCache::State::Changed()
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void pkgDepCache::State::UnIgnoreAll()
|
||||||
|
{
|
||||||
|
memset(PkgIgnore, 0, Dep->Head().PackageCount*sizeof(*PkgIgnore));
|
||||||
|
}
|
||||||
|
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
// vim:sts=3:sw=3
|
// vim:sts=3:sw=3
|
||||||
|
@ -244,6 +244,9 @@ class pkgDepCache::State
|
|||||||
bool Changed();
|
bool Changed();
|
||||||
|
|
||||||
void Ignore(PkgIterator const &I) {PkgIgnore[I->ID] = true;};
|
void Ignore(PkgIterator const &I) {PkgIgnore[I->ID] = true;};
|
||||||
|
void UnIgnore(PkgIterator const &I) {PkgIgnore[I->ID] = false;};
|
||||||
|
bool Ignored(PkgIterator const &I) {return PkgIgnore[I->ID];};
|
||||||
|
void UnIgnoreAll();
|
||||||
|
|
||||||
StateCache &operator [](pkgCache::PkgIterator const &I) {return PkgState[I->ID];};
|
StateCache &operator [](pkgCache::PkgIterator const &I) {return PkgState[I->ID];};
|
||||||
|
|
||||||
@ -256,11 +259,25 @@ class pkgDepCache::State
|
|||||||
inline unsigned long BrokenCount() {return iBrokenCount;};
|
inline unsigned long BrokenCount() {return iBrokenCount;};
|
||||||
inline unsigned long BadCount() {return iBadCount;};
|
inline unsigned long BadCount() {return iBadCount;};
|
||||||
|
|
||||||
|
void Copy(State const &Other);
|
||||||
|
void operator =(State const &Other)
|
||||||
|
{
|
||||||
|
delete[] PkgState;
|
||||||
|
delete[] DepState;
|
||||||
|
delete[] PkgIgnore;
|
||||||
|
Copy(Other);
|
||||||
|
};
|
||||||
|
State(const State &Other)
|
||||||
|
{ Copy(Other); };
|
||||||
State(pkgDepCache *Dep=NULL)
|
State(pkgDepCache *Dep=NULL)
|
||||||
: Dep(0), PkgState(0), DepState(0), PkgIgnore(0)
|
: Dep(0), PkgState(0), DepState(0), PkgIgnore(0)
|
||||||
{ if (Dep != NULL) Save(Dep); };
|
{ if (Dep != NULL) Save(Dep); };
|
||||||
~State()
|
~State()
|
||||||
{ delete[] PkgState; delete[] DepState; delete[] PkgIgnore; };
|
{
|
||||||
|
delete[] PkgState;
|
||||||
|
delete[] DepState;
|
||||||
|
delete[] PkgIgnore;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -15,6 +15,10 @@
|
|||||||
#include <apti18n.h>
|
#include <apti18n.h>
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
// CNC:2003-03-17
|
||||||
|
#include <apt-pkg/luaiface.h>
|
||||||
|
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
#define Stringfy_(x) # x
|
#define Stringfy_(x) # x
|
||||||
@ -72,7 +76,8 @@ bool pkgInitConfig(Configuration &Cnf)
|
|||||||
Cnf.Set("Dir::Etc::main","apt.conf");
|
Cnf.Set("Dir::Etc::main","apt.conf");
|
||||||
Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
Cnf.Set("Dir::Etc::parts","apt.conf.d");
|
||||||
Cnf.Set("Dir::Etc::preferences","preferences");
|
Cnf.Set("Dir::Etc::preferences","preferences");
|
||||||
Cnf.Set("Dir::Bin::methods","/usr/lib/apt/methods");
|
Cnf.Set("Dir::Bin::methods",LIBDIR "/apt/methods");
|
||||||
|
Cnf.Set("Acquire::ComprExtension", ".bz2");
|
||||||
|
|
||||||
bool Res = true;
|
bool Res = true;
|
||||||
|
|
||||||
@ -152,7 +157,12 @@ bool pkgInitSystem(Configuration &Cnf,pkgSystem *&Sys)
|
|||||||
if (Sys == 0)
|
if (Sys == 0)
|
||||||
return _error->Error(_("Unable to determine a suitable system type"));
|
return _error->Error(_("Unable to determine a suitable system type"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return Sys->Initialize(Cnf);
|
// CNC:2003-03-15
|
||||||
|
bool Ret = Sys->Initialize(Cnf);
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
_lua->RunScripts("Scripts::Init", false);
|
||||||
|
#endif
|
||||||
|
return Ret;
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
1072
apt/apt-pkg/luaiface.cc
Normal file
1072
apt/apt-pkg/luaiface.cc
Normal file
File diff suppressed because it is too large
Load Diff
109
apt/apt-pkg/luaiface.h
Normal file
109
apt/apt-pkg/luaiface.h
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
|
||||||
|
#ifndef LUAIFACE_H
|
||||||
|
#define LUAIFACE_H
|
||||||
|
|
||||||
|
#ifdef __GNUG__
|
||||||
|
#pragma interface "apt-pkg/luaiface.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
class pkgCache;
|
||||||
|
class pkgDepCache;
|
||||||
|
class pkgProblemResolver;
|
||||||
|
class lua_State;
|
||||||
|
typedef int (*lua_CFunction)(struct lua_State*);
|
||||||
|
|
||||||
|
class LuaCacheControl {
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual pkgDepCache *Open();
|
||||||
|
virtual pkgDepCache *Open(bool Write) = 0;
|
||||||
|
virtual void Close() = 0;
|
||||||
|
|
||||||
|
virtual ~LuaCacheControl() {};
|
||||||
|
};
|
||||||
|
|
||||||
|
class Lua {
|
||||||
|
protected:
|
||||||
|
|
||||||
|
struct CacheData {
|
||||||
|
int Begin;
|
||||||
|
int End;
|
||||||
|
};
|
||||||
|
|
||||||
|
lua_State *L;
|
||||||
|
map<string,CacheData> ChunkCache;
|
||||||
|
|
||||||
|
vector<string> Globals;
|
||||||
|
|
||||||
|
pkgDepCache *DepCache;
|
||||||
|
pkgCache *Cache;
|
||||||
|
|
||||||
|
LuaCacheControl *CacheControl;
|
||||||
|
|
||||||
|
pkgProblemResolver *Fix;
|
||||||
|
bool DontFix;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
bool RunScripts(const char *ConfListKey, bool CacheChunks);
|
||||||
|
bool HasScripts(const char *ConfListKey);
|
||||||
|
|
||||||
|
void SetGlobal(const char *Name, const char *Value);
|
||||||
|
void SetGlobal(const char *Name, double Value);
|
||||||
|
void SetGlobal(const char *Name, void *Value);
|
||||||
|
void SetGlobal(const char *Name, string Value)
|
||||||
|
{ SetGlobal(Name, Value.c_str()); };
|
||||||
|
void SetGlobal(const char *Name, int Value)
|
||||||
|
{ SetGlobal(Name, (double)Value); };
|
||||||
|
void SetGlobal(const char *Name, lua_CFunction Value);
|
||||||
|
void SetGlobal(const char *Name, const char **Value, int Total=-1);
|
||||||
|
void SetGlobal(const char *Name, vector<const char *> &Value,
|
||||||
|
int Total=-1);
|
||||||
|
void SetGlobal(const char *Name, vector<string> &Value,
|
||||||
|
int Total=-1);
|
||||||
|
void SetGlobal(const char *Name, vector<pkgCache::Package*> &Value,
|
||||||
|
int Total=-1);
|
||||||
|
void ResetGlobals();
|
||||||
|
|
||||||
|
const char *GetGlobal(const char *Name);
|
||||||
|
double GetGlobalI(const char *Name);
|
||||||
|
void *GetGlobalP(const char *Name);
|
||||||
|
void GetGlobalVS(const char *Name, vector<string> &VS);
|
||||||
|
|
||||||
|
static const double NoGlobalI;
|
||||||
|
|
||||||
|
void SetDepCache(pkgDepCache *DepCache_);
|
||||||
|
void SetCache(pkgCache *Cache_) { Cache = Cache_; };
|
||||||
|
void SetCacheControl(LuaCacheControl *CacheControl_);
|
||||||
|
void SetProblemResolver(pkgProblemResolver *Fix_) { Fix = Fix_; };
|
||||||
|
void SetDontFix() { DontFix = true; };
|
||||||
|
void ResetCaches()
|
||||||
|
{ DepCache = NULL; Cache = NULL; Fix = NULL; DontFix = false; };
|
||||||
|
|
||||||
|
// For API functions
|
||||||
|
pkgDepCache *GetDepCache(lua_State *L=NULL);
|
||||||
|
pkgCache *GetCache(lua_State *L=NULL);
|
||||||
|
LuaCacheControl *GetCacheControl() { return CacheControl; };
|
||||||
|
pkgProblemResolver *GetProblemResolver() { return Fix; };
|
||||||
|
bool GetDontFix() { return DontFix; };
|
||||||
|
|
||||||
|
Lua();
|
||||||
|
~Lua();
|
||||||
|
};
|
||||||
|
|
||||||
|
// The same system used with _error
|
||||||
|
Lua *_GetLuaObj();
|
||||||
|
#define _lua _GetLuaObj()
|
||||||
|
|
||||||
|
#endif // WITH_LUA
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// vim:sts=3:sw=3
|
@ -1,74 +0,0 @@
|
|||||||
# -*- make -*-
|
|
||||||
BASE=..
|
|
||||||
SUBDIR=apt-pkg
|
|
||||||
|
|
||||||
# Header location
|
|
||||||
# CNC:2002-07-03
|
|
||||||
SUBDIRS = rpm deb contrib
|
|
||||||
HEADER_TARGETDIRS = apt-pkg
|
|
||||||
|
|
||||||
# Bring in the default rules
|
|
||||||
include ../buildlib/defaults.mak
|
|
||||||
|
|
||||||
# The library name, don't forget to update init.h and the copy in
|
|
||||||
# methods/makefile - FIXME
|
|
||||||
LIBRARY=apt-pkg
|
|
||||||
LIBEXT=$(GLIBC_VER)$(LIBSTDCPP_VER)
|
|
||||||
MAJOR=3.3
|
|
||||||
MINOR=0
|
|
||||||
# CNC:2002-07-03
|
|
||||||
SLIBS=$(PTHREADLIB) $(INTLLIBS) $(RPMLIBS)
|
|
||||||
APT_DOMAIN:=libapt-pkg$(MAJOR)
|
|
||||||
|
|
||||||
# Source code for the contributed non-core things
|
|
||||||
SOURCE = contrib/mmap.cc contrib/error.cc contrib/strutl.cc \
|
|
||||||
contrib/configuration.cc contrib/progress.cc contrib/cmndline.cc \
|
|
||||||
contrib/md5.cc contrib/sha1.cc contrib/hashes.cc \
|
|
||||||
contrib/cdromutl.cc contrib/crc-16.cc \
|
|
||||||
contrib/fileutl.cc
|
|
||||||
HEADERS = mmap.h error.h configuration.h fileutl.h cmndline.h \
|
|
||||||
md5.h crc-16.h cdromutl.h strutl.h sptr.h sha1.h hashes.h
|
|
||||||
|
|
||||||
# Source code for the core main library
|
|
||||||
# CNC:2002-07-03
|
|
||||||
SOURCE+= pkgcache.cc version.cc depcache.cc \
|
|
||||||
orderlist.cc tagfile.cc sourcelist.cc packagemanager.cc \
|
|
||||||
pkgrecords.cc algorithms.cc acquire.cc\
|
|
||||||
acquire-worker.cc acquire-method.cc init.cc clean.cc \
|
|
||||||
srcrecords.cc cachefile.cc versionmatch.cc policy.cc \
|
|
||||||
pkgsystem.cc indexfile.cc pkgcachegen.cc acquire-item.cc \
|
|
||||||
repository.cc
|
|
||||||
HEADERS+= algorithms.h depcache.h pkgcachegen.h cacheiterators.h \
|
|
||||||
orderlist.h sourcelist.h packagemanager.h tagfile.h \
|
|
||||||
init.h pkgcache.h version.h progress.h pkgrecords.h \
|
|
||||||
acquire.h acquire-worker.h acquire-item.h acquire-method.h \
|
|
||||||
clean.h srcrecords.h cachefile.h versionmatch.h policy.h \
|
|
||||||
pkgsystem.h indexfile.h repository.h
|
|
||||||
|
|
||||||
# CNC:2003-02-15
|
|
||||||
WITH_DEB=no
|
|
||||||
ifeq ($(WITH_DEB),yes)
|
|
||||||
# Source code for the debian specific components
|
|
||||||
# In theory the deb headers do not need to be exported..
|
|
||||||
SOURCE+= deb/deblistparser.cc deb/debrecords.cc deb/dpkgpm.cc \
|
|
||||||
deb/debsrcrecords.cc deb/debversion.cc deb/debsystem.cc \
|
|
||||||
deb/debindexfile.cc deb/debindexfile.cc
|
|
||||||
HEADERS+= debversion.h debsrcrecords.h dpkgpm.h debrecords.h \
|
|
||||||
deblistparser.h debsystem.h debindexfile.h
|
|
||||||
endif
|
|
||||||
|
|
||||||
# CNC:2002-07-03
|
|
||||||
# Source code for the rpm specific components
|
|
||||||
SOURCE+= rpm/rpmhandler.cc rpm/rpmindexfile.cc rpm/rpmlistparser.cc \
|
|
||||||
rpm/rpmpackagedata.cc rpm/rpmpm.cc rpm/rpmrecords.cc \
|
|
||||||
rpm/rpmsrcrecords.cc rpm/rpmsystem.cc rpm/rpmversion.cc
|
|
||||||
HEADERS+= rpmhandler.h rpmindexfile.h rpmlistparser.h rpmpackagedata.h \
|
|
||||||
rpmpm.h rpmrecords.h rpmsrcrecords.h rpmsystem.h rpmversion.h \
|
|
||||||
rpmmisc.h
|
|
||||||
|
|
||||||
HEADERS := $(addprefix apt-pkg/,$(HEADERS))
|
|
||||||
|
|
||||||
# Private header files
|
|
||||||
HEADERS+= system.h
|
|
||||||
|
|
||||||
include $(LIBRARY_H)
|
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: packagemanager.cc,v 1.8 2003/01/31 16:32:30 niemeyer Exp $
|
// $Id: packagemanager.cc,v 1.30 2003/04/27 03:04:15 doogie Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Package Manager - Abstacts the package manager
|
Package Manager - Abstacts the package manager
|
||||||
@ -133,7 +133,7 @@ bool pkgPackageManager::CreateOrderList()
|
|||||||
delete List;
|
delete List;
|
||||||
List = new pkgOrderList(&Cache);
|
List = new pkgOrderList(&Cache);
|
||||||
|
|
||||||
bool NoImmConfigure = _config->FindB("APT::Immediate-Configure",false);
|
bool NoImmConfigure = !_config->FindB("APT::Immediate-Configure",true);
|
||||||
|
|
||||||
// Generate the list of affected packages and sort it
|
// Generate the list of affected packages and sort it
|
||||||
for (PkgIterator I = Cache.PkgBegin(); I.end() == false; I++)
|
for (PkgIterator I = Cache.PkgBegin(); I.end() == false; I++)
|
||||||
@ -542,7 +542,6 @@ bool pkgPackageManager::SmartUnPack(PkgIterator Pkg)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Check for reverse conflicts.
|
// Check for reverse conflicts.
|
||||||
if (CheckRConflicts(Pkg,Pkg.RevDependsList(),
|
if (CheckRConflicts(Pkg,Pkg.RevDependsList(),
|
||||||
@ -552,6 +551,7 @@ bool pkgPackageManager::SmartUnPack(PkgIterator Pkg)
|
|||||||
for (PrvIterator P = Cache[Pkg].InstVerIter(Cache).ProvidesList();
|
for (PrvIterator P = Cache[Pkg].InstVerIter(Cache).ProvidesList();
|
||||||
P.end() == false; P++)
|
P.end() == false; P++)
|
||||||
CheckRConflicts(Pkg,P.ParentPkg().RevDependsList(),P.ProvideVersion());
|
CheckRConflicts(Pkg,P.ParentPkg().RevDependsList(),P.ProvideVersion());
|
||||||
|
#endif
|
||||||
|
|
||||||
if (Install(Pkg,FileNames[Pkg->ID]) == false)
|
if (Install(Pkg,FileNames[Pkg->ID]) == false)
|
||||||
return false;
|
return false;
|
||||||
|
@ -52,9 +52,16 @@ pkgCache::Header::Header()
|
|||||||
|
|
||||||
/* Whenever the structures change the major version should be bumped,
|
/* Whenever the structures change the major version should be bumped,
|
||||||
whenever the generator changes the minor version should be bumped. */
|
whenever the generator changes the minor version should be bumped. */
|
||||||
MajorVersion = 4;
|
// CNC:2003-11-24
|
||||||
|
MajorVersion = 6;
|
||||||
MinorVersion = 0;
|
MinorVersion = 0;
|
||||||
Dirty = false;
|
Dirty = false;
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
HasFileDeps = false;
|
||||||
|
|
||||||
|
// CNC:2003-11-24
|
||||||
|
OptionsHash = 0;
|
||||||
|
|
||||||
HeaderSz = sizeof(pkgCache::Header);
|
HeaderSz = sizeof(pkgCache::Header);
|
||||||
PackageSz = sizeof(pkgCache::Package);
|
PackageSz = sizeof(pkgCache::Package);
|
||||||
|
@ -167,6 +167,12 @@ struct pkgCache::Header
|
|||||||
short MajorVersion;
|
short MajorVersion;
|
||||||
short MinorVersion;
|
short MinorVersion;
|
||||||
bool Dirty;
|
bool Dirty;
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
bool HasFileDeps;
|
||||||
|
|
||||||
|
// CNC:2003-11-24
|
||||||
|
unsigned long OptionsHash;
|
||||||
|
|
||||||
// Size of structure values
|
// Size of structure values
|
||||||
unsigned short HeaderSz;
|
unsigned short HeaderSz;
|
||||||
|
@ -626,6 +626,10 @@ static bool CheckValidity(string CacheFile, FileIterator Start,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// CNC:2003-11-24
|
||||||
|
if (_system->OptionsHash() != Cache.HeaderP->OptionsHash)
|
||||||
|
return false;
|
||||||
|
|
||||||
/* Now we check every index file, see if it is in the cache,
|
/* Now we check every index file, see if it is in the cache,
|
||||||
verify the IMS data and check that it is on the disk too.. */
|
verify the IMS data and check that it is on the disk too.. */
|
||||||
SPtrArray<bool> Visited = new bool[Cache.HeaderP->PackageFileCount];
|
SPtrArray<bool> Visited = new bool[Cache.HeaderP->PackageFileCount];
|
||||||
@ -724,27 +728,21 @@ static bool BuildCache(pkgCacheGenerator &Gen,
|
|||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
static bool CollectFileProvides(pkgCacheGenerator &Gen,
|
static bool CollectFileProvides(pkgCacheGenerator &Gen,
|
||||||
OpProgress &Progress,
|
OpProgress &Progress,
|
||||||
|
unsigned long &CurrentSize,unsigned long TotalSize,
|
||||||
FileIterator Start, FileIterator End)
|
FileIterator Start, FileIterator End)
|
||||||
{
|
{
|
||||||
FileIterator I;
|
for (FileIterator I = Start; I != End; I++)
|
||||||
if (Gen.HasFileDeps() == true)
|
|
||||||
{
|
{
|
||||||
Progress.Done();
|
if ((*I)->HasPackages() == false || (*I)->Exists() == false)
|
||||||
unsigned long TotalSize = ComputeSize(Start, End);
|
continue;
|
||||||
unsigned long CurrentSize = 0;
|
|
||||||
for (I = Start; I != End; I++)
|
|
||||||
{
|
|
||||||
if ((*I)->HasPackages() == false || (*I)->Exists() == false)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
unsigned long Size = (*I)->Size();
|
unsigned long Size = (*I)->Size();
|
||||||
Progress.OverallProgress(CurrentSize,TotalSize,Size,_("Collecting File Provides"));
|
Progress.OverallProgress(CurrentSize,TotalSize,Size,_("Reading Package Lists"));
|
||||||
CurrentSize += Size;
|
CurrentSize += Size;
|
||||||
if ((*I)->MergeFileProvides(Gen,Progress) == false)
|
|
||||||
return false;
|
if ((*I)->MergeFileProvides(Gen,Progress) == false)
|
||||||
}
|
return false;
|
||||||
Progress.Done();
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -831,6 +829,12 @@ bool pkgMakeStatusCache(pkgSourceList &List,OpProgress &Progress,
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
TotalSize = ComputeSize(Files.begin()+EndOfSource,Files.end());
|
TotalSize = ComputeSize(Files.begin()+EndOfSource,Files.end());
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
// For the file provides collection phase.
|
||||||
|
unsigned long SrcSize = ComputeSize(Files.begin(),
|
||||||
|
Files.begin()+EndOfSource);
|
||||||
|
TotalSize = TotalSize+(TotalSize+SrcSize);
|
||||||
|
|
||||||
// Build the status cache
|
// Build the status cache
|
||||||
pkgCacheGenerator Gen(Map.Get(),&Progress);
|
pkgCacheGenerator Gen(Map.Get(),&Progress);
|
||||||
@ -840,16 +844,31 @@ bool pkgMakeStatusCache(pkgSourceList &List,OpProgress &Progress,
|
|||||||
Files.begin()+EndOfSource,Files.end()) == false)
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// CNC:2003-03-03
|
// CNC:2003-03-18
|
||||||
// Collect file provides over *all* files (sources + database), since
|
if (Gen.HasFileDeps() == true) {
|
||||||
// the cache is saved without them.
|
// There are new file dependencies. Collect over all packages.
|
||||||
if (CollectFileProvides(Gen,Progress,
|
Gen.GetCache().HeaderP->HasFileDeps = true;
|
||||||
Files.begin(),Files.end()) == false)
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
return false;
|
Files.begin(),Files.end()) == false)
|
||||||
|
return false;
|
||||||
|
} else if (Gen.GetCache().HeaderP->HasFileDeps == true) {
|
||||||
|
// Jump entries which are not going to be parsed.
|
||||||
|
CurrentSize += SrcSize;
|
||||||
|
// No new file dependencies. Collect over the new packages.
|
||||||
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
TotalSize = ComputeSize(Files.begin(),Files.end());
|
TotalSize = ComputeSize(Files.begin(),Files.end());
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
// For the file provides collection phase.
|
||||||
|
unsigned long SrcSize = ComputeSize(Files.begin(),
|
||||||
|
Files.begin()+EndOfSource);
|
||||||
|
TotalSize = (TotalSize*2)+SrcSize;
|
||||||
|
|
||||||
// Build the source cache
|
// Build the source cache
|
||||||
pkgCacheGenerator Gen(Map.Get(),&Progress);
|
pkgCacheGenerator Gen(Map.Get(),&Progress);
|
||||||
@ -858,6 +877,23 @@ bool pkgMakeStatusCache(pkgSourceList &List,OpProgress &Progress,
|
|||||||
if (BuildCache(Gen,Progress,CurrentSize,TotalSize,
|
if (BuildCache(Gen,Progress,CurrentSize,TotalSize,
|
||||||
Files.begin(),Files.begin()+EndOfSource) == false)
|
Files.begin(),Files.begin()+EndOfSource) == false)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
// CNC:2003-11-24
|
||||||
|
Gen.GetCache().HeaderP->OptionsHash = _system->OptionsHash();
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
if (Gen.HasFileDeps() == true) {
|
||||||
|
// There are file dependencies. Collect over source packages.
|
||||||
|
Gen.GetCache().HeaderP->HasFileDeps = true;
|
||||||
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
|
Files.begin(),Files.begin()+EndOfSource) == false)
|
||||||
|
return false;
|
||||||
|
// Reset to check for new file dependencies in the status cache.
|
||||||
|
Gen.ResetFileDeps();
|
||||||
|
} else {
|
||||||
|
// Jump entries which are not going to be parsed.
|
||||||
|
CurrentSize += SrcSize;
|
||||||
|
}
|
||||||
|
|
||||||
// Write it back
|
// Write it back
|
||||||
// CNC:2003-03-03 - Notice that it is without the file provides. This
|
// CNC:2003-03-03 - Notice that it is without the file provides. This
|
||||||
@ -891,12 +927,21 @@ bool pkgMakeStatusCache(pkgSourceList &List,OpProgress &Progress,
|
|||||||
Files.begin()+EndOfSource,Files.end()) == false)
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// CNC:2003-03-03
|
// CNC:2003-03-18
|
||||||
// Collect file provides over *all* files (sources + database), since
|
if (Gen.HasFileDeps() == true) {
|
||||||
// the cache is saved without them.
|
// There are new file dependencies. Collect over all packages.
|
||||||
if (CollectFileProvides(Gen,Progress,
|
Gen.GetCache().HeaderP->HasFileDeps = true;
|
||||||
Files.begin(),Files.end()) == false)
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
return false;
|
Files.begin(),Files.end()) == false)
|
||||||
|
return false;
|
||||||
|
} else if (Gen.GetCache().HeaderP->HasFileDeps == true) {
|
||||||
|
// Jump entries which are not going to be parsed.
|
||||||
|
CurrentSize += SrcSize;
|
||||||
|
// No new file dependencies. Collect over the new packages.
|
||||||
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_error->PendingError() == true)
|
if (_error->PendingError() == true)
|
||||||
@ -938,6 +983,10 @@ bool pkgMakeOnlyStatusCache(OpProgress &Progress,DynamicMMap **OutMap)
|
|||||||
unsigned long TotalSize = 0;
|
unsigned long TotalSize = 0;
|
||||||
|
|
||||||
TotalSize = ComputeSize(Files.begin()+EndOfSource,Files.end());
|
TotalSize = ComputeSize(Files.begin()+EndOfSource,Files.end());
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
// For the file provides collection phase.
|
||||||
|
TotalSize *= 2;
|
||||||
|
|
||||||
// Build the status cache
|
// Build the status cache
|
||||||
Progress.OverallProgress(0,1,1,_("Reading Package Lists"));
|
Progress.OverallProgress(0,1,1,_("Reading Package Lists"));
|
||||||
@ -948,12 +997,12 @@ bool pkgMakeOnlyStatusCache(OpProgress &Progress,DynamicMMap **OutMap)
|
|||||||
Files.begin()+EndOfSource,Files.end()) == false)
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// CNC:2003-03-03
|
// CNC:2003-03-18
|
||||||
// Collect file provides over *all* files (sources + database), since
|
if (Gen.HasFileDeps() == true) {
|
||||||
// the cache is saved without them.
|
if (CollectFileProvides(Gen,Progress,CurrentSize,TotalSize,
|
||||||
if (CollectFileProvides(Gen,Progress,
|
Files.begin()+EndOfSource,Files.end()) == false)
|
||||||
Files.begin(),Files.end()) == false)
|
return false;
|
||||||
return false;
|
}
|
||||||
|
|
||||||
if (_error->PendingError() == true)
|
if (_error->PendingError() == true)
|
||||||
return false;
|
return false;
|
||||||
|
@ -74,6 +74,9 @@ class pkgCacheGenerator
|
|||||||
|
|
||||||
bool HasFileDeps() {return FoundFileDeps;};
|
bool HasFileDeps() {return FoundFileDeps;};
|
||||||
bool MergeFileProvides(ListParser &List);
|
bool MergeFileProvides(ListParser &List);
|
||||||
|
|
||||||
|
// CNC:2003-03-18
|
||||||
|
inline void ResetFileDeps() {FoundFileDeps = false;};
|
||||||
|
|
||||||
pkgCacheGenerator(DynamicMMap *Map,OpProgress *Progress);
|
pkgCacheGenerator(DynamicMMap *Map,OpProgress *Progress);
|
||||||
~pkgCacheGenerator();
|
~pkgCacheGenerator();
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: pkgrecords.cc,v 1.2 2002/11/28 18:54:15 niemeyer Exp $
|
// $Id: pkgrecords.cc,v 1.8 2003/09/02 04:52:16 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Package Records - Allows access to complete package description records
|
Package Records - Allows access to complete package description records
|
||||||
|
@ -70,6 +70,9 @@ class pkgRecords::Parser
|
|||||||
|
|
||||||
// The record in binary form
|
// The record in binary form
|
||||||
virtual void GetRec(const char *&Start,const char *&Stop) {Start = Stop = 0;};
|
virtual void GetRec(const char *&Start,const char *&Stop) {Start = Stop = 0;};
|
||||||
|
|
||||||
|
// CNC:2003-11-21
|
||||||
|
virtual bool HasFile(const char *File) {return false;};
|
||||||
|
|
||||||
virtual ~Parser() {};
|
virtual ~Parser() {};
|
||||||
};
|
};
|
||||||
|
@ -89,6 +89,8 @@ class pkgSystem
|
|||||||
|
|
||||||
// Return a list of system index files..
|
// Return a list of system index files..
|
||||||
virtual bool AddStatusFiles(std::vector<pkgIndexFile *> &List) = 0;
|
virtual bool AddStatusFiles(std::vector<pkgIndexFile *> &List) = 0;
|
||||||
|
// CNC:2003-11-21
|
||||||
|
virtual bool AddSourceFiles(std::vector<pkgIndexFile *> &List) {};
|
||||||
virtual bool FindIndex(pkgCache::PkgFileIterator File,
|
virtual bool FindIndex(pkgCache::PkgFileIterator File,
|
||||||
pkgIndexFile *&Found) const = 0;
|
pkgIndexFile *&Found) const = 0;
|
||||||
|
|
||||||
@ -105,6 +107,9 @@ class pkgSystem
|
|||||||
virtual bool IgnoreDep(pkgVersioningSystem &VS, pkgCache::DepIterator &Dep)
|
virtual bool IgnoreDep(pkgVersioningSystem &VS, pkgCache::DepIterator &Dep)
|
||||||
{return false;};
|
{return false;};
|
||||||
|
|
||||||
|
// CNC:2003-11-24
|
||||||
|
virtual unsigned long OptionsHash() const {return 0;};
|
||||||
|
|
||||||
pkgSystem();
|
pkgSystem();
|
||||||
virtual ~pkgSystem() {};
|
virtual ~pkgSystem() {};
|
||||||
};
|
};
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
// -*- mode: cpp; mode: fold -*-
|
// -*- mode: cpp; mode: fold -*-
|
||||||
// Description /*{{{*/
|
// Description /*{{{*/
|
||||||
// $Id: policy.cc,v 1.2 2003/01/29 18:43:48 niemeyer Exp $
|
// $Id: policy.cc,v 1.10 2003/08/12 00:17:37 mdz Exp $
|
||||||
/* ######################################################################
|
/* ######################################################################
|
||||||
|
|
||||||
Package Version Policy implementation
|
Package Version Policy implementation
|
||||||
@ -336,8 +336,14 @@ bool ReadPinFile(pkgPolicy &Plcy,string File)
|
|||||||
}
|
}
|
||||||
for (; Word != End && isspace(*Word) != 0; Word++);
|
for (; Word != End && isspace(*Word) != 0; Word++);
|
||||||
|
|
||||||
Plcy.CreatePin(Type,Name,string(Word,End),
|
short int priority = Tags.FindI("Pin-Priority", 0);
|
||||||
Tags.FindI("Pin-Priority"));
|
if (priority == 0)
|
||||||
|
{
|
||||||
|
_error->Warning(_("No priority (or zero) specified for pin"));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
Plcy.CreatePin(Type,Name,string(Word,End),priority);
|
||||||
}
|
}
|
||||||
|
|
||||||
Plcy.InitDefaults();
|
Plcy.InitDefaults();
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <utime.h>
|
#include <utime.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
#include <apt-pkg/error.h>
|
#include <apt-pkg/error.h>
|
||||||
#include <apt-pkg/configuration.h>
|
#include <apt-pkg/configuration.h>
|
||||||
@ -26,7 +27,7 @@
|
|||||||
|
|
||||||
#include <apti18n.h>
|
#include <apti18n.h>
|
||||||
|
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
#include <rpm/rpmts.h>
|
#include <rpm/rpmts.h>
|
||||||
#include <rpm/rpmdb.h>
|
#include <rpm/rpmdb.h>
|
||||||
#define rpmxxInitIterator(a,b,c,d) rpmtsInitIterator(a,(rpmTag)b,c,d)
|
#define rpmxxInitIterator(a,b,c,d) rpmtsInitIterator(a,(rpmTag)b,c,d)
|
||||||
@ -142,6 +143,68 @@ string RPMFileHandler::MD5Sum()
|
|||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RPMSingleFileHandler::Skip()
|
||||||
|
{
|
||||||
|
if (FD == NULL)
|
||||||
|
return false;
|
||||||
|
if (HeaderP != NULL) {
|
||||||
|
headerFree(HeaderP);
|
||||||
|
HeaderP = NULL;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rpmts TS = rpmtsCreate();
|
||||||
|
rpmtsSetVSFlags(TS, (rpmVSFlags_e)-1);
|
||||||
|
int rc = rpmReadPackageFile(TS, FD, sFilePath.c_str(), &HeaderP);
|
||||||
|
if (rc != RPMRC_OK && rc != RPMRC_NOTTRUSTED && rc != RPMRC_NOKEY) {
|
||||||
|
_error->Error(_("Failed reading file %s"), sFilePath.c_str());
|
||||||
|
HeaderP = NULL;
|
||||||
|
}
|
||||||
|
rpmtsFree(TS);
|
||||||
|
#else
|
||||||
|
int rc = rpmReadPackageHeader(FD, &HeaderP, 0, NULL, NULL);
|
||||||
|
if (rc) {
|
||||||
|
_error->Error(_("Failed reading file %s"), sFilePath.c_str());
|
||||||
|
HeaderP = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return (HeaderP != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool RPMSingleFileHandler::Jump(unsigned Offset)
|
||||||
|
{
|
||||||
|
assert(Offset == 0);
|
||||||
|
Rewind();
|
||||||
|
return RPMFileHandler::Jump(Offset);
|
||||||
|
}
|
||||||
|
|
||||||
|
void RPMSingleFileHandler::Rewind()
|
||||||
|
{
|
||||||
|
if (FD == NULL)
|
||||||
|
return;
|
||||||
|
if (HeaderP != NULL) {
|
||||||
|
HeaderP = NULL;
|
||||||
|
headerFree(HeaderP);
|
||||||
|
}
|
||||||
|
lseek(Fileno(FD),0,SEEK_SET);
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned long RPMSingleFileHandler::FileSize()
|
||||||
|
{
|
||||||
|
struct stat S;
|
||||||
|
if (stat(sFilePath.c_str(),&S) != 0)
|
||||||
|
return 0;
|
||||||
|
return S.st_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
string RPMSingleFileHandler::MD5Sum()
|
||||||
|
{
|
||||||
|
MD5Summation MD5;
|
||||||
|
FileFd File(sFilePath, FileFd::ReadOnly);
|
||||||
|
MD5.AddFD(File.Fd(), File.Size());
|
||||||
|
File.Close();
|
||||||
|
return MD5.Result().Value();
|
||||||
|
}
|
||||||
|
|
||||||
RPMDirHandler::RPMDirHandler(string DirName)
|
RPMDirHandler::RPMDirHandler(string DirName)
|
||||||
: sDirName(DirName)
|
: sDirName(DirName)
|
||||||
@ -154,8 +217,9 @@ RPMDirHandler::RPMDirHandler(string DirName)
|
|||||||
while (nextFileName() != NULL)
|
while (nextFileName() != NULL)
|
||||||
iSize += 1;
|
iSize += 1;
|
||||||
rewinddir(Dir);
|
rewinddir(Dir);
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
TS = rpmtsCreate();
|
TS = rpmtsCreate();
|
||||||
|
rpmtsSetVSFlags(TS, (rpmVSFlags_e)-1);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -188,7 +252,7 @@ RPMDirHandler::~RPMDirHandler()
|
|||||||
{
|
{
|
||||||
if (HeaderP != NULL)
|
if (HeaderP != NULL)
|
||||||
headerFree(HeaderP);
|
headerFree(HeaderP);
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
rpmtsFree(TS);
|
rpmtsFree(TS);
|
||||||
#endif
|
#endif
|
||||||
if (Dir != NULL)
|
if (Dir != NULL)
|
||||||
@ -212,7 +276,7 @@ bool RPMDirHandler::Skip()
|
|||||||
FD_t FD = Fopen(sFilePath.c_str(), "r");
|
FD_t FD = Fopen(sFilePath.c_str(), "r");
|
||||||
if (FD == NULL)
|
if (FD == NULL)
|
||||||
continue;
|
continue;
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
int rc = rpmReadPackageFile(TS, FD, fname, &HeaderP);
|
int rc = rpmReadPackageFile(TS, FD, fname, &HeaderP);
|
||||||
Fclose(FD);
|
Fclose(FD);
|
||||||
if (rc != RPMRC_OK
|
if (rc != RPMRC_OK
|
||||||
@ -260,7 +324,7 @@ unsigned long RPMDirHandler::FileSize()
|
|||||||
return 0;
|
return 0;
|
||||||
struct stat St;
|
struct stat St;
|
||||||
if (stat(sFilePath.c_str(),&St) != 0) {
|
if (stat(sFilePath.c_str(),&St) != 0) {
|
||||||
_error->Errno("stat","Unable to determine the file size");
|
_error->Errno("stat",_("Unable to determine the file size"));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return St.st_size;
|
return St.st_size;
|
||||||
@ -295,11 +359,12 @@ RPMDBHandler::RPMDBHandler(bool WriteLock)
|
|||||||
stat(DataPath(false).c_str(), &St);
|
stat(DataPath(false).c_str(), &St);
|
||||||
DbFileMtime = St.st_mtime;
|
DbFileMtime = St.st_mtime;
|
||||||
|
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
RpmIter = NULL;
|
RpmIter = NULL;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
Handler = rpmtsCreate();
|
Handler = rpmtsCreate();
|
||||||
|
rpmtsSetVSFlags(Handler, (rpmVSFlags_e)-1);
|
||||||
if (!Dir.empty())
|
if (!Dir.empty())
|
||||||
rpmtsSetRootDir(Handler, Dir.c_str());
|
rpmtsSetRootDir(Handler, Dir.c_str());
|
||||||
if (rpmtsOpenDB(Handler, WriteLock?O_RDWR:O_RDONLY) != 0)
|
if (rpmtsOpenDB(Handler, WriteLock?O_RDWR:O_RDONLY) != 0)
|
||||||
@ -317,7 +382,7 @@ RPMDBHandler::RPMDBHandler(bool WriteLock)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
RpmIter = rpmxxInitIterator(Handler, RPMDBI_PACKAGES, NULL, 0);
|
RpmIter = rpmxxInitIterator(Handler, RPMDBI_PACKAGES, NULL, 0);
|
||||||
if (RpmIter == NULL) {
|
if (RpmIter == NULL) {
|
||||||
_error->Error(_("could not create RPM database iterator"));
|
_error->Error(_("could not create RPM database iterator"));
|
||||||
@ -349,7 +414,7 @@ RPMDBHandler::RPMDBHandler(bool WriteLock)
|
|||||||
|
|
||||||
RPMDBHandler::~RPMDBHandler()
|
RPMDBHandler::~RPMDBHandler()
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
if (RpmIter == NULL)
|
if (RpmIter == NULL)
|
||||||
return;
|
return;
|
||||||
rpmdbFreeIterator(RpmIter);
|
rpmdbFreeIterator(RpmIter);
|
||||||
@ -359,7 +424,7 @@ RPMDBHandler::~RPMDBHandler()
|
|||||||
headerFree(HeaderP);
|
headerFree(HeaderP);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
rpmtsFree(Handler);
|
rpmtsFree(Handler);
|
||||||
#else
|
#else
|
||||||
rpmdbClose(Handler);
|
rpmdbClose(Handler);
|
||||||
@ -377,19 +442,23 @@ RPMDBHandler::~RPMDBHandler()
|
|||||||
string RPMDBHandler::DataPath(bool DirectoryOnly)
|
string RPMDBHandler::DataPath(bool DirectoryOnly)
|
||||||
{
|
{
|
||||||
string File = "packages.rpm";
|
string File = "packages.rpm";
|
||||||
#ifdef HAVE_RPM4
|
char *tmp = (char *) rpmExpand("%{_dbpath}", NULL);
|
||||||
|
string DBPath(_config->Find("RPM::RootDir")+tmp);
|
||||||
|
free(tmp);
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
if (rpmExpandNumeric("%{_dbapi}") >= 3)
|
if (rpmExpandNumeric("%{_dbapi}") >= 3)
|
||||||
File = "Packages";
|
File = "Packages";
|
||||||
#endif
|
#endif
|
||||||
if (DirectoryOnly == true)
|
if (DirectoryOnly == true)
|
||||||
return _config->Find("RPM::RootDir")+"/var/lib/rpm";
|
return DBPath;
|
||||||
else
|
else
|
||||||
return _config->Find("RPM::RootDir")+"/var/lib/rpm/"+File;
|
return DBPath+"/"+File;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RPMDBHandler::Skip()
|
bool RPMDBHandler::Skip()
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
if (RpmIter == NULL)
|
if (RpmIter == NULL)
|
||||||
return false;
|
return false;
|
||||||
HeaderP = rpmdbNextIterator(RpmIter);
|
HeaderP = rpmdbNextIterator(RpmIter);
|
||||||
@ -416,7 +485,7 @@ bool RPMDBHandler::Skip()
|
|||||||
bool RPMDBHandler::Jump(unsigned int Offset)
|
bool RPMDBHandler::Jump(unsigned int Offset)
|
||||||
{
|
{
|
||||||
iOffset = Offset;
|
iOffset = Offset;
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
if (RpmIter == NULL)
|
if (RpmIter == NULL)
|
||||||
return false;
|
return false;
|
||||||
rpmdbFreeIterator(RpmIter);
|
rpmdbFreeIterator(RpmIter);
|
||||||
@ -434,7 +503,7 @@ bool RPMDBHandler::Jump(unsigned int Offset)
|
|||||||
|
|
||||||
void RPMDBHandler::Rewind()
|
void RPMDBHandler::Rewind()
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
if (RpmIter == NULL)
|
if (RpmIter == NULL)
|
||||||
return;
|
return;
|
||||||
rpmdbFreeIterator(RpmIter);
|
rpmdbFreeIterator(RpmIter);
|
||||||
|
@ -45,6 +45,7 @@ class RPMHandler
|
|||||||
virtual string Directory() {return "";};
|
virtual string Directory() {return "";};
|
||||||
virtual unsigned long FileSize() {return 1;};
|
virtual unsigned long FileSize() {return 1;};
|
||||||
virtual string MD5Sum() {return "";};
|
virtual string MD5Sum() {return "";};
|
||||||
|
virtual bool ProvideFileName() {return false;};
|
||||||
|
|
||||||
RPMHandler() : iOffset(0), iSize(0), HeaderP(0) {};
|
RPMHandler() : iOffset(0), iSize(0), HeaderP(0) {};
|
||||||
virtual ~RPMHandler() {};
|
virtual ~RPMHandler() {};
|
||||||
@ -53,6 +54,8 @@ class RPMHandler
|
|||||||
|
|
||||||
class RPMFileHandler : public RPMHandler
|
class RPMFileHandler : public RPMHandler
|
||||||
{
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
FD_t FD;
|
FD_t FD;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -72,15 +75,40 @@ class RPMFileHandler : public RPMHandler
|
|||||||
virtual ~RPMFileHandler();
|
virtual ~RPMFileHandler();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class RPMSingleFileHandler : public RPMFileHandler
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
|
string sFilePath;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual bool Skip();
|
||||||
|
virtual bool Jump(unsigned int Offset);
|
||||||
|
virtual void Rewind();
|
||||||
|
|
||||||
|
virtual string FileName() {return sFilePath;};
|
||||||
|
virtual string Directory() {return "";};
|
||||||
|
virtual unsigned long FileSize();
|
||||||
|
virtual string MD5Sum();
|
||||||
|
virtual bool ProvideFileName() {return true;};
|
||||||
|
|
||||||
|
RPMSingleFileHandler(string File) : RPMFileHandler(File), sFilePath(File) {};
|
||||||
|
virtual ~RPMSingleFileHandler() {};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class RPMDBHandler : public RPMHandler
|
class RPMDBHandler : public RPMHandler
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RPM41
|
protected:
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
rpmts Handler;
|
rpmts Handler;
|
||||||
#else
|
#else
|
||||||
rpmdb Handler;
|
rpmdb Handler;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_RPM4
|
#if RPM_VERSION >= 0x040000
|
||||||
rpmdbMatchIterator RpmIter;
|
rpmdbMatchIterator RpmIter;
|
||||||
#endif
|
#endif
|
||||||
bool WriteLock;
|
bool WriteLock;
|
||||||
@ -104,13 +132,14 @@ class RPMDBHandler : public RPMHandler
|
|||||||
|
|
||||||
class RPMDirHandler : public RPMHandler
|
class RPMDirHandler : public RPMHandler
|
||||||
{
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
DIR *Dir;
|
DIR *Dir;
|
||||||
string sDirName;
|
string sDirName;
|
||||||
string sFileName;
|
string sFileName;
|
||||||
string sFilePath;
|
string sFilePath;
|
||||||
|
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
rpmts TS;
|
rpmts TS;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ bool rpmListIndex::Exists() const
|
|||||||
return FileExists(IndexPath());
|
return FileExists(IndexPath());
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
// SrcListIndex::Size - Return the size of the index /*{{{*/
|
// rpmListIndex::Size - Return the size of the index /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
unsigned long rpmListIndex::Size() const
|
unsigned long rpmListIndex::Size() const
|
||||||
@ -237,7 +237,10 @@ string rpmSrcListIndex::ArchiveURI(string File) const
|
|||||||
else
|
else
|
||||||
Res = URI + Dist;
|
Res = URI + Dist;
|
||||||
|
|
||||||
Res += "/" + File;
|
if (File.find("/") != string::npos)
|
||||||
|
Res += '/' + File;
|
||||||
|
else
|
||||||
|
Res += "/SRPMS."+Section + '/' + File;
|
||||||
|
|
||||||
if (rpmdata->HasSourceTranslation() == true)
|
if (rpmdata->HasSourceTranslation() == true)
|
||||||
{
|
{
|
||||||
@ -320,7 +323,7 @@ string rpmPkgListIndex::ArchiveURI(string File) const
|
|||||||
if (File.find("/") != string::npos)
|
if (File.find("/") != string::npos)
|
||||||
Res += '/' + File;
|
Res += '/' + File;
|
||||||
else
|
else
|
||||||
Res += "/RPMS."+Section + '/' + File;
|
Res += "/RPMS." + Section + '/' + File;
|
||||||
|
|
||||||
if (rpmdata->HasBinaryTranslation() == true)
|
if (rpmdata->HasBinaryTranslation() == true)
|
||||||
{
|
{
|
||||||
@ -328,7 +331,11 @@ string rpmPkgListIndex::ArchiveURI(string File) const
|
|||||||
Dict["uri"] = URI;
|
Dict["uri"] = URI;
|
||||||
Dict["dist"] = Dist;
|
Dict["dist"] = Dist;
|
||||||
Dict["sect"] = Section;
|
Dict["sect"] = Section;
|
||||||
Dict["file"] = File;
|
string::size_type pos = File.rfind("/");
|
||||||
|
if (pos != string::npos)
|
||||||
|
Dict["file"] = string(File, pos+1);
|
||||||
|
else
|
||||||
|
Dict["file"] = File;
|
||||||
rpmdata->TranslateBinary(Res, Dict);
|
rpmdata->TranslateBinary(Res, Dict);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -373,7 +380,7 @@ bool rpmPkgListIndex::Merge(pkgCacheGenerator &Gen,OpProgress &Prog) const
|
|||||||
if (stat(PackageFile.c_str(),&St) != 0)
|
if (stat(PackageFile.c_str(),&St) != 0)
|
||||||
{
|
{
|
||||||
delete Handler;
|
delete Handler;
|
||||||
return _error->Errno("stat","Failed to stat");
|
return _error->Errno("stat",_("Failed to stat %s"), PackageFile.c_str());
|
||||||
}
|
}
|
||||||
File->Size = St.st_size;
|
File->Size = St.st_size;
|
||||||
File->mtime = St.st_mtime;
|
File->mtime = St.st_mtime;
|
||||||
@ -475,6 +482,51 @@ unsigned long rpmPkgDirIndex::Size() const
|
|||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
|
// SrcDirIndex::Index* - Return the URI to the index files /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
inline string rpmSrcDirIndex::IndexPath() const
|
||||||
|
{
|
||||||
|
return ::URI(ArchiveURI("")).Path;
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// SrcDirIndex::Size - Return the size of the index /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* This is really only used for progress reporting. */
|
||||||
|
unsigned long rpmSrcDirIndex::Size() const
|
||||||
|
{
|
||||||
|
// XXX: Must optimize this somehow.
|
||||||
|
RPMHandler *Handler = CreateHandler();
|
||||||
|
unsigned long Res = Handler->Size();
|
||||||
|
delete Handler;
|
||||||
|
return Res;
|
||||||
|
}
|
||||||
|
|
||||||
|
// SinglePkgIndex::ArchiveURI - URI for the archive /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
string rpmSinglePkgIndex::ArchiveURI(string File) const
|
||||||
|
{
|
||||||
|
char *cwd = getcwd(NULL,0);
|
||||||
|
if (File[0] == '.' && File[1] == '/')
|
||||||
|
File = string(File, 2);
|
||||||
|
string URI = "file://"+flCombine(cwd, File);
|
||||||
|
free(cwd);
|
||||||
|
return URI;
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// SinglePkgIndex::ArchiveURI - URI for the archive /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
string rpmSingleSrcIndex::ArchiveURI(string File) const
|
||||||
|
{
|
||||||
|
char *cwd = getcwd(NULL,0);
|
||||||
|
if (File[0] == '.' && File[1] == '/')
|
||||||
|
File = string(File, 2);
|
||||||
|
string URI = "file://"+flCombine(cwd, File);
|
||||||
|
free(cwd);
|
||||||
|
return URI;
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
|
||||||
// DatabaseIndex::rpmDatabaseIndex - Constructor /*{{{*/
|
// DatabaseIndex::rpmDatabaseIndex - Constructor /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
@ -515,7 +567,7 @@ bool rpmDatabaseIndex::Merge(pkgCacheGenerator &Gen,OpProgress &Prog) const
|
|||||||
pkgCache::PkgFileIterator CFile = Gen.GetCurFile();
|
pkgCache::PkgFileIterator CFile = Gen.GetCurFile();
|
||||||
struct stat St;
|
struct stat St;
|
||||||
if (stat(Handler->DataPath(false).c_str(),&St) != 0)
|
if (stat(Handler->DataPath(false).c_str(),&St) != 0)
|
||||||
return _error->Errno("fstat","Failed to stat");
|
return _error->Errno("fstat",_("Failed to stat %s"), Handler->DataPath(false).c_str());
|
||||||
CFile->Size = St.st_size;
|
CFile->Size = St.st_size;
|
||||||
CFile->mtime = Handler->Mtime();
|
CFile->mtime = Handler->Mtime();
|
||||||
|
|
||||||
@ -679,9 +731,30 @@ class rpmSLTypeRpmDir : public rpmSLTypeGen
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class rpmSLTypeSrpmDir : public rpmSLTypeGen
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
bool CreateItem(vector<pkgIndexFile *> &List,
|
||||||
|
string URI, string Dist, string Section,
|
||||||
|
pkgSourceList::Vendor const *Vendor) const
|
||||||
|
{
|
||||||
|
pkgRepository *Rep = GetRepository(URI,Dist,Vendor);
|
||||||
|
List.push_back(new rpmSrcDirIndex(URI,Dist,Section,Rep));
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
rpmSLTypeSrpmDir()
|
||||||
|
{
|
||||||
|
Name = "rpm-src-dir";
|
||||||
|
Label = "Local SRPM directory tree";
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
rpmSLTypeRpm _apt_rpmType;
|
rpmSLTypeRpm _apt_rpmType;
|
||||||
rpmSLTypeSrpm _apt_rpmSrcType;
|
rpmSLTypeSrpm _apt_rpmSrcType;
|
||||||
rpmSLTypeRpmDir _apt_rpmDirType;
|
rpmSLTypeRpmDir _apt_rpmDirType;
|
||||||
|
rpmSLTypeSrpmDir _apt_rpmSrcDirType;
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
// Index File types for rpm /*{{{*/
|
// Index File types for rpm /*{{{*/
|
||||||
class rpmIFTypeSrc : public pkgIndexFile::Type
|
class rpmIFTypeSrc : public pkgIndexFile::Type
|
||||||
@ -722,10 +795,22 @@ const pkgIndexFile::Type *rpmPkgListIndex::GetType() const
|
|||||||
{
|
{
|
||||||
return &_apt_Pkg;
|
return &_apt_Pkg;
|
||||||
}
|
}
|
||||||
|
const pkgIndexFile::Type *rpmSrcDirIndex::GetType() const
|
||||||
|
{
|
||||||
|
return &_apt_Src;
|
||||||
|
}
|
||||||
const pkgIndexFile::Type *rpmPkgDirIndex::GetType() const
|
const pkgIndexFile::Type *rpmPkgDirIndex::GetType() const
|
||||||
{
|
{
|
||||||
return &_apt_Pkg;
|
return &_apt_Pkg;
|
||||||
}
|
}
|
||||||
|
const pkgIndexFile::Type *rpmSinglePkgIndex::GetType() const
|
||||||
|
{
|
||||||
|
return &_apt_Pkg;
|
||||||
|
}
|
||||||
|
const pkgIndexFile::Type *rpmSingleSrcIndex::GetType() const
|
||||||
|
{
|
||||||
|
return &_apt_Src;
|
||||||
|
}
|
||||||
const pkgIndexFile::Type *rpmDatabaseIndex::GetType() const
|
const pkgIndexFile::Type *rpmDatabaseIndex::GetType() const
|
||||||
{
|
{
|
||||||
return &_apt_DB;
|
return &_apt_DB;
|
||||||
|
@ -195,5 +195,83 @@ class rpmPkgDirIndex : public rpmPkgListIndex
|
|||||||
{};
|
{};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class rpmSrcDirIndex : public rpmSrcListIndex
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
|
virtual string MainType() const {return "srcdir";}
|
||||||
|
virtual string IndexPath() const;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual bool GetReleases(pkgAcquire *Owner) const { return true; }
|
||||||
|
virtual bool GetIndexes(pkgAcquire *Owner) const { return true; }
|
||||||
|
|
||||||
|
// Creates a RPMHandler suitable for usage with this object
|
||||||
|
virtual RPMHandler *CreateHandler() const
|
||||||
|
{ return new RPMDirHandler(IndexPath()); };
|
||||||
|
|
||||||
|
virtual const Type *GetType() const;
|
||||||
|
|
||||||
|
// Interface for the Cache Generator
|
||||||
|
virtual unsigned long Size() const;
|
||||||
|
|
||||||
|
rpmSrcDirIndex(string URI,string Dist,string Section,
|
||||||
|
pkgRepository *Repository) :
|
||||||
|
rpmSrcListIndex(URI,Dist,Section,Repository)
|
||||||
|
{};
|
||||||
|
};
|
||||||
|
|
||||||
|
class rpmSinglePkgIndex : public rpmPkgListIndex
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
|
string FilePath;
|
||||||
|
|
||||||
|
virtual string MainType() const {return "pkg";}
|
||||||
|
virtual string IndexPath() const {return FilePath;}
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual bool GetReleases(pkgAcquire *Owner) const { return true; }
|
||||||
|
virtual bool GetIndexes(pkgAcquire *Owner) const { return true; }
|
||||||
|
|
||||||
|
// Creates a RPMHandler suitable for usage with this object
|
||||||
|
virtual RPMHandler *CreateHandler() const
|
||||||
|
{ return new RPMSingleFileHandler(IndexPath()); };
|
||||||
|
|
||||||
|
virtual string ArchiveURI(string File) const;
|
||||||
|
|
||||||
|
virtual const Type *GetType() const;
|
||||||
|
|
||||||
|
rpmSinglePkgIndex(string File) :
|
||||||
|
rpmPkgListIndex("", "", "", NULL), FilePath(File) {};
|
||||||
|
};
|
||||||
|
|
||||||
|
class rpmSingleSrcIndex : public rpmSrcListIndex
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
|
||||||
|
string FilePath;
|
||||||
|
|
||||||
|
virtual string MainType() const {return "src";}
|
||||||
|
virtual string IndexPath() const {return FilePath;}
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual bool GetReleases(pkgAcquire *Owner) const { return true; }
|
||||||
|
virtual bool GetIndexes(pkgAcquire *Owner) const { return true; }
|
||||||
|
|
||||||
|
// Creates a RPMHandler suitable for usage with this object
|
||||||
|
virtual RPMHandler *CreateHandler() const
|
||||||
|
{ return new RPMSingleFileHandler(IndexPath()); };
|
||||||
|
|
||||||
|
virtual string ArchiveURI(string File) const;
|
||||||
|
|
||||||
|
virtual const Type *GetType() const;
|
||||||
|
|
||||||
|
rpmSingleSrcIndex(string File) :
|
||||||
|
rpmSrcListIndex("", "", "", NULL), FilePath(File) {};
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
#include <rpm/rpmlib.h>
|
#include <rpm/rpmlib.h>
|
||||||
|
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
#include <rpm/rpmds.h>
|
#include <rpm/rpmds.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -108,7 +108,7 @@ string rpmListParser::Package()
|
|||||||
|
|
||||||
if (headerGetEntry(header, RPMTAG_NAME, &type, (void**)&str, &count) != 1)
|
if (headerGetEntry(header, RPMTAG_NAME, &type, (void**)&str, &count) != 1)
|
||||||
{
|
{
|
||||||
_error->Error("Corrupt pkglist: no RPMTAG_NAME in header entry");
|
_error->Error(_("Corrupt pkglist: no RPMTAG_NAME in header entry"));
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -251,6 +251,10 @@ bool rpmListParser::NewVersion(pkgCache::VerIterator Ver)
|
|||||||
if (ParseProvides(Ver) == false)
|
if (ParseProvides(Ver) == false)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if (Handler->ProvideFileName() &&
|
||||||
|
NewProvides(Ver, Handler->FileName(), "") == false)
|
||||||
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
@ -278,11 +282,12 @@ bool rpmListParser::UsePackage(pkgCache::PkgIterator Pkg,
|
|||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
|
|
||||||
|
/*
|
||||||
static int compare(const void *a, const void *b)
|
static int compare(const void *a, const void *b)
|
||||||
{
|
{
|
||||||
return strcmp(*(char**)a, *(char**)b);
|
return strcmp(*(char**)a, *(char**)b);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
unsigned short rpmListParser::VersionHash()
|
unsigned short rpmListParser::VersionHash()
|
||||||
{
|
{
|
||||||
@ -384,7 +389,7 @@ bool rpmListParser::ParseDepends(pkgCache::VerIterator Ver,
|
|||||||
|
|
||||||
if (namel[i][0] == 'r' && strncmp(namel[i], "rpmlib", 6) == 0)
|
if (namel[i][0] == 'r' && strncmp(namel[i], "rpmlib", 6) == 0)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RPM41
|
#if RPM_VERSION >= 0x040100
|
||||||
rpmds ds = rpmdsSingle(RPMTAG_PROVIDENAME,
|
rpmds ds = rpmdsSingle(RPMTAG_PROVIDENAME,
|
||||||
namel[i], verl?verl[i]:NULL, flagl[i]);
|
namel[i], verl?verl[i]:NULL, flagl[i]);
|
||||||
int res = rpmCheckRpmlibProvides(ds);
|
int res = rpmCheckRpmlibProvides(ds);
|
||||||
@ -519,9 +524,21 @@ bool rpmListParser::CollectFileProvides(pkgCache &Cache,
|
|||||||
NULL, (void **) &names, &count);
|
NULL, (void **) &names, &count);
|
||||||
while (count--)
|
while (count--)
|
||||||
{
|
{
|
||||||
pkgCache::Package *P = Cache.FindPackage(names[count]);
|
const char *FileName = names[count];
|
||||||
if (P != NULL && !NewProvides(Ver, names[count], ""))
|
pkgCache::Package *P = Cache.FindPackage(FileName);
|
||||||
return false;
|
if (P != NULL) {
|
||||||
|
// Check if this is already provided.
|
||||||
|
bool Found = false;
|
||||||
|
for (pkgCache::PrvIterator Prv = Ver.ProvidesList();
|
||||||
|
Prv.end() == false; Prv++) {
|
||||||
|
if (strcmp(Prv.Name(), FileName) == 0) {
|
||||||
|
Found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Found == false && NewProvides(Ver, FileName, "") == false)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -646,7 +663,7 @@ bool rpmListParser::LoadReleaseInfo(pkgCache::PkgFileIterator FileI,
|
|||||||
|
|
||||||
if (Section.FindFlag("NotAutomatic",FileI->Flags,
|
if (Section.FindFlag("NotAutomatic",FileI->Flags,
|
||||||
pkgCache::Flag::NotAutomatic) == false)
|
pkgCache::Flag::NotAutomatic) == false)
|
||||||
_error->Warning("Bad NotAutomatic flag");
|
_error->Warning(_("Bad NotAutomatic flag"));
|
||||||
|
|
||||||
return !_error->PendingError();
|
return !_error->PendingError();
|
||||||
}
|
}
|
||||||
@ -702,8 +719,8 @@ void rpmListParser::VirtualizePackage(string Name)
|
|||||||
// read the comment above).
|
// read the comment above).
|
||||||
map_ptrloc *ToVerLast = &ToPkgI->VersionList;
|
map_ptrloc *ToVerLast = &ToPkgI->VersionList;
|
||||||
for (pkgCache::VerIterator ToVerLastI = ToPkgI.VersionList();
|
for (pkgCache::VerIterator ToVerLastI = ToPkgI.VersionList();
|
||||||
ToVerLastI.end() == false;
|
ToVerLastI.end() == false; ToVerLastI++)
|
||||||
ToVerLast = &ToVerLastI->NextVer, ToVerLast++);
|
ToVerLast = &ToVerLastI->NextVer;
|
||||||
|
|
||||||
*ToVerLast = FromVerI.Index();
|
*ToVerLast = FromVerI.Index();
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#ifndef RPMMISC_H
|
#ifndef RPMMISC_H
|
||||||
#define RPMMISC_H
|
#define RPMMISC_H
|
||||||
|
|
||||||
#ifdef WITH_HASH_MAP
|
#ifdef WITH_GNU_HASH_MAP
|
||||||
|
|
||||||
#include <ext/hash_map>
|
#include <ext/hash_map>
|
||||||
|
|
||||||
@ -23,7 +23,7 @@ struct cstr_eq_pred
|
|||||||
size_t operator()(const char *s1, const char *s2) const
|
size_t operator()(const char *s1, const char *s2) const
|
||||||
{ return strcmp(s1, s2) == 0; };
|
{ return strcmp(s1, s2) == 0; };
|
||||||
};
|
};
|
||||||
#endif /* WITH_HASH_MAP */
|
#endif /* WITH_GNU_HASH_MAP */
|
||||||
|
|
||||||
struct cstr_lt_pred
|
struct cstr_lt_pred
|
||||||
{
|
{
|
||||||
|
@ -67,7 +67,11 @@ class RPMPackageData
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
inline pkgCache::State::VerPriority VerPriority(string Package)
|
inline pkgCache::State::VerPriority VerPriority(string Package)
|
||||||
{return Priorities[Package];};
|
{
|
||||||
|
if (Priorities.find(Package) != Priorities.end())
|
||||||
|
return Priorities[Package];
|
||||||
|
return pkgCache::State::Standard;
|
||||||
|
};
|
||||||
inline pkgCache::Flag::PkgFlags PkgFlags(string Package)
|
inline pkgCache::Flag::PkgFlags PkgFlags(string Package)
|
||||||
{return Flags[Package];};
|
{return Flags[Package];};
|
||||||
|
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
#include <apt-pkg/rpmpm.h>
|
#include <apt-pkg/rpmpm.h>
|
||||||
#include <apt-pkg/error.h>
|
#include <apt-pkg/error.h>
|
||||||
#include <apt-pkg/configuration.h>
|
#include <apt-pkg/configuration.h>
|
||||||
|
#include <apt-pkg/luaiface.h>
|
||||||
|
#include <apt-pkg/depcache.h>
|
||||||
|
|
||||||
#include <apti18n.h>
|
#include <apti18n.h>
|
||||||
|
|
||||||
@ -32,9 +34,19 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
#include <rpm/rpmlib.h>
|
#include <rpm/rpmdb.h>
|
||||||
/*}}}*/
|
#define packagesTotal rpmcliPackagesTotal
|
||||||
|
#else
|
||||||
|
#define rpmpsPrint(a,b) rpmProblemSetPrint(a,b)
|
||||||
|
#define rpmpsFree(a) rpmProblemSetFree(a)
|
||||||
|
#define rpmReadPackageFile(a,b,c,d) rpmReadPackageHeader(b,d,0,NULL,NULL)
|
||||||
|
#if RPM_VERSION < 0x040000
|
||||||
|
#define rpmtransFlags int
|
||||||
|
#define rpmprobFilterFlags int
|
||||||
|
#include "rpmshowprogress.h"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
// RPMPM::pkgRPMPM - Constructor /*{{{*/
|
// RPMPM::pkgRPMPM - Constructor /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
@ -162,7 +174,7 @@ bool pkgRPMPM::RunScriptsWithPkgs(const char *Cnf)
|
|||||||
// Create the pipes
|
// Create the pipes
|
||||||
int Pipes[2];
|
int Pipes[2];
|
||||||
if (pipe(Pipes) != 0)
|
if (pipe(Pipes) != 0)
|
||||||
return _error->Errno("pipe","Failed to create IPC pipe to subprocess");
|
return _error->Errno("pipe",_("Failed to create IPC pipe to subprocess"));
|
||||||
SetCloseExec(Pipes[0],true);
|
SetCloseExec(Pipes[0],true);
|
||||||
SetCloseExec(Pipes[1],true);
|
SetCloseExec(Pipes[1],true);
|
||||||
|
|
||||||
@ -221,7 +233,157 @@ bool pkgRPMPM::RunScriptsWithPkgs(const char *Cnf)
|
|||||||
|
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|
||||||
|
// RPMPM::Go - Run the sequence /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* This globs the operations and calls rpm */
|
||||||
|
bool pkgRPMPM::Go()
|
||||||
|
{
|
||||||
|
if (RunScripts("RPM::Pre-Invoke") == false)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (RunScriptsWithPkgs("RPM::Pre-Install-Pkgs") == false)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
vector<const char*> install_or_upgrade;
|
||||||
|
vector<const char*> install;
|
||||||
|
vector<const char*> upgrade;
|
||||||
|
vector<const char*> uninstall;
|
||||||
|
vector<pkgCache::Package*> pkgs_install;
|
||||||
|
vector<pkgCache::Package*> pkgs_uninstall;
|
||||||
|
|
||||||
|
vector<char*> unalloc;
|
||||||
|
|
||||||
|
for (vector<Item>::iterator I = List.begin(); I != List.end(); I++)
|
||||||
|
{
|
||||||
|
switch (I->Op)
|
||||||
|
{
|
||||||
|
case Item::Purge:
|
||||||
|
case Item::Remove:
|
||||||
|
if (strchr(I->Pkg.Name(), '#') != NULL)
|
||||||
|
{
|
||||||
|
char *name = strdup(I->Pkg.Name());
|
||||||
|
char *p = strchr(name, '#');
|
||||||
|
*(p++) = '-';
|
||||||
|
const char *epoch = strchr(p, ':');
|
||||||
|
if (epoch != NULL)
|
||||||
|
memmove(p, epoch+1, strlen(epoch+1)+1);
|
||||||
|
unalloc.push_back(name);
|
||||||
|
uninstall.push_back(name);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
uninstall.push_back(I->Pkg.Name());
|
||||||
|
pkgs_uninstall.push_back(I->Pkg);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Item::Configure:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Item::Install:
|
||||||
|
if (strchr(I->Pkg.Name(), '#') != NULL) {
|
||||||
|
char *name = strdup(I->Pkg.Name());
|
||||||
|
char *p = strchr(name, '#');
|
||||||
|
*p = 0;
|
||||||
|
PkgIterator Pkg = Cache.FindPkg(name);
|
||||||
|
free(name);
|
||||||
|
PrvIterator Prv = Pkg.ProvidesList();
|
||||||
|
bool Installed = false;
|
||||||
|
for (; Prv.end() == false; Prv++) {
|
||||||
|
if (Prv.OwnerPkg().CurrentVer().end() == false) {
|
||||||
|
Installed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Installed)
|
||||||
|
install.push_back(I->File.c_str());
|
||||||
|
else
|
||||||
|
upgrade.push_back(I->File.c_str());
|
||||||
|
} else {
|
||||||
|
upgrade.push_back(I->File.c_str());
|
||||||
|
}
|
||||||
|
install_or_upgrade.push_back(I->File.c_str());
|
||||||
|
pkgs_install.push_back(I->Pkg);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return _error->Error(_("Unknown pkgRPMPM operation."));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Ret = true;
|
||||||
|
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
if (_lua->HasScripts("Scripts::PM::Pre") == true) {
|
||||||
|
_lua->SetGlobal("files_install", install_or_upgrade);
|
||||||
|
_lua->SetGlobal("names_remove", uninstall);
|
||||||
|
_lua->SetGlobal("pkgs_install", pkgs_install);
|
||||||
|
_lua->SetGlobal("pkgs_remove", pkgs_uninstall);
|
||||||
|
_lua->SetDepCache(&Cache);
|
||||||
|
_lua->RunScripts("Scripts::PM::Pre", false);
|
||||||
|
_lua->ResetCaches();
|
||||||
|
_lua->ResetGlobals();
|
||||||
|
if (_error->PendingError() == true) {
|
||||||
|
Ret = false;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (Process(install, upgrade, uninstall) == false)
|
||||||
|
Ret = false;
|
||||||
|
|
||||||
|
#ifdef WITH_LUA
|
||||||
|
if (_lua->HasScripts("Scripts::PM::Post") == true) {
|
||||||
|
_lua->SetGlobal("files_install", install_or_upgrade);
|
||||||
|
_lua->SetGlobal("names_remove", uninstall);
|
||||||
|
_lua->SetGlobal("pkgs_install", pkgs_install);
|
||||||
|
_lua->SetGlobal("pkgs_remove", pkgs_uninstall);
|
||||||
|
_lua->SetDepCache(&Cache);
|
||||||
|
_lua->RunScripts("Scripts::PM::Post", false);
|
||||||
|
_lua->ResetCaches();
|
||||||
|
_lua->ResetGlobals();
|
||||||
|
if (_error->PendingError() == true) {
|
||||||
|
Ret = false;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
if (Ret == true)
|
||||||
|
Ret = RunScripts("RPM::Post-Invoke");
|
||||||
|
|
||||||
|
exit:
|
||||||
|
for (vector<char *>::iterator I = unalloc.begin(); I != unalloc.end(); I++)
|
||||||
|
free(*I);
|
||||||
|
|
||||||
|
return Ret;
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// pkgRPMPM::Reset - Dump the contents of the command list /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
void pkgRPMPM::Reset()
|
||||||
|
{
|
||||||
|
List.erase(List.begin(),List.end());
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// RPMExtPM::pkgRPMExtPM - Constructor /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
pkgRPMExtPM::pkgRPMExtPM(pkgDepCache *Cache) : pkgRPMPM(Cache)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// RPMExtPM::pkgRPMExtPM - Destructor /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
pkgRPMExtPM::~pkgRPMExtPM()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
|
||||||
|
bool pkgRPMExtPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
||||||
{
|
{
|
||||||
const char *Args[10000];
|
const char *Args[10000];
|
||||||
const char *operation;
|
const char *operation;
|
||||||
@ -285,7 +447,8 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bool oldpackage = _config->FindB("RPM::OldPackage",true);
|
bool oldpackage = _config->FindB("RPM::OldPackage",
|
||||||
|
(op == Item::RPMUpgrade));
|
||||||
bool replacepkgs = _config->FindB("APT::Get::ReInstall",false);
|
bool replacepkgs = _config->FindB("APT::Get::ReInstall",false);
|
||||||
bool replacefiles = _config->FindB("APT::Get::ReInstall",false);
|
bool replacefiles = _config->FindB("APT::Get::ReInstall",false);
|
||||||
Opts = _config->Tree("RPM::Install-Options");
|
Opts = _config->Tree("RPM::Install-Options");
|
||||||
@ -333,8 +496,35 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
if (_config->FindB("RPM::Order",false) == false)
|
if (_config->FindB("RPM::Order",false) == false)
|
||||||
Args[n++] = "--noorder";
|
Args[n++] = "--noorder";
|
||||||
|
|
||||||
for (vector<const char*>::iterator I = files.begin(); I != files.end(); I++)
|
bool FilesInArgs = true;
|
||||||
Args[n++] = *I;
|
char *ArgsFileName = NULL;
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
|
if (op != Item::RPMErase && files.size() > 50) {
|
||||||
|
string FileName = _config->FindDir("Dir::Cache", "/tmp/") +
|
||||||
|
"filelist.XXXXXX";
|
||||||
|
ArgsFileName = strdup(FileName.c_str());
|
||||||
|
if (ArgsFileName) {
|
||||||
|
int fd = mkstemp(ArgsFileName);
|
||||||
|
if (fd != -1) {
|
||||||
|
FileFd File(fd);
|
||||||
|
for (vector<const char*>::iterator I = files.begin();
|
||||||
|
I != files.end(); I++) {
|
||||||
|
File.Write(*I, strlen(*I));
|
||||||
|
File.Write("\n", 1);
|
||||||
|
}
|
||||||
|
File.Close();
|
||||||
|
FilesInArgs = false;
|
||||||
|
Args[n++] = ArgsFileName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (FilesInArgs == true) {
|
||||||
|
for (vector<const char*>::iterator I = files.begin();
|
||||||
|
I != files.end(); I++)
|
||||||
|
Args[n++] = *I;
|
||||||
|
}
|
||||||
|
|
||||||
Args[n++] = 0;
|
Args[n++] = 0;
|
||||||
|
|
||||||
@ -343,6 +533,10 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
for (unsigned int k = 0; k < n; k++)
|
for (unsigned int k = 0; k < n; k++)
|
||||||
clog << Args[k] << ' ';
|
clog << Args[k] << ' ';
|
||||||
clog << endl;
|
clog << endl;
|
||||||
|
if (ArgsFileName) {
|
||||||
|
unlink(ArgsFileName);
|
||||||
|
free(ArgsFileName);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -386,7 +580,7 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
}
|
}
|
||||||
|
|
||||||
execvp(Args[0],(char **)Args);
|
execvp(Args[0],(char **)Args);
|
||||||
cerr << "Could not exec " << Args[0] << endl;
|
cerr << _("Could not exec ") << Args[0] << endl;
|
||||||
_exit(100);
|
_exit(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -397,7 +591,15 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
if (errno == EINTR)
|
if (errno == EINTR)
|
||||||
continue;
|
continue;
|
||||||
RunScripts("RPM::Post-Invoke");
|
RunScripts("RPM::Post-Invoke");
|
||||||
return _error->Errno("waitpid","Couldn't wait for subprocess");
|
if (ArgsFileName) {
|
||||||
|
unlink(ArgsFileName);
|
||||||
|
free(ArgsFileName);
|
||||||
|
}
|
||||||
|
return _error->Errno("waitpid",_("Couldn't wait for subprocess"));
|
||||||
|
}
|
||||||
|
if (ArgsFileName) {
|
||||||
|
unlink(ArgsFileName);
|
||||||
|
free(ArgsFileName);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Restore sig int/quit
|
// Restore sig int/quit
|
||||||
@ -417,12 +619,12 @@ bool pkgRPMPM::ExecRPM(Item::RPMOps op, vector<const char*> &files)
|
|||||||
|
|
||||||
return _error->Error(_("Sub-process %s exited unexpectedly"),Args[0]);
|
return _error->Error(_("Sub-process %s exited unexpectedly"),Args[0]);
|
||||||
}
|
}
|
||||||
|
cout << _("Done.") << endl;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool pkgRPMExtPM::Process(vector<const char*> &install,
|
||||||
bool pkgRPMPM::Process(vector<const char*> &install,
|
|
||||||
vector<const char*> &upgrade,
|
vector<const char*> &upgrade,
|
||||||
vector<const char*> &uninstall)
|
vector<const char*> &uninstall)
|
||||||
{
|
{
|
||||||
@ -435,83 +637,316 @@ bool pkgRPMPM::Process(vector<const char*> &install,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// RPMLibPM::pkgRPMLibPM - Constructor /*{{{*/
|
||||||
// RPMPM::Go - Run the sequence /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
|
||||||
/* This globs the operations and calls rpm */
|
|
||||||
bool pkgRPMPM::Go()
|
|
||||||
{
|
|
||||||
if (RunScripts("RPM::Pre-Invoke") == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (RunScriptsWithPkgs("RPM::Pre-Install-Pkgs") == false)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
vector<const char*> install;
|
|
||||||
vector<const char*> upgrade;
|
|
||||||
vector<const char*> uninstall;
|
|
||||||
|
|
||||||
vector<char*> unalloc;
|
|
||||||
|
|
||||||
for (vector<Item>::iterator I = List.begin(); I != List.end(); I++)
|
|
||||||
{
|
|
||||||
switch (I->Op)
|
|
||||||
{
|
|
||||||
case Item::Purge:
|
|
||||||
case Item::Remove:
|
|
||||||
if (strchr(I->Pkg.Name(), '#') != NULL)
|
|
||||||
{
|
|
||||||
char *name = strdup(I->Pkg.Name());
|
|
||||||
char *p = strchr(name, '#');
|
|
||||||
*(p++) = '-';
|
|
||||||
const char *epoch = strchr(p, ':');
|
|
||||||
if (epoch != NULL)
|
|
||||||
memmove(p, epoch+1, strlen(epoch+1)+1);
|
|
||||||
unalloc.push_back(name);
|
|
||||||
uninstall.push_back(name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
uninstall.push_back(I->Pkg.Name());
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Item::Configure:
|
|
||||||
break;
|
|
||||||
|
|
||||||
case Item::Install:
|
|
||||||
if (strchr(I->Pkg.Name(), '#') != NULL)
|
|
||||||
install.push_back(I->File.c_str());
|
|
||||||
else
|
|
||||||
upgrade.push_back(I->File.c_str());
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return _error->Error("Unknown pkgRPMPM operation.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Ret = true;
|
|
||||||
|
|
||||||
if (Process(install, upgrade, uninstall) == false)
|
|
||||||
Ret = false;
|
|
||||||
|
|
||||||
for (vector<char *>::iterator I = unalloc.begin(); I != unalloc.end(); I++)
|
|
||||||
free(*I);
|
|
||||||
|
|
||||||
if (Ret == true)
|
|
||||||
Ret = RunScripts("RPM::Post-Invoke");
|
|
||||||
|
|
||||||
return Ret;
|
|
||||||
}
|
|
||||||
/*}}}*/
|
|
||||||
// pkgRPMPM::Reset - Dump the contents of the command list /*{{{*/
|
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
void pkgRPMPM::Reset()
|
pkgRPMLibPM::pkgRPMLibPM(pkgDepCache *Cache) : pkgRPMPM(Cache)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
/*}}}*/
|
||||||
|
// RPMLibPM::pkgRPMLibPM - Destructor /*{{{*/
|
||||||
|
// ---------------------------------------------------------------------
|
||||||
|
/* */
|
||||||
|
pkgRPMLibPM::~pkgRPMLibPM()
|
||||||
{
|
{
|
||||||
List.erase(List.begin(),List.end());
|
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
|
bool pkgRPMLibPM::AddToTransaction(Item::RPMOps op, vector<const char*> &files)
|
||||||
|
{
|
||||||
|
int debug = _config->FindB("Debug::pkgRPMPM", false);
|
||||||
|
int n = 0, rc, xx;
|
||||||
|
FD_t fd;
|
||||||
|
rpmHeader hdr;
|
||||||
|
|
||||||
|
for (vector<const char*>::iterator I = files.begin(); I != files.end(); I++)
|
||||||
|
{
|
||||||
|
int upgrade = 0;
|
||||||
|
|
||||||
|
switch (op)
|
||||||
|
{
|
||||||
|
case Item::RPMUpgrade:
|
||||||
|
upgrade = 1;
|
||||||
|
case Item::RPMInstall:
|
||||||
|
fd = Fopen(*I, "r.ufdio");
|
||||||
|
if (fd == NULL)
|
||||||
|
_error->Error(_("Failed opening %s"), *I);
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rc = rpmReadPackageFile(TS, fd, *I, &hdr);
|
||||||
|
if (rc != RPMRC_OK && rc != RPMRC_NOTTRUSTED && rc != RPMRC_NOKEY)
|
||||||
|
_error->Error(_("Failed reading file %s"), *I);
|
||||||
|
rc = rpmtsAddInstallElement(TS, hdr, *I, upgrade, 0);
|
||||||
|
#else
|
||||||
|
rc = rpmReadPackageHeader(fd, &hdr, 0, NULL, NULL);
|
||||||
|
if (rc)
|
||||||
|
_error->Error(_("Failed reading file %s"), *I);
|
||||||
|
rc = rpmtransAddPackage(TS, hdr, NULL, *I, upgrade, 0);
|
||||||
|
#endif
|
||||||
|
if (rc)
|
||||||
|
_error->Error(_("Failed adding %s to transaction %s"),
|
||||||
|
*I, "(install)");
|
||||||
|
headerFree(hdr);
|
||||||
|
Fclose(fd);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Item::RPMErase:
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
|
rpmdbMatchIterator MI;
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
MI = rpmtsInitIterator(TS, (rpmTag)RPMDBI_LABEL, *I, 0);
|
||||||
|
#else
|
||||||
|
MI = rpmdbInitIterator(DB, RPMDBI_LABEL, *I, 0);
|
||||||
|
#endif
|
||||||
|
while ((hdr = rpmdbNextIterator(MI)) != NULL)
|
||||||
|
{
|
||||||
|
unsigned int recOffset = rpmdbGetIteratorOffset(MI);
|
||||||
|
if (recOffset) {
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rc = rpmtsAddEraseElement(TS, hdr, recOffset);
|
||||||
|
#else
|
||||||
|
rc = rpmtransRemovePackage(TS, recOffset);
|
||||||
|
#endif
|
||||||
|
if (rc)
|
||||||
|
_error->Error(_("Failed adding %s to transaction %s"),
|
||||||
|
*I, "(erase)");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
MI = rpmdbFreeIterator(MI);
|
||||||
|
#else // RPM 3.X
|
||||||
|
dbiIndexSet matches;
|
||||||
|
rc = rpmdbFindByLabel(DB, *I, &matches);
|
||||||
|
if (rc == 0) {
|
||||||
|
for (int i = 0; i < dbiIndexSetCount(matches); i++) {
|
||||||
|
unsigned int recOffset = dbiIndexRecordOffset(matches, i);
|
||||||
|
if (recOffset)
|
||||||
|
rpmtransRemovePackage(TS, recOffset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pkgRPMLibPM::Process(vector<const char*> &install,
|
||||||
|
vector<const char*> &upgrade,
|
||||||
|
vector<const char*> &uninstall)
|
||||||
|
{
|
||||||
|
int rc = 0;
|
||||||
|
bool Success = false;
|
||||||
|
int debug = _config->FindB("Debug::pkgRPMPM", false);
|
||||||
|
string Dir = _config->Find("RPM::RootDir");
|
||||||
|
rpmReadConfigFiles(NULL, NULL);
|
||||||
|
|
||||||
|
int probFilter = 0;
|
||||||
|
int notifyFlags = 0;
|
||||||
|
int tsFlags = 0;
|
||||||
|
|
||||||
|
if (uninstall.empty() == false)
|
||||||
|
ParseRpmOpts("RPM::Erase-Options", &tsFlags, &probFilter);
|
||||||
|
if (install.empty() == false || upgrade.empty() == false)
|
||||||
|
ParseRpmOpts("RPM::Install-Options", &tsFlags, &probFilter);
|
||||||
|
ParseRpmOpts("RPM::Options", &tsFlags, &probFilter);
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rpmps probs;
|
||||||
|
TS = rpmtsCreate();
|
||||||
|
rpmtsSetVSFlags(TS, (rpmVSFlags_e)-1);
|
||||||
|
// 4.1 needs this always set even if NULL,
|
||||||
|
// otherwise all scriptlets fail
|
||||||
|
rpmtsSetRootDir(TS, Dir.c_str());
|
||||||
|
if (rpmtsOpenDB(TS, O_RDWR) != 0)
|
||||||
|
{
|
||||||
|
_error->Error(_("Could not open RPM database"));
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
rpmProblemSet probs;
|
||||||
|
const char *RootDir = NULL;
|
||||||
|
if (!Dir.empty())
|
||||||
|
RootDir = Dir.c_str();
|
||||||
|
if (rpmdbOpen(RootDir, &DB, O_RDWR, 0644) != 0)
|
||||||
|
{
|
||||||
|
_error->Error(_("Could not open RPM database"));
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
TS = rpmtransCreateSet(DB, Dir.c_str());
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (_config->FindB("RPM::OldPackage", true) || !upgrade.empty()) {
|
||||||
|
probFilter |= RPMPROB_FILTER_OLDPACKAGE;
|
||||||
|
}
|
||||||
|
if (_config->FindB("APT::Get::ReInstall", false)) {
|
||||||
|
probFilter |= RPMPROB_FILTER_REPLACEPKG;
|
||||||
|
probFilter |= RPMPROB_FILTER_REPLACEOLDFILES;
|
||||||
|
probFilter |= RPMPROB_FILTER_REPLACENEWFILES;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_config->FindB("RPM::Interactive", true))
|
||||||
|
notifyFlags |= INSTALL_LABEL | INSTALL_HASH;
|
||||||
|
else
|
||||||
|
notifyFlags |= INSTALL_LABEL | INSTALL_PERCENT;
|
||||||
|
|
||||||
|
if (uninstall.empty() == false)
|
||||||
|
AddToTransaction(Item::RPMErase, uninstall);
|
||||||
|
if (install.empty() == false)
|
||||||
|
AddToTransaction(Item::RPMInstall, install);
|
||||||
|
if (upgrade.empty() == false)
|
||||||
|
AddToTransaction(Item::RPMUpgrade, upgrade);
|
||||||
|
|
||||||
|
// Setup the gauge used by rpmShowProgress.
|
||||||
|
packagesTotal = install.size()+upgrade.size();
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rc = rpmtsCheck(TS);
|
||||||
|
probs = rpmtsProblems(TS);
|
||||||
|
if (rc || probs->numProblems > 0) {
|
||||||
|
rpmpsPrint(NULL, probs);
|
||||||
|
rpmpsFree(probs);
|
||||||
|
_error->Error(_("Transaction set check failed"));
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#if RPM_VERSION < 0x040000
|
||||||
|
rpmDependencyConflict *conflicts;
|
||||||
|
#else
|
||||||
|
rpmDependencyConflict conflicts;
|
||||||
|
#endif
|
||||||
|
int numConflicts;
|
||||||
|
if (_config->FindB("RPM::NoDeps", false) == false &&
|
||||||
|
rpmdepCheck(TS, &conflicts, &numConflicts))
|
||||||
|
{
|
||||||
|
_error->Error(_("Transaction set check failed"));
|
||||||
|
if (conflicts) {
|
||||||
|
printDepProblems(stderr, conflicts, numConflicts);
|
||||||
|
rpmdepFreeConflicts(conflicts, numConflicts);
|
||||||
|
}
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
rc = 0;
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
if (_config->FindB("RPM::Order", true) == true)
|
||||||
|
rc = rpmtsOrder(TS);
|
||||||
|
#else
|
||||||
|
if (_config->FindB("RPM::Order", true) == true)
|
||||||
|
rc = rpmdepOrder(TS);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (rc > 0) {
|
||||||
|
_error->Error(_("Ordering failed for %d packages"), rc);
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
cout << _("Committing changes...") << endl << flush;
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
probFilter |= rpmtsFilterFlags(TS);
|
||||||
|
rpmtsSetFlags(TS, (rpmtransFlags)(rpmtsFlags(TS) | tsFlags));
|
||||||
|
rpmtsClean(TS);
|
||||||
|
rc = rpmtsSetNotifyCallback(TS, rpmShowProgress, (void *)notifyFlags);
|
||||||
|
rc = rpmtsRun(TS, NULL, (rpmprobFilterFlags)probFilter);
|
||||||
|
probs = rpmtsProblems(TS);
|
||||||
|
#else
|
||||||
|
rc = rpmRunTransactions(TS, rpmShowProgress, (void *)notifyFlags, NULL,
|
||||||
|
&probs, (rpmtransFlags)tsFlags,
|
||||||
|
(rpmprobFilterFlags)probFilter);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (rc > 0) {
|
||||||
|
_error->Error(_("Error while running transaction"));
|
||||||
|
if (probs->numProblems > 0)
|
||||||
|
rpmpsPrint(stderr, probs);
|
||||||
|
} else {
|
||||||
|
Success = true;
|
||||||
|
if (rc < 0)
|
||||||
|
_error->Warning(_("Some errors occurred while running transaction"));
|
||||||
|
else
|
||||||
|
cout << _("Done.") << endl;
|
||||||
|
}
|
||||||
|
rpmpsFree(probs);
|
||||||
|
|
||||||
|
exit:
|
||||||
|
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rpmtsFree(TS);
|
||||||
|
#else
|
||||||
|
rpmdbClose(DB);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return Success;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool pkgRPMLibPM::ParseRpmOpts(const char *Cnf, int *tsFlags, int *probFilter)
|
||||||
|
{
|
||||||
|
Configuration::Item const *Opts = _config->Tree(Cnf);
|
||||||
|
|
||||||
|
if (Opts != 0)
|
||||||
|
{
|
||||||
|
Opts = Opts->Child;
|
||||||
|
for (; Opts != 0; Opts = Opts->Next)
|
||||||
|
{
|
||||||
|
if (Opts->Value.empty() == true)
|
||||||
|
continue;
|
||||||
|
// Transaction set flags
|
||||||
|
if (Opts->Value == "--noscripts")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_NOSCRIPTS;
|
||||||
|
else if (Opts->Value == "--notriggers")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_NOTRIGGERS;
|
||||||
|
else if (Opts->Value == "--nodocs" ||
|
||||||
|
Opts->Value == "--excludedocs")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_NODOCS;
|
||||||
|
else if (Opts->Value == "--allfiles")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_ALLFILES;
|
||||||
|
else if (Opts->Value == "--justdb")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_JUSTDB;
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
|
else if (Opts->Value == "--nomd5")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_NOMD5;
|
||||||
|
else if (Opts->Value == "--repackage")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_REPACKAGE;
|
||||||
|
#endif
|
||||||
|
#if RPM_VERSION >= 0x040200
|
||||||
|
else if (Opts->Value == "--noconfigs" ||
|
||||||
|
Opts->Value == "--excludeconfigs")
|
||||||
|
*tsFlags |= RPMTRANS_FLAG_NOCONFIGS;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Problem filter flags
|
||||||
|
else if (Opts->Value == "--replacefiles")
|
||||||
|
{
|
||||||
|
*probFilter |= RPMPROB_FILTER_REPLACEOLDFILES;
|
||||||
|
*probFilter |= RPMPROB_FILTER_REPLACENEWFILES;
|
||||||
|
}
|
||||||
|
else if (Opts->Value == "--replacepkgs")
|
||||||
|
*probFilter |= RPMPROB_FILTER_REPLACEPKG;
|
||||||
|
else if (Opts->Value == "--ignoresize")
|
||||||
|
{
|
||||||
|
*probFilter |= RPMPROB_FILTER_DISKSPACE;
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
|
*probFilter |= RPMPROB_FILTER_DISKNODES;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
else if (Opts->Value == "--badreloc")
|
||||||
|
*probFilter |= RPMPROB_FILTER_FORCERELOCATE;
|
||||||
|
|
||||||
|
// Misc things having apt config counterparts
|
||||||
|
else if (Opts->Value == "--force")
|
||||||
|
_config->Set("APT::Get::ReInstall", true);
|
||||||
|
else if (Opts->Value == "--oldpackage")
|
||||||
|
_config->Set("RPM::OldPackage", true);
|
||||||
|
else if (Opts->Value == "--nodeps")
|
||||||
|
_config->Set("RPM::NoDeps", true);
|
||||||
|
else if (Opts->Value == "--noorder")
|
||||||
|
_config->Set("RPM::Order", false);
|
||||||
|
// TODO: --root, --relocate, --prefix, --excludepath etc...
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
#endif /* HAVE_RPM */
|
#endif /* HAVE_RPM */
|
||||||
|
|
||||||
// vim:sts=3:sw=3
|
// vim:sts=3:sw=3
|
||||||
|
@ -11,6 +11,16 @@
|
|||||||
#ifndef PKGLIB_rpmPM_H
|
#ifndef PKGLIB_rpmPM_H
|
||||||
#define PKGLIB_rpmPM_H
|
#define PKGLIB_rpmPM_H
|
||||||
|
|
||||||
|
#include <rpm/rpmlib.h>
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
#include <rpm/rpmts.h>
|
||||||
|
#endif
|
||||||
|
#if RPM_VERSION >= 0x040000
|
||||||
|
#include <rpm/rpmcli.h>
|
||||||
|
#endif
|
||||||
|
/*}}}*/
|
||||||
|
typedef Header rpmHeader;
|
||||||
|
|
||||||
#ifdef __GNUG__
|
#ifdef __GNUG__
|
||||||
#pragma interface "apt-pkg/rpmpm.h"
|
#pragma interface "apt-pkg/rpmpm.h"
|
||||||
#endif
|
#endif
|
||||||
@ -46,10 +56,9 @@ class pkgRPMPM : public pkgPackageManager
|
|||||||
virtual bool Configure(PkgIterator Pkg);
|
virtual bool Configure(PkgIterator Pkg);
|
||||||
virtual bool Remove(PkgIterator Pkg,bool Purge = false);
|
virtual bool Remove(PkgIterator Pkg,bool Purge = false);
|
||||||
|
|
||||||
bool ExecRPM(Item::RPMOps op, vector<const char*> &files);
|
virtual bool Process(vector<const char*> &install,
|
||||||
bool Process(vector<const char*> &install,
|
|
||||||
vector<const char*> &upgrade,
|
vector<const char*> &upgrade,
|
||||||
vector<const char*> &uninstall);
|
vector<const char*> &uninstall) {return false;};
|
||||||
|
|
||||||
virtual bool Go();
|
virtual bool Go();
|
||||||
virtual void Reset();
|
virtual void Reset();
|
||||||
@ -60,6 +69,41 @@ class pkgRPMPM : public pkgPackageManager
|
|||||||
virtual ~pkgRPMPM();
|
virtual ~pkgRPMPM();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class pkgRPMExtPM : public pkgRPMPM
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
bool ExecRPM(Item::RPMOps op, vector<const char*> &files);
|
||||||
|
virtual bool Process(vector<const char*> &install,
|
||||||
|
vector<const char*> &upgrade,
|
||||||
|
vector<const char*> &uninstall);
|
||||||
|
|
||||||
|
public:
|
||||||
|
pkgRPMExtPM(pkgDepCache *Cache);
|
||||||
|
virtual ~pkgRPMExtPM();
|
||||||
|
};
|
||||||
|
|
||||||
|
class pkgRPMLibPM : public pkgRPMPM
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
#if RPM_VERSION >= 0x040100
|
||||||
|
rpmts TS;
|
||||||
|
#else
|
||||||
|
rpmTransactionSet TS;
|
||||||
|
rpmdb DB;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
bool ParseRpmOpts(const char *Cnf, int *tsFlags, int *probFilter);
|
||||||
|
bool AddToTransaction(Item::RPMOps op, vector<const char*> &files);
|
||||||
|
virtual bool Process(vector<const char*> &install,
|
||||||
|
vector<const char*> &upgrade,
|
||||||
|
vector<const char*> &uninstall);
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
pkgRPMLibPM(pkgDepCache *Cache);
|
||||||
|
virtual ~pkgRPMLibPM();
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// vim:sts=3:sw=3
|
// vim:sts=3:sw=3
|
||||||
|
@ -23,6 +23,8 @@
|
|||||||
#include <apt-pkg/rpmhandler.h>
|
#include <apt-pkg/rpmhandler.h>
|
||||||
#include <apt-pkg/rpmsystem.h>
|
#include <apt-pkg/rpmsystem.h>
|
||||||
|
|
||||||
|
#include <apti18n.h>
|
||||||
|
|
||||||
// RecordParser::rpmRecordParser - Constructor /*{{{*/
|
// RecordParser::rpmRecordParser - Constructor /*{{{*/
|
||||||
// ---------------------------------------------------------------------
|
// ---------------------------------------------------------------------
|
||||||
/* */
|
/* */
|
||||||
@ -37,6 +39,8 @@ rpmRecordParser::rpmRecordParser(string File, pkgCache &Cache)
|
|||||||
struct stat Buf;
|
struct stat Buf;
|
||||||
if (stat(File.c_str(),&Buf) == 0 && S_ISDIR(Buf.st_mode))
|
if (stat(File.c_str(),&Buf) == 0 && S_ISDIR(Buf.st_mode))
|
||||||
Handler = new RPMDirHandler(File);
|
Handler = new RPMDirHandler(File);
|
||||||
|
else if (flExtension(File) == "rpm")
|
||||||
|
Handler = new RPMSingleFileHandler(File);
|
||||||
else
|
else
|
||||||
Handler = new RPMFileHandler(File);
|
Handler = new RPMFileHandler(File);
|
||||||
}
|
}
|
||||||
@ -172,6 +176,8 @@ string rpmRecordParser::LongDesc()
|
|||||||
/* */
|
/* */
|
||||||
string rpmRecordParser::SourcePkg()
|
string rpmRecordParser::SourcePkg()
|
||||||
{
|
{
|
||||||
|
// This must be the *package* name, not the *file* name. We have no
|
||||||
|
// current way to extract it safely from the file name.
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
@ -192,7 +198,7 @@ void rpmRecordParser::BufCat(const char *begin, const char *end)
|
|||||||
char *tmp = (char*)realloc(Buffer, BufSize);
|
char *tmp = (char*)realloc(Buffer, BufSize);
|
||||||
if (tmp == NULL)
|
if (tmp == NULL)
|
||||||
{
|
{
|
||||||
_error->Errno("realloc", "could not allocate buffer for record text");
|
_error->Errno("realloc", _("Could not allocate buffer for record text"));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Buffer = tmp;
|
Buffer = tmp;
|
||||||
@ -275,7 +281,6 @@ void rpmRecordParser::GetRec(const char *&Start,const char *&Stop)
|
|||||||
char *str;
|
char *str;
|
||||||
char **strv;
|
char **strv;
|
||||||
char **strv2;
|
char **strv2;
|
||||||
int num;
|
|
||||||
int_32 *numv;
|
int_32 *numv;
|
||||||
char buf[32];
|
char buf[32];
|
||||||
|
|
||||||
@ -419,6 +424,24 @@ void rpmRecordParser::GetRec(const char *&Start,const char *&Stop)
|
|||||||
Stop = Buffer + BufUsed;
|
Stop = Buffer + BufUsed;
|
||||||
}
|
}
|
||||||
/*}}}*/
|
/*}}}*/
|
||||||
|
|
||||||
|
bool rpmRecordParser::HasFile(const char *File)
|
||||||
|
{
|
||||||
|
if (*File == '\0')
|
||||||
|
return false;
|
||||||
|
char **names = NULL;
|
||||||
|
int_32 count = 0;
|
||||||
|
rpmHeaderGetEntry(HeaderP, RPMTAG_OLDFILENAMES,
|
||||||
|
NULL, (void **) &names, &count);
|
||||||
|
while (count--)
|
||||||
|
{
|
||||||
|
char *name = names[count];
|
||||||
|
if (strcmp(name, File) == 0)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* HAVE_RPM */
|
#endif /* HAVE_RPM */
|
||||||
|
|
||||||
// vim:sts=3:sw=3
|
// vim:sts=3:sw=3
|
||||||
|
@ -65,6 +65,8 @@ class rpmRecordParser : public pkgRecords::Parser
|
|||||||
// The record in raw text, in standard Debian format
|
// The record in raw text, in standard Debian format
|
||||||
virtual void GetRec(const char *&Start,const char *&Stop);
|
virtual void GetRec(const char *&Start,const char *&Stop);
|
||||||
|
|
||||||
|
virtual bool HasFile(const char *File);
|
||||||
|
|
||||||
rpmRecordParser(string File,pkgCache &Cache);
|
rpmRecordParser(string File,pkgCache &Cache);
|
||||||
~rpmRecordParser();
|
~rpmRecordParser();
|
||||||
};
|
};
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user