summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/cmdline/cmdline_do_action.cc1
-rw-r--r--src/generic/apt/download_install_manager.cc12
-rw-r--r--src/generic/apt/download_install_manager.h5
-rw-r--r--src/gtk/gui.cc1
-rw-r--r--src/main.cc2
-rw-r--r--src/ui.cc1
6 files changed, 21 insertions, 1 deletions
diff --git a/src/cmdline/cmdline_do_action.cc b/src/cmdline/cmdline_do_action.cc
index 36ded861..a7b2ce3f 100644
--- a/src/cmdline/cmdline_do_action.cc
+++ b/src/cmdline/cmdline_do_action.cc
@@ -384,6 +384,7 @@ int cmdline_do_action(int argc, char *argv[],
aptitude::cmdline::apply_user_tags(user_tags);
download_install_manager m(download_only,
+ aptcfg->FindB(PACKAGE "::CmdLine::Fix-Missing", false),
sigc::ptr_fun(&run_dpkg_directly));
// FIXME: Temporary work-around for bug #677175 in apt.
diff --git a/src/generic/apt/download_install_manager.cc b/src/generic/apt/download_install_manager.cc
index 7c9aa835..a499faa5 100644
--- a/src/generic/apt/download_install_manager.cc
+++ b/src/generic/apt/download_install_manager.cc
@@ -38,8 +38,11 @@
using namespace std;
download_install_manager::download_install_manager(bool _download_only,
+ bool _fix_missing,
const run_dpkg_in_terminal_func &_run_dpkg_in_terminal)
- : log(NULL), download_only(_download_only),
+ : log(NULL),
+ download_only(_download_only),
+ fix_missing(_fix_missing),
pm(new pkgDPkgPM(*apt_cache_file)),
run_dpkg_in_terminal(_run_dpkg_in_terminal)
{
@@ -139,6 +142,13 @@ download_manager::result download_install_manager::finish_pre_dpkg(pkgAcquire::R
}
}
+ if(failed == true && fix_missing == false)
+ {
+ _error->Error(_("Unable to fetch some archives, maybe run aptitude"
+ " update or try with --fix-missing?"));
+ return failure;
+ }
+
if(failed && !pm->FixMissing())
{
_error->Error(_("Unable to correct for unavailable packages"));
diff --git a/src/generic/apt/download_install_manager.h b/src/generic/apt/download_install_manager.h
index 24989883..069a1a41 100644
--- a/src/generic/apt/download_install_manager.h
+++ b/src/generic/apt/download_install_manager.h
@@ -59,6 +59,10 @@ class download_install_manager : public download_manager
/** If \b true, don't actually invoke the package manager. */
bool download_only;
+ /** If \b true, attempt to correct for packages which fail
+ to download or are unavailable. */
+ bool fix_missing;
+
/** The package manager object used when installing packages */
pkgPackageManager *pm;
@@ -112,6 +116,7 @@ public:
* \param _run_dpkg_in_terminal how to set up the terminal for dpkg.
*/
download_install_manager(bool _download_only,
+ bool _fix_missing,
const run_dpkg_in_terminal_func &_run_dpkg_in_terminal);
~download_install_manager();
diff --git a/src/gtk/gui.cc b/src/gtk/gui.cc
index d44a8499..b1715bb5 100644
--- a/src/gtk/gui.cc
+++ b/src/gtk/gui.cc
@@ -956,6 +956,7 @@ namespace gui
boost::shared_ptr<download_install_manager> m =
boost::make_shared<download_install_manager>(false,
+ true,
sigc::ptr_fun(&gui_run_dpkg));
start_download(m,
diff --git a/src/main.cc b/src/main.cc
index 47b305d4..baf1b0fc 100644
--- a/src/main.cc
+++ b/src/main.cc
@@ -313,6 +313,8 @@ CommandLine::Args opts[] = {
{0, "group-by", PACKAGE "::CmdLine::Versions-Group-By", CommandLine::HasArg},
{0, "show-package-names", PACKAGE "::CmdLine::Versions-Show-Package-Names", CommandLine::HasArg},
{'f', "fix-broken", PACKAGE "::CmdLine::Fix-Broken", 0},
+ {'m', "ignore-missing", PACKAGE "::CmdLine::Fix-Missing", 0},
+ {0, "fix-missing", PACKAGE "::CmdLine::Fix-Missing", 0},
{'Z', "show-size-changes", PACKAGE "::CmdLine::Show-Size-Changes", 0},
{'S', "pkgstates", PACKAGE "::%::pkgstates.in", CommandLine::HasArg},
{'c', "config-file", 0, CommandLine::ConfigFile},
diff --git a/src/ui.cc b/src/ui.cc
index 084046e5..1f8bfe31 100644
--- a/src/ui.cc
+++ b/src/ui.cc
@@ -1258,6 +1258,7 @@ void install_or_remove_packages()
{
boost::shared_ptr<download_install_manager> m =
boost::make_shared<download_install_manager>(false,
+ true,
sigc::ptr_fun(&run_dpkg_with_cwidget_suspended));
m->post_forget_new_hook.connect(package_states_changed.make_slot());