2026-05-11 23:28:17 +02:00
|
|
|
# C++ Bindings for nim-timer
|
|
|
|
|
|
|
|
|
|
## Purpose
|
|
|
|
|
|
2026-05-16 01:08:42 +02:00
|
|
|
This folder contains **auto-generated C++ bindings** for the `timer` Nim library. It is generated from `../timer.nim` and provides:
|
2026-05-11 23:28:17 +02:00
|
|
|
|
2026-05-16 01:08:42 +02:00
|
|
|
- `timer.hpp`: High-level C++ class (`TimerCtx`) wrapping the FFI interface
|
2026-05-11 23:28:17 +02:00
|
|
|
- `main.cpp`: Example executable demonstrating how to use the bindings
|
|
|
|
|
- `CMakeLists.txt`: Build configuration that compiles the Nim library and links the C++ example
|
|
|
|
|
|
|
|
|
|
## How It's Generated
|
|
|
|
|
|
|
|
|
|
Generate or regenerate these bindings by running from the parent directory:
|
|
|
|
|
|
|
|
|
|
```sh
|
2026-05-16 01:08:42 +02:00
|
|
|
cd examples/timer
|
2026-05-11 23:28:17 +02:00
|
|
|
nimble genbindings_cpp
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
This command:
|
|
|
|
|
1. Invokes the Nim compiler with `-d:targetLang:cpp` flag
|
2026-05-16 01:08:42 +02:00
|
|
|
2. Triggers `genBindings("examples/timer/cpp_bindings", "../timer.nim")` in `timer.nim`
|
2026-05-11 23:28:17 +02:00
|
|
|
3. Creates/updates the generated binding files
|
|
|
|
|
|
|
|
|
|
## Building the Example
|
|
|
|
|
|
|
|
|
|
```sh
|
2026-05-16 01:08:42 +02:00
|
|
|
cd examples/timer/cpp_bindings
|
2026-05-11 23:28:17 +02:00
|
|
|
cmake -S . -B build
|
|
|
|
|
cmake --build build
|
|
|
|
|
./build/example
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Do Not Edit
|
|
|
|
|
|
|
|
|
|
The generated files in this folder are overwritten each time `nimble genbindings_cpp` runs. Any manual changes will be lost.
|