mirror of
https://github.com/logos-messaging/logos-messaging-go-bindings.git
synced 2026-06-14 12:49:28 +00:00
Add internal/ffi/liblogosdelivery, the cgo bridge over liblogosdelivery (Messaging API), mirroring the libwaku subpackage from #114: synchronous request/response plumbing, a shared async event callback, and a handle->handler registry, exposing Go-typed primitives (New/Start/Stop/Destroy, Subscribe/Unsubscribe/Send, SetEventHandler, Handle, RetOK, EventHandler). It self-links liblogosdelivery via a #cgo directive. For symmetry — and so the two bridges never need a shared global -l flag — add the same #cgo LDFLAGS: -lwaku to the libwaku subpackage. Each subpackage now links exactly its own library; no binary links both (until logos-delivery#3851). Extend the PR gate to build liblogosdelivery, set CGO_CFLAGS for both headers with no -l (each package self-links), run the messaging unit tests, and compile the kernel tests. Part of #106. Co-authored-by: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
97 lines
3.6 KiB
YAML
97 lines
3.6 KiB
YAML
name: PR
|
|
|
|
on:
|
|
pull_request:
|
|
branches:
|
|
- master
|
|
|
|
# Cancel superseded runs on the same PR.
|
|
concurrency:
|
|
group: pr-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
gate:
|
|
runs-on: ubuntu-latest
|
|
env:
|
|
# Clone the logos-delivery checkout OUTSIDE the module tree: a directory
|
|
# named `vendor/` at the module root would put Go into vendor mode.
|
|
LOGOS_DELIVERY_DIR: ${{ github.workspace }}/.logos-delivery
|
|
# Both kernel (libwaku) and messaging (liblogosdelivery) headers are on
|
|
# the include path so every package compiles. `-l` is deliberately NOT
|
|
# set here: each internal/ffi subpackage selects its own library via a
|
|
# `#cgo LDFLAGS` directive, so no binary links both libs (they export
|
|
# overlapping symbols until logos-delivery#3851).
|
|
CGO_CFLAGS: -I${{ github.workspace }}/.logos-delivery/library/ -I${{ github.workspace }}/.logos-delivery/liblogosdelivery/
|
|
CGO_LDFLAGS: -L${{ github.workspace }}/.logos-delivery/build/ -Wl,-rpath,${{ github.workspace }}/.logos-delivery/build/
|
|
# Build in module mode; never use a vendor/ dir.
|
|
GOFLAGS: -mod=mod
|
|
|
|
steps:
|
|
- name: Check out repository
|
|
uses: actions/checkout@v4
|
|
with:
|
|
fetch-depth: 0
|
|
|
|
- name: Set up Go
|
|
uses: actions/setup-go@v5
|
|
with:
|
|
go-version: "1.24"
|
|
|
|
- name: Resolve logos-delivery commit
|
|
# Cache the built libraries keyed on the exact upstream commit, so the
|
|
# expensive clone + build is skipped while logos-delivery's HEAD is
|
|
# unchanged. ls-remote gives us the SHA before we clone.
|
|
id: logos-delivery-rev
|
|
run: |
|
|
rev=$(git ls-remote https://github.com/logos-messaging/logos-delivery.git HEAD | cut -f1)
|
|
echo "rev=$rev" >> "$GITHUB_OUTPUT"
|
|
|
|
- name: Cache logos-delivery build
|
|
id: logos-delivery-cache
|
|
uses: actions/cache@v4
|
|
with:
|
|
path: ${{ env.LOGOS_DELIVERY_DIR }}
|
|
key: logos-delivery-${{ runner.os }}-${{ steps.logos-delivery-rev.outputs.rev }}
|
|
|
|
- name: Clone logos-delivery
|
|
if: steps.logos-delivery-cache.outputs.cache-hit != 'true'
|
|
run: git clone --depth 1 https://github.com/logos-messaging/logos-delivery.git "$LOGOS_DELIVERY_DIR"
|
|
|
|
- name: Build libwaku + liblogosdelivery
|
|
if: steps.logos-delivery-cache.outputs.cache-hit != 'true'
|
|
run: make -C "$LOGOS_DELIVERY_DIR" libwaku liblogosdelivery -j
|
|
|
|
- name: go build
|
|
run: go build ./...
|
|
|
|
- name: go vet
|
|
run: go vet ./...
|
|
|
|
- name: go mod tidy is clean
|
|
# `go mod tidy` must be a no-op on a well-maintained module. If it
|
|
# changes go.mod/go.sum the PR left them out of sync — fail and show
|
|
# the diff so the author can commit the tidied result.
|
|
run: |
|
|
go mod tidy
|
|
git diff --exit-code go.mod go.sum
|
|
|
|
- name: Ensure base ref is available for lint
|
|
# golangci-lint's new-from-merge-base needs origin/master present.
|
|
run: git fetch --no-tags origin master
|
|
|
|
- name: golangci-lint
|
|
# v7 is required for golangci-lint v2.
|
|
uses: golangci/golangci-lint-action@v7
|
|
with:
|
|
version: v2.4.0
|
|
|
|
- name: go test messaging (run)
|
|
# Fast, network-free unit tests for the Messaging API + its ffi bridge.
|
|
run: go test ./pkg/messaging/... ./internal/ffi/liblogosdelivery/...
|
|
|
|
- name: go test kernel (compile)
|
|
# The kernel suite is heavy integration (runs nightly in CI.yml), so
|
|
# only compile its test binaries here.
|
|
run: go test -run '^$' ./pkg/kernel/... ./internal/ffi/libwaku/...
|