yifengyou / rpms / yum

Forked from rpms/yum 3 years ago
Clone

Blame SOURCES/BZ-1188960-API-missing-requires.patch

5e9bef
commit 423f5ee15cb0184d6583b57429ba9cb5bd8cdd35
5e9bef
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
5e9bef
Date:   Wed Jun 24 17:05:59 2015 +0200
5e9bef
5e9bef
    Plugin API update: missing_requires, pretty_output_update and promptYN fix. BZ#1188960
5e9bef
5e9bef
diff --git a/output.py b/output.py
5e9bef
index 091b58e..5a73f8e 100755
5e9bef
--- a/output.py
5e9bef
+++ b/output.py
5e9bef
@@ -2795,6 +2795,13 @@ to exit.
5e9bef
             if lastdbv.end_rpmdbversion != rpmdbv:
5e9bef
                 self._rpmdb_warn_checks()
5e9bef
 
5e9bef
+    @staticmethod
5e9bef
+    def pretty_output_restring(restring):
5e9bef
+        for msg in restring:
5e9bef
+            prefix = _('Error: %s')
5e9bef
+            prefix2nd = (' ' * (utf8_width(prefix) - 2))
5e9bef
+            yield (prefix, msg.replace('\n', '\n' + prefix2nd))
5e9bef
+
5e9bef
 
5e9bef
 class DepSolveProgressCallBack:
5e9bef
     """A class to provide text output callback functions for Dependency Solver callback."""
5e9bef
diff --git a/utils.py b/utils.py
5e9bef
index dbcd605..5ba320f 100755
5e9bef
--- a/utils.py
5e9bef
+++ b/utils.py
5e9bef
@@ -393,10 +393,8 @@ class YumUtilBase(YumBaseCli):
5e9bef
             return 0
5e9bef
         elif result == 1:
5e9bef
             # Fatal error
5e9bef
-            for msg in resultmsgs:
5e9bef
-                prefix = _('Error: %s')
5e9bef
-                prefix2nd = (' ' * (utf8_width(prefix) - 2))
5e9bef
-                self.logger.critical(prefix, msg.replace('\n', '\n' + prefix2nd))
5e9bef
+            for prefix, msg in self.pretty_output_restring(resultmsgs):
5e9bef
+                self.logger.critical(prefix, msg)
5e9bef
             if not self.conf.skip_broken:
5e9bef
                 self.verbose_logger.info(_(" You could try using --skip-broken to work around the problem"))
5e9bef
             if not self._rpmdb_warn_checks(out=self.verbose_logger.info, warn=False):
5e9bef
diff --git a/yum/depsolve.py b/yum/depsolve.py
5e9bef
index 797826f..a1aeac3 100644
5e9bef
--- a/yum/depsolve.py
5e9bef
+++ b/yum/depsolve.py
5e9bef
@@ -120,6 +120,7 @@ class Depsolve(object):
5e9bef
 
5e9bef
         self.installedFileRequires = None
5e9bef
         self.installedUnresolvedFileRequires = None
5e9bef
+        self._missing_requires = False
5e9bef
 
5e9bef
     def doTsSetup(self):
5e9bef
         """Sets up the transaction set before it is used."""
5e9bef
@@ -375,6 +376,7 @@ class Depsolve(object):
5e9bef
         return self._prco_req_nfv2req(req[0], req[1], req[2])
5e9bef
             
5e9bef
     def _err_missing_requires(self, reqPo, reqTup):
5e9bef
+        self._missing_requires = True
5e9bef
         if hasattr(self.dsCallback, 'format_missing_requires'):
5e9bef
             msg = self.dsCallback.format_missing_requires(reqPo, reqTup)
5e9bef
             if msg is not None: # PK
5e9bef
diff --git a/yum/plugins.py b/yum/plugins.py
5e9bef
index f34ea19..7034da9 100644
5e9bef
--- a/yum/plugins.py
5e9bef
+++ b/yum/plugins.py
5e9bef
@@ -63,7 +63,7 @@ from yum.i18n import utf8_width
5e9bef
 # API, the major version number must be incremented and the minor version number
5e9bef
 # reset to 0. If a change is made that doesn't break backwards compatibility,
5e9bef
 # then the minor number must be incremented.
5e9bef
-API_VERSION = '2.6'
5e9bef
+API_VERSION = '2.7'
5e9bef
 
5e9bef
 class DeprecatedInt(int):
