diff --git a/docs/posts/2024/2024-11-10-python-adding-version-info-to-docstrings.md b/docs/posts/2024/2024-11-10-python-adding-version-info-to-docstrings.md new file mode 100644 index 00000000..a65724aa --- /dev/null +++ b/docs/posts/2024/2024-11-10-python-adding-version-info-to-docstrings.md @@ -0,0 +1,61 @@ +--- +authors: +- copdips +categories: +- python +comments: true +date: + created: 2024-11-10 +--- + +# Python adding version info to docstrings + +When checking PySpark's source code, find a nice way it uses to add version information to docstrings by decorators. Here is an example: + + + +```python title="decorator since defined in pypsark.since" +# https://github.com/apache/spark/blob/5d757993f4cfcd859eb11640d210a560d6136465/python/pyspark/__init__.py#L81-L97 + +_F = TypeVar("_F", bound=Callable) + +def since(version: Union[str, float]) -> Callable[[_F], _F]: + """ + A decorator that annotates a function to append the version of Spark the function was added. + """ + import re + + indent_p = re.compile(r"\n( +)") + + def deco(f: _F) -> _F: + assert f.__doc__ is not None + + indents = indent_p.findall(f.__doc__) + indent = " " * (min(len(m) for m in indents) if indents else 0) + f.__doc__ = f.__doc__.rstrip() + "\n\n%s.. versionadded:: %s" % (indent, version) + return f + + return deco +``` + +```python title="usage of since decorator in delta.tables" +# https://github.com/apache/spark/blob/5d757993f4cfcd859eb11640d210a560d6136465/python/pyspark/ml/tuning.py#L191-L205 + +@since("1.4.0") +def build(self) -> List["ParamMap"]: + """ + Builds and returns all combinations of parameters specified + by the param grid. + """ +``` + +This will generate the following docstring for the `build` method when using `help(build)` in the Python REPL: + +```python +""" +Builds and returns all combinations of parameters specified +by the param grid. + +.. versionadded:: 1.4.0 +""" +```