[jhbuild/wip/sysdeps: 3/4] Parse 'pkg-config' attribute on modules
- From: Colin Walters <walters src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [jhbuild/wip/sysdeps: 3/4] Parse 'pkg-config' attribute on modules
- Date: Fri, 24 Jun 2011 17:44:39 +0000 (UTC)
commit ca2955c70818bb92b320a92df3ab3e8569481ea8
Author: Colin Walters <walters verbum org>
Date: Thu Jun 23 16:59:56 2011 -0400
Parse 'pkg-config' attribute on modules
https://bugzilla.gnome.org/show_bug.cgi?id=564373
jhbuild/modtypes/__init__.py | 3 ++-
jhbuild/modtypes/autotools.py | 5 ++++-
jhbuild/modtypes/cmake.py | 7 ++++---
jhbuild/modtypes/distutils.py | 7 ++++---
jhbuild/modtypes/perl.py | 7 ++++---
jhbuild/modtypes/tarball.py | 3 ++-
jhbuild/modtypes/waf.py | 7 ++++---
jhbuild/utils/systeminstall.py | 12 ++++++------
8 files changed, 30 insertions(+), 21 deletions(-)
---
diff --git a/jhbuild/modtypes/__init__.py b/jhbuild/modtypes/__init__.py
index 739d043..52425e4 100644
--- a/jhbuild/modtypes/__init__.py
+++ b/jhbuild/modtypes/__init__.py
@@ -125,8 +125,9 @@ class Package:
type = 'base'
PHASE_START = 'start'
PHASE_DONE = 'done'
- def __init__(self, name, dependencies = [], after = [], suggests = []):
+ def __init__(self, name, dependencies = [], after = [], suggests = [], pkg_config=None):
self.name = name
+ self.pkg_config = pkg_config
self.dependencies = dependencies
self.after = after
self.suggests = suggests
diff --git a/jhbuild/modtypes/autotools.py b/jhbuild/modtypes/autotools.py
index 52fa4af..609d5e4 100644
--- a/jhbuild/modtypes/autotools.py
+++ b/jhbuild/modtypes/autotools.py
@@ -49,13 +49,14 @@ class AutogenModule(Package, DownloadableModule):
def __init__(self, name, branch, autogenargs='', makeargs='',
makeinstallargs='',
dependencies=[], after=[], suggests=[],
+ pkg_config=None,
supports_non_srcdir_builds=True,
skip_autogen=False,
autogen_sh='autogen.sh',
makefile='Makefile',
autogen_template=None,
check_target=True):
- Package.__init__(self, name, dependencies, after, suggests)
+ Package.__init__(self, name, dependencies, after, suggests, pkg_config)
self.branch = branch
self.autogenargs = autogenargs
self.makeargs = makeargs
@@ -315,6 +316,7 @@ class AutogenModule(Package, DownloadableModule):
def parse_autotools(node, config, uri, repositories, default_repo):
id = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
autogenargs = ''
makeargs = ''
makeinstallargs = ''
@@ -381,6 +383,7 @@ def parse_autotools(node, config, uri, repositories, default_repo):
dependencies=dependencies,
after=after,
suggests=suggests,
+ pkg_config=pkg_config,
supports_non_srcdir_builds=supports_non_srcdir_builds,
skip_autogen=skip_autogen,
autogen_sh=autogen_sh,
diff --git a/jhbuild/modtypes/cmake.py b/jhbuild/modtypes/cmake.py
index b24eb83..e16d039 100644
--- a/jhbuild/modtypes/cmake.py
+++ b/jhbuild/modtypes/cmake.py
@@ -39,8 +39,8 @@ class CMakeModule(Package, DownloadableModule):
PHASE_INSTALL = 'install'
def __init__(self, name, branch, cmakeargs='', makeargs='',
- dependencies=[], after=[], suggests=[]):
- Package.__init__(self, name, dependencies, after, suggests)
+ dependencies=[], after=[], suggests=[], pkg_config=None):
+ Package.__init__(self, name, dependencies, after, suggests, pkg_config)
self.branch = branch
self.cmakeargs = cmakeargs
self.makeargs = makeargs
@@ -145,6 +145,7 @@ class CMakeModule(Package, DownloadableModule):
def parse_cmake(node, config, uri, repositories, default_repo):
id = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
cmakeargs = ''
makeargs = ''
if node.hasAttribute('cmakeargs'):
@@ -157,7 +158,7 @@ def parse_cmake(node, config, uri, repositories, default_repo):
return CMakeModule(id, branch, cmakeargs, makeargs,
dependencies = dependencies, after = after,
- suggests = suggests)
+ suggests = suggests, pkg_config=pkg_config)
register_module_type('cmake', parse_cmake)
diff --git a/jhbuild/modtypes/distutils.py b/jhbuild/modtypes/distutils.py
index d4d56a1..4b3d933 100644
--- a/jhbuild/modtypes/distutils.py
+++ b/jhbuild/modtypes/distutils.py
@@ -39,8 +39,8 @@ class DistutilsModule(Package, DownloadableModule):
def __init__(self, name, branch,
dependencies = [], after = [], suggests = [],
- supports_non_srcdir_builds = True):
- Package.__init__(self, name, dependencies, after, suggests)
+ supports_non_srcdir_builds = True, pkg_config=None):
+ Package.__init__(self, name, dependencies, after, suggests, pkg_config)
self.branch = branch
self.supports_non_srcdir_builds = supports_non_srcdir_builds
self.supports_install_destdir = True
@@ -92,6 +92,7 @@ class DistutilsModule(Package, DownloadableModule):
def parse_distutils(node, config, uri, repositories, default_repo):
id = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
supports_non_srcdir_builds = True
if node.hasAttribute('supports-non-srcdir-builds'):
@@ -102,7 +103,7 @@ def parse_distutils(node, config, uri, repositories, default_repo):
return DistutilsModule(id, branch,
dependencies = dependencies, after = after,
- suggests = suggests,
+ suggests = suggests, pkg_config = pkg_config,
supports_non_srcdir_builds = supports_non_srcdir_builds)
register_module_type('distutils', parse_distutils)
diff --git a/jhbuild/modtypes/perl.py b/jhbuild/modtypes/perl.py
index f5173b6..905d892 100644
--- a/jhbuild/modtypes/perl.py
+++ b/jhbuild/modtypes/perl.py
@@ -39,8 +39,8 @@ class PerlModule(Package, DownloadableModule):
PHASE_INSTALL = 'install'
def __init__(self, name, branch, makeargs='',
- dependencies=[], after=[], suggests=[]):
- Package.__init__(self, name, dependencies, after, suggests)
+ dependencies=[], after=[], suggests=[], pkg_config=None):
+ Package.__init__(self, name, dependencies, after, suggests, pkg_config)
self.branch = branch
self.makeargs = makeargs
@@ -82,6 +82,7 @@ class PerlModule(Package, DownloadableModule):
def parse_perl(node, config, uri, repositories, default_repo):
id = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
makeargs = ''
if node.hasAttribute('makeargs'):
makeargs = node.getAttribute('makeargs')
@@ -95,6 +96,6 @@ def parse_perl(node, config, uri, repositories, default_repo):
return PerlModule(id, branch, makeargs,
dependencies=dependencies, after=after,
- suggests=suggests)
+ suggests=suggests, pkg_config=pkg_config)
register_module_type('perl', parse_perl)
diff --git a/jhbuild/modtypes/tarball.py b/jhbuild/modtypes/tarball.py
index 70d797a..ced9c7c 100644
--- a/jhbuild/modtypes/tarball.py
+++ b/jhbuild/modtypes/tarball.py
@@ -31,6 +31,7 @@ from jhbuild.modtypes import register_module_type, get_dependencies
def parse_tarball(node, config, uri, repositories, default_repo):
name = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
version = node.getAttribute('version')
source_url = None
source_size = None
@@ -100,7 +101,7 @@ def parse_tarball(node, config, uri, repositories, default_repo):
return AutogenModule(name, branch,
autogenargs, makeargs, makeinstallargs,
- dependencies, after, suggests,
+ dependencies, after, suggests, pkg_config,
supports_non_srcdir_builds = supports_non_srcdir_builds,
skip_autogen = False, autogen_sh = 'configure',
makefile = makefile)
diff --git a/jhbuild/modtypes/waf.py b/jhbuild/modtypes/waf.py
index e12b16c..a9cfb54 100644
--- a/jhbuild/modtypes/waf.py
+++ b/jhbuild/modtypes/waf.py
@@ -44,9 +44,9 @@ class WafModule(Package, DownloadableModule):
PHASE_DIST = 'dist'
PHASE_INSTALL = 'install'
- def __init__(self, name, branch, dependencies=[], after=[], suggests=[],
+ def __init__(self, name, branch, dependencies=[], after=[], suggests=[], pkg_config=None,
waf_cmd='./waf'):
- Package.__init__(self, name, dependencies, after, suggests)
+ Package.__init__(self, name, dependencies, after, suggests, pkg_config)
self.branch = branch
self.waf_cmd = waf_cmd
self.supports_install_destdir = True
@@ -148,6 +148,7 @@ class WafModule(Package, DownloadableModule):
def parse_waf(node, config, uri, repositories, default_repo):
module_id = node.getAttribute('id')
+ pkg_config = node.getAttribute('pkg-config')
waf_cmd = './waf'
if node.hasAttribute('waf-command'):
waf_cmd = node.getAttribute('waf-command')
@@ -157,6 +158,6 @@ def parse_waf(node, config, uri, repositories, default_repo):
branch = get_branch(node, repositories, default_repo, config)
return WafModule(module_id, branch, dependencies=dependencies, after=after,
- suggests=suggests, waf_cmd=waf_cmd)
+ suggests=suggests, pkg_config=pkg_config, waf_cmd=waf_cmd)
register_module_type('waf', parse_waf)
diff --git a/jhbuild/utils/systeminstall.py b/jhbuild/utils/systeminstall.py
index e58e074..13c2c89 100644
--- a/jhbuild/utils/systeminstall.py
+++ b/jhbuild/utils/systeminstall.py
@@ -62,10 +62,10 @@ class PkconSystemInstall(SystemInstall):
def __init__(self):
SystemInstall.__init__(self)
- def _get_package_for(self, pkgid):
- assert pkgid.endswith('.pc')
- pkgid = pkgid[:-3]
- proc = subprocess.Popen(['pkcon', '-p', 'what-provides', 'pkgconfig(%s)' % (pkgid, ),
+ def _get_package_for(self, pkg_config):
+ assert pkg_config.endswith('.pc')
+ pkg_config = pkg_config[:-3]
+ proc = subprocess.Popen(['pkcon', '-p', 'what-provides', 'pkgconfig(%s)' % (pkg_config, ),
'--filter=arch;newest'], stdout=subprocess.PIPE, close_fds=True)
devnull.close()
stdout = proc.communicate()[0]
@@ -80,11 +80,11 @@ class PkconSystemInstall(SystemInstall):
def install(self, pkgconfig_ids):
required_pkgs = []
- for pkgid in pkgconfig_ids:
+ for pkg_config in pkgconfig_ids:
if not pkg.endswith('.pc'):
logging.warn("Invalid pkg-config id " + pkg)
continue
- providing_pkg = self._get_package_for(pkgid)
+ providing_pkg = self._get_package_for(pkg_config)
if providing_pkg is not None:
required_pkgs.append(providing_pkg)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]