]> git.pld-linux.org Git - projects/pld-ftp-admin.git/blobdiff - wwwbin/ftp-freshness.py
Comaptibility updates for rpm4/python3
[projects/pld-ftp-admin.git] / wwwbin / ftp-freshness.py
index ddfe53f6c59fe2ebd66976876b161deebbd060ad..924f737d0409391ed3427f7364a9ee65d9c16a01 100755 (executable)
@@ -37,32 +37,47 @@ class Pkgs(object):
         rpm.addMacro('requires_releq', '#')
         rpm.addMacro('requires_ge', '#')
         rpm.addMacro('requires_ge_to', '#')
-        self.ts = rpm.ts()
+        rpm.setVerbosity(rpm.RPMLOG_ERR)
+        if sys.version_info[0] == 2:
+            self.ts = rpm.ts()
+
+    def __print_stderr(self, msg):
+        if sys.version_info[0] == 3:
+            print(msg, file=sys.stderr, flush=True)
+        else:
+            print(msg, file=sys.stderr)
 
     def __clean_macros(self):
+        if sys.version_info[0] == 3:
+            rpm.reloadConfig()
         for macro in ['rel', '_rel', 'snap', '_snap', 'rc', '_rc', 'subver', 'githash']:
             rpm.delMacro(macro)
-        macros = rpm.getMacros()
-        for macro in iter(macros.keys()):
-            if macro[:5] == 'with_' or macro[:8] == 'without_':
-                rpm.delMacro(macro.split()[0])
+        if sys.version_info[0] == 2:
+            macros = rpm.getMacros()
+            for macro in iter(macros.keys()):
+                if macro[:5] == 'with_' or macro[:8] == 'without_':
+                    rpm.delMacro(macro.split()[0])
 
     def __get_from_cvs(self, name):
         spec = os.path.join(specsdir, name + '.spec')
         if not os.path.isfile(spec):
-            print('Spec file does not exist: %s' % spec, file=sys.stderr)
+            self.__print_stderr('Spec file does not exist: %s' % spec)
             return ('','','')
-        print('Processing: %s.spec' % name, file=sys.stderr)
+        self.__print_stderr('Processing: %s.spec' % name)
         self.__clean_macros()
         try:
-            s = self.ts.parseSpec(spec)
-            header = s.headers()[0]
+            if sys.version_info[0] == 2:
+                s = self.ts.parseSpec(spec)
+                header = s.headers()[2]
+            else:
+                s = rpm.spec(spec)
+                header = s.sourceHeader
             name = header[rpm.RPMTAG_NAME]
             version = header[rpm.RPMTAG_VERSION]
             release = header[rpm.RPMTAG_RELEASE].partition('@')[0]
             return (name, version, release)
-        except rpm.error:
-            print('Failed to parse: %s.spec' % name, file=sys.stderr)
+        except (ValueError, rpm.error):
+            self.__print_stderr('Failed to parse: %s.spec' % name)
             return ('','','')
 
     def __update_cvs(self, name):
@@ -73,8 +88,14 @@ class Pkgs(object):
         cvs_nvr = self.cvs[name]
         pkg_nvr = self.pkg[name]
 
-        cvs_rpm_vr = rpm.labelCompare(cvs_nvr, pkg_nvr)
-        cvs_rpm_v = rpm.labelCompare((cvs_nvr[0], cvs_nvr[1], ""), (pkg_nvr[0], pkg_nvr[1], ""))
+        try:
+            cvs_rpm_vr = rpm.labelCompare(cvs_nvr, pkg_nvr)
+        except ValueError:
+            cvs_rpm_vr = -1
+        try:
+            cvs_rpm_v = rpm.labelCompare((cvs_nvr[0], cvs_nvr[1], ""), (pkg_nvr[0], pkg_nvr[1], ""))
+        except ValueError:
+            cvs_rpm_v = -1
 
         if cvs_rpm_v > 0:
             self.cvs_new_nv.append(name)
@@ -97,8 +118,11 @@ class Pkgs(object):
         nvr = tuple(file_name.rsplit('-', 2))
         name = nvr[0]
         if name in self.pkg:
-            if rpm.labelCompare(nvr, self.pkg[name]) > 0:
-                self.pkg[name] = nvr
+            try:
+                if rpm.labelCompare(nvr, self.pkg[name]) > 0:
+                    self.pkg[name] = nvr
+            except ValueError:
+                pass
         else:
             self.pkg[name] = nvr
         self.__update_cvs(name)
This page took 0.061644 seconds and 4 git commands to generate.