Commit graph

6 commits

Author SHA1 Message Date
zmike
80b027ef9f add missing cef types from last sync 2015-09-14 16:01:16 -04:00
zmike
5f9aac6c1a update cef interfaces from upstream 2015-09-14 14:02:35 -04:00
Mike Blumenkrantz
6011d39ca1 one more embedding interfaces update because they removed cef_url & time_t 2015-05-06 12:49:32 -04:00
Mike Blumenkrantz
efb2b37185 update embedding interfaces/mod.rs to add MPL 2015-05-06 12:33:14 -04:00
Mike Blumenkrantz
4679fc77b0 update cef embedding interfaces to latest cef 2015-05-05 17:01:53 -04:00
Patrick Walton
3bf779cd21 ports/cef: Use the CEF translator tool to generate the full set of CEF
bindings.

This replaces hand-implemented CEF bindings with proper Rust wrappers
automatically generated from the C++ headers. This means that, whenever
CEF's C++ headers change, we can easily generate both the appropriate C
API and the appropriate Rust API. It eliminates much of the hand-written
unsafe code within the CEF port, because the CEF translator tool now
knows how to generate Rust smart pointer wrappers for each class that
corrently perform reference counting.

Additionally, this commit adds utility macros (located in `macros.rs`)
that make it easier to correctly expose Rust objects as CEF objects.
They handle the marshaling of objects between Rust and CEF properly.
The net result of this is that you can write mostly-natural-looking Rust
in the CEF port and interact with it with a natural-looking C++ API on
the embedding side.

This setup relies on the branch of CEF located here:

    https://github.com/pcwalton/chromium-embedded-framework

To regenerate, follow the instructions in `ports/cef/README.md`. For
convenience, and because I don't anticipate the API to change much, I
have vendored in all of the appropriate interfaces.
2014-11-27 10:31:32 -06:00