name: frb-docker description: Use when working with flutter_rust_bridge Docker/devcontainer setup, local Docker usage, Apple Silicon containers, or publishing the dev Docker image
FRB Docker
Use this skill for FRB Docker/devcontainer work: local container usage, Apple Silicon behavior, Dockerfile validation, and publishing fzyzcjy/flutter_rust_bridge_dev.
Source of Truth
- Devcontainer config:
.devcontainer/devcontainer.json - Dockerfile:
.devcontainer/Dockerfile - Publish workflow:
.github/workflows/publish_dev_docker.yaml - Published image:
fzyzcjy/flutter_rust_bridge_dev
The Dockerfile is the source of truth for tool versions. Derive image tags from its ARG values instead of hardcoding stale versions.
Daily Local Use
Devcontainer
Prefer devcontainer for normal development.
Dev Containers: Reopen in Container
The devcontainer builds from .devcontainer/Dockerfile and runs ./frb_internal pub-get-all to prepare Dart/Flutter package dependencies; first Rust/wasm builds may still be slow because crate compilation caches are not warmed.
Published Image
Default behavior is still to build locally from .devcontainer/Dockerfile. If you want to use a prebuilt image instead, switch to the full version tag derived from the current Dockerfile args rather than latest.
docker run --rm -it -v "$PWD:/workspace" -w /workspace fzyzcjy/flutter_rust_bridge_dev:latest bash
Use latest only for quick local checks where reproducibility does not matter.
Manual Docker Build
Use this when not using VS Code devcontainers, or when validating local Dockerfile changes.
docker build -f .devcontainer/Dockerfile -t frb-dev .devcontainer
docker run --rm -it -v "$PWD:/workspace" -w /workspace frb-dev bash
Inside a fresh manual container, run:
./frb_internal pub-get-all
Then run normal development commands such as:
./frb_internal lint
cargo check
Apple Silicon
Apple Silicon Macs use the same commands as other platforms. Do not add --platform linux/amd64 for normal local development.
Docker should select linux/arm64 automatically for multi-arch images. If a command only works with --platform linux/amd64, treat that as a regression to investigate.
Publishing
Local Validation
For Dockerfile changes, validate at least:
docker build -f .devcontainer/Dockerfile -t frb-dev .devcontainer
docker run --rm -v "$PWD:/workspace" -w /workspace frb-dev bash -lc './frb_internal --help'
For environment changes, smoke-test the installed tools:
docker run --rm -v "$PWD:/workspace" -w /workspace frb-dev bash -lc '
set -euo pipefail
flutter --version
dart --version
node --version
npm --version
cargo --version
wasm-pack --version
"${CHROME_BIN}" --version
'
For broader confidence, run:
docker run --rm -v "$PWD:/workspace" -w /workspace frb-dev bash -lc './frb_internal pub-get-all && ./frb_internal lint --fix'
docker run --rm -v "$PWD:/workspace" -w /workspace/frb_rust frb-dev bash -lc 'cargo check && cargo check --target wasm32-unknown-unknown'
If generated files drift during lint/codegen, do not manually edit generated files. Restore unrelated generated drift unless the task intentionally changes generation outputs.
Publish Workflow
Publish the dev image from the workflow:
gh workflow run publish_dev_docker.yaml --ref master
Manual dispatch defaults to publish=true.
To verify the workflow without publishing:
gh workflow run publish_dev_docker.yaml --ref master -f publish=false
The workflow builds and smoke-tests:
linux/amd64onubuntu-latestlinux/arm64onubuntu-24.04-arm
When publishing, it pushes per-platform images and then creates multi-arch tags:
latestflutter-<flutter_version>-rust-<rust_version>-nightly-<rust_nightly_version>flutter-<flutter_version>-rust-<rust_version>-nightly-<rust_nightly_version>-code-<short_sha>sha-<short_sha>
After publishing, inspect the manifest:
docker buildx imagetools inspect fzyzcjy/flutter_rust_bridge_dev:latest
It should include linux/amd64 and linux/arm64. BuildKit attestation manifests may appear as unknown/unknown; those are not platform images.
Inspect the image revision label when checking exactly which source commit was published:
docker inspect fzyzcjy/flutter_rust_bridge_dev:latest \
--format '{{ index .Config.Labels "org.opencontainers.image.revision" }}'
CI Workflow Guidance
Avoid building the full Rust/Flutter arm64 image under QEMU on an amd64 runner; it is much slower than native arm64 and can make the workflow impractical. Use native arch runners for heavy image builds.
If a dry-run passes but publishing fails, inspect whether Docker Hub login, per-platform push, or manifest creation failed; those are separate phases in the workflow.