|
|
@ -1946,18 +1946,29 @@ class OptionOverrideProxy(collections.abc.Mapping): |
|
|
|
# TODO: the typing here could be made more explicit using a TypeDict from |
|
|
|
# TODO: the typing here could be made more explicit using a TypeDict from |
|
|
|
# python 3.8 or typing_extensions |
|
|
|
# python 3.8 or typing_extensions |
|
|
|
|
|
|
|
|
|
|
|
def __init__(self, overrides: T.Dict['OptionKey', T.Any], options: 'KeyedOptionDictType'): |
|
|
|
def __init__(self, overrides: T.Dict['OptionKey', T.Any], options: 'KeyedOptionDictType', |
|
|
|
|
|
|
|
subproject: T.Optional[str] = None): |
|
|
|
self.overrides = overrides |
|
|
|
self.overrides = overrides |
|
|
|
self.options = options |
|
|
|
self.options = options |
|
|
|
|
|
|
|
self.subproject = subproject |
|
|
|
|
|
|
|
|
|
|
|
def __getitem__(self, key: 'OptionKey') -> 'UserOption': |
|
|
|
def __getitem__(self, key: 'OptionKey') -> 'UserOption': |
|
|
|
if key in self.options: |
|
|
|
# FIXME: This is fundamentally the same algorithm than interpreter.get_option_internal(). |
|
|
|
|
|
|
|
# We should try to share the code somehow. |
|
|
|
|
|
|
|
key = key.evolve(subproject=self.subproject) |
|
|
|
|
|
|
|
if not key.is_project(): |
|
|
|
|
|
|
|
opt = self.options.get(key) |
|
|
|
|
|
|
|
if opt is None or opt.yielding: |
|
|
|
|
|
|
|
opt = self.options[key.as_root()] |
|
|
|
|
|
|
|
else: |
|
|
|
opt = self.options[key] |
|
|
|
opt = self.options[key] |
|
|
|
if key in self.overrides: |
|
|
|
if opt.yielding: |
|
|
|
|
|
|
|
opt = self.options.get(key.as_root(), opt) |
|
|
|
|
|
|
|
override_value = self.overrides.get(key.as_root()) |
|
|
|
|
|
|
|
if override_value is not None : |
|
|
|
opt = copy.copy(opt) |
|
|
|
opt = copy.copy(opt) |
|
|
|
opt.set_value(self.overrides[key]) |
|
|
|
opt.set_value(override_value) |
|
|
|
return opt |
|
|
|
return opt |
|
|
|
raise KeyError('Option not found', key) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def __iter__(self) -> T.Iterator['OptionKey']: |
|
|
|
def __iter__(self) -> T.Iterator['OptionKey']: |
|
|
|
return iter(self.options) |
|
|
|
return iter(self.options) |
|
|
@ -1968,8 +1979,8 @@ class OptionOverrideProxy(collections.abc.Mapping): |
|
|
|
def __eq__(self, other: object) -> bool: |
|
|
|
def __eq__(self, other: object) -> bool: |
|
|
|
if not isinstance(other, OptionOverrideProxy): |
|
|
|
if not isinstance(other, OptionOverrideProxy): |
|
|
|
return NotImplemented |
|
|
|
return NotImplemented |
|
|
|
t1 = (self.overrides, self.options) |
|
|
|
t1 = (self.overrides, self.subproject, self.options) |
|
|
|
t2 = (other.overrides, other.options) |
|
|
|
t2 = (other.overrides, other.subproject, other.options) |
|
|
|
return t1 == t2 |
|
|
|
return t1 == t2 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|