loki.types.symbol_table
Representation of symbol tables and scopes in Loki’s internal representation (IR)
Classes
|
Lookup table for symbol types that maps symbol names to |
- class SymbolTable(*args, case_sensitive=False, **kwargs)
Bases:
dictLookup table for symbol types that maps symbol names to
SymbolAttributesIt is used to store types for declared variables, defined types or imported symbols within their respective scope. If its associated scope is nested into an enclosing scope, it allows to perform recursive look-ups in parent scopes.
The interface of this table behaves like a
dict.- Parameters:
parent (
SymbolTable, optional) – The symbol table of the parent scope for recursive look-ups.case_sensitive (bool, optional) – Respect the case of symbol names in lookups (default: False).
- property parent
The symbol table of the parent scope
- Return type:
SymbolTableor None
- property case_sensitive
Indicate if the
SymbolTableis case-sensitive when looking up names- Return type:
bool
- format_lookup_name(name)
Format a variable name for look-up (e.g., convert to lower case if case-insensitive)
- Parameters:
name (str) – the name to look up
- Returns:
the name used for look-ups
- Return type:
- lookup(name, recursive=True)
Look-up a symbol in the symbol table and return the type or None if not found.
- Parameters:
name (str) – Name of the type or symbol
recursive (bool, optional) – If no entry by that name is found, try to find it in the table of the parent scope
- Return type:
SymbolAttributesor None
- get(key, default=None)
Get a symbol’s entry without recursive lookup
- Parameters:
key (str) – Name of the type or symbol
default (optional) – Return this value if
keyis not found in the table
- setdefault(key, default=None)
Insert a default value for a key into the table if it does not exist
- Parameters:
key (str) – Name of the type or symbol
default (optional) – The default value to store for the key. Defaults to
SymbolAttributes(BasicType.DEFERRED).
- update(other)
Update this symbol table with entries from
other
- clone(**kwargs)
Create a copy of the symbol table with the option to override individual parameters
- Parameters:
**kwargs – Any parameters from the constructor of
SymbolTable- Returns:
The clone symbol table with copies of all
SymbolAttributes- Return type: