diff options
author | Todd Gamblin <tgamblin@llnl.gov> | 2024-11-29 23:17:28 -0800 |
---|---|---|
committer | Todd Gamblin <tgamblin@llnl.gov> | 2024-12-04 22:49:18 -0800 |
commit | f54526957aff1485f975302375c4feec917c2762 (patch) | |
tree | fb637315328d987c81ce0ba9b2ed3a5c510f8918 | |
parent | 175a4bf101adf7eb6071e13159881510928a5344 (diff) | |
download | spack-f54526957aff1485f975302375c4feec917c2762.tar.gz spack-f54526957aff1485f975302375c4feec917c2762.tar.bz2 spack-f54526957aff1485f975302375c4feec917c2762.tar.xz spack-f54526957aff1485f975302375c4feec917c2762.zip |
directives: add type annotations to `DirectiveMeta` class
Some of the class-level annotations were wrong, and some were missing. Annotate all the
functions here and fix the class properties to match what's actually happening.
Signed-off-by: Todd Gamblin <tgamblin@llnl.gov>
-rw-r--r-- | lib/spack/spack/directives_meta.py | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/lib/spack/spack/directives_meta.py b/lib/spack/spack/directives_meta.py index 70ba0298a8..0ba1acb7bb 100644 --- a/lib/spack/spack/directives_meta.py +++ b/lib/spack/spack/directives_meta.py @@ -5,7 +5,7 @@ import collections.abc import functools -from typing import List, Set +from typing import Any, Callable, Dict, List, Optional, Sequence, Set, Type, Union import llnl.util.lang @@ -25,11 +25,13 @@ class DirectiveMeta(type): # Set of all known directives _directive_dict_names: Set[str] = set() - _directives_to_be_executed: List[str] = [] - _when_constraints_from_context: List[str] = [] + _directives_to_be_executed: List[Callable] = [] + _when_constraints_from_context: List[spack.spec.Spec] = [] _default_args: List[dict] = [] - def __new__(cls, name, bases, attr_dict): + def __new__( + cls: Type["DirectiveMeta"], name: str, bases: tuple, attr_dict: dict + ) -> "DirectiveMeta": # Initialize the attribute containing the list of directives # to be executed. Here we go reversed because we want to execute # commands: @@ -60,7 +62,7 @@ class DirectiveMeta(type): return super(DirectiveMeta, cls).__new__(cls, name, bases, attr_dict) - def __init__(cls, name, bases, attr_dict): + def __init__(cls: "DirectiveMeta", name: str, bases: tuple, attr_dict: dict): # The instance is being initialized: if it is a package we must ensure # that the directives are called to set it up. @@ -81,27 +83,27 @@ class DirectiveMeta(type): super(DirectiveMeta, cls).__init__(name, bases, attr_dict) @staticmethod - def push_to_context(when_spec): + def push_to_context(when_spec: spack.spec.Spec) -> None: """Add a spec to the context constraints.""" DirectiveMeta._when_constraints_from_context.append(when_spec) @staticmethod - def pop_from_context(): + def pop_from_context() -> spack.spec.Spec: """Pop the last constraint from the context""" return DirectiveMeta._when_constraints_from_context.pop() @staticmethod - def push_default_args(default_args): + def push_default_args(default_args: Dict[str, Any]) -> None: """Push default arguments""" DirectiveMeta._default_args.append(default_args) @staticmethod - def pop_default_args(): + def pop_default_args() -> dict: """Pop default arguments""" return DirectiveMeta._default_args.pop() @staticmethod - def directive(dicts=None): + def directive(dicts: Optional[Union[Sequence[str], str]] = None) -> Callable: """Decorator for Spack directives. Spack directives allow you to modify a package while it is being @@ -156,7 +158,7 @@ class DirectiveMeta(type): DirectiveMeta._directive_dict_names |= set(dicts) # This decorator just returns the directive functions - def _decorator(decorated_function): + def _decorator(decorated_function: Callable) -> Callable: directive_names.append(decorated_function.__name__) @functools.wraps(decorated_function) |