mirror of
https://git.yoctoproject.org/poky
synced 2026-06-02 13:29:49 +00:00
oe/manifest.py: Add manifest creation for opkg
In this commit: * add ability to create initial manifest for opkg; * make var_map available to all backends; (From OE-Core rev: 8d14fbedcee02b723288004ae29a5c29524eec5a) Signed-off-by: Laurentiu Palcu <laurentiu.palcu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
7fc9bdaeed
commit
fdd40ce2f6
+44
-7
@@ -33,6 +33,10 @@ class Manifest(object):
|
|||||||
self.initial_manifest = os.path.join(self.manifest_dir, "initial_manifest")
|
self.initial_manifest = os.path.join(self.manifest_dir, "initial_manifest")
|
||||||
self.final_manifest = os.path.join(self.manifest_dir, "final_manifest")
|
self.final_manifest = os.path.join(self.manifest_dir, "final_manifest")
|
||||||
|
|
||||||
|
self.var_map = {"PACKAGE_INSTALL": "mip",
|
||||||
|
"PACKAGE_INSTALL_ATTEMPTONLY": "aop",
|
||||||
|
"LINGUAS_INSTALL": "lgp"}
|
||||||
|
|
||||||
"""
|
"""
|
||||||
This creates a standard initial manifest for core-image-(minimal|sato|sato-sdk).
|
This creates a standard initial manifest for core-image-(minimal|sato|sato-sdk).
|
||||||
This will be used for testing until the class is implemented properly!
|
This will be used for testing until the class is implemented properly!
|
||||||
@@ -119,8 +123,45 @@ class RpmManifest(Manifest):
|
|||||||
|
|
||||||
|
|
||||||
class OpkgManifest(Manifest):
|
class OpkgManifest(Manifest):
|
||||||
|
"""
|
||||||
|
Returns a dictionary object with mip and mlp packages.
|
||||||
|
"""
|
||||||
|
def _split_multilib(self, pkg_list):
|
||||||
|
pkgs = dict()
|
||||||
|
|
||||||
|
for pkg in pkg_list.split():
|
||||||
|
pkg_type = 'mip'
|
||||||
|
|
||||||
|
ml_variants = self.d.getVar('MULTILIB_VARIANTS', True).split()
|
||||||
|
|
||||||
|
for ml_variant in ml_variants:
|
||||||
|
if pkg.startswith(ml_variant + '-'):
|
||||||
|
pkg_type = 'mlp'
|
||||||
|
|
||||||
|
if not pkg_type in pkgs:
|
||||||
|
pkgs[pkg_type] = pkg
|
||||||
|
else:
|
||||||
|
pkgs[pkg_type] += " " + pkg
|
||||||
|
|
||||||
|
return pkgs
|
||||||
|
|
||||||
def create_initial(self):
|
def create_initial(self):
|
||||||
self._create_dummy_initial()
|
pkgs = dict()
|
||||||
|
|
||||||
|
with open(self.initial_manifest, "w+") as manifest:
|
||||||
|
manifest.write(self.initial_manifest_file_header)
|
||||||
|
|
||||||
|
for var in self.var_map:
|
||||||
|
if var == "PACKAGE_INSTALL":
|
||||||
|
split_pkgs = self._split_multilib(self.d.getVar(var, True))
|
||||||
|
if split_pkgs is not None:
|
||||||
|
pkgs = dict(pkgs.items() + split_pkgs.items())
|
||||||
|
else:
|
||||||
|
pkgs[self.var_map[var]] = self.d.getVar(var, True)
|
||||||
|
|
||||||
|
for pkg_type in pkgs:
|
||||||
|
for pkg in pkgs[pkg_type].split():
|
||||||
|
manifest.write("%s,%s\n" % (pkg_type, pkg))
|
||||||
|
|
||||||
def create_final(self):
|
def create_final(self):
|
||||||
pass
|
pass
|
||||||
@@ -128,21 +169,17 @@ class OpkgManifest(Manifest):
|
|||||||
|
|
||||||
class DpkgManifest(Manifest):
|
class DpkgManifest(Manifest):
|
||||||
def create_initial(self):
|
def create_initial(self):
|
||||||
var_map = {"PACKAGE_INSTALL": "mip",
|
|
||||||
"PACKAGE_INSTALL_ATTEMPTONLY": "aop",
|
|
||||||
"LINGUAS_INSTALL": "lgp"}
|
|
||||||
|
|
||||||
with open(self.initial_manifest, "w+") as manifest:
|
with open(self.initial_manifest, "w+") as manifest:
|
||||||
manifest.write(self.initial_manifest_file_header)
|
manifest.write(self.initial_manifest_file_header)
|
||||||
|
|
||||||
for var in var_map:
|
for var in self.var_map:
|
||||||
pkg_list = self.d.getVar(var, True)
|
pkg_list = self.d.getVar(var, True)
|
||||||
|
|
||||||
if pkg_list is None:
|
if pkg_list is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
for pkg in pkg_list.split():
|
for pkg in pkg_list.split():
|
||||||
manifest.write("%s,%s\n" % (var_map[var], pkg))
|
manifest.write("%s,%s\n" % (self.var_map[var], pkg))
|
||||||
|
|
||||||
def create_final(self):
|
def create_final(self):
|
||||||
pass
|
pass
|
||||||
|
|||||||
Reference in New Issue
Block a user