- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.1k
          Add type annotations to synapse.metrics
          #10847
        
      Changes from 5 commits
66d63c0
              934fe41
              f058e4f
              dbe4345
              949439c
              d55eb93
              ab66469
              d1ee5da
              6924ce8
              7ab1153
              77120c2
              dba3f61
              b483e31
              dd276d1
              055dbde
              b7d099b
              6c2f682
              53ff8f5
              550d1bc
              File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -203,6 +203,9 @@ def run_as_background_process( # type: ignore[misc] | |
| ... | ||
| # The `type: ignore[misc]` above suppresses | ||
| # "error: Overloaded function signatures 1 and 2 overlap with incompatible return types [misc]" | ||
| # | ||
| # Overloads are used instead of a `Union` here because mypy fails to infer the type of `R` | ||
| # and complains about almost every call to this function when `func` is a `Union`. | ||
|  | ||
|  | ||
| @overload | ||
|  | @@ -287,19 +290,19 @@ async def run() -> Optional[R]: | |
| F = TypeVar("F", bound=Callable[..., Any]) | ||
|  | ||
|  | ||
| # NB: Return type is incorrect and should be a callable returning an F with a | ||
| # Deferred[Optional[R]] return, which we can't express correctly until Python 3.10. | ||
| def wrap_as_background_process(desc: str) -> Callable[[F], F]: | ||
| """Decorator that wraps a function that gets called as a background | ||
| process. | ||
|  | ||
| Equivalent to calling the function with `run_as_background_process`. | ||
|  | ||
| Note that `run_as_background_process` changes the return type into | ||
| Note that the annotated return type of this function is incorrect. | ||
| The return type of the function, once wrapped, is actually a | ||
| `Deferred[Optional[T]]`. | ||
| """ | ||
|  | ||
| # NB: Return type is incorrect and should be F with a Deferred[Optional[R]] return | ||
|          | ||
| # We can't expression the return types correctly until Python 3.10. | ||
|         
                  DMRobertson marked this conversation as resolved.
              Outdated
          
            Show resolved
            Hide resolved | ||
| def wrap_as_background_process_inner(func: F) -> F: | ||
| @wraps(func) | ||
| def wrap_as_background_process_inner_2( | ||
|  | ||
Uh oh!
There was an error while loading. Please reload this page.