Signature#
signature
module#
- mmodel.signature.check_args(base_params, arglist)[source]#
Check if args list is valid.
- Parameters:
base_params (list) – list of signature parameters
arglist (list) – list of positional arguments
- mmodel.signature.check_kwargs(base_params, kwarglist)[source]#
Check if kwargs list is valid.
- Parameters:
base_params (list) – list of signature parameters
kwarglist (list) – list of keyword arguments
- mmodel.signature.check_signature(base_params, param_list, param_type, nonvar_kind, var_kind)[source]#
Check if the function signature is valid.
Check for the number of parameters based on original signature requirements.
- mmodel.signature.convert_func(func, sig)[source]#
Wrap the input node function and redirect the input parameters.
The signature is constructed in the node definition that defines the new signature following the old signature. The wrapper split the into the positional and keyword arguments, and apply them to the function.
- mmodel.signature.get_node_signature(base_params, inputs_list)[source]#
Get the node signature based on the function and argument lists.
If the inputs_list are empty, the function returns the signature with only the required parameters and no var- parameters. If the inputs_list are not empty, the function checks if the argument lists meet the minimum and maximum requirements of the function. The inputs can be separated by “*” to indicate the keyword only parameters.
- Parameters:
param_dict (dict) – dictionary of parameters
inputs_list (list) – list of input parameters
- mmodel.signature.get_parameters(func)[source]#
Get the parameter dictionary for the function.
If the function has no signature, the function returns a dictionary with *args and **kwargs. Empty input definition is allowed, therefore a function without a signature and without argument lists is valid.
- Parameters:
func (callable) – function to get the parameters
- mmodel.signature.restructure_signature(signature, default_dict)[source]#
Add defaults to signature for Model.
Here the parameter kinds are replaced with kind (defaults to positional-or-keyword), and defaults are applied. The final signatures are sorted.
- Parameters:
signature (inspect.Signature) – signature to add defaults
default_dict (dict) – default values for the parameters