1 # vi: encoding=utf-8 ts=8 sts=4 sw=4 et
19 def close_killset(killset):
23 rx = re.compile(r' marks ([^\s]+)-[^-]+-[^-]+$')
28 errors += "cannot remove %s because it's crucial\n" % p
30 f = chroot.popen("poldek --noask --test --erase %s" % p, user = "root")
33 for l in f.xreadlines():
38 errors += "cannot remove %s because it's required " \
39 "by %s, that is crucial\n" % (p, pkg)
50 def upgrade_from_batch(r, b):
51 f = chroot.popen("rpm --test -F %s 2>&1" % string.join(b.files), user = "root")
53 rx = re.compile(r' \(installed\) ([^\s]+)-[^-]+-[^-]+$')
54 for l in f.xreadlines():
56 if m: killset[m.group(1)] = 1
59 err = close_killset(killset)
61 util.append_to(b.logfile, err)
62 log.notice("cannot upgrade rpms")
64 k = string.join(killset.keys())
66 b.log_line("upgrade requires removal of %s" % k)
67 res = chroot.run("rpm -e %s" % k, logfile = b.logfile, user = "root")
69 b.log_line("package removal failed")
72 b.log_line("packages removed sucessfuly")
74 b.log_line("upgrade would need removal of %s" % k)
76 b.log_line("upgrading packages")
77 logbuf = StringIO.StringIO()
78 res = chroot.run("rpm -Fvh %s" % string.join(b.files), user = "root", logfile = b.logfile)
80 b.log_line("package upgrade failed")
86 def uninstall(conflicting, b):
87 b.log_line("uninstalling conflicting packages")
88 err = close_killset(conflicting)
90 util.append_to(b.logfile, err)
91 b.log_line("error: conflicting packages uninstallation failed")
94 k = string.join(conflicting.keys())
95 b.log_line("removing %s" % k)
96 res = chroot.run("poldek --noask --erase %s" % k, logfile = b.logfile, user = "root")
98 b.log_line("package removal failed")
102 def uninstall_self_conflict(b):
103 b.log_line("checking BuildConflict-ing packages")
104 rpmbuild_opt = "%s %s %s" % (b.target_string(), b.kernel_string(), b.bconds_string())
105 tmpdir = "/tmp/BR." + b.b_id[0:6]
106 f = chroot.popen("cd rpm/SPECS; TMPDIR=%s rpmbuild -bp --nobuild --short-circuit --define 'prep exit 0' %s %s 2>&1" \
107 % (tmpdir, rpmbuild_opt, b.spec))
108 rx = re.compile(r".*conflicts with ([^\s]+-[^-]+-[^-]+)\.src$")
110 for l in f.xreadlines():
111 b.log_line("rpmbuild: %s" % l.rstrip())
113 if m: conflicting[m.group(1)] = 1
115 if len(conflicting) and not uninstall(conflicting, b):
117 b.log_line("no BuildConflicts found")
120 def install_br(r, b):
121 # ignore internal rpm dependencies, see lib/rpmns.c for list
122 ignore_br = re.compile(r'^\s*(rpmlib|cpuinfo|getconf|uname|soname|user|group|mounted|diskspace|digest|gnupg|macro|envvar|running|sanitycheck|vcheck|signature|verify|exists|executable|readable|writable)\(.*')
124 tmpdir = "/tmp/BR." + b.b_id[0:6]
125 chroot.run("install -m 700 -d %s" % tmpdir)
126 cmd = "cd rpm/SPECS; TMPDIR=%s rpmbuild --nobuild %s %s 2>&1" \
127 % (tmpdir, b.bconds_string(), b.spec)
128 f = chroot.popen(cmd)
129 rx = re.compile(r"^\s*([^\s]+) .*is needed by")
131 b.log_line("checking BR")
132 for l in f.xreadlines():
133 b.log_line("rpm: %s" % l.rstrip())
135 if m and not ignore_br.match(l):
136 needed[m.group(1)] = 1
138 chroot.run("rm -rf %s" % tmpdir)
140 b.log_line("no BR needed")
143 for bre in needed.keys():
144 nbr = nbr + " " + re.escape(bre)
145 br = string.strip(nbr)
146 b.log_line("updating poldek cache...")
147 chroot.run("poldek --up --upa", user = "root", logfile = b.logfile)
148 # check conflicts in BRed packages
149 b.log_line("checking conflicting packages in BRed packages")
150 f = chroot.popen("poldek --test --noask --caplookup -Q -v --upgrade %s" % br, user = "root")
151 rx = re.compile(r".*conflicts with installed ([^\s]+)-[^-]+-[^-]+$")
153 for l in f.xreadlines():
154 b.log_line("poldek: %s" % l.rstrip())
156 if m: conflicting[m.group(1)] = 1
158 if len(conflicting) == 0:
159 b.log_line("no conflicts found")
161 if not uninstall(conflicting):
163 b.log_line("installing BR: %s" % br)
164 res = chroot.run("poldek --noask --caplookup -Q -v --upgrade %s" % br,
168 b.log_line("error: BR installation failed")