just wanted to bump this general theme, and connect some extra dots across other AP-software, since any other projects will have to keep compatibility with at least those three:
while I personally like the idea of in-modules docs, my experience with the lib (and a few other alternatives) is not good at all because of 2. mentioned by @rinpatch - it is absolutely true that all such libs will fall behind upstream specs and writing plain openapi.json will always be easier and more powerful option.
Well… I prefer JSON than YAML, format is much simpler and doesn't relies on weird-space indentation that can get hard to review. And we already use JSON a lot anyway, we only use YAML for gitlab-ci (and I have to lint it all the time…).
Some more questions so we can decide on what to use and start working on this
Need to be an Elixir developer to edit it, harming the re-usability by other projects
What other projects are supposed to edit our spec? And can't open-api-spex generate the 'plain' spec files?
Need to wait for/implement a wrapper for new features OpenAPI spec gets
True, but doesn't seem like a big thing.
I just don't like thousand line modules with 800 lines of it being the in-line docs
I suspect this might be your main dislike :) As far a I can see, that's not really necessary, we can have a separate module for these and then defdelegate.
Either way, I'd like to be able to cast and validate params coming in, but I see that you can do the same with plain spec files. Are you opposed to library overall or just to in-module specs? if so, what about in-other-module specs as opposed to plain specs files