<div dir="ltr">Hi Kieran,<br><br>On Mon, 21 Nov 2022 at 17:58, Kieran Bingham <<a href="mailto:kieran.bingham@ideasonboard.com">kieran.bingham@ideasonboard.com</a>> wrote:<br>><br>> Hi Jurgis,<br>><br>> Quoting Jurgis Balciunas via libcamera-devel (2022-11-21 15:27:14)<br>> > Hello everyone,<br>><br>> Welcome to libcamera. And thanks for diving in!<br><br>Thanks!<br><br>> > I'm not used to mailing lists and patchwork process so pardon me if I'm<br>> > writing this at the wrong place.<br>><br>> Entirely correct, don't worry.<br>><br>> > I've been working on Rust bindings for the libcamera and wanted to let<br>> > everyone know in case someone would be interested. So far I've gotten as<br>> > far as capturing JPEG image from webcam entirely in safe Rust and I think<br>> > this already covers ~70% of libcamera API. The wrapper library is currently<br>><br>>  \o/<br>><br>> > published at <a href="https://github.com/lit-robotics/libcamera-rs">https://github.com/lit-robotics/libcamera-rs</a>. It consists of 2<br>> > main parts: libcamera-sys, which contains raw unsafe bindings to libcamera<br>> > and libcamera-rs, which implements a higher-level memory-safe API on top of<br>> > libcamera-sys.<br>> ><br>> > The most difficult part was C++ not being FFI friendly and most of the<br>> > automatic binding generation tools break with complex C++ codebases,<br>> > especially when templates are used. So instead I've written a thin C<br>> > wrapper around libcamera (under libcamera-sys/c_api<br>> > <<a href="https://github.com/lit-robotics/libcamera-rs/tree/main/libcamera-sys/c_api">https://github.com/lit-robotics/libcamera-rs/tree/main/libcamera-sys/c_api</a>>),<br>> > which was used to autogenerate libcamera-sys. We had a discussion in<br>> > <a href="https://github.com/kbingham/libcamera/issues/58">https://github.com/kbingham/libcamera/issues/58</a> that this C wrapper could<br>> > be useful not only for Rust bindings, but I'm personally not sure about any<br>> > uses outside FFI? If it were a part of libcamera, the difficult part would<br>><br>> C-bindings will be useful else where indeed. Either for other language<br>> bindings, (Anyone going to work on Go next ?) or just to expose a direct<br>> C api.<br>><br>> > be maintaining documentation as the C API does not map 1:1 with C++,<br>> > especially anything related to STL containers.<br>><br>> Yes, we'll have to figure out how to document the C API potentially<br>> alongside the C++ API.<br>><br>> Ideally, we'd continue our doxygen integration there.<br>><br>><br>> > Anyway, there is quite a lot to these bindings (~5k LoC excluding the<br>> > auto-generated stuff) and too many design decisions to explain in this<br>> > introductory email. I'm happy to answer any questions instead.<br>><br>> Well the next questions will be - what should our next steps be to<br>> getting your work integrated.<br>><br>> Ideally, we would like contributors to have read:<br>>  - <a href="https://libcamera.org/contributing.html">https://libcamera.org/contributing.html</a><br>>  - <a href="https://libcamera.org/coding-style.html#coding-style-guidelines">https://libcamera.org/coding-style.html#coding-style-guidelines</a><br>><br>> and have the checkstyle hooks added to their repository:<br>>  cp utils/hooks/post-commit .git/hooks/post-commit<br>><br>> And have clean commits that we can review on list. I anticipate getting<br>> the full c-bindings merged may be a fair bit of work - so do let us know<br>> if there's anything that we can do to help or support you.<br><br>I'm not sure what the best way to move c-bindings forward would be. I don't have much experience with either Go or "idiomatic" C to judge if an API is well-written. Ideally, I would have someone else interested in this matter to take on the C bindings, while I would mostly focus on Rust.<div><br></div><div>Since it's still very early in the inception and there is a lot of trial and error involved, I don't think that patch process would work now. It needs to reach an MVP stage first. Maybe a separate repository or a branch would be appropriate for this?<br><div><br>><br>> I would anticpate that the rust bindings would live in the libcamera<br>> repostiory as well as the c-bindings. Is that how other rust projects<br>> work?<br>><br>> Are you happy for this work to live in the libcamera upstream<br>> repositories? If it's upstream we can expect to maintain it and validate<br>> it against any ABI/API changes. I might need some help setting up extra<br>> automation and testing to make sure the rust bindings are functional...<br>> (I've got extremely little rust experience).<br><br>I think this might be a problem, because rust has no mechanism to discover locally available packages. The official way is to publish on <a href="http://crates.io">crates.io</a> package repository and match the bindings semver to the target library semver. This is unfortunate for libraries that don't have a stable semver yet, like libcamera. Since rust is mostly statically linked, a lot of projects have a build script which pulls in the library source and builds it. This works for simple libraries with few dependencies, but I don't think it would work with libcamera, which requires multiple libraries and build tools. Until libcamera has a stable semver release, I think the only way is to use git dependencies with the matching libcamera revision hash.</div><div><br></div><div>I have no issue with moving this to the upstream repositories. Although I'm not sure if it should be included in the main repository, since it can't be distributed together with libcamera. From what I observed, most of the Rust bindings usually live in a separate official repository (i.e. <a href="https://gitlab.freedesktop.org/gstreamer/gstreamer-rs">https://gitlab.freedesktop.org/gstreamer/gstreamer-rs</a>)</div><div><br></div><div>><br>> --<br>> Kieran<br>><br>><br>> ><br>> > Regards,<br>> > Jurgis</div></div></div>