项目作者: AldaronLau

项目描述 :
The easiest, simplest and safest way to load dynamic (shared object) libraries from Rust!
高级语言: Rust
项目地址: git://github.com/AldaronLau/dl_api.git
创建时间: 2018-06-01T05:20:47Z
项目社区:https://github.com/AldaronLau/dl_api

开源协议:Other

下载


" class="reference-link">DL API

The easiest, simplest and safest way to load dynamic (shared object) libraries from Rust!

Build Status
Docs
crates.io

  • Macro to create a structure that dynamically loads a C API
  • Works on Linux (and probably other unix) and Windows

Roadmap to 1.0 (Future Features)

  • Make it easier to load parts of API at any time (modular loading from same .so
    file).
  • Support some other obscure OS’s.
  • Different loading macro for Rust ABI / other ABIS (possible ABI parameter to
    the macro?)
  • Make sure it’s perfect.

Table of Contents

Getting Started

Add the following to your Cargo.toml.

  1. [dependencies]
  2. dl_api = "0.4"

Example

The code inside of the curly braces for link!() matches exactly with code
inside of the curly braces for extern "C". This makes it easy for you to turn
your extern "C"s into link!()s.

  1. // Shared object: either "libmylibrary.so.1", "mylibrary-1.dll" or "libMyLibrary.dylib"
  2. dl_api::link!(MyApi, "libmylibrary.so.1", {
  3. fn cFunction(param_name: ParamType) -> ReturnType;
  4. });
  5. fn main() {
  6. let api = MyApi::new().unwrap(); // unwrap the `Result`.
  7. let rtn: ReturnType = unsafe {
  8. (api.cFunction)(0);
  9. };
  10. }

API

API documentation can be found on docs.rs.

Features

There are no optional features.

Upgrade

You can use the
changelog
to facilitate upgrading this crate as a dependency.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.

Contributors are always welcome (thank you for being interested!), whether it
be a bug report, bug fix, feature request, feature implementation or whatever.
Don’t be shy about getting involved. I always make time to fix bugs, so usually
a patched version of the library will be out a few days after a report.
Features requests will not complete as fast. If you have any questions, design
critques, or want me to find you something to work on based on your skill level,
you can email me at jeronlau@plopgrizzly.com.
Otherwise,
here’s a link to the issues on GitHub.
Before contributing, check out the
contribution guidelines,
and, as always, make sure to follow the
code of conduct.