-
-
Notifications
You must be signed in to change notification settings - Fork 355
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
Experimental clib
from doxygen
#1835
base: main
Are you sure you want to change the base?
Conversation
f37d89b
to
6226766
Compare
6226766
to
4f4d79f
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks Ingmar! I know this is still in draft but I wanted to leave a small comment that might be intrusive later
9f3f308
to
17b2c98
Compare
Also, add README.md for clib_experimental interface
In addition, switch typing information to Python 3.10 standard.
22be9f9
to
a06ec48
Compare
@speth and @bryanwweber ... this is ready for a review.
|
a06ec48
to
97bfa50
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for all this work Ingmar! Nearly all of my comments here are suggestions to improve the type hinting. In some cases, you'll need to add an import (I think just for Iterable
). Obviously these don't affect the runtime, but my thought was that if we're going to have type hints they should at least be complete 😄
Also fix issues caused by differences of doxygen and Cantera whitespace conventions in argument lists and add recipes for functions used in googletests.
97bfa50
to
2350a3d
Compare
Thanks, @bryanwweber, for the prompt review! I agree that having done most of the type hints already, it makes sense to take it all the way. I adopted almost all of the suggestions directly and added some conversions, so the |
739aa5d
to
d48f3e8
Compare
@bryanwweber and @speth ... the PR ready for further comments/reviews. PS: had to fix some unexpected CI failures. / PPS: decided to include support for custom code to be nearly feature-complete. |
639916f
to
0a976c1
Compare
Adding tests to clang-compiler workflow.
0a976c1
to
19ca9a4
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks Ingmar! The Python looks good to me 😄 I'm not that familiar with the overall use case though as I've been out of the loop with these changes, so I assume that it works the way we want and anyways we're early in the 3.2 cycle so we can always fix it 😃
Thanks, @bryanwweber! The overall use case is Cantera/enhancements#39 (specifically, a drop-in replacement for the existing |
code: |- | ||
try { | ||
auto obj = SolutionCabinet::at(handle); | ||
TransportCabinet::del( | ||
TransportCabinet::index(*(obj->transport()), handle)); | ||
obj->setTransportModel(model); | ||
return TransportCabinet::add(obj->transport(), handle); | ||
} catch (...) { | ||
return handleAllExceptions(-2, ERR); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On second thought, the custom code section I added here should be moved from this main configuration file to clib/config.yaml
as it is an implementation detail. This isn't difficult to change, but I'll hold off until there are other review comments.
Changes proposed in this pull request
This PR seeks to implement a basis for future auto-generated Cantera APIs that are fully documented based on information provided in C++ docstrings.
clib
version ("clib-experimental
")clib
scaffolder is based on doxygen tag files and associated XML anchorfilesinterfaces/sourcegen/sourcegen/_data/README.md
)clib
googletests is adopted for illustration and code coverage astest-clib-experimental
clang-compiler
actionThis proof of concept re-implements approaches of the traditional CLib library and is newr feature-complete, although the conversion of
zeroD
andoneD
objects is currently omitted.One other currently omitted feature involves the inclusion of code that is difficult to automate, although it is expected to be rare;in many instances, tweaks to the C++ interface may be the go-to approach instead. Edit: custom code is now supported.The configuration involves YAML markup that only uses minimal information for each entry, e.g.
which produces fully documented declarations
and implementations (click to expand)
Here is an example for a full YAML input used for code generation
sol3_auto.yaml (click to expand)
If applicable, fill in the issue number this pull request is fixing
See Cantera/enhancements#39
Partially addresses Cantera/enhancements#220
If applicable, provide an example illustrating new features this pull request is introducing
Run the following command from the Cantera root folder:
A partial test suite based on the traditional CLib ensures that code performs as expected:
Checklist
scons build
&scons test
) and unit tests address code coverage