cachekit-core 0.2.0

LZ4 compression, xxHash3 integrity, AES-256-GCM encryption for byte payloads
Documentation
name: CodeQL

on:
  push:
    branches: [main]
  pull_request:
    branches: [main]
  schedule:
    # Weekly scan on Sundays
    - cron: '0 0 * * 0'

concurrency:
  group: ${{ github.workflow }}-${{ github.ref }}
  cancel-in-progress: true

jobs:
  analyze:
    name: Analyze
    runs-on: ubuntu-latest
    permissions:
      actions: read
      contents: read
      security-events: write

    steps:
      - uses: actions/checkout@v6

      - name: Install Rust toolchain
        uses: dtolnay/rust-toolchain@stable

      - name: Initialize CodeQL
        uses: github/codeql-action/init@v4
        with:
          languages: cpp
          # Analyze generated C FFI headers and cross-language test code

      - name: Build and compile C FFI test
        run: |
          # Build Rust library with FFI to generate C header
          cargo build --release --features ffi,encryption
          # Verify header was generated
          ls -la include/cachekit.h
          # Compile C FFI test (CodeQL traces compilation)
          cd tests/cross_language
          cc -std=c99 -Wall -Wextra -I../../include -c test_c.c -o test_c.o

      - name: Perform CodeQL Analysis
        uses: github/codeql-action/analyze@v4
        with:
          category: "/language:cpp"