diff options
| author | Chris Larson <chris_larson@mentor.com> | 2010-10-05 20:19:31 -0700 | 
|---|---|---|
| committer | Richard Purdie <rpurdie@linux.intel.com> | 2011-01-04 14:46:37 +0000 | 
| commit | f3406dd28846f4782bec36cb0bd1f834e068147b (patch) | |
| tree | 32ad721ecc92b3bcf9ef0ec72911b16b767c02b0 | |
| parent | 6491ed9e2ee6562a9ffc548fdd9ee6e13ba96657 (diff) | |
| download | openembedded-core-f3406dd28846f4782bec36cb0bd1f834e068147b.tar.gz openembedded-core-f3406dd28846f4782bec36cb0bd1f834e068147b.tar.bz2 openembedded-core-f3406dd28846f4782bec36cb0bd1f834e068147b.zip | |
Fix __getitem__ for DataSmart
Ensure it raises KeyError for a missing key, this is required to use this as a
mapping in various places, e.g. as locals in an eval.
(Bitbake rev: 8d661ce0c303e8d69f17c1d095545d5ed086d1d5)
Signed-off-by: Chris Larson <chris_larson@mentor.com>
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
| -rw-r--r-- | bitbake/lib/bb/data_smart.py | 8 | 
1 files changed, 6 insertions, 2 deletions
| diff --git a/bitbake/lib/bb/data_smart.py b/bitbake/lib/bb/data_smart.py index 7de90056d5..17a642ee2d 100644 --- a/bitbake/lib/bb/data_smart.py +++ b/bitbake/lib/bb/data_smart.py @@ -150,7 +150,7 @@ class DataSmart(MutableMapping):              for var in vars:                  name = var[:-l]                  try: -                    self[name] = self[var] +                    self.setVar(name, self.getVar(var, False))                  except Exception:                      logger.info("Untracked delVar") @@ -366,7 +366,11 @@ class DataSmart(MutableMapping):          return len(frozenset(self))      def __getitem__(self, item): -        return self.getVar(item, False) +        value = self.getVar(item, False) +        if value is None: +            raise KeyError(item) +        else: +            return value      def __setitem__(self, var, value):          self.setVar(var, value) | 
