opendal
opendal copied to clipboard
feat(bindings/python): add auto-generated api docs
I hereby agree to the terms of the CLA available at: https://databend.rs/dev/policies/cla/
Summary
- Move to mixed Python/Rust project layout to include type hints for
opendal.layers
- Add sphinx-autoapi based API docs
data:image/s3,"s3://crabby-images/c1406/c140608b8397184b22ee467f08653d9079d8d49a" alt="image"
It looks a bit complicated, I think pdoc might be much simpler.
I don't mind switching to pdoc
, though it can't document opendal.layers
yet:
pdoc opendal/
pdoc server ready at http://localhost:8080
Warn: Error parsing type stubs for opendal:
Traceback (most recent call last):
File "/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py", line 105, in include_typeinfo_from_stub_files
imported_stub = _import_stub_file(module.modulename, stub_file)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py", line 40, in _import_stub_file
eval(code, m.__dict__, m.__dict__)
File "opendal/__init__.pyi", line 19, in <module>
from .layers import ConcurrentLimitLayer, ImmutableIndexLayer, RetryLayer
ImportError: attempted relative import with no known parent package
(/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py:107)
And pdoc
doesn't pickup docstrings in .pyi
files with current setup.
data:image/s3,"s3://crabby-images/a7093/a70933e7c50a0557a6b9f9c16d24fa40c05e1f5c" alt="image"
And
pdoc
doesn't pickup docstrings in.pyi
files with current setup.
Related to https://github.com/mitmproxy/pdoc/issues/239?
And
pdoc
doesn't pickup docstrings in.pyi
files with current setup.Related to mitmproxy/pdoc#239?
Probably just need to move docstrings to Rust side.
Just an example #1614
I don't mind switching to
pdoc
, though it can't documentopendal.layers
yet:pdoc opendal/ pdoc server ready at http://localhost:8080 Warn: Error parsing type stubs for opendal: Traceback (most recent call last): File "/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py", line 105, in include_typeinfo_from_stub_files imported_stub = _import_stub_file(module.modulename, stub_file) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py", line 40, in _import_stub_file eval(code, m.__dict__, m.__dict__) File "opendal/__init__.pyi", line 19, in <module> from .layers import ConcurrentLimitLayer, ImmutableIndexLayer, RetryLayer ImportError: attempted relative import with no known parent package (/Users/messense/.pyenv/versions/3.11.0/envs/test-3.11/lib/python3.11/site-packages/pdoc/doc_pyi.py:107)
Can't solve this yet, this boils down to https://github.com/PyO3/pyo3/issues/759 and the workaround doens't work with pdoc
.
I am not satisfied with the current state of the Layers API. Therefore, I am fine if we do not document any API related to layers at this time. Maybe we can setup the Operator
related API first?
We can update here together.
https://github.com/apache/incubator-opendal/blob/27abd5123c14fbc6eb3438197183640744ac47b3/website/docusaurus.config.js#L92-L96
Hello, @messense. I apologize for the broken CI. It has been fixed now. Kindly update your branch and try again.