diff options
| -rw-r--r-- | meta/classes/package.bbclass | 4 | ||||
| -rw-r--r-- | meta/classes/package_rpm.bbclass | 3 | ||||
| -rw-r--r-- | meta/classes/packagedata.bbclass | 68 | ||||
| -rw-r--r-- | meta/lib/oe/packagedata.py | 106 |
4 files changed, 115 insertions, 66 deletions
diff --git a/meta/classes/package.bbclass b/meta/classes/package.bbclass index 4eb349d431..2c6d30ccd8 100644 --- a/meta/classes/package.bbclass +++ b/meta/classes/package.bbclass | |||
| @@ -295,7 +295,9 @@ def runstrip(file, elftype, d): | |||
| 295 | # | 295 | # |
| 296 | 296 | ||
| 297 | def get_package_mapping (pkg, d): | 297 | def get_package_mapping (pkg, d): |
| 298 | data = read_subpkgdata(pkg, d) | 298 | import oe.packagedata |
| 299 | |||
| 300 | data = oe.packagedata.read_subpkgdata(pkg, d) | ||
| 299 | key = "PKG_%s" % pkg | 301 | key = "PKG_%s" % pkg |
| 300 | 302 | ||
| 301 | if key in data: | 303 | if key in data: |
diff --git a/meta/classes/package_rpm.bbclass b/meta/classes/package_rpm.bbclass index b86356de2e..1d8c686330 100644 --- a/meta/classes/package_rpm.bbclass +++ b/meta/classes/package_rpm.bbclass | |||
| @@ -316,6 +316,7 @@ package_install_internal_rpm () { | |||
| 316 | 316 | ||
| 317 | python write_specfile () { | 317 | python write_specfile () { |
| 318 | import textwrap | 318 | import textwrap |
| 319 | import oe.packagedata | ||
| 319 | 320 | ||
| 320 | # We need to change '-' in a version field to '+' | 321 | # We need to change '-' in a version field to '+' |
| 321 | # This needs to be done BEFORE the mapping_rename_hook | 322 | # This needs to be done BEFORE the mapping_rename_hook |
| @@ -328,7 +329,7 @@ python write_specfile () { | |||
| 328 | ver = depends_dict[dep] | 329 | ver = depends_dict[dep] |
| 329 | if dep and ver: | 330 | if dep and ver: |
| 330 | if '-' in ver: | 331 | if '-' in ver: |
| 331 | subd = read_subpkgdata_dict(dep, d) | 332 | subd = oe.packagedata.read_subpkgdata_dict(dep, d) |
| 332 | pv = subd['PV'] | 333 | pv = subd['PV'] |
| 333 | reppv = pv.replace('-', '+') | 334 | reppv = pv.replace('-', '+') |
| 334 | ver = ver.replace(pv, reppv) | 335 | ver = ver.replace(pv, reppv) |
diff --git a/meta/classes/packagedata.bbclass b/meta/classes/packagedata.bbclass index 86f18a9e96..bf051feea8 100644 --- a/meta/classes/packagedata.bbclass +++ b/meta/classes/packagedata.bbclass | |||
| @@ -1,73 +1,13 @@ | |||
| 1 | def packaged(pkg, d): | ||
| 2 | return os.access(get_subpkgedata_fn(pkg, d) + '.packaged', os.R_OK) | ||
| 3 | |||
| 4 | def read_pkgdatafile(fn): | ||
| 5 | pkgdata = {} | ||
| 6 | |||
| 7 | def decode(str): | ||
| 8 | import codecs | ||
| 9 | c = codecs.getdecoder("string_escape") | ||
| 10 | return c(str)[0] | ||
| 11 | |||
| 12 | if os.access(fn, os.R_OK): | ||
| 13 | import re | ||
| 14 | f = file(fn, 'r') | ||
| 15 | lines = f.readlines() | ||
| 16 | f.close() | ||
| 17 | r = re.compile("([^:]+):\s*(.*)") | ||
| 18 | for l in lines: | ||
| 19 | m = r.match(l) | ||
| 20 | if m: | ||
| 21 | pkgdata[m.group(1)] = decode(m.group(2)) | ||
| 22 | |||
| 23 | return pkgdata | ||
| 24 | |||
| 25 | def get_subpkgedata_fn(pkg, d): | ||
| 26 | archs = bb.data.expand("${PACKAGE_ARCHS}", d).split(" ") | ||
| 27 | archs.reverse() | ||
| 28 | pkgdata = bb.data.expand('${TMPDIR}/pkgdata/', d) | ||
| 29 | targetdir = bb.data.expand('${TARGET_VENDOR}-${TARGET_OS}/runtime/', d) | ||
| 30 | for arch in archs: | ||
| 31 | fn = pkgdata + arch + targetdir + pkg | ||
| 32 | if os.path.exists(fn): | ||
| 33 | return fn | ||
| 34 | return bb.data.expand('${PKGDATA_DIR}/runtime/%s' % pkg, d) | ||
| 35 | |||
| 36 | def has_subpkgdata(pkg, d): | ||
| 37 | return os.access(get_subpkgedata_fn(pkg, d), os.R_OK) | ||
| 38 | |||
| 39 | def read_subpkgdata(pkg, d): | ||
| 40 | return read_pkgdatafile(get_subpkgedata_fn(pkg, d)) | ||
| 41 | |||
| 42 | def has_pkgdata(pn, d): | ||
| 43 | fn = bb.data.expand('${PKGDATA_DIR}/%s' % pn, d) | ||
| 44 | return os.access(fn, os.R_OK) | ||
| 45 | |||
| 46 | def read_pkgdata(pn, d): | ||
| 47 | fn = bb.data.expand('${PKGDATA_DIR}/%s' % pn, d) | ||
| 48 | return read_pkgdatafile(fn) | ||
| 49 | |||
| 50 | python read_subpackage_metadata () { | 1 | python read_subpackage_metadata () { |
| 51 | data = read_pkgdata(bb.data.getVar('PN', d, 1), d) | 2 | import oe.packagedata |
| 3 | |||
| 4 | data = oe.packagedata.read_pkgdata(bb.data.getVar('PN', d, 1), d) | ||
| 52 | 5 | ||
| 53 | for key in data.keys(): | 6 | for key in data.keys(): |
| 54 | bb.data.setVar(key, data[key], d) | 7 | bb.data.setVar(key, data[key], d) |
| 55 | 8 | ||
| 56 | for pkg in bb.data.getVar('PACKAGES', d, 1).split(): | 9 | for pkg in bb.data.getVar('PACKAGES', d, 1).split(): |
| 57 | sdata = read_subpkgdata(pkg, d) | 10 | sdata = oe.packagedata.read_subpkgdata(pkg, d) |
| 58 | for key in sdata.keys(): | 11 | for key in sdata.keys(): |
| 59 | bb.data.setVar(key, sdata[key], d) | 12 | bb.data.setVar(key, sdata[key], d) |
| 60 | } | 13 | } |
| 61 | |||
| 62 | |||
| 63 | # | ||
| 64 | # Collapse FOO_pkg variables into FOO | ||
| 65 | # | ||
| 66 | def read_subpkgdata_dict(pkg, d): | ||
| 67 | ret = {} | ||
| 68 | subd = read_pkgdatafile(get_subpkgedata_fn(pkg, d)) | ||
| 69 | for var in subd: | ||
| 70 | newvar = var.replace("_" + pkg, "") | ||
| 71 | ret[newvar] = subd[var] | ||
| 72 | return ret | ||
| 73 | |||
diff --git a/meta/lib/oe/packagedata.py b/meta/lib/oe/packagedata.py new file mode 100644 index 0000000000..7f0a89d282 --- /dev/null +++ b/meta/lib/oe/packagedata.py | |||
| @@ -0,0 +1,106 @@ | |||
| 1 | import os | ||
| 2 | import bb.data | ||
| 3 | import codecs | ||
| 4 | |||
| 5 | def packaged(pkg, d): | ||
| 6 | return os.access(get_subpkgedata_fn(pkg, d) + '.packaged', os.R_OK) | ||
| 7 | |||
| 8 | def read_pkgdatafile(fn): | ||
| 9 | pkgdata = {} | ||
| 10 | |||
| 11 | def decode(str): | ||
| 12 | c = codecs.getdecoder("string_escape") | ||
| 13 | return c(str)[0] | ||
| 14 | |||
| 15 | if os.access(fn, os.R_OK): | ||
| 16 | import re | ||
| 17 | f = file(fn, 'r') | ||
| 18 | lines = f.readlines() | ||
| 19 | f.close() | ||
| 20 | r = re.compile("([^:]+):\s*(.*)") | ||
| 21 | for l in lines: | ||
| 22 | m = r.match(l) | ||
| 23 | if m: | ||
| 24 | pkgdata[m.group(1)] = decode(m.group(2)) | ||
| 25 | |||
| 26 | return pkgdata | ||
| 27 | |||
| 28 | def get_subpkgedata_fn(pkg, d): | ||
| 29 | archs = bb.data.expand("${PACKAGE_ARCHS}", d).split(" ") | ||
| 30 | archs.reverse() | ||
| 31 | pkgdata = bb.data.expand('${TMPDIR}/pkgdata/', d) | ||
| 32 | targetdir = bb.data.expand('${TARGET_VENDOR}-${TARGET_OS}/runtime/', d) | ||
| 33 | for arch in archs: | ||
| 34 | fn = pkgdata + arch + targetdir + pkg | ||
| 35 | if os.path.exists(fn): | ||
| 36 | return fn | ||
| 37 | return bb.data.expand('${PKGDATA_DIR}/runtime/%s' % pkg, d) | ||
| 38 | |||
| 39 | def has_subpkgdata(pkg, d): | ||
| 40 | return os.access(get_subpkgedata_fn(pkg, d), os.R_OK) | ||
| 41 | |||
| 42 | def read_subpkgdata(pkg, d): | ||
| 43 | return read_pkgdatafile(get_subpkgedata_fn(pkg, d)) | ||
| 44 | |||
| 45 | def has_pkgdata(pn, d): | ||
| 46 | fn = bb.data.expand('${PKGDATA_DIR}/%s' % pn, d) | ||
| 47 | return os.access(fn, os.R_OK) | ||
| 48 | |||
| 49 | def read_pkgdata(pn, d): | ||
| 50 | fn = bb.data.expand('${PKGDATA_DIR}/%s' % pn, d) | ||
| 51 | return read_pkgdatafile(fn) | ||
| 52 | |||
| 53 | # | ||
| 54 | # Collapse FOO_pkg variables into FOO | ||
| 55 | # | ||
| 56 | def read_subpkgdata_dict(pkg, d): | ||
| 57 | ret = {} | ||
| 58 | subd = read_pkgdatafile(get_subpkgedata_fn(pkg, d)) | ||
| 59 | for var in subd: | ||
| 60 | newvar = var.replace("_" + pkg, "") | ||
| 61 | ret[newvar] = subd[var] | ||
| 62 | return ret | ||
| 63 | |||
| 64 | def _pkgmap(d): | ||
| 65 | """Return a dictionary mapping package to recipe name.""" | ||
| 66 | |||
| 67 | target_os = d.getVar("TARGET_OS", True) | ||
| 68 | target_vendor = d.getVar("TARGET_VENDOR", True) | ||
| 69 | basedir = os.path.dirname(d.getVar("PKGDATA_DIR", True)) | ||
| 70 | |||
| 71 | dirs = ("%s%s-%s" % (arch, target_vendor, target_os) | ||
| 72 | for arch in d.getVar("PACKAGE_ARCHS", True).split()) | ||
| 73 | |||
| 74 | pkgmap = {} | ||
| 75 | for pkgdatadir in (os.path.join(basedir, sys) for sys in dirs): | ||
| 76 | try: | ||
| 77 | files = os.listdir(pkgdatadir) | ||
| 78 | except OSError: | ||
| 79 | continue | ||
| 80 | |||
| 81 | for pn in filter(lambda f: not os.path.isdir(os.path.join(pkgdatadir, f)), files): | ||
| 82 | try: | ||
| 83 | pkgdata = read_pkgdatafile(os.path.join(pkgdatadir, pn)) | ||
| 84 | except OSError: | ||
| 85 | continue | ||
| 86 | |||
| 87 | for pkg in pkgdata["PACKAGES"].split(): | ||
| 88 | pkgmap[pkg] = pn | ||
| 89 | |||
| 90 | return pkgmap | ||
| 91 | |||
| 92 | def pkgmap(d): | ||
| 93 | """Return a dictionary mapping package to recipe name. | ||
| 94 | Cache the mapping in the metadata""" | ||
| 95 | |||
| 96 | pkgmap_data = d.getVar("__pkgmap_data", False) | ||
| 97 | if pkgmap_data is None: | ||
| 98 | pkgmap_data = _pkgmap(d) | ||
| 99 | d.setVar("__pkgmap_data", pkgmap_data) | ||
| 100 | |||
| 101 | return pkgmap_data | ||
| 102 | |||
| 103 | def recipename(pkg, d): | ||
| 104 | """Return the recipe name for the given binary package name.""" | ||
| 105 | |||
| 106 | return pkgmap(d).get(pkg) | ||
