diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2016-01-19 00:18:26 +1300 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-01-19 16:35:38 +0000 | 
| commit | c58669fb0977f7f0cb79f252484d5c5ef0dfb7e4 (patch) | |
| tree | 8b38fe093d0f91eeb708d52dc3318a6f45cf5ec0 /scripts/lib | |
| parent | b9d400be06bc4a4bb9f9c6a6a0c8e5ecfd4e2dfb (diff) | |
| download | openembedded-core-c58669fb0977f7f0cb79f252484d5c5ef0dfb7e4.tar.gz openembedded-core-c58669fb0977f7f0cb79f252484d5c5ef0dfb7e4.tar.bz2 openembedded-core-c58669fb0977f7f0cb79f252484d5c5ef0dfb7e4.zip | |
recipetool: create: improve extraction of pkg-config / lib deps
* The regexes for PKG_CHECK_MODULES / AC_CHECK_LIB were a bit too strict
  and thus we were skipping some macros.
* Add support for PKG_CHECK_EXISTS
* Avoid duplicates in warning on missing pkg-config dependencies
* Ignore dependency on musl (since this may come up if it's the selected
  C library)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'scripts/lib')
| -rw-r--r-- | scripts/lib/recipetool/create_buildsys.py | 18 | 
1 files changed, 14 insertions, 4 deletions
| diff --git a/scripts/lib/recipetool/create_buildsys.py b/scripts/lib/recipetool/create_buildsys.py index 1674aba28a..7fedb2a917 100644 --- a/scripts/lib/recipetool/create_buildsys.py +++ b/scripts/lib/recipetool/create_buildsys.py @@ -157,12 +157,13 @@ class AutotoolsRecipeHandler(RecipeHandler):          progclassmap = {'gconftool-2': 'gconf',                  'pkg-config': 'pkgconfig'} -        ignoredeps = ['gcc-runtime', 'glibc', 'uclibc', 'tar-native', 'binutils-native'] +        ignoredeps = ['gcc-runtime', 'glibc', 'uclibc', 'musl', 'tar-native', 'binutils-native']          ignorelibs = ['socket'] -        pkg_re = re.compile('PKG_CHECK_MODULES\(\[?[a-zA-Z0-9]*\]?, \[?([^,\]]*)[),].*') -        lib_re = re.compile('AC_CHECK_LIB\(\[?([a-zA-Z0-9]*)\]?, .*') -        progs_re = re.compile('_PROGS?\(\[?[a-zA-Z0-9]*\]?, \[?([^,\]]*)\]?[),].*') +        pkg_re = re.compile('PKG_CHECK_MODULES\(\[?[a-zA-Z0-9_]*\]?, *\[?([^,\]]*)\]?[),].*') +        pkgce_re = re.compile('PKG_CHECK_EXISTS\(\[?([^,\]]*)\]?[),].*') +        lib_re = re.compile('AC_CHECK_LIB\(\[?([^,\]]*)\]?,.*') +        progs_re = re.compile('_PROGS?\(\[?[a-zA-Z0-9_]*\]?, \[?([^,\]]*)\]?[),].*')          dep_re = re.compile('([^ ><=]+)( [<>=]+ [^ ><=]+)?')          ac_init_re = re.compile('AC_INIT\(([^,]+), *([^,]+)[,)].*')          am_init_re = re.compile('AM_INIT_AUTOMAKE\(([^,]+), *([^,]+)[,)].*') @@ -249,6 +250,13 @@ class AutotoolsRecipeHandler(RecipeHandler):                      if res:                          pcdeps.extend([x[0] for x in res])                  inherits.append('pkgconfig') +            elif keyword == 'PKG_CHECK_EXISTS': +                res = pkgce_re.search(value) +                if res: +                    res = dep_re.findall(res.group(1)) +                    if res: +                        pcdeps.extend([x[0] for x in res]) +                inherits.append('pkgconfig')              elif keyword in ('AM_GNU_GETTEXT', 'AM_GLIB_GNU_GETTEXT', 'GETTEXT_PACKAGE'):                  inherits.append('gettext')              elif keyword in ('AC_PROG_INTLTOOL', 'IT_PROG_INTLTOOL'): @@ -313,6 +321,7 @@ class AutotoolsRecipeHandler(RecipeHandler):                          defines[key] = value          keywords = ['PKG_CHECK_MODULES', +                    'PKG_CHECK_EXISTS',                      'AM_GNU_GETTEXT',                      'AM_GLIB_GNU_GETTEXT',                      'GETTEXT_PACKAGE', @@ -375,6 +384,7 @@ class AutotoolsRecipeHandler(RecipeHandler):          recipemap = read_pkgconfig_provides(tinfoil.config_data)          unmapped = [] +        pcdeps = list(set(pcdeps))          for pcdep in pcdeps:              recipe = recipemap.get(pcdep, None)              if recipe: | 
