# vi: encoding=utf-8 ts=8 sts=4 sw=4 et
-import os, config, string, urllib, re, rpm
+from __future__ import print_function
+
+import os
+import config
+import string
+try:
+ import urllib.request as urlmess
+except ImportError:
+ import urllib as urlmess
+ pass
+import re
+import rpm
from common import fileexists, noarchcachedir
from baseftptree import BasePkg, BaseFtpTree
from sign import is_signed
return
def __str__(self):
- print "","An Error occured!"
+ return "An Error occured!"
def bailoutonerror():
if not errnum == 0:
- print "%d error(s) encountered... aborting" % errnum
- raise SomeError
+ print("%d error(s) encountered... aborting" % errnum)
+ raise SomeError()
def pinfo(msg):
- print 'INFO: ' + msg
+ print('INFO: ' + msg)
def perror(msg):
global errnum
errnum = errnum + 1
- print 'ERR: ' + msg
+ print('ERR: ' + msg)
def pwarning(msg):
- print 'WARN: ' + msg
+ print('WARN: ' + msg)
def rm(file, test = False):
if test:
else:
try:
os.remove(file)
- except OSError, e:
+ except OSError as e:
pinfo("os.remove(%s): %s" % (file, e))
#raise
else:
try:
os.rename(fsrc, fdst)
- except OSError, e:
+ except OSError as e:
pinfo("os.rename(%s, %s): %s" % (fsrc, fdst, e))
raise
class Pkg(BasePkg):
def __init__(self, nvr, tree):
BasePkg.__init__(self, nvr, tree)
- self.name = string.join(nvr.split('-')[:-2], '-')
+ self.name = '-'.join(nvr.split('-')[:-2])
self.version = nvr.split('-')[-2]
self.release = nvr.split('-')[-1]
self.marked4removal = False
if not config.separate_debuginfo:
return False
pkg = nvr.split('-')[:-2]
- return pkg[-1] == 'debuginfo'
+ return pkg[-1] == 'debuginfo' or pkg[-1] == 'debugsource'
def is_sourcefile(self, file):
"""
"""
return file[-8:] == '.src.rpm'
- # returns true if package build is integer
- def is_release(self):
- """
- To account Release tags with subver macros, we consider integer release
- if it contains odd number of dots:
-
- 1 -> True
- 0.1 -> False
- 0.%{subver}.%{rel}, %{rel} = 1 -> 0.20010.1 -> True
- 0.%{subver}.%{rel}, %{rel} = 0.1 -> 0.20010.0.1 -> False
- """
- return self.release.count('.') % 2 == 0
-
def mark4moving(self):
if not self.marked4moving:
# Only one pkg in this pool can be marked for moving
def load(self, content=None):
BasePkg.load(self, content)
- if self.info.has_key('move'):
+ if 'move' in self.info:
self.mark4moving()
def writeinfo(self):
for bid in self.build.keys():
f.write("info:build:%s:requester:%s\ninfo:build:%s:requester_email:%s\n" % (bid, self.build[bid].requester, bid, self.build[bid].requester_email))
for key in self.info.keys():
- f.write("info:%s:%s\n" % (key, string.join(self.info[key], ':')))
+ f.write("info:%s:%s\n" % (key, ':'.join(self.info[key])))
for arch in self.files.keys():
for rpm in self.files[arch]:
f.write("file:%s:%s\n" % (arch, rpm))
self.do_checkbuild = True
def __getitem__(self, key):
- if self.loadedpkgs.has_key(key):
+ if key in self.loadedpkgs:
return self.loadedpkgs[key]
elif key in self.pkgnames:
pkg=Pkg(key, self)
self.loadedpkgs[key]=pkg
return pkg
else:
- raise KeyError, key
+ raise KeyError(key)
def has_key(self, key):
if key in self.pkgnames:
self.__checksigns(dsttree, self.marked4moving, test = True)
self.__checkforobsoletes(dsttree, self.marked4moving, test = True)
- self.__checkforrelease(dsttree, self.marked4moving, test = True)
if not self.treename.count("archive"):
self.__rmolderfromsrc(test = True)
return True
else:
return False
- list = filter(checkfiletype, os.listdir(self.basedir+'/SRPMS/.metadata'))
- self.pkgnames = map((lambda x: x[:-13]), list)
+ pkglist = list(filter(checkfiletype, os.listdir(self.basedir+'/SRPMS/.metadata')))
+ self.pkgnames = list(map((lambda x: x[:-13]), pkglist))
def __mark4something(self, wannabepkgs, markfunction):
def chopoffextension(pkg):
Reads config.builderqueue to grab the info
"""
- f = urllib.urlopen(config.builderqueue)
+ f = urlmess.urlopen(config.builderqueue)
requests = {}
reid = re.compile(r'^.*id=(.*) pri.*$')
regb = re.compile(r'^group:.*$|builders:.*$', re.M)
- for i in re.findall(regb, f.read()):
+ for i in re.findall(regb, f.read().decode('utf-8')):
if i[0] == 'g':
id = reid.sub(r'\1', i)
requests[id] = ""
for pkg in marked:
for bid in pkg.build.keys():
- if requests.has_key(bid) and not requests[bid].find('?') == -1:
+ if bid in requests and not requests[bid].find('?') == -1:
pkg.error("(buildid %s) building not finished" % bid)
def __checkarchs(self, dsttree, marked):
return True
else:
return False
- return filter(filter_other_pkgs, tree.pkgnames)
+ return list(filter(filter_other_pkgs, tree.pkgnames))
def __find_older_pkgs(self, pkg):
def filter_older_pkgs(x):
return True
else:
return False
- return filter(filter_older_pkgs, self.__find_other_pkgs(pkg, self))
+ return list(filter(filter_older_pkgs, self.__find_other_pkgs(pkg, self)))
def __checksigns(self, tree, pkgs, test = False):
"""
def findbyname(name):
def x(nvr):
return '-'.join(nvr.split('-')[:-2]) == name
- return filter(x, tree.pkgnames)
+ return list(filter(x, tree.pkgnames))
for pkg in pkgs:
obsoletes = pkg.obsoletes()
p = findbyname(item)
if p:
pkg.warning('obsoletes %s (via %s) in dest tree, perhaps you want rmpkg' % (p,pn))
-
- def __checkforrelease(self, tree, pkgs, test = False):
- """
- Checks queue file if package release is non integer.
-
- """
- if test != True:
- return
-
- for pkg in pkgs:
- if not pkg.is_release():
- pkg.warning('non-integer release: %s' % pkg.release)