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):
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)
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)