Crates.io | sm-ext |
lib.rs | sm-ext |
version | 0.3.0 |
source | src |
created_at | 2020-01-06 18:49:24.981667 |
updated_at | 2020-01-18 22:23:34.360008 |
description | Helpers for writing SourceMod Extensions in Rust |
homepage | |
repository | https://github.com/asherkin/sm-ext-rs |
max_upload_size | |
id | 195890 |
size | 114,542 |
FFI wrappers and helpers for writing SourceMod extensions in Rust.
This crate makes heavy use of unsafe
for interoperability with SourceMod but aims to expose safe interfaces with no unsound behaviour. However it may be possible to violate some of Rust's safety constraints (particularly aliasing guarantees) using APIs exposed by SourceMod. The aim of this project is to make it easier to write stable SourceMod extensions than when using C++, not to be 100% safe Rust.
Documentation
cargo +nightly doc --no-deps
Windows Debug Build
RUSTFLAGS="-C target-feature=+crt-static" cargo build --all --all-targets --target=i686-pc-windows-msvc
Windows Release Build
RUSTFLAGS="-C target-feature=+crt-static -C codegen-units=1" cargo build --all --all-targets --target=i686-pc-windows-msvc --release
Linux Debug Build
cargo build --all --all-targets --target=i686-unknown-linux-gnu
Linux Release Build
cargo build --all --all-targets --target=i686-unknown-linux-gnu --release
You'll probably want to wrap something around the cargo build to rename the output binary to match SourceMod's convention, and on Linux you'll want to strip release binaries before distribution with strip --strip-debug
.