Ivan FB 9524108474
enhance cpp and rust tokio examples
Co-authored-by: Copilot <copilot@github.com>
2026-05-03 15:48:47 +02:00
..
2026-05-03 15:48:47 +02:00
2026-05-03 15:48:47 +02:00
2026-05-03 15:48:47 +02:00
2026-05-03 15:48:47 +02:00

Rust Bindings for nim-timer

Purpose

This folder contains auto-generated Rust bindings (the nimtimer crate) for the nim_timer Nim library. It is generated from ../nim_timer.nim and provides:

  • src/lib.rs: Main library exposing high-level Rust types and the NimTimerCtx API
  • src/api.rs: High-level async/sync wrapper around the FFI
  • src/ffi.rs: Raw extern "C" declarations for the Nim library
  • src/types.rs: Serializable Rust types matching the Nim FFI types
  • build.rs: Build script that compiles the Nim library to libnimtimer.dylib (or .so/.dll)
  • Cargo.toml: Package manifest with serde and serde_json dependencies

How It's Generated

Generate or regenerate these bindings by running from the parent directory:

cd examples/nim_timer
nimble genbindings_rust

This command:

  1. Invokes the Nim compiler with -d:targetLang:rust flag
  2. Triggers genBindings("examples/nim_timer/rust_bindings", "../nim_timer.nim") in nim_timer.nim
  3. Creates/updates the generated binding files

Using as a Dependency

The rust_client example consumes this crate:

[dependencies]
nimtimer = { path = "../rust_bindings" }

Do Not Edit

The generated files in this folder are overwritten each time nimble genbindings_rust runs. Any manual changes will be lost.