Function¤
Function ¤
Function(
*args: Any,
parameters: Parameters | None = None,
returns: str | Expr | None = None,
decorators: list[Decorator] | None = None,
**kwargs: Any,
)
flowchart TD
griffe.Function[Function]
_griffe.models.Object[Object]
_griffe.mixins.ObjectAliasMixin[ObjectAliasMixin]
_griffe.mixins.GetMembersMixin[GetMembersMixin]
_griffe.mixins.SetMembersMixin[SetMembersMixin]
_griffe.mixins.DelMembersMixin[DelMembersMixin]
_griffe.mixins.SerializationMixin[SerializationMixin]
_griffe.models.Object --> griffe.Function
_griffe.mixins.ObjectAliasMixin --> _griffe.models.Object
_griffe.mixins.GetMembersMixin --> _griffe.mixins.ObjectAliasMixin
_griffe.mixins.SetMembersMixin --> _griffe.mixins.ObjectAliasMixin
_griffe.mixins.DelMembersMixin --> _griffe.mixins.ObjectAliasMixin
_griffe.mixins.SerializationMixin --> _griffe.mixins.ObjectAliasMixin
click griffe.Function href "" "griffe.Function"
click _griffe.models.Object href "" "_griffe.models.Object"
click _griffe.mixins.ObjectAliasMixin href "" "_griffe.mixins.ObjectAliasMixin"
click _griffe.mixins.GetMembersMixin href "" "_griffe.mixins.GetMembersMixin"
click _griffe.mixins.SetMembersMixin href "" "_griffe.mixins.SetMembersMixin"
click _griffe.mixins.DelMembersMixin href "" "_griffe.mixins.DelMembersMixin"
click _griffe.mixins.SerializationMixin href "" "_griffe.mixins.SerializationMixin"
The class representing a Python function.
Parameters:
-
*args
¤Any
, default:()
) –See
griffe.Object
. -
parameters
¤Parameters | None
, default:None
) –The function parameters.
-
returns
¤str | Expr | None
, default:None
) –The function return annotation.
-
decorators
¤list[Decorator] | None
, default:None
) –The function decorators, if any.
-
**kwargs
¤Any
, default:{}
) –See
griffe.Object
.
Methods:
-
__bool__
–An object is always true-ish.
-
__delitem__
–Delete a member with its name or path.
-
__getitem__
–Get a member with its name or path.
-
__len__
–The number of members in this object, recursively.
-
__setitem__
–Set a member with its name or path.
-
as_dict
–Return this function's data as a dictionary.
-
as_json
–Return this object's data as a JSON string.
-
del_member
–Delete a member with its name or path.
-
filter_members
–Filter and return members based on predicates.
-
from_json
–Create an instance of this class from a JSON string.
-
get_member
–Get a member with its name or path.
-
has_labels
–Tell if this object has all the given labels.
-
is_kind
–Tell if this object is of the given kind.
-
resolve
–Resolve a name within this object's and parents' scope.
-
set_member
–Set a member with its name or path.
Attributes:
-
aliases
(dict[str, Alias]
) –The aliases pointing to this object.
-
all_members
(dict[str, Object | Alias]
) –All members (declared and inherited).
-
annotation
(str | Expr | None
) –The type annotation of the returned value.
-
attributes
(dict[str, Attribute]
) –The attribute members.
-
canonical_path
(str
) –The full dotted path of this object.
-
classes
(dict[str, Class]
) –The class members.
-
decorators
(list[Decorator]
) –The function decorators.
-
deprecated
(bool | str | None
) –Whether this object is deprecated (boolean or deprecation message).
-
docstring
(Docstring | None
) –The object docstring.
-
endlineno
(int | None
) –The ending line number of the object.
-
exports
(set[str] | list[str | ExprName] | None
) –The names of the objects exported by this (module) object through the
__all__
variable. -
extra
(dict[str, dict[str, Any]]
) –Namespaced dictionaries storing extra metadata for this object, used by extensions.
-
filepath
(Path | list[Path]
) –The file path (or directory list for namespace packages) where this object was defined.
-
functions
(dict[str, Function]
) –The function members.
-
has_docstring
(bool
) –Whether this object has a docstring (empty or not).
-
has_docstrings
(bool
) –Whether this object or any of its members has a docstring (empty or not).
-
imports
(dict[str, str]
) –The other objects imported by this object.
-
inherited
(bool
) –Always false for objects.
-
inherited_members
(dict[str, Alias]
) –Members that are inherited from base classes.
-
is_alias
(bool
) –Always false for objects.
-
is_attribute
(bool
) –Whether this object is an attribute.
-
is_class
(bool
) –Whether this object is a class.
-
is_class_private
(bool
) –Whether this object/alias is class-private (starts with
__
and is a class member). -
is_collection
(bool
) –Always false for objects.
-
is_deprecated
(bool
) –Whether this object is deprecated.
-
is_exported
(bool
) –Whether this object/alias is exported (listed in
__all__
). -
is_function
(bool
) –Whether this object is a function.
-
is_imported
(bool
) –Whether this object/alias was imported from another module.
-
is_init_module
(bool
) –Whether this object is an
__init__.py
module. -
is_module
(bool
) –Whether this object is a module.
-
is_namespace_package
(bool
) –Whether this object is a namespace package (top folder, no
__init__.py
). -
is_namespace_subpackage
(bool
) –Whether this object is a namespace subpackage.
-
is_package
(bool
) –Whether this object is a package (top module).
-
is_private
(bool
) –Whether this object/alias is private (starts with
_
) but not special. -
is_public
(bool
) –Whether this object is considered public.
-
is_special
(bool
) –Whether this object/alias is special ("dunder" attribute/method, starts and end with
__
). -
is_subpackage
(bool
) –Whether this object is a subpackage.
-
is_wildcard_exposed
(bool
) –Whether this object/alias is exposed to wildcard imports.
-
kind
–The object kind.
-
labels
(set[str]
) –The object labels (
property
,dataclass
, etc.). -
lineno
(int | None
) –The starting line number of the object.
-
lines
(list[str]
) –The lines containing the source of this object.
-
lines_collection
(LinesCollection
) –The lines collection attached to this object or its parents.
-
members
(dict[str, Object | Alias]
) –The object members (modules, classes, functions, attributes).
-
module
(Module
) –The parent module of this object.
-
modules
(dict[str, Module]
) –The module members.
-
modules_collection
(ModulesCollection
) –The modules collection attached to this object or its parents.
-
name
(str
) –The object name.
-
overloads
(list[Function] | None
) –The overloaded signatures of this function.
-
package
(Module
) –The absolute top module (the package) of this object.
-
parameters
(Parameters
) –The function parameters.
-
parent
(Module | Class | None
) –The parent of the object (none if top module).
-
path
(str
) –The dotted path of this object.
-
public
(bool | None
) –Whether this object is public.
-
relative_filepath
(Path
) –The file path where this object was defined, relative to the current working directory.
-
relative_package_filepath
(Path
) –The file path where this object was defined, relative to the top module path.
-
returns
(str | Expr | None
) –The function return type annotation.
-
runtime
(bool
) –Whether this object is available at runtime.
-
source
(str
) –The source code of this object.
all_members property
¤
All members (declared and inherited).
This method is part of the consumer API: do not use when producing Griffe trees!
attributes property
¤
The attribute members.
This method is part of the consumer API: do not use when producing Griffe trees!
canonical_path property
¤
canonical_path: str
The full dotted path of this object.
The canonical path is the path where the object was defined (not imported).
See also: path
.
classes property
¤
The class members.
This method is part of the consumer API: do not use when producing Griffe trees!
decorators instance-attribute
¤
decorators: list[Decorator] = decorators or []
The function decorators.
deprecated instance-attribute
¤
Whether this object is deprecated (boolean or deprecation message).
docstring instance-attribute
¤
The object docstring.
See also: has_docstring
, has_docstrings
.
exports instance-attribute
¤
The names of the objects exported by this (module) object through the __all__
variable.
Exports can contain string (object names) or resolvable names, like other lists of exports coming from submodules:
from .submodule import __all__ as submodule_all
__all__ = ["hello", *submodule_all]
Exports get expanded by the loader before it expands wildcards and resolves aliases.
See also: GriffeLoader.expand_exports
.
extra instance-attribute
¤
Namespaced dictionaries storing extra metadata for this object, used by extensions.
filepath property
¤
The file path (or directory list for namespace packages) where this object was defined.
See also: relative_filepath
, relative_package_filepath
.
Examples:
>>> import griffe
>>> markdown = griffe.load("markdown")
>>> markdown.filepath
PosixPath('~/project/.venv/lib/python3.11/site-packages/markdown/__init__.py')
functions property
¤
The function members.
This method is part of the consumer API: do not use when producing Griffe trees!
has_docstring property
¤
has_docstring: bool
Whether this object has a docstring (empty or not).
See also: docstring
, has_docstrings
.
has_docstrings property
¤
has_docstrings: bool
Whether this object or any of its members has a docstring (empty or not).
Inherited members are not considered. Imported members are not considered, unless they are also public.
See also: docstring
, has_docstring
.
imports instance-attribute
¤
The other objects imported by this object.
Keys are the names within the object (from ... import ... as AS_NAME
), while the values are the actual names of the objects (from ... import REAL_NAME as ...
).
inherited class-attribute
instance-attribute
¤
inherited: bool = False
Always false for objects.
Only aliases can be marked as inherited.
inherited_members property
¤
Members that are inherited from base classes.
This method is part of the consumer API: do not use when producing Griffe trees!
See also: members
.
is_attribute property
¤
is_attribute: bool
Whether this object is an attribute.
See also: is_module
. is_class
, is_function
, is_alias
, is_kind
.
is_class property
¤
is_class: bool
Whether this object is a class.
See also: is_module
. is_function
, is_attribute
, is_alias
, is_kind
.
is_class_private property
¤
is_class_private: bool
Whether this object/alias is class-private (starts with __
and is a class member).
is_collection class-attribute
instance-attribute
¤
is_collection: bool = False
Always false for objects.
is_function property
¤
is_function: bool
Whether this object is a function.
See also: is_module
. is_class
, is_attribute
, is_alias
, is_kind
.
is_imported property
¤
is_imported: bool
Whether this object/alias was imported from another module.
is_init_module property
¤
is_init_module: bool
Whether this object is an __init__.py
module.
See also: is_module
.
is_module property
¤
is_module: bool
Whether this object is a module.
See also: is_init_module
. is_class
, is_function
, is_attribute
, is_alias
, is_kind
.
is_namespace_package property
¤
is_namespace_package: bool
Whether this object is a namespace package (top folder, no __init__.py
).
See also: is_namespace_subpackage
.
is_namespace_subpackage property
¤
is_namespace_subpackage: bool
Whether this object is a namespace subpackage.
See also: is_namespace_package
.
is_package property
¤
is_package: bool
Whether this object is a package (top module).
See also: is_subpackage
.
is_private property
¤
is_private: bool
Whether this object/alias is private (starts with _
) but not special.
is_public property
¤
is_public: bool
Whether this object is considered public.
In modules, developers can mark objects as public thanks to the __all__
variable. In classes however, there is no convention or standard to do so.
Therefore, to decide whether an object is public, we follow this algorithm:
- If the object's
public
attribute is set (boolean), return its value. - If the object is listed in its parent's (a module)
__all__
attribute, it is public. - If the parent (module) defines
__all__
and the object is not listed in, it is private. - If the object has a private name, it is private.
- If the object was imported from another module, it is private.
- Otherwise, the object is public.
is_special property
¤
is_special: bool
Whether this object/alias is special ("dunder" attribute/method, starts and end with __
).
is_subpackage property
¤
is_subpackage: bool
Whether this object is a subpackage.
See also: is_package
.
is_wildcard_exposed property
¤
is_wildcard_exposed: bool
Whether this object/alias is exposed to wildcard imports.
To be exposed to wildcard imports, an object/alias must:
- be available at runtime
- have a module as parent
- be listed in
__all__
if__all__
is defined - or not be private (having a name starting with an underscore)
Special case for Griffe trees: a submodule is only exposed if its parent imports it.
Returns:
-
bool
–True or False.
labels instance-attribute
¤
The object labels (property
, dataclass
, etc.).
See also: has_labels
.
lines property
¤
The lines containing the source of this object.
See also: lines_collection
, source
.
lines_collection property
¤
lines_collection: LinesCollection
The lines collection attached to this object or its parents.
Raises:
-
ValueError
–When no modules collection can be found in the object or its parents.
members instance-attribute
¤
The object members (modules, classes, functions, attributes).
See also: inherited_members
, get_member
, set_member
, filter_members
.
module property
¤
module: Module
The parent module of this object.
See also: package
.
Examples:
>>> import griffe
>>> markdown = griffe.load("markdown")
>>> markdown["core.Markdown.references"].module
Module(PosixPath('~/project/.venv/lib/python3.11/site-packages/markdown/core.py'))
>>> # The `module` of a module is itself.
>>> markdown["core"].module
Module(PosixPath('~/project/.venv/lib/python3.11/site-packages/markdown/core.py'))
Raises:
-
ValueError
–When the object is not a module and does not have a parent.
modules property
¤
The module members.
This method is part of the consumer API: do not use when producing Griffe trees!
modules_collection property
¤
modules_collection: ModulesCollection
The modules collection attached to this object or its parents.
Raises:
-
ValueError
–When no modules collection can be found in the object or its parents.
overloads instance-attribute
¤
The overloaded signatures of this function.
package property
¤
package: Module
The absolute top module (the package) of this object.
See also: module
.
Examples:
>>> import griffe
>>> markdown = griffe.load("markdown")
>>> markdown["core.Markdown.references"].package
Module(PosixPath('~/project/.venv/lib/python3.11/site-packages/markdown/__init__.py'))
parameters instance-attribute
¤
parameters: Parameters = parameters or Parameters()
The function parameters.
parent instance-attribute
¤
The parent of the object (none if top module).
path property
¤
path: str
The dotted path of this object.
On regular objects (not aliases), the path is the canonical path.
See also: canonical_path
.
Examples:
>>> import griffe
>>> markdown = griffe.load("markdown")
>>> markdown["core.Markdown.references"].path
'markdown.core.Markdown.references'
relative_filepath property
¤
relative_filepath: Path
The file path where this object was defined, relative to the current working directory.
If this object's file path is not relative to the current working directory, return its absolute path.
See also: filepath
, relative_package_filepath
.
Raises:
-
ValueError
–When the relative path could not be computed.
relative_package_filepath property
¤
relative_package_filepath: Path
The file path where this object was defined, relative to the top module path.
See also: filepath
, relative_filepath
.
Raises:
-
ValueError
–When the relative path could not be computed.
returns instance-attribute
¤
The function return type annotation.
runtime instance-attribute
¤
Whether this object is available at runtime.
Typically, type-guarded objects (under an if TYPE_CHECKING
condition) are not available at runtime.
__delitem__ ¤
Delete a member with its name or path.
This method is part of the consumer API: do not use when producing Griffe trees!
Members will be looked up in both declared members and inherited ones, triggering computation of the latter.
Parameters:
Examples:
>>> del griffe_object["foo"]
>>> del griffe_object["path.to.bar"]
>>> del griffe_object[("path", "to", "qux")]
__getitem__ ¤
Get a member with its name or path.
This method is part of the consumer API: do not use when producing Griffe trees!
Members will be looked up in both declared members and inherited ones, triggering computation of the latter.
Parameters:
Examples:
>>> foo = griffe_object["foo"]
>>> bar = griffe_object["path.to.bar"]
>>> qux = griffe_object[("path", "to", "qux")]
__setitem__ ¤
Set a member with its name or path.
This method is part of the consumer API: do not use when producing Griffe trees!
Parameters:
-
key
¤str | Sequence[str]
) –The name or path of the member.
-
value
¤Object | Alias
) –The member.
Examples:
>>> griffe_object["foo"] = foo
>>> griffe_object["path.to.bar"] = bar
>>> griffe_object[("path", "to", "qux")] = qux
as_dict ¤
as_json ¤
del_member ¤
Delete a member with its name or path.
This method is part of the producer API: you can use it safely while building Griffe trees (for example in Griffe extensions).
Members will be looked up in declared members only, not inherited ones.
Parameters:
Examples:
>>> griffe_object.del_member("foo")
>>> griffe_object.del_member("path.to.bar")
>>> griffe_object.del_member(("path", "to", "qux"))
filter_members ¤
from_json classmethod
¤
from_json(json_string: str, **kwargs: Any) -> _ObjType
Create an instance of this class from a JSON string.
Parameters:
-
json_string
¤str
) –JSON to decode into Object.
-
**kwargs
¤Any
, default:{}
) –Additional options passed to decoder.
Returns:
-
_ObjType
–An Object instance.
Raises:
-
TypeError
–When the json_string does not represent and object of the class from which this classmethod has been called.
get_member ¤
Get a member with its name or path.
This method is part of the producer API: you can use it safely while building Griffe trees (for example in Griffe extensions).
Members will be looked up in declared members only, not inherited ones.
Parameters:
Examples:
>>> foo = griffe_object["foo"]
>>> bar = griffe_object["path.to.bar"]
>>> bar = griffe_object[("path", "to", "bar")]
has_labels ¤
is_kind ¤
Tell if this object is of the given kind.
See also: is_module
, is_class
, is_function
, is_attribute
, is_alias
.
Parameters:
Raises:
-
ValueError
–When an empty set is given as argument.
Returns:
-
bool
–True or False.
resolve ¤
Resolve a name within this object's and parents' scope.
Parameters:
Raises:
-
NameResolutionError
–When the name could not be resolved.
Returns:
-
str
–The resolved name.
set_member ¤
Set a member with its name or path.
This method is part of the producer API: you can use it safely while building Griffe trees (for example in Griffe extensions).
Parameters:
-
key
¤str | Sequence[str]
) –The name or path of the member.
-
value
¤Object | Alias
) –The member.
Examples:
>>> griffe_object.set_member("foo", foo)
>>> griffe_object.set_member("path.to.bar", bar)
>>> griffe_object.set_member(("path", "to", "qux"), qux)
Parameters ¤
Parameters(*parameters: Parameter)
This class is a container for parameters.
It allows to get parameters using their position (index) or their name:
>>> parameters = Parameters(Parameter("hello"))
>>> parameters[0] is parameters["hello"]
True
See also: Parameter
.
Parameters:
Methods:
-
__contains__
–Whether a parameter with the given name is present.
-
__delitem__
–Delete a parameter by index or name.
-
__getitem__
–Get a parameter by index or name.
-
__iter__
–Iterate over the parameters, in order.
-
__len__
–The number of parameters.
-
__setitem__
–Set a parameter by index or name.
-
add
–Add a parameter to the container.
__setitem__ ¤
Set a parameter by index or name.
Parameter ¤
Parameter(
name: str,
*,
annotation: str | Expr | None = None,
kind: ParameterKind | None = None,
default: str | Expr | None = None,
docstring: Docstring | None = None
)
This class represent a function parameter.
See also: Parameters
.
Parameters:
-
name
¤str
) –The parameter name, without leading stars (
*
or**
). -
annotation
¤str | Expr | None
, default:None
) –The parameter annotation, if any.
-
kind
¤ParameterKind | None
, default:None
) –The parameter kind.
-
default
¤str | Expr | None
, default:None
) –The parameter default, if any.
-
docstring
¤Docstring | None
, default:None
) –The parameter docstring.
Methods:
-
__eq__
–Parameters are equal if all their attributes except
docstring
andfunction
are equal. -
as_dict
–Return this parameter's data as a dictionary.
Attributes:
-
annotation
(str | Expr | None
) –The parameter type annotation.
-
default
(str | Expr | None
) –The parameter default value.
-
docstring
(Docstring | None
) –The parameter docstring.
-
function
(Function | None
) –The parent function of the parameter.
-
kind
(ParameterKind | None
) –The parameter kind.
-
name
(str
) –The parameter name.
-
required
(bool
) –Whether this parameter is required.
annotation instance-attribute
¤
annotation: str | Expr | None = annotation
The parameter type annotation.
function instance-attribute
¤
function: Function | None = None
The parent function of the parameter.
__eq__ ¤
Parameters are equal if all their attributes except docstring
and function
are equal.
ParameterKind ¤
flowchart TD
griffe.ParameterKind[ParameterKind]
click griffe.ParameterKind href "" "griffe.ParameterKind"
Enumeration of the different parameter kinds.
Attributes:
-
keyword_only
–Keyword-only parameter.
-
positional_only
–Positional-only parameter.
-
positional_or_keyword
–Positional or keyword parameter.
-
var_keyword
–Variadic keyword parameter.
-
var_positional
–Variadic positional parameter.
keyword_only class-attribute
instance-attribute
¤
keyword_only = 'keyword-only'
Keyword-only parameter.
positional_only class-attribute
instance-attribute
¤
positional_only = 'positional-only'
Positional-only parameter.
positional_or_keyword class-attribute
instance-attribute
¤
positional_or_keyword = 'positional or keyword'
Positional or keyword parameter.
var_keyword class-attribute
instance-attribute
¤
var_keyword = 'variadic keyword'
Variadic keyword parameter.
var_positional class-attribute
instance-attribute
¤
var_positional = 'variadic positional'
Variadic positional parameter.
ParametersType module-attribute
¤
Type alias for the list of parameters of a function.
Decorator ¤
This class represents decorators.
Parameters:
-
value
¤str | Expr
) –The decorator code.
-
lineno
¤int | None
) –The starting line number.
-
endlineno
¤int | None
) –The ending line number.
Methods:
-
as_dict
–Return this decorator's data as a dictionary.
Attributes: