diff options
author | Richard Purdie <rpurdie@linux.intel.com> | 2010-07-02 00:05:38 +0100 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2010-07-02 00:06:50 +0100 |
commit | 968d00de157bcc614cc7c47a4a36db29d677ab89 (patch) | |
tree | 403601f6dcd3e5c5a69075010bfa5353b0e118a4 | |
parent | 8a020432658e49579078b6a1194405feae7eb439 (diff) | |
download | poky-968d00de157bcc614cc7c47a4a36db29d677ab89.tar.gz |
package_deb.bbclass: Fix packaging functions to use versioned dependency package functions correctly
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
-rw-r--r-- | meta/classes/package_deb.bbclass | 74 |
1 files changed, 39 insertions, 35 deletions
diff --git a/meta/classes/package_deb.bbclass b/meta/classes/package_deb.bbclass index cd8d1dfc69..edec2a47f6 100644 --- a/meta/classes/package_deb.bbclass +++ b/meta/classes/package_deb.bbclass | |||
@@ -20,13 +20,13 @@ python package_deb_fn () { | |||
20 | 20 | ||
21 | addtask package_deb_install | 21 | addtask package_deb_install |
22 | python do_package_deb_install () { | 22 | python do_package_deb_install () { |
23 | pkg = bb.data.getVar('PKG', d, 1) | 23 | pkg = bb.data.getVar('PKG', d, True) |
24 | pkgfn = bb.data.getVar('PKGFN', d, 1) | 24 | pkgfn = bb.data.getVar('PKGFN', d, True) |
25 | rootfs = bb.data.getVar('IMAGE_ROOTFS', d, 1) | 25 | rootfs = bb.data.getVar('IMAGE_ROOTFS', d, True) |
26 | debdir = bb.data.getVar('DEPLOY_DIR_DEB', d, 1) | 26 | debdir = bb.data.getVar('DEPLOY_DIR_DEB', d, True) |
27 | apt_config = bb.data.expand('${STAGING_ETCDIR_NATIVE}/apt/apt.conf', d) | 27 | apt_config = bb.data.expand('${STAGING_ETCDIR_NATIVE}/apt/apt.conf', d) |
28 | stagingbindir = bb.data.getVar('STAGING_BINDIR_NATIVE', d, 1) | 28 | stagingbindir = bb.data.getVar('STAGING_BINDIR_NATIVE', d, True) |
29 | tmpdir = bb.data.getVar('TMPDIR', d, 1) | 29 | tmpdir = bb.data.getVar('TMPDIR', d, True) |
30 | 30 | ||
31 | if None in (pkg,pkgfn,rootfs): | 31 | if None in (pkg,pkgfn,rootfs): |
32 | raise bb.build.FuncFailed("missing variables (one or more of PKG, PKGFN, IMAGE_ROOTFS)") | 32 | raise bb.build.FuncFailed("missing variables (one or more of PKG, PKGFN, IMAGE_ROOTFS)") |
@@ -68,28 +68,28 @@ python do_package_deb_install () { | |||
68 | python do_package_deb () { | 68 | python do_package_deb () { |
69 | import re, copy | 69 | import re, copy |
70 | 70 | ||
71 | workdir = bb.data.getVar('WORKDIR', d, 1) | 71 | workdir = bb.data.getVar('WORKDIR', d, True) |
72 | if not workdir: | 72 | if not workdir: |
73 | bb.error("WORKDIR not defined, unable to package") | 73 | bb.error("WORKDIR not defined, unable to package") |
74 | return | 74 | return |
75 | 75 | ||
76 | outdir = bb.data.getVar('DEPLOY_DIR_DEB', d, 1) | 76 | outdir = bb.data.getVar('DEPLOY_DIR_DEB', d, True) |
77 | if not outdir: | 77 | if not outdir: |
78 | bb.error("DEPLOY_DIR_DEB not defined, unable to package") | 78 | bb.error("DEPLOY_DIR_DEB not defined, unable to package") |
79 | return | 79 | return |
80 | 80 | ||
81 | dvar = bb.data.getVar('D', d, 1) | 81 | dvar = bb.data.getVar('D', d, True) |
82 | if not dvar: | 82 | if not dvar: |
83 | bb.error("D not defined, unable to package") | 83 | bb.error("D not defined, unable to package") |
84 | return | 84 | return |
85 | bb.mkdirhier(dvar) | 85 | bb.mkdirhier(dvar) |
86 | 86 | ||
87 | packages = bb.data.getVar('PACKAGES', d, 1) | 87 | packages = bb.data.getVar('PACKAGES', d, True) |
88 | if not packages: | 88 | if not packages: |
89 | bb.debug(1, "PACKAGES not defined, nothing to package") | 89 | bb.debug(1, "PACKAGES not defined, nothing to package") |
90 | return | 90 | return |
91 | 91 | ||
92 | tmpdir = bb.data.getVar('TMPDIR', d, 1) | 92 | tmpdir = bb.data.getVar('TMPDIR', d, True) |
93 | 93 | ||
94 | if os.access(os.path.join(tmpdir, "stamps", "DEB_PACKAGE_INDEX_CLEAN"),os.R_OK): | 94 | if os.access(os.path.join(tmpdir, "stamps", "DEB_PACKAGE_INDEX_CLEAN"),os.R_OK): |
95 | os.unlink(os.path.join(tmpdir, "stamps", "DEB_PACKAGE_INDEX_CLEAN")) | 95 | os.unlink(os.path.join(tmpdir, "stamps", "DEB_PACKAGE_INDEX_CLEAN")) |
@@ -100,14 +100,14 @@ python do_package_deb () { | |||
100 | 100 | ||
101 | for pkg in packages.split(): | 101 | for pkg in packages.split(): |
102 | localdata = bb.data.createCopy(d) | 102 | localdata = bb.data.createCopy(d) |
103 | pkgdest = bb.data.getVar('PKGDEST', d, 1) | 103 | pkgdest = bb.data.getVar('PKGDEST', d, True) |
104 | root = "%s/%s" % (pkgdest, pkg) | 104 | root = "%s/%s" % (pkgdest, pkg) |
105 | 105 | ||
106 | lf = bb.utils.lockfile(root + ".lock") | 106 | lf = bb.utils.lockfile(root + ".lock") |
107 | 107 | ||
108 | bb.data.setVar('ROOT', '', localdata) | 108 | bb.data.setVar('ROOT', '', localdata) |
109 | bb.data.setVar('ROOT_%s' % pkg, root, localdata) | 109 | bb.data.setVar('ROOT_%s' % pkg, root, localdata) |
110 | pkgname = bb.data.getVar('PKG_%s' % pkg, localdata, 1) | 110 | pkgname = bb.data.getVar('PKG_%s' % pkg, localdata, True) |
111 | if not pkgname: | 111 | if not pkgname: |
112 | pkgname = pkg | 112 | pkgname = pkg |
113 | bb.data.setVar('PKG', pkgname, localdata) | 113 | bb.data.setVar('PKG', pkgname, localdata) |
@@ -121,7 +121,7 @@ python do_package_deb () { | |||
121 | bb.data.update_data(localdata) | 121 | bb.data.update_data(localdata) |
122 | basedir = os.path.join(os.path.dirname(root)) | 122 | basedir = os.path.join(os.path.dirname(root)) |
123 | 123 | ||
124 | pkgoutdir = os.path.join(outdir, bb.data.getVar('PACKAGE_ARCH', localdata, 1)) | 124 | pkgoutdir = os.path.join(outdir, bb.data.getVar('PACKAGE_ARCH', localdata, True)) |
125 | bb.mkdirhier(pkgoutdir) | 125 | bb.mkdirhier(pkgoutdir) |
126 | 126 | ||
127 | os.chdir(root) | 127 | os.chdir(root) |
@@ -133,7 +133,7 @@ python do_package_deb () { | |||
133 | except ValueError: | 133 | except ValueError: |
134 | pass | 134 | pass |
135 | if not g and bb.data.getVar('ALLOW_EMPTY', localdata) != "1": | 135 | if not g and bb.data.getVar('ALLOW_EMPTY', localdata) != "1": |
136 | bb.note("Not creating empty archive for %s-%s-%s" % (pkg, bb.data.getVar('PV', localdata, 1), bb.data.getVar('PR', localdata, 1))) | 136 | bb.note("Not creating empty archive for %s-%s-%s" % (pkg, bb.data.getVar('PV', localdata, True), bb.data.getVar('PR', localdata, True))) |
137 | bb.utils.unlockfile(lf) | 137 | bb.utils.unlockfile(lf) |
138 | continue | 138 | continue |
139 | 139 | ||
@@ -149,7 +149,7 @@ python do_package_deb () { | |||
149 | raise bb.build.FuncFailed("unable to open control file for writing.") | 149 | raise bb.build.FuncFailed("unable to open control file for writing.") |
150 | 150 | ||
151 | fields = [] | 151 | fields = [] |
152 | pe = bb.data.getVar('PE', d, 1) | 152 | pe = bb.data.getVar('PE', d, True) |
153 | if pe and int(pe) > 0: | 153 | if pe and int(pe) > 0: |
154 | fields.append(["Version: %s:%s-%s\n", ['PE', 'PV', 'PR']]) | 154 | fields.append(["Version: %s:%s-%s\n", ['PE', 'PV', 'PR']]) |
155 | else: | 155 | else: |
@@ -169,10 +169,10 @@ python do_package_deb () { | |||
169 | def pullData(l, d): | 169 | def pullData(l, d): |
170 | l2 = [] | 170 | l2 = [] |
171 | for i in l: | 171 | for i in l: |
172 | data = bb.data.getVar(i, d, 1) | 172 | data = bb.data.getVar(i, d, True) |
173 | if data is None: | 173 | if data is None: |
174 | raise KeyError(f) | 174 | raise KeyError(f) |
175 | if i == 'DPKG_ARCH' and bb.data.getVar('PACKAGE_ARCH', d, 1) == 'all': | 175 | if i == 'DPKG_ARCH' and bb.data.getVar('PACKAGE_ARCH', d, True) == 'all': |
176 | data = 'all' | 176 | data = 'all' |
177 | l2.append(data) | 177 | l2.append(data) |
178 | return l2 | 178 | return l2 |
@@ -192,30 +192,34 @@ python do_package_deb () { | |||
192 | 192 | ||
193 | bb.build.exec_func("mapping_rename_hook", localdata) | 193 | bb.build.exec_func("mapping_rename_hook", localdata) |
194 | 194 | ||
195 | rdepends = bb.utils.explode_deps(unicode(bb.data.getVar("RDEPENDS", localdata, 1) or "")) | 195 | rdepends = bb.utils.explode_dep_versions(bb.data.getVar("RDEPENDS", localdata, True) or "") |
196 | rdepends = [dep for dep in rdepends if not '*' in dep] | 196 | for dep in rdepends: |
197 | rrecommends = bb.utils.explode_deps(unicode(bb.data.getVar("RRECOMMENDS", localdata, 1) or "")) | 197 | if '*' in dep: |
198 | rrecommends = [rec for rec in rrecommends if not '*' in rec] | 198 | del rdepends[dep] |
199 | rsuggests = bb.utils.explode_deps(unicode(bb.data.getVar("RSUGGESTS", localdata, 1) or "")) | 199 | rrecommends = bb.utils.explode_dep_versions(bb.data.getVar("RRECOMMENDS", localdata, True) or "") |
200 | rprovides = bb.utils.explode_deps(unicode(bb.data.getVar("RPROVIDES", localdata, 1) or "")) | 200 | for dep in rrecommends: |
201 | rreplaces = bb.utils.explode_deps(unicode(bb.data.getVar("RREPLACES", localdata, 1) or "")) | 201 | if '*' in dep: |
202 | rconflicts = bb.utils.explode_deps(unicode(bb.data.getVar("RCONFLICTS", localdata, 1) or "")) | 202 | del rrecommends[dep] |
203 | rsuggests = bb.utils.explode_dep_versions(bb.data.getVar("RSUGGESTS", localdata, True) or "") | ||
204 | rprovides = bb.utils.explode_dep_versions(bb.data.getVar("RPROVIDES", localdata, True) or "") | ||
205 | rreplaces = bb.utils.explode_dep_versions(bb.data.getVar("RREPLACES", localdata, True) or "") | ||
206 | rconflicts = bb.utils.explode_dep_versions(bb.data.getVar("RCONFLICTS", localdata, True) or "") | ||
203 | if rdepends: | 207 | if rdepends: |
204 | ctrlfile.write(u"Depends: %s\n" % bb.utils.join_deps(rdepends)) | 208 | ctrlfile.write("Depends: %s\n" % unicode(bb.utils.join_deps(rdepends))) |
205 | if rsuggests: | 209 | if rsuggests: |
206 | ctrlfile.write(u"Suggests: %s\n" % bb.utils.join_deps(rsuggests)) | 210 | ctrlfile.write("Suggests: %s\n" % unicode(bb.utils.join_deps(rsuggests))) |
207 | if rrecommends: | 211 | if rrecommends: |
208 | ctrlfile.write(u"Recommends: %s\n" % bb.utils.join_deps(rrecommends)) | 212 | ctrlfile.write("Recommends: %s\n" % unicode(bb.utils.join_deps(rrecommends))) |
209 | if rprovides: | 213 | if rprovides: |
210 | ctrlfile.write(u"Provides: %s\n" % bb.utils.join_deps(rprovides)) | 214 | ctrlfile.write("Provides: %s\n" % unicode(bb.utils.join_deps(rprovides))) |
211 | if rreplaces: | 215 | if rreplaces: |
212 | ctrlfile.write(u"Replaces: %s\n" % bb.utils.join_deps(rreplaces)) | 216 | ctrlfile.write("Replaces: %s\n" % unicode(bb.utils.join_deps(rreplaces))) |
213 | if rconflicts: | 217 | if rconflicts: |
214 | ctrlfile.write(u"Conflicts: %s\n" % bb.utils.join_deps(rconflicts)) | 218 | ctrlfile.write("Conflicts: %s\n" % unicode(bb.utils.join_deps(rconflicts))) |
215 | ctrlfile.close() | 219 | ctrlfile.close() |
216 | 220 | ||
217 | for script in ["preinst", "postinst", "prerm", "postrm"]: | 221 | for script in ["preinst", "postinst", "prerm", "postrm"]: |
218 | scriptvar = bb.data.getVar('pkg_%s' % script, localdata, 1) | 222 | scriptvar = bb.data.getVar('pkg_%s' % script, localdata, True) |
219 | if not scriptvar: | 223 | if not scriptvar: |
220 | continue | 224 | continue |
221 | try: | 225 | try: |
@@ -228,7 +232,7 @@ python do_package_deb () { | |||
228 | scriptfile.close() | 232 | scriptfile.close() |
229 | os.chmod(os.path.join(controldir, script), 0755) | 233 | os.chmod(os.path.join(controldir, script), 0755) |
230 | 234 | ||
231 | conffiles_str = bb.data.getVar("CONFFILES", localdata, 1) | 235 | conffiles_str = bb.data.getVar("CONFFILES", localdata, True) |
232 | if conffiles_str: | 236 | if conffiles_str: |
233 | try: | 237 | try: |
234 | conffiles = file(os.path.join(controldir, 'conffiles'), 'w') | 238 | conffiles = file(os.path.join(controldir, 'conffiles'), 'w') |
@@ -240,7 +244,7 @@ python do_package_deb () { | |||
240 | conffiles.close() | 244 | conffiles.close() |
241 | 245 | ||
242 | os.chdir(basedir) | 246 | os.chdir(basedir) |
243 | ret = os.system("PATH=\"%s\" fakeroot dpkg-deb -b %s %s" % (bb.data.getVar("PATH", localdata, 1), root, pkgoutdir)) | 247 | ret = os.system("PATH=\"%s\" fakeroot dpkg-deb -b %s %s" % (bb.data.getVar("PATH", localdata, True), root, pkgoutdir)) |
244 | if ret != 0: | 248 | if ret != 0: |
245 | bb.utils.unlockfile(lf) | 249 | bb.utils.unlockfile(lf) |
246 | raise bb.build.FuncFailed("dpkg-deb execution failed") | 250 | raise bb.build.FuncFailed("dpkg-deb execution failed") |