Skip to content

kenz-gelsoft/wxRust2

Repository files navigation

wxRust2

This is my 2nd exploration of binding the wxWidgets cross-platform toolkit.

This project is in the very-early stage of the development. I'm playing with this in my very limited spare time. So don't expect this project will be usable (or useful) state in the near future.

Goals (not to resurrect the predecessor for):

  • Smaller footprint by supporting the wx's multilib configuration (in code size), and avoiding Box-ing everything (in calling overhead).
    • I'm not convinced forcing generic programming rather than trait object flexibility, but gtk-rs looks like usable with this choice AFAIK
  • Simpler integration with the Rust ecosystem by utilizing the cc crate rather than CMake and of course, the Cargo.
  • Easier to support new APIs by depending wx directly and generating both Rust and C(++) parts of the binding from the single richer metadata (Doxygen XML output, yes, the proven way by the wxPython Phoenix project).

Current status

Implementing the binding generator to be usable state with a small set of wx classes.

  • Working on
    • #61 Core library coverage
      • generate for all classes in core library
  • Next
    • Other libraries
      • after that, more libraries would be generated
  • Done
    • Investigating modern binding approaches
      • rust-bindgen's C++ support: expected to be the easiest way to binding exising C++ APIs, but it doesn't support some edge cases. especially methods inlined and absent in binary.
      • autocxx: this is for newly(specially) designed API. it supports limited but sane subset of the C++ construct. not suitable for binding an existing API (when I investigated).
      • cxx.rs: this is also for newly designed API, but it allows calling C++ methods handy by generating only the rust API definition and ctor manually.
    • Prototyping handy-binding with cxx.rs
      • minimal effort to generate first some methods bindings, it looks promising then. small part of the API could be generated with this approach.
      • but found I need some hacks and codegen in C++ header/source code to work around cxx.rs limitations to support wider range of API.
    • Codegen without cxx.rs (or rust-bindgen)
    • Lifetime management
      • owned non-wxWindow wxObjects has value semantics (impl Drop to call native dtor)
      • #51 planning to use wxTrackable for WeakRef-like wx managed (non-owned) object
      • doesn't manage wxWindow object for now (almost all of them will be managed by wx's windowing system)
    • Small set of API working
      • compiles and bare simple example runs on macOS, Linux
      • working to compile on Window (fighting with linking error)

How to use

(T.B.D.)

Use vendored wx binary crate

Specify --features vendored to cargo, to use vendored prebuilt wx binary crate. This configuration links to following per-build-target crates by default. You should be able to override this by crate name:

Build target Crate name Git repository Build configuration
cfg(target_os = "macos") wx-universal-apple-darwin https://github.com/ancwrd1/wx-universal-apple-darwin Lean and mean config, see repo.
x86_64-pc-windows-gnu wx-x86_64-pc-windows-gnu https://github.com/ancwrd1/wx-x86_64-pc-windows-gnu Lean and mean config, see repo.
x86_64-pc-windows-msvc wx-x86_64-pc-windows-msvc https://github.com/kenz-gelsoft/wx-x86_64-pc-windows-msvc Bundled wx3.1.7 official build

@ancwrd1 suggested this feature and kindly helped to support this. Thank you!

License

MIT License. but you can (and shoudld) treat this library as wxWindows Library Licence (same with required wxWidgets library dependency).

Large part of this project is the binding generator in Python (doxybindgen). This part may be usable and want to be used for another traditional C++ APIs with Doxygen documented (c.f. like Haiku OS APIs(Kits)) in future. So permissive license is desirable.