- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.2k
feat(types): rework of arg/return type hints to support .noconvert() #5486
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
Conversation
| Checks using C++11 fail because I used auto return type deduction which is only supported since C++14. | 
| This PR is now feature complete. @rwgk it would be nice if you could review this, if you have time, since you helped with reviewing #5450. :) @InvincibleRMC if this gets accepted, I would like to refresh your PR #5212. io_name(
    "Annotated[np.typing.ArrayLike, \"Shape[5, 6]\"]", // type hint for args with convert=true
    "Annotated[np.typing.NDArray[np.float32], \"Shape[5, 6], flags.writeable, flags.f_contiguous\"]" // type hint for return or args with convert=false
)The specifics could be discussed later, but having correct typing for arg/return and noconvert would be great. | 
| I have added tests and a fix for  | 
| Sorry this PR pushes the complexity of the type hint code beyond what I can meaningfully review. I don't have the free bandwidth; these changes are very far removed from my current job-role-related interests. @wjakob could you maybe take a look? IIUC this PR more-or-less backports the nanobind  | 
| No problem, thanks for forwarding! Yes, it is a backport of the  
 | 
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.
It looks like it changes the way you'd set these, but I don't see usages of it in the wild, so I think it's fine and a better API.
| Thanks! | 
Description
While working on improving type hints for Eigen/numpy, I found that with the current solution from #5450 it is not possible to have the type hints be influenced by the
py::arg().noconvert()option.Certain Eigen types offer to be loaded from anything
np.array()accepts which would fit tonp.typing.ArrayLike.With
.noconvert()however, only instances of numpy arrays are accepted, which would fitnp.typing.NDArray[<dtype>].It would be nice if
.noconvert()would force using the return type (which is the more specific type).Meanwhile, I found that nanobind implements a similar arg/return type hint system using
io_name.This system inserts
@arg-type@return-type@using@as a special character, which is evaluated in a later signature parsing stage.At this stage, the
.noconvert()info is available, and I was able to implement it similarly.Additionally, I added
arg_descrandreturn_descrto force using arg or return type hints.This is useful for correctly type hinting
typing::Callable.The current implementation in this PR does not allow nested Callables (e.g., Callable that has a Callable as argument), but I will add support for that later this week (requires using a stack container to track nested
arg_descr/return_descr).(See 077d0b6)
Finally, I found bugs when using
typing::Literalwith certain special characters:Currently,
%,{,}fail withImportError: Internal error while parsing type signature (2).With this PR, the added special character
@fails as well when used in a Literal.I will try to find a solution for that later this week as well.
(See 9877aca)
This also fixes #5477 by using
pathlib.Pathinstead ofPath.(See 9d0766c)
Suggested changelog entry:
Rework of arg/return type hints to support ``.noconvert()``Open issues:
arg_descr/return_descrdo not work (require tracking using a Stack)typing.Literalfail (%,{,},@)Relevant nanobind code
This PR is based on the following code in nanobind:
https://github.com/wjakob/nanobind/blob/698f449a207e321b364278ff68f0b161127fd3a0/include/nanobind/nb_descr.h#L81-L86
https://github.com/wjakob/nanobind/blob/698f449a207e321b364278ff68f0b161127fd3a0/src/nb_func.cpp#L1018-L1234