5e9bef
     """A simple int subclass that is used to check when a deprecated
5e9bef
@@ -416,18 +416,22 @@ class PluginConduit:
5e9bef
         converted_level = logginglevels.logLevelFromErrorLevel(level)
5e9bef
         self.logger.log(converted_level, msg)
5e9bef
 
5e9bef
-    def promptYN(self, msg):
5e9bef
+    def promptYN(self, msg, prompt=None):
5e9bef
         """Return a yes or no response, either from assumeyes already
5e9bef
         being set, or from prompting the user.
5e9bef
 
5e9bef
-        :param msg: the message to prompt the user with
5e9bef
+        :param msg: the message to show to the user
5e9bef
+        :param prompt: the question to ask the user (optional); defaults to 'Is this ok [y/N]: '
5e9bef
         :return: 1 if the response is yes, and 0 if the response is no
5e9bef
         """
5e9bef
         self.info(2, msg)
5e9bef
+        if self._base.conf.assumeno:
5e9bef
+            return False
5e9bef
         if self._base.conf.assumeyes:
5e9bef
-            return 1
5e9bef
+            return True
5e9bef
         else:
5e9bef
-            return self._base.userconfirm()
5e9bef
+            kwargs = {'prompt': prompt} if prompt else {}
5e9bef
+            return bool(self._base.userconfirm(**kwargs))
5e9bef
 
5e9bef
     def getYumVersion(self):
5e9bef
         """Return a string representing the current version of yum."""
5e9bef
@@ -704,6 +708,14 @@ class DepsolvePluginConduit(MainPluginConduit):
5e9bef
         self.resultcode = rescode
5e9bef
         self.resultstring = restring
5e9bef
 
5e9bef
+    @property
5e9bef
+    def missing_requires(self):
5e9bef
+        """Boolean indicating if depsolving failed due to missing dependencies."""
5e9bef
+        return self._base._missing_requires
5e9bef
+
5e9bef
+    def pretty_output_restring(self):
5e9bef
+        return '\n'.join(prefix % msg for prefix, msg in self._base.pretty_output_restring(self.resultstring))
5e9bef
+
5e9bef
 class CompareProvidersPluginConduit(MainPluginConduit):
5e9bef
     """Conduit to compare different providers of packages."""
5e9bef
 
5e9bef
diff --git a/yummain.py b/yummain.py
5e9bef
index 0c7c535..32680a8 100755
5e9bef
--- a/yummain.py
5e9bef
+++ b/yummain.py
5e9bef
@@ -248,10 +248,8 @@ def main(args):
5e9bef
         return base.exit_code
5e9bef
     elif result == 1:
5e9bef
         # Fatal error
5e9bef
-        for msg in resultmsgs:
5e9bef
-            prefix = _('Error: %s')
5e9bef
-            prefix2nd = (' ' * (utf8_width(prefix) - 2))
5e9bef
-            logger.critical(prefix, msg.replace('\n', '\n' + prefix2nd))
5e9bef
+        for prefix, msg in base.pretty_output_restring(resultmsgs):
5e9bef
+            logger.critical(prefix, msg)
5e9bef
         if base._depsolving_failed:
5e9bef
             if not base.conf.skip_broken:
5e9bef
                 verbose_logger.info(_(" You could try using --skip-broken to work around the problem"))
5e9bef
commit 1c883b65432c288ad941a362a49c15a8e4fb74b9
5e9bef
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
5e9bef
Date:   Mon Jun 29 16:56:13 2015 +0200
5e9bef
5e9bef
    Add conduit.confList to plugin API
5e9bef
5e9bef
diff --git a/yum/plugins.py b/yum/plugins.py
5e9bef
index 7034da9..6857626 100644
5e9bef
--- a/yum/plugins.py
5e9bef
+++ b/yum/plugins.py
5e9bef
@@ -504,6 +504,17 @@ class PluginConduit:
5e9bef
         """
5e9bef
         return config.getOption(self._conf, section, opt, config.BoolOption(default))
5e9bef
 
5e9bef
+    def confList(self, section, opt, default=None):
5e9bef
+        """Read a boolean value from the plugin's own configuration file
5e9bef
+
5e9bef
+        :param section: configuration file section to read
5e9bef
+        :param opt: option name to read
5e9bef
+        :param default: value to read if the option is missing
5e9bef
+        :return: boolean option value read, or *default* if the option
5e9bef
+            was missing or could not be parsed
5e9bef
+        """
5e9bef
+        return config.getOption(self._conf, section, opt, config.ListOption(default))
5e9bef
+
5e9bef
     def registerPackageName(self, name):
5e9bef
         """Register the name of a package to use.
5e9bef