Skip to content
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

Nanobind port #9

Open
jiawen opened this issue Sep 5, 2023 · 4 comments
Open

Nanobind port #9

jiawen opened this issue Sep 5, 2023 · 4 comments

Comments

@jiawen
Copy link

jiawen commented Sep 5, 2023

Nanobind looks fairly stable at this point. I recently got nanobind to work with my various Bazel projects and considering doing a port.

Are there any plans to release a nanobind_abseil? If not, I'm happy to take a stab at it in my spare time.

@rwgk
Copy link
Contributor

rwgk commented Sep 6, 2023

How similar are the nanobind type_casters to the pybind11 one? Could we just have the nanobind casters inherit from the pybind11 casters?

If not, to not develop a severe case of copy-pasteritis, we'd need to factor out the guts of the type conversions into core from-python and to-python functions, then hook them into the type_caster frameworks for pybind11 and nanobind.

@jiawen
Copy link
Author

jiawen commented Sep 6, 2023

Interesting perspective. AFAICT, they're identical, except for changing the namespace. But of course there could easily be some odd corners where they differ (in particular, the removal of the holder concept when dealing with smart pointers).

I suppose there's only one way to find out - I will attempt a copy paste and see what happens to the tests.

Re: inheritance - would that not introduce a dependency on pybind11 as well as nanobind? This can easily increase binary size.

@rwgk
Copy link
Contributor

rwgk commented Sep 6, 2023

the removal of the holder concept when dealing with smart pointers).

I don't think there is a connection between type_caster_base and other type_casters in this respect.

This can easily increase binary size.

Duplicating all casters & then having to maintain everything twice is far worse. Of course divergence will appear ~immediately, creating a whack-a-mole game. (The "far worse" aspect is probably not very obvious for a single project in isolation, but I'm working with a gigantic codebase in a mono repo, it's very clear then how much human time is lost when something is copy-pasted like nanobind was.)

Re: inheritance - would that not introduce a dependency on pybind11 as well as nanobind?

Another ~easy solution is to factor our generic casters and inherit in the pybind11::detail and nanobind::detail namespaces.

@Mizux
Copy link
Collaborator

Mizux commented Jan 12, 2024

My 2 cents, Google Benchmark seems to use nanobind...
https://github.com/google/benchmark/tree/main/bindings/python

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants