|
| 1 | +from ngcsimlib.logger import critical, debug |
| 2 | + |
| 3 | +__component_transitions = {} |
| 4 | +__transition_meta_data = {} |
| 5 | + |
| 6 | + |
| 7 | +def get_transition(klass, transition_key, root=None): |
| 8 | + """ |
| 9 | + A helper method for searching through the transition list |
| 10 | + """ |
| 11 | + class_name = klass.__name__ |
| 12 | + |
| 13 | + if class_name + "/" + transition_key not in __component_transitions.keys(): |
| 14 | + parent_classes = klass.__bases__ |
| 15 | + if len(parent_classes) == 0: |
| 16 | + return None, None |
| 17 | + |
| 18 | + transition = None |
| 19 | + for parent in parent_classes: |
| 20 | + transition, meta = get_transition(parent, transition_key, |
| 21 | + root=klass if root is None else root) |
| 22 | + if transition is not None: |
| 23 | + return transition, meta |
| 24 | + |
| 25 | + if transition is None and root is None: |
| 26 | + critical(class_name, "has no transition for", transition_key) |
| 27 | + if transition is None: |
| 28 | + return None, None |
| 29 | + |
| 30 | + if root is not None: |
| 31 | + debug( |
| 32 | + f"{root.__name__} is using the transition from {class_name} for " |
| 33 | + f"resolving key \"{transition_key}\"") |
| 34 | + return __component_transitions[class_name + "/" + transition_key], \ |
| 35 | + __transition_meta_data[class_name + "/" + transition_key] |
| 36 | + |
| 37 | + |
| 38 | +def add_component_transition(class_name, transition_key, data): |
| 39 | + """ |
| 40 | + A helper function for adding component transitions |
| 41 | + """ |
| 42 | + __component_transitions[class_name + "/" + transition_key] = data |
| 43 | + |
| 44 | + |
| 45 | +def add_transition_meta(class_name, transition_key, data): |
| 46 | + """ |
| 47 | + A helper function for adding component transition metadata |
| 48 | + """ |
| 49 | + __transition_meta_data[class_name + "/" + transition_key] = data |
| 50 | + |
| 51 | + |
| 52 | +def using_transition(**kwargs): |
| 53 | + """ |
| 54 | + A decorator for linking transitions defined in other classes to this class. |
| 55 | + the keyword arguments are compile_key=class_to_inherit_transition_from. This |
| 56 | + will add the transition directly to the class and thus will get used before |
| 57 | + any transitions in parent classes. |
| 58 | +
|
| 59 | + Args: |
| 60 | + **kwargs: any number or compile_key=class_to_inherit_transition_from |
| 61 | + """ |
| 62 | + |
| 63 | + def _klass_wrapper(cls): |
| 64 | + klass_name = cls.__name__ |
| 65 | + for key, value in kwargs.items(): |
| 66 | + transition, data = get_transition(value, key) |
| 67 | + add_component_transition(klass_name, key, transition) |
| 68 | + add_transition_meta(klass_name, key, data) |
| 69 | + return cls |
| 70 | + |
| 71 | + return _klass_wrapper |
0 commit comments