# Lanes & Pipelines
Lanes let you chain tasks into named pipelines. Define them in `fledge.toml`, run them with `fledge lanes run ci`. All lane commands live under `fledge lanes`. They support parallel groups and configurable failure behavior.
## Quick Start
Already have tasks in `fledge.toml`? Generate lanes automatically:
```bash
fledge lanes init
```
This looks at your project type and creates sensible defaults. Then just run one:
```bash
fledge lanes run ci
```
## Defining Lanes
Lanes go in `fledge.toml` alongside your tasks:
```toml
[tasks]
fmt = "cargo fmt --check"
lint = "cargo clippy -- -D warnings"
test = "cargo test"
build = "cargo build"
[lanes.ci]
description = "Full CI pipeline"
steps = ["fmt", "lint", "test", "build"]
[lanes.check]
description = "Quick quality check"
steps = [
{ parallel = ["fmt", "lint"] },
"test"
]
```
### Lane Options
| `description` | string | `(no description)` | Shows up when listing lanes |
| `steps` | array | required | Ordered list of steps |
| `fail_fast` | bool | `true` | Stop on first failure vs. run everything and report |
## Step Types
You can mix these freely in a lane:
### Task References
Just name a task from your `[tasks]` section. Dependencies (`deps`) get resolved automatically.
```toml
steps = ["lint", "test", "build"]
```
### Inline Commands
One-off shell commands without cluttering your task list:
```toml
steps = [
"test",
{ run = "cargo build --release" },
{ run = "echo 'Build complete'" },
]
```
### Parallel Groups
Run multiple items at the same time. Everything in the group finishes before the next step starts. Items can be task references or inline commands.
```toml
steps = [
{ parallel = ["fmt", "lint"] },
"test",
"build"
]
```
Here `fmt` and `lint` run concurrently, then `test`, then `build`.
You can mix task references and inline commands in a parallel group:
```toml
steps = [
{ parallel = ["lint", { run = "echo checking..." }, "fmt"] },
"test"
]
```
## Failure Behavior
Default is `fail_fast = true`. Pipeline stops on the first failure.
```toml
[lanes.ci]
description = "Stop on first failure"
steps = ["lint", "test", "build"]
```
Set `fail_fast = false` when you want the full picture:
```toml
[lanes.audit]
description = "Run everything, report all failures"
fail_fast = false
steps = ["lint", "test", "security-check", "license-check"]
```
## Step Timing
Every step prints its elapsed time, and the lane summary shows total time:
```
▶️ Lane: ci, Full CI pipeline
▶️ Running parallel: fmt, lint
✔ Step 1 done (245ms)
▶️ Running task: test
✔ Step 2 done (1.032s)
▶️ Running task: build
✔ Step 3 done (3.456s)
✅ Lane ci completed (3 steps in 4.733s)
```
This helps identify slow steps in your pipeline without any extra tooling.
## Task Configuration
### Short Form
```toml
[tasks]
lint = "cargo clippy"
```
### Full Form
```toml
[tasks.build]
cmd = "cargo build --release"
description = "Build release binary"
deps = ["lint"]
env = { RUST_LOG = "info" }
dir = "crates/core"
```
| `cmd` | string | Shell command to run |
| `description` | string | Shows up when listing tasks |
| `deps` | array | Tasks to run first (resolved recursively) |
| `env` | table | Environment variables for this task |
| `dir` | string | Working directory (relative to project root) |
## Examples
### CI Pipeline
```toml
[lanes.ci]
description = "Full CI pipeline"
steps = [
{ parallel = ["fmt", "lint"] },
"test",
"build"
]
```
### Release
```toml
[lanes.release]
description = "Build and package a release"
steps = [
"test",
{ run = "cargo build --release" },
{ run = "strip target/release/my-app" },
{ run = "tar -czf release.tar.gz -C target/release my-app" },
]
```
### Full Audit
```toml
[lanes.audit]
description = "All quality checks"
fail_fast = false
steps = [
"lint",
"test",
{ run = "cargo audit" },
{ run = "cargo deny check" },
]
```
## Auto-Generated Defaults
`fledge lanes init` detects your project type:
| Rust | `Cargo.toml` | `ci` (fmt, lint, test, build), `check` (parallel fmt+lint, test) |
| Node.js | `package.json` | `ci` (lint, test, build), `check` (parallel lint+test) |
| Go | `go.mod` | `ci` (fmt, lint, test, build), `check` (parallel fmt+lint, test) |
| Python | `pyproject.toml` | `ci` (fmt, lint, test), `check` (parallel fmt+lint, test) |
## CLI
```bash
fledge lanes run ci # run a lane
fledge lanes run ci --dry-run # preview the plan
fledge lanes list # list lanes
fledge lanes list --json
fledge lanes init # generate defaults
fledge lanes search # find community lanes
fledge lanes search rust # search with keyword
fledge lanes import owner/repo # import lanes from GitHub
fledge lanes import owner/repo@v1.0.0 # pin to a version
fledge lanes publish --org MyOrg # publish lanes to GitHub
fledge lanes create my-lanes # scaffold a new lane repo
fledge lanes validate # validate lane definitions
fledge lanes validate --strict # treat warnings as errors
fledge lanes validate --json # machine-readable output
```
## Community Lane Registry
Share and discover lanes via GitHub. Repos with the `fledge-lane` topic are discoverable through `fledge lanes search`.
### Official Examples
[CorvidLabs/fledge-lanes](https://github.com/CorvidLabs/fledge-lanes) is the official collection of language-specific lane examples. Each subdirectory contains a fully-documented `fledge.toml`.
| Rust | `fledge lanes import CorvidLabs/fledge-lanes/rust` |
| Python | `fledge lanes import CorvidLabs/fledge-lanes/python` |
| Node/TypeScript | `fledge lanes import CorvidLabs/fledge-lanes/node-typescript` |
| Go | `fledge lanes import CorvidLabs/fledge-lanes/go` |
### Creating Lanes
Use `fledge lanes create` to scaffold a ready-to-publish lane repo:
```bash
fledge lanes create my-lanes
```
This creates a directory with a starter `fledge.toml` containing example tasks and lanes, a README, and a `.gitignore`. Edit the lanes, then validate and publish:
```bash
fledge lanes validate ./my-lanes # check for errors
fledge lanes publish ./my-lanes # push to GitHub (validates first)
```
### Publishing Lanes
1. Create a repo with a `fledge.toml` containing your lanes and tasks (or use `fledge lanes create`)
2. Validate with `fledge lanes validate` (publish does this automatically)
3. Publish with `fledge lanes publish` (sets the `fledge-lane` topic automatically)
4. Others can find it with `fledge lanes search` and import it
### Importing Lanes
```bash
fledge lanes import CorvidLabs/fledge-lanes
```
This fetches the remote repo's `fledge.toml`, extracts its lanes and any required tasks, and merges them into your local `fledge.toml`. Existing lanes with the same name are skipped (not overwritten).
You can pin to a specific branch or tag:
```bash
fledge lanes import CorvidLabs/fledge-lanes@v1.0.0
```
## Related
- [Configuration](./configuration.md), global config, GitHub tokens
- [Plugins](./plugins.md), extend fledge with community commands, use plugins in lanes
- [CLI Reference](./cli-reference.md), full `fledge lanes` subcommand reference
- [Example Lanes](https://github.com/CorvidLabs/fledge-lanes), official community lane collection
## Tips
- Start with `fledge lanes init` and customize from there.
- Use parallel groups for independent checks. Linting and formatting don't need to wait for each other.
- Keep `fail_fast = true` for CI. No point building if tests fail.
- Use `fail_fast = false` for audit lanes where you want the full report.
- Inline commands are great for one-off steps that don't need to be named tasks.