diff -urN aptitude-0.3.1-orig/configure.ac aptitude-0.3.1/configure.ac --- aptitude-0.3.1-orig/configure.ac 2005-01-11 03:06:25 +0300 +++ aptitude-0.3.1/configure.ac 2005-01-30 20:29:56 +0300 @@ -23,6 +23,15 @@ HAVE_LIBPTHREAD=1 , [AC_MSG_WARN([Can't find the POSIX thread libraries -- configuring without threads])]) +dnl popt checking +AC_CHECK_LIB(popt, main, + HAVE_POPT=1, + AC_MSG_ERROR([Can't find the popt library -- please install popt-devel package])) +dnl rpm checking +AC_CHECK_LIB(rpm, main, + HAVE_RPM=1, + AC_MSG_ERROR([Can't find the rpm library -- please install librpm-devel package])) + ALL_LINGUAS="ar bs ca cs da de el es eu fi fr gl it ja lt nb nl nn pl pt pt_BR ro ru sk tr zh_CN zh_TW" AM_GNU_GETTEXT @@ -139,6 +148,24 @@ [AC_MSG_WARN([POSIX thread header not installed -- configuring without threading support])]) fi +if test x$HAVE_RPM = x1 +then + AC_CHECK_HEADER(rpm/rpmio.h, + CXXFLAGS="$CXXFLAGS -I/usr/include/rpm" + LDFLAGS="$LDFLAGS -lrpm" + [AC_DEFINE(HAVE_RPM, , [Define if rpm is available])], + [AC_MSG_ERROR([RPM headers not found. Please verify your build system.])]) +fi + +if test x$HAVE_POPT = x1 +then + AC_CHECK_HEADER(popt.h, + CXXFLAGS="$CXXFLAGS" + LDFLAGS="$LDFLAGS -lpopt" + [AC_DEFINE(HAVE_POPT, , [Define if popt is available])], + [AC_MSG_ERROR([POPT headers not found. Please verify your build system.])]) +fi + WERROR="-Werror" AC_ARG_ENABLE(werror, diff -urN aptitude-0.3.1-orig/src/cmdline/cmdline_prompt.cc aptitude-0.3.1/src/cmdline/cmdline_prompt.cc --- aptitude-0.3.1-orig/src/cmdline/cmdline_prompt.cc 2004-12-04 03:57:11 +0300 +++ aptitude-0.3.1/src/cmdline/cmdline_prompt.cc 2005-01-30 20:29:56 +0300 @@ -18,10 +18,10 @@ #include #include -#include #include #include #include +#include using namespace std; @@ -43,7 +43,7 @@ if(!l.ReadMainList()) return _error->Error(_("Couldn't read list of sources")); - pkgDPkgPM pm(*apt_cache_file); + pkgPackageManager &pm = *_system->CreatePM(*apt_cache_file); pm.GetArchives(&fetcher, &l, apt_package_records); f.FetchBytes=fetcher.FetchNeeded(); diff -urN aptitude-0.3.1-orig/src/dep_item.cc aptitude-0.3.1/src/dep_item.cc --- aptitude-0.3.1-orig/src/dep_item.cc 2004-12-04 03:57:16 +0300 +++ aptitude-0.3.1/src/dep_item.cc 2005-01-30 20:29:56 +0300 @@ -30,7 +30,8 @@ #include "generic/apt.h" #include "generic/config_signal.h" -#include +#include +#include using namespace std; using namespace __gnu_cxx; diff -urN aptitude-0.3.1-orig/src/desc_parse.cc aptitude-0.3.1/src/desc_parse.cc --- aptitude-0.3.1-orig/src/desc_parse.cc 2004-12-04 08:13:10 +0300 +++ aptitude-0.3.1/src/desc_parse.cc 2005-01-30 20:30:51 +0300 @@ -16,13 +16,6 @@ string::size_type loc=0; vector fragments; - // Skip the short description - while(loc #include #include -#include #include #include #include @@ -227,7 +226,7 @@ time_t curtime=time(NULL); fprintf(f, "Aptitude " VERSION ": %s\n%s\n\n", _("log report"), ctime(&curtime)); - fprintf(f, _("IMPORTANT: this log only lists intended actions; actions which fail due to\ndpkg problems may not be completed.\n\n")); + fprintf(f, _("IMPORTANT: this log only lists intended actions; actions which fail due to\nrpm problems may not be completed.\n\n")); fprintf(f, _("Will install %li packages, and remove %li packages.\n"), (*apt_cache_file)->InstCount(), (*apt_cache_file)->DelCount()); if((*apt_cache_file)->UsrSize()>0) fprintf(f, _("%sB of disk space will be used\n"), @@ -346,7 +345,7 @@ } // Make a package manager, get ready to download - pkgDPkgPM pm(*apt_cache_file); + pkgPackageManager &pm = *_system->CreatePM(*apt_cache_file); if(!pm.GetArchives(&fetcher, &list, apt_package_records) || _error->PendingError()) { _error->Error(_("Internal error: couldn't generate list of packages to download")); @@ -462,9 +461,8 @@ { case pkgPackageManager::Failed: _error->DumpErrors(); - cerr<<_("Ack! Something bad happened while installing packages. Trying to recover:")<Discard(); ok=false; @@ -503,7 +501,7 @@ if(!apt_cache_file->GainLock()) // This really shouldn't happen. { - _error->Error(_("Could not regain the system lock! (Perhaps another apt or dpkg is running?)")); + _error->Error(_("Could not regain the system lock! (Perhaps another apt or rpm is running?)")); ok=false; break; } diff -urN aptitude-0.3.1-orig/src/download_item.cc aptitude-0.3.1/src/download_item.cc --- aptitude-0.3.1-orig/src/download_item.cc 2004-12-04 05:05:32 +0300 +++ aptitude-0.3.1/src/download_item.cc 2005-01-30 20:29:56 +0300 @@ -41,8 +41,11 @@ return get_color("DownloadHit"); case pkgAcquire::Item::StatError: return get_color("Error"); +// Not yet implemented in apt 0.5 +#if 0 case pkgAcquire::Item::StatAuthError: return get_color("Error"); +#endif default: assert(0); } @@ -106,8 +109,11 @@ case pkgAcquire::Item::StatError: output+=item.Owner->ErrorText; break; +// Not yet implemented in apt 0.5 +#if 0 case pkgAcquire::Item::StatAuthError: output+=item.Owner->ErrorText; +#endif } win->mvaddnstr(y, 0, output.c_str(), width); diff -urN aptitude-0.3.1-orig/src/generic/apt.cc aptitude-0.3.1/src/generic/apt.cc --- aptitude-0.3.1-orig/src/generic/apt.cc 2005-01-11 02:52:02 +0300 +++ aptitude-0.3.1/src/generic/apt.cc 2005-01-30 20:29:56 +0300 @@ -474,6 +474,8 @@ bool package_trusted(const pkgCache::VerIterator &ver) { +// Not yet implemented in apt 0.5 +#if 0 for(pkgCache::VerFileIterator i = ver.FileList(); !i.end(); ++i) { pkgIndexFile *index; @@ -481,6 +483,6 @@ if(apt_source_list->FindIndex(i.File(), index) && !index->IsTrusted()) return false; } - +#endif return true; } diff -urN aptitude-0.3.1-orig/src/generic/matchers.cc aptitude-0.3.1/src/generic/matchers.cc --- aptitude-0.3.1-orig/src/generic/matchers.cc 2004-12-04 05:15:15 +0300 +++ aptitude-0.3.1/src/generic/matchers.cc 2005-01-30 20:29:56 +0300 @@ -40,7 +40,7 @@ #include #include #include -#include +#define pkgCheckDep _system->checkDep #include #include diff -urN aptitude-0.3.1-orig/src/generic/matchers.h aptitude-0.3.1/src/generic/matchers.h --- aptitude-0.3.1-orig/src/generic/matchers.h 2004-12-04 03:57:13 +0300 +++ aptitude-0.3.1/src/generic/matchers.h 2005-01-30 20:29:56 +0300 @@ -24,6 +24,7 @@ #define MATCHERS_H #include +#include class pkg_matcher // A closure describing a matching rule. Note that we match on a particular diff -urN aptitude-0.3.1-orig/src/generic/tasks.cc aptitude-0.3.1/src/generic/tasks.cc --- aptitude-0.3.1-orig/src/generic/tasks.cc 2004-12-04 05:15:25 +0300 +++ aptitude-0.3.1/src/generic/tasks.cc 2005-01-30 20:29:57 +0300 @@ -63,49 +63,6 @@ // This should never be called before load_tasks has initialized the // tasks structure. assert(tasks_by_package); - - list &lst=tasks_by_package[pkg->ID]; - - lst.clear(); - - if(apt_package_records) - { - const char *start,*stop; - pkgTagSection sec; - - // Pull out pointers to the underlying record. - apt_package_records->Lookup(verfile).GetRec(start, stop); - - // Parse it as a section. - sec.Scan(start, stop-start+1); - - string tasks=sec.FindS("Task"); - - string::size_type loc=0, firstcomma=0; - - // Strip leading whitespace - while(loc #include +#ifndef HAVE_LIBAPT_PKG3 +#define pkgCheckDep _system->checkDep +#endif + #include column_definition_list *pkg_item::pkg_columnizer::columns=NULL; diff -urN aptitude-0.3.1-orig/src/pkg_info_screen.cc aptitude-0.3.1/src/pkg_info_screen.cc --- aptitude-0.3.1-orig/src/pkg_info_screen.cc 2004-12-04 08:24:18 +0300 +++ aptitude-0.3.1/src/pkg_info_screen.cc 2005-01-30 20:29:57 +0300 @@ -81,7 +81,7 @@ pkgRecords::Parser &rec=apt_package_records->Lookup(ver.FileList()); string desc=apt_package_records->Lookup(ver.FileList()).LongDesc(); - string shortdesc=string(desc, 0, desc.find('\n')); + string shortdesc=apt_package_records->Lookup(ver.FileList()).ShortDesc(); vector frags; diff -urN aptitude-0.3.1-orig/src/pkg_ver_item.cc aptitude-0.3.1/src/pkg_ver_item.cc --- aptitude-0.3.1-orig/src/pkg_ver_item.cc 2004-12-04 05:29:26 +0300 +++ aptitude-0.3.1/src/pkg_ver_item.cc 2005-01-30 20:29:57 +0300 @@ -47,6 +47,8 @@ using namespace std; +#define pkgCheckDep _system->checkDep + class pkg_ver_columnizer:public pkg_item::pkg_columnizer { bool show_pkg_name; diff -urN aptitude-0.3.1-orig/src/pkg_ver_item.h aptitude-0.3.1/src/pkg_ver_item.h --- aptitude-0.3.1-orig/src/pkg_ver_item.h 2004-12-04 03:57:10 +0300 +++ aptitude-0.3.1/src/pkg_ver_item.h 2005-01-30 20:29:57 +0300 @@ -30,9 +30,13 @@ #include "pkg_grouppolicy.h" #include "pkg_item_with_subtree.h" -#include #include #include +#include + +#ifndef HAVE_LIBAPT_PKG3 +#define pkgVersionCompare _system->versionCompare +#endif class pkg_ver_item:public pkg_tree_node { diff -urN aptitude-0.3.1-orig/src/vs_progress.cc aptitude-0.3.1/src/vs_progress.cc --- aptitude-0.3.1-orig/src/vs_progress.cc 2004-12-06 04:35:58 +0300 +++ aptitude-0.3.1/src/vs_progress.cc 2005-01-30 20:29:57 +0300 @@ -31,7 +31,8 @@ if(!Op.empty()) { - assert(Percent>=0 && Percent<=100); + if ( Percent > 100 ) + Percent = 100; barsize=int(Percent*width/100.0); snprintf(percent_string, 50, ": %i%%", int(Percent));