Improve magic functions docs (#391)

* Improve documentation of magic functions

* Improve wording for decorators
This commit is contained in:
János Benjamin Antal 2022-05-17 15:33:28 +02:00 committed by GitHub
parent a7f4c98bea
commit 8059a3e653
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 56 additions and 17 deletions

View File

@ -1559,7 +1559,7 @@ enum mgp_error mgp_func_add_opt_arg(struct mgp_func *func, const char *name, str
typedef void (*mgp_func_cb)(struct mgp_list *, struct mgp_func_context *, struct mgp_func_result *, typedef void (*mgp_func_cb)(struct mgp_list *, struct mgp_func_context *, struct mgp_func_result *,
struct mgp_memory *); struct mgp_memory *);
/// Register a Memgraph magic function /// Register a Memgraph magic function.
/// ///
/// The `name` must be a sequence of digits, underscores, lowercase and /// The `name` must be a sequence of digits, underscores, lowercase and
/// uppercase Latin letters. The name must begin with a non-digit character. /// uppercase Latin letters. The name must begin with a non-digit character.

View File

@ -1179,16 +1179,15 @@ def read_proc(func: typing.Callable[..., Record]):
""" """
Register `func` as a read-only procedure of the current module. Register `func` as a read-only procedure of the current module.
`read_proc` is meant to be used as a decorator function to register module The decorator `read_proc` is meant to be used to register module procedures.
procedures. The registered `func` needs to be a callable which optionally The registered `func` needs to be a callable which optionally takes
takes `ProcCtx` as the first argument. Other arguments of `func` will be `ProcCtx` as its first argument. Other arguments of `func` will be bound to
bound to values passed in the cypherQuery. The full signature of `func` values passed in the cypherQuery. The full signature of `func` needs to be
needs to be annotated with types. The return type must be annotated with types. The return type must be `Record(field_name=type, ...)`
`Record(field_name=type, ...)` and the procedure must produce either a and the procedure must produce either a complete Record or None. To mark a
complete Record or None. To mark a field as deprecated, use field as deprecated, use `Record(field_name=Deprecated(type), ...)`.
`Record(field_name=Deprecated(type), ...)`. Multiple records can be Multiple records can be produced by returning an iterable of them.
produced by returning an iterable of them. Registering generator functions Registering generator functions is currently not supported.
is currently not supported.
Example usage. Example usage.
@ -1222,16 +1221,16 @@ def write_proc(func: typing.Callable[..., Record]):
""" """
Register `func` as a writeable procedure of the current module. Register `func` as a writeable procedure of the current module.
`write_proc` is meant to be used as a decorator function to register module The decorator `write_proc` is meant to be used to register module
procedures. The registered `func` needs to be a callable which optionally procedures. The registered `func` needs to be a callable which optionally
takes `ProcCtx` as the first argument. Other arguments of `func` will be takes `ProcCtx` as the first argument. Other arguments of `func` will be
bound to values passed in the cypherQuery. The full signature of `func` bound to values passed in the cypherQuery. The full signature of `func`
needs to be annotated with types. The return type must be needs to be annotated with types. The return type must be
`Record(field_name=type, ...)` and the procedure must produce either a `Record(field_name=type, ...)` and the procedure must produce either a
complete Record or None. To mark a field as deprecated, use complete Record or None. To mark a field as deprecated, use
`Record(field_name=Deprecated(type), ...)`. Multiple records can be `Record(field_name=Deprecated(type), ...)`. Multiple records can be produced
produced by returning an iterable of them. Registering generator functions by returning an iterable of them. Registering generator functions is
is currently not supported. currently not supported.
Example usage. Example usage.
@ -1459,8 +1458,9 @@ def transformation(func: typing.Callable[..., Record]):
class FuncCtx: class FuncCtx:
"""Context of a function being executed. """Context of a function being executed.
Access to a FuncCtx is only valid during a single execution of a transformation. Access to a FuncCtx is only valid during a single execution of a function in
You should not globally store a FuncCtx instance. a query. You should not globally store a FuncCtx instance. The graph object
within the FuncCtx is not mutable.
""" """
__slots__ = "_graph" __slots__ = "_graph"
@ -1475,6 +1475,45 @@ class FuncCtx:
def function(func: typing.Callable): def function(func: typing.Callable):
"""
Register `func` as a user-defined function in the current module.
The decorator `function` is meant to be used to register module functions.
The registered `func` needs to be a callable which optionally takes
`FuncCtx` as its first argument. Other arguments of `func` will be bound to
values passed in the Cypher query. Only the funcion arguments need to be
annotated with types. The return type doesn't need to be specified, but it
has to be supported by `mgp.Any`. Registering generator functions is
currently not supported.
Example usage.
```
import mgp
@mgp.function
def func_example(context: mgp.FuncCtx,
required_arg: str,
optional_arg: mgp.Nullable[str] = None
):
return_args = [required_arg]
if optional_arg is not None:
return_args.append(optional_arg)
# Return any kind of result supported by mgp.Any
return return_args
```
The example function above returns a list of provided arguments:
* `required_arg` is always present and its value is the first argument of
the function.
* `optional_arg` is present if the second argument of the function is not
`null`.
Any errors can be reported by raising an Exception.
The function can be invoked in Cypher using the following calls:
RETURN example.func_example("first argument", "second_argument");
RETURN example.func_example("first argument");
Naturally, you may pass in different arguments.
"""
raise_if_does_not_meet_requirements(func) raise_if_does_not_meet_requirements(func)
register_func = _mgp.Module.add_function register_func = _mgp.Module.add_function
sig = inspect.signature(func) sig = inspect.signature(func)