2024-11-27 12:08:50 +02:00
|
|
|
# Waku Go Bindings
|
|
|
|
|
|
2025-10-30 10:59:13 +00:00
|
|
|
Go bindings for the Waku library.
|
2024-11-27 12:08:50 +02:00
|
|
|
|
2025-10-30 10:59:13 +00:00
|
|
|
## Install
|
2024-11-27 12:08:50 +02:00
|
|
|
|
2025-10-30 10:59:13 +00:00
|
|
|
```
|
2025-12-12 22:48:53 +01:00
|
|
|
go get -u github.com/logos-messaging/logos-messaging-go-bindings
|
2025-10-30 10:59:13 +00:00
|
|
|
```
|
2024-11-27 12:08:50 +02:00
|
|
|
|
2025-12-19 14:43:52 +05:30
|
|
|
## Building & Dependencies
|
2024-11-27 12:08:50 +02:00
|
|
|
|
2025-12-22 14:29:52 +05:30
|
|
|
`libwaku` (from `logos-messaging-nim`) is required at compile-time.
|
|
|
|
|
|
|
|
|
|
### Building with Makefile
|
|
|
|
|
|
|
|
|
|
If you have `logos-messaging-nim` checked out, point the build to it:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
# path to your existing logos-messaging-nim clone
|
|
|
|
|
export LMN_DIR=/absolute/path/to/logos-messaging-nim
|
|
|
|
|
export CGO_CFLAGS="-I${LMN_DIR}/library"
|
|
|
|
|
export CGO_LDFLAGS="-L${LMN_DIR}/build -lwaku -Wl,-rpath,${LMN_DIR}/build"
|
|
|
|
|
|
|
|
|
|
# compile all packages
|
|
|
|
|
make -C waku build
|
|
|
|
|
|
|
|
|
|
# run all tests
|
|
|
|
|
make -C waku test
|
|
|
|
|
|
|
|
|
|
# run a specific test
|
|
|
|
|
make -C waku test TEST=TestConnectedPeersInfo
|
|
|
|
|
```
|
2025-03-13 15:22:58 +02:00
|
|
|
|
2025-10-30 10:59:13 +00:00
|
|
|
## Development
|
2025-03-26 16:29:51 +02:00
|
|
|
|
2025-12-16 03:06:15 +05:30
|
|
|
When working on this repository itself, `logos-messaging-nim` is included as a git submodule for convenience.
|
2025-03-26 16:29:51 +02:00
|
|
|
|
2025-10-30 10:59:13 +00:00
|
|
|
- Initialize and update the submodule, then build `libwaku`
|
|
|
|
|
```sh
|
|
|
|
|
git submodule update --init --recursive
|
|
|
|
|
make -C waku build-libwaku
|
|
|
|
|
```
|
|
|
|
|
- Build the project. Submodule paths are used by default to find `libwaku`.
|
|
|
|
|
```shell
|
|
|
|
|
make -C waku build
|
|
|
|
|
```
|