Tutorial series and reference documentation for building Logos modules.
New to Logos? Start with the developer guide -- it walks through creating, building, packaging, and running your first module:
Step-by-step tutorials that build on each other. Each creates a working module you can run.
-
Part 1: Wrapping a C Library -- build
calc_module, a core module that wraps a C library (libcalc). Covers external library configuration, CMake integration, building, inspecting withlm, testing withlogoscore, and packaging withnix-bundle-lgx. -
Part 2: Building a QML UI App -- build
calc_ui, a QML-onlyui_qmlmodule that callscalc_modulethrough thelogos.callModule()bridge. No compilation needed. Scaffold:nix flake init -t ...#ui-qml -
Part 3: Building a C++ UI Module (Process-Isolated) β build
calc_ui_cpp, aui_qmlmodule with a C++ backend that runs in a separateui-hostprocess. Define the remote interface in a.repfile; the C++ backend inherits from the generatedSimpleSource; QML accesses it via a typed replica usinglogos.module()andQtRemoteObjects.watch(). Scaffold:nix flake init -t ...#ui-qml-backend -
logos-dev-boost: (
β οΈ EXPERIMENTAL β NOT READY) Scaffolding Modules with logos-dev-boost β use thelogos-dev-boostCLI to auto-generate modules from C library directories. Wraps libcalc (source-only) and sqlcipher (pre-built.so), including integration tests that create encrypted databases. Covers--type module,--type full-app, and--lib-dir.
Tutorials have YAML specs in tests/ that can be both executed (to verify they work) and used to generate the .md files. They run through the shared doctest CLI, invoked directly via its flake (nix run github:logos-co/logos-doctest -- β¦). See docs/spec.md for the full format reference.
# Run a tutorial end-to-end (temp dir, deleted afterwards)
nix run github:logos-co/logos-doctest -- run tests/tutorial-wrapping-c-library.test.yaml --verbose
# Keep the build results in a directory of your choice (created if missing,
# never deleted). For a chained tutorial each part lands in its own subdir.
nix run github:logos-co/logos-doctest -- run tests/tutorial-cpp-ui-app.test.yaml \
--output-dir ./outputs --continue-on-fail
# Write a two-column HTML report: rendered tutorial on the left, the commands
# actually run and their output on the right. Open the file in a browser.
nix run github:logos-co/logos-doctest -- run tests/tutorial-cpp-ui-app.test.yaml \
--report ./tutorial-report.html --continue-on-fail
# Generate the .md tutorial from the YAML spec
nix run github:logos-co/logos-doctest -- generate tests/tutorial-wrapping-c-library.test.yaml
# Pin all GitHub URLs to a specific release tag
nix run github:logos-co/logos-doctest -- run tests/tutorial-wrapping-c-library.test.yaml --release tutorial-v2
nix run github:logos-co/logos-doctest -- generate tests/tutorial-wrapping-c-library.test.yaml --release tutorial-v2Tip: developing against a local
logos-doctestcheckout? Swapgithub:logos-co/logos-doctestforpath:../logos-doctest(or wherever your checkout lives) to run your local changes.
-
--output-dir DIRβ run intoDIRand keep it (created if missing, never auto-deleted). This is the flag to use when you want to inspect or reuse the built modules. A tutorial withrequires:(e.g. Part 3, which pulls in Parts 1 and 2) treatsDIRas the chain root and writes each project into its own subdirectory:./outputs/ βββ logos-calc-module/ # Part 1 (built first via requires:) βββ logos-calc-ui/ # Part 2 βββ logos-calc-ui-cpp/ # Part 3A standalone spec (no
requires:) is written directly intoDIR. -
--workdir DIRβ run into an existing directory. Unlike--output-dir, it does not create the directory, it is deleted on exit unless you add--keep-workdir, and it runs the spec standalone (prerequisiterequires:chains are skipped). Prefer--output-dirfor chained tutorials. -
Without either flag, a temp directory is created and deleted after the run (add
--keep-workdirto preserve the temp dir).
--report PATH writes a self-contained HTML report with two columns per step:
- left β the rendered tutorial markdown (identical to the published
.md), - right β the command(s) actually executed at that step and their output, with a pass/fail badge.
It covers every step type (file writes, shell commands, check_file, and headless ui_test runs). Pair it with --continue-on-fail so the report captures the whole run instead of stopping at the first failure. CI publishes this report for every run β see .github/workflows/ci.yml.
--tui runs the same two-column view live in your terminal instead of writing a file: the left pane shows the rendered tutorial for the current step, the right pane shows the command being run and its output, updating as the run proceeds.
# Auto-advancing: steps run one after another
nix run github:logos-co/logos-doctest -- run tests/tutorial-cpp-ui-app.test.yaml --tui
# Iterative: press the down/right arrow (or space) to execute each next step
nix run github:logos-co/logos-doctest -- run tests/tutorial-cpp-ui-app.test.yaml --tui --iterativePress q to quit at any time. --tui needs an interactive terminal and the rich package β both are bundled in the doctest flake, so no extra install is needed when using nix.
The --release flag (or the release field in the YAML) pins all {release} placeholders in GitHub URLs to a git tag, so github:logos-co/repo{release}#output becomes github:logos-co/repo/tutorial-v2#output. Set it to "" or omit it for latest.
Working module source code used by the tutorials:
| Directory | Module | Type | Tutorial |
|---|---|---|---|
logos-calc-module/ |
calc_module |
core (wraps libcalc) |
Part 1 |
logos-calc-ui/ |
calc_ui |
ui_qml (QML-only) |
Part 2 |
logos-calc-ui-cpp/ |
calc_ui_cpp |
ui_qml (C++ backend + QML view) |
Part 3 |
The outputs/ directory (the rendered .md tutorials linked above, plus the built module source trees) is generated from the YAML specs. To regenerate it, run:
./run.shThis:
- Runs the full tutorial chain (Part 1 β 2 β 3) into
./outputs/, executing every step so the result is verified, not just rendered. Each part lands in its own subdirectory (outputs/logos-calc-module/,outputs/logos-calc-ui/,outputs/logos-calc-ui-cpp/). - Generates the
.mdtutorial for everytests/*.test.yamlspec intooutputs/(tutorial-wrapping-c-library.md,tutorial-qml-ui-app.md,tutorial-cpp-ui-app.md). - Cleans each output project so only the source remains β it removes the per-project
.git/directories (each tutorialgit inits its project), the nix out-link symlinks (lm,logos,pm,result*), build output (modules/), and compiled libraries (*.dylib,*.so).
Note: the run requires Nix with flakes and pulls/builds real dependencies (Qt, the Logos SDK), so the first run is slow. On Linux, add
--continue-on-failto theruncommand inrun.shif a known-failing prerequisite step would otherwise stop the chain early.