2021-03-16 16:15:16 +00:00
|
|
|
# Copyright The PyTorch Lightning team.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
import inspect
|
2021-08-24 18:45:54 +00:00
|
|
|
from typing import Callable, Optional
|
2021-03-16 16:15:16 +00:00
|
|
|
|
|
|
|
|
2021-08-24 18:45:54 +00:00
|
|
|
def is_param_in_hook_signature(
|
|
|
|
hook_fx: Callable, param: str, explicit: bool = False, min_args: Optional[int] = None
|
|
|
|
) -> bool:
|
2021-08-16 19:01:09 +00:00
|
|
|
"""
|
|
|
|
Args:
|
|
|
|
hook_fx: the hook callable
|
|
|
|
param: the name of the parameter to check
|
|
|
|
explicit: whether the parameter has to be explicitly declared
|
2021-08-24 18:45:54 +00:00
|
|
|
min_args: whether the `signature` as at least `min_args` parameters
|
2021-08-16 19:01:09 +00:00
|
|
|
"""
|
2021-03-16 16:15:16 +00:00
|
|
|
hook_params = list(inspect.signature(hook_fx).parameters)
|
2021-08-24 18:45:54 +00:00
|
|
|
return (
|
|
|
|
param in hook_params
|
|
|
|
or (not explicit and "args" in hook_params)
|
|
|
|
or (isinstance(min_args, int) and len(hook_params) >= min_args)
|
|
|
|
)
|