2004-01-16 19:01:26 +00:00
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.
2004-05-13 12:23:54 +00:00
--- apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc.orig 2004-05-11 15:08:07 +0400
+++ apt-0.5.15cnc5/apt-pkg/rpm/rpmpm.cc 2004-05-11 15:19:12 +0400
@@ -390,6 +390,7 @@
2004-01-16 19:01:26 +00:00
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();
2004-05-13 12:23:54 +00:00
@@ -398,18 +399,12 @@
2004-01-16 19:01:26 +00:00
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:
2004-05-13 12:23:54 +00:00
@@ -421,8 +416,22 @@
2004-01-16 19:01:26 +00:00
}
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())
2004-05-13 12:23:54 +00:00
@@ -551,6 +560,7 @@
2004-01-16 19:01:26 +00:00
return true;
}
+ if (quiet <= 2)
cout << _("Executing RPM (")<<cmd<<")..." << endl;
cout << flush;
2004-05-13 12:23:54 +00:00
@@ -631,7 +641,7 @@
2004-01-16 19:01:26 +00:00
return _error->Error(_("Sub-process %s exited unexpectedly"),Args[0]);
}
2004-05-13 12:23:54 +00:00
- if (Interactive == true)
2004-01-16 19:01:26 +00:00
+ if (quiet <= 2)
2004-05-13 12:23:54 +00:00
cout << _("Done.") << endl;
2004-01-16 19:01:26 +00:00
return true;
2004-05-13 12:23:54 +00:00
@@ -749,6 +759,7 @@
2004-01-16 19:01:26 +00:00
bool Success = false;
2004-05-13 12:23:54 +00:00
bool Interactive = _config->FindB("RPM::Interactive",true);
2004-01-16 19:01:26 +00:00
string Dir = _config->Find("RPM::RootDir");
+ int quiet = _config->FindI("quiet",0);
rpmReadConfigFiles(NULL, NULL);
int probFilter = 0;
2004-05-13 12:23:54 +00:00
@@ -795,10 +806,21 @@
2004-01-16 19:01:26 +00:00
probFilter |= RPMPROB_FILTER_REPLACENEWFILES;
}
2004-05-13 12:23:54 +00:00
- if (Interactive == true)
2004-01-16 19:01:26 +00:00
- notifyFlags |= INSTALL_LABEL | INSTALL_HASH;
- else
- notifyFlags |= INSTALL_LABEL | INSTALL_PERCENT;
2004-05-13 12:23:54 +00:00
+ if (quiet <= 2)
+ notifyFlags |= INSTALL_LABEL;
2004-01-16 19:01:26 +00:00
+
2004-05-13 12:23:54 +00:00
+ if (quiet <= 1)
+ {
+ if (Interactive == true)
2004-01-16 19:01:26 +00:00
+ {
2004-05-13 12:23:54 +00:00
+ notifyFlags |= INSTALL_HASH;
+ extern int fancyPercents;
+ fancyPercents = (quiet <= 0) ? 1 : 0;
+ } else
+ {
+ notifyFlags |= INSTALL_PERCENT;
2004-01-16 19:01:26 +00:00
+ }
2004-05-13 12:23:54 +00:00
+ }
2004-01-16 19:01:26 +00:00
if (uninstall.empty() == false)
AddToTransaction(Item::RPMErase, uninstall);
2004-05-13 12:23:54 +00:00
@@ -854,6 +877,7 @@
2004-01-16 19:01:26 +00:00
goto exit;
}
+ if (quiet <= 2)
cout << _("Committing changes...") << endl << flush;
#if RPM_VERSION >= 0x040100
2004-05-13 12:23:54 +00:00
@@ -877,7 +901,7 @@
Success = true;
2004-01-16 19:01:26 +00:00
if (rc < 0)
_error->Warning(_("Some errors occurred while running transaction"));
2004-05-13 12:23:54 +00:00
- else if (Interactive == true)
+ else if (quiet <= 2)
2004-01-16 19:01:26 +00:00
cout << _("Done.") << endl;
}
rpmpsFree(probs);