-
-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bug: Pydantic dataclasses with extra args break parsing of the function signature #303
Comments
Hi @Vodes, thanks for the report. For future reference and ease of reading, could you add a snippet showing your Pydantic dataclass declaration? |
Yeah no problem. The class that is also used in the screenshots is defined right here. |
Thanks, let me update the issue body with these. |
I suppose we will have to somehow duplicate the code of our built-in |
So I understand, this is out of scope for griffe without the extension? I'm not really interested in pydantic stuff outside of the dataclass and I only really care about the actual attributes being presented properly. |
Yep, what we incorporate in Griffe is support for the standard lib and the Python language itself. Dataclasses, even though standard, are a bit special (and quite hard to handle statically) so they are supported through a built-in extension. Pydantic models and dataclasses are third-party, so they are handled through an external extension. If you don't want to become a sponsor 😜 and rely on the Pydantic extension, you could try to force dynamic analysis on such dataclasses (which could help for the issue here). I'll add an example on how to do that in the docs 🙂 |
Hey so I just noticed that there were some docs related commits lately but would you mind pointing me in the right direction of what I should enable to make this work? |
I didn't want to bump this but I assume now that the extension is public this isn't really a concern anymore. Feel free to close if so. |
Sorry, missed your previous reply. By the way, feel free to ping me if I don't answer in the future (that's what my GitHub status say 😄!). The griffe-pydantic extension just became public indeed (thanks to my awesome sponsors 🚀), but it doesn't have any kind of support for Pydantic's dataclasses yet, so I believe we can keep this open. |
Description of the bug
Griffe fails to parse the class init signature for pydantic dataclasses that allow extra kwargs.
The result is missing types in the documentation and everything marked as required.
To Reproduce
Install the package with the
dynamic-dataclasses
branch.pip install git+https://github.com/Jaded-Encoding-Thaumaturgy/muxtools.git@dynamic-dataclasses
And then either use the docs repo itself like
http://localhost:8000/muxtools/audio/encoders/ will then show the issue.
or just use a blanket docs setup that just embeds the encoders file like this
Full traceback
Full traceback
Expected behavior
Properly parse types in the signature.
Using a vanilla python dataclass results in the wanted behavior.
Environment information
Boost priority
The text was updated successfully, but these errors were encountered: