def is_subset_of(self, other: 'Kconfig') -> bool: for name, value in self._entries.items():
b = other._entries.get(name) if b isNone: if value == 'n': continue returnFalse if value != b: returnFalse returnTrue
def conflicting_options(self, other: 'Kconfig') -> List[Tuple[KconfigEntry, KconfigEntry]]:
diff = [] # type: List[Tuple[KconfigEntry, KconfigEntry]] for name, value in self._entries.items():
b = other._entries.get(name) if b and value != b:
pair = (KconfigEntry(name, value), KconfigEntry(name, b))
diff.append(pair) return diff
def merge_in_entries(self, other: 'Kconfig') -> None: for name, value in other._entries.items():
self._entries[name] = value
def write_to_file(self, path: str) -> None: with open(path, 'a+') as f: for e in self.as_entries():
f.write(str(e) + '\n')
def parse_file(path: str) -> Kconfig: with open(path, 'r') as f: return parse_from_string(f.read())
def parse_from_string(blob: str) -> Kconfig: """Parses a string containing Kconfig entries."""
kconfig = Kconfig()
is_not_set_matcher = re.compile(CONFIG_IS_NOT_SET_PATTERN)
config_matcher = re.compile(CONFIG_PATTERN) for line in blob.split('\n'):
line = line.strip() ifnot line: continue
match = config_matcher.match(line) if match:
kconfig.add_entry(match.group(1), match.group(2)) continue
empty_match = is_not_set_matcher.match(line) if empty_match:
kconfig.add_entry(empty_match.group(1), 'n') continue
if line[0] == '#': continue raise KconfigParseError('Failed to parse: ' + line) return kconfig
Messung V0.5
¤ Dauer der Verarbeitung: 0.14 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.