diff options
| author | Richard Purdie <rpurdie@linux.intel.com> | 2010-01-19 15:33:31 +0000 | 
|---|---|---|
| committer | Richard Purdie <rpurdie@linux.intel.com> | 2010-01-19 15:34:01 +0000 | 
| commit | b65e8ec5931afbfcb29482db5a3afb9a752166cf (patch) | |
| tree | 4eecc2d466e0e7d68e2a73c348c9051a36df9fbd /bitbake-dev/lib/bb/providers.py | |
| parent | 43788606bda9bef3e0c796271af8a03e01d9853d (diff) | |
| download | openembedded-core-b65e8ec5931afbfcb29482db5a3afb9a752166cf.tar.gz openembedded-core-b65e8ec5931afbfcb29482db5a3afb9a752166cf.tar.bz2 openembedded-core-b65e8ec5931afbfcb29482db5a3afb9a752166cf.zip | |
bitbake-dev: Sync again with upstream after fixes from Poky bitbake 1.8 were merged
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
Diffstat (limited to 'bitbake-dev/lib/bb/providers.py')
| -rw-r--r-- | bitbake-dev/lib/bb/providers.py | 14 | 
1 files changed, 13 insertions, 1 deletions
| diff --git a/bitbake-dev/lib/bb/providers.py b/bitbake-dev/lib/bb/providers.py index 6c1cf78eb3..8617251ca3 100644 --- a/bitbake-dev/lib/bb/providers.py +++ b/bitbake-dev/lib/bb/providers.py @@ -63,6 +63,18 @@ def sortPriorities(pn, dataCache, pkg_pn = None):      return tmp_pn +def preferredVersionMatch(pe, pv, pr, preferred_e, preferred_v, preferred_r): +    """ +    Check if the version pe,pv,pr is the preferred one. +    If there is preferred version defined and ends with '%', then pv has to start with that version after removing the '%'  +    """ +    if (pr == preferred_r or preferred_r == None): +        if (pe == preferred_e or preferred_e == None): +            if preferred_v == pv: +                return True +            if preferred_v != None and preferred_v.endswith('%') and pv.startswith(preferred_v[:len(preferred_v)-1]): +                return True +    return False  def findPreferredProvider(pn, cfgData, dataCache, pkg_pn = None, item = None):      """ @@ -96,7 +108,7 @@ def findPreferredProvider(pn, cfgData, dataCache, pkg_pn = None, item = None):          for file_set in pkg_pn:              for f in file_set:                  pe,pv,pr = dataCache.pkg_pepvpr[f] -                if preferred_v == pv and (preferred_r == pr or preferred_r == None) and (preferred_e == pe or preferred_e == None): +                if preferredVersionMatch(pe, pv, pr, preferred_e, preferred_v, preferred_r):                      preferred_file = f                      preferred_ver = (pe, pv, pr)                      break | 
