#shared #shared-memory #api-bindings #dlopen #load #dylib #memory-safe

libloading

Bindings around the platform's dynamic library loading primitives with greatly improved memory safety

35 releases

Uses old Rust 2015

0.8.5 Jul 20, 2024
0.8.3 Mar 5, 2024
0.8.1 Sep 30, 2023
0.8.0 Apr 11, 2023
0.2.0 Nov 8, 2015

#8 in Operating systems

Download history 1529549/week @ 2024-08-01 1699845/week @ 2024-08-08 1690609/week @ 2024-08-15 1783893/week @ 2024-08-22 1597823/week @ 2024-08-29 1724814/week @ 2024-09-05 1600105/week @ 2024-09-12 1597239/week @ 2024-09-19 2005678/week @ 2024-09-26 2464611/week @ 2024-10-03 2638151/week @ 2024-10-10 2012876/week @ 2024-10-17 1518368/week @ 2024-10-24 1551131/week @ 2024-10-31 1576918/week @ 2024-11-07 1449318/week @ 2024-11-14

6,368,101 downloads per month
Used in 7,415 crates (513 directly)

ISC license

95KB
972 lines

Contains (Windows DLL, 4KB) tests/nagisa32.dll, (Windows DLL, 3KB) tests/nagisa64.dll

libloading

Bindings around the platform's dynamic library loading primitives with greatly improved memory safety. The most important safety guarantee of this library is the prevention of dangling Symbols that may occur after a Library is unloaded.

Using this library allows the loading of dynamic libraries, also known as shared libraries, as well as the use of the functions and static variables that these libraries may contain.

libloading is available to use under ISC (MIT-like) license.


lib.rs:

Bindings around the platform's dynamic library loading primitives with greatly improved memory safety.

Using this library allows the loading of dynamic libraries, also known as shared libraries, and the use of the functions and static variables they contain.

The libloading crate exposes a cross-platform interface to load a library and make use of its contents, but little is done to hide the differences in behaviour between platforms. The API documentation strives to document such differences as much as possible.

Platform-specific APIs are also available in the os module. These APIs are more flexible, but less safe.

Installation

Add the libloading library to your dependencies in Cargo.toml:

[dependencies]
libloading = "0.8"

Usage

In your code, run the following:

fn call_dynamic() -> Result<u32, Box<dyn std::error::Error>> {
    unsafe {
        let lib = libloading::Library::new("/path/to/liblibrary.so")?;
        let func: libloading::Symbol<unsafe extern fn() -> u32> = lib.get(b"my_func")?;
        Ok(func())
    }
}

The compiler will ensure that the loaded function will not outlive the Library from which it comes, preventing the most common memory-safety issues.

Dependencies

~0–4.5MB