# tmux

Terminal multiplexer

**Score:** 54% pass rate
**Principles:** 2/8 met

## Embed the badge

The [badge floor](https://anc.dev/badge) is 70%; this scorecard is at 54% (16 points below). Once the score clears the floor, the embed snippet will appear here.

| Status | Audit | Principle | Evidence |
|--------|-------|-----------|----------|
| FAIL | Help flag produces useful output | [P3](https://anc.dev/p3) | --help exited with code 1 |
| FAIL | Version flag works (`--version` plus short alias) | [P3](https://anc.dev/p3) | `--version` exited with code 1 |
| FAIL | Version flag works (`--version` plus short alias) | [P3](https://anc.dev/p3) | `--version` exited with code 1 |
| OPT-OUT | Structured output support | [P2](https://anc.dev/p2) | no --output/--format flag detected — tool does not ship structured output. Schema-discovery requirements (p2-must-schema-print, p2-should-schema-file) collapse to n/a via antecedent propagation. |
| PASS | Rejects invalid arguments | [P4](https://anc.dev/p4) |  |
| WARN | Quiet mode available | [P7](https://anc.dev/p7) | no --quiet/-q flag detected in --help output |
| SKIP | Handles SIGPIPE gracefully | [P6](https://anc.dev/p6) | suppressed by audit_profile: human-tui |
| SKIP | Non-interactive by default | [P1](https://anc.dev/p1) | suppressed by audit_profile: human-tui |
| SKIP | Non-interactive gate flag advertised in --help | [P1](https://anc.dev/p1) | suppressed by audit_profile: human-tui |
| SKIP | Flags advertise env-var bindings in --help | [P1](https://anc.dev/p1) | target exposes no flags in --help |
| SKIP | Pager-using CLI ships --no-pager escape hatch | [P6](https://anc.dev/p6) | no pager signal (less/more/$PAGER/--pager) in --help |
| PASS | Respects NO_COLOR | [P6](https://anc.dev/p6) |  |
| PASS | Secret-bearing flags expose stdin or *-file companion | [P1](https://anc.dev/p1) |  |
| N/A | Structured-output CLI exposes its schema at runtime | [P2](https://anc.dev/p2) | antecedent `p2-json-output` is opt_out: no --output/--format flag detected — tool does not ship structured output. Schema-discovery requirements (p2-must-schema-print, p2-should-schema-file) collapse to n/a via antecedent propagation. |
| WARN | --json / --jsonl short aliases for --output | [P2](https://anc.dev/p2) | no --json or --jsonl short alias found. Agents and pipelines benefit from short forms alongside the canonical `--output` enum. |
| SKIP | Subcommand verbs follow community-standard names | [P6](https://anc.dev/p6) | no subcommands parsed from --help |
| PASS | Skill bundle has install path (`tool skill install [<host>]`) | [P8](https://anc.dev/p8) |  |
| PASS | `skill install --all` for multi-runtime install | [P8](https://anc.dev/p8) |  |
| PASS | `skill update` / `skill upgrade` for bundle refresh | [P8](https://anc.dev/p8) |  |
| WARN | `--raw` flag for pipe-safe unformatted output | [P2](https://anc.dev/p2) | no `--raw` flag advertised. MAY-tier — useful for pipelines that want to strip formatting before piping to other tools. |
| SKIP | `--output` advertises additional formats beyond text/json | [P2](https://anc.dev/p2) | no `--output` or `--format` flag advertised; vacuous skip for MAY-tier extra formats. |
| WARN | `examples` subcommand or `--examples` flag for curated usage patterns | [P3](https://anc.dev/p3) | no `examples` subcommand or `--examples` flag found. MAY-tier — a curated usage block keeps agents from hunting through long help text. |
| WARN | `--color` flag for explicit color control | [P6](https://anc.dev/p6) | no `--color` flag advertised. MAY-tier — `auto\|always\|never` lets agents and pipelines override the TTY-based default. |
| WARN | `--verbose` flag for diagnostic escalation | [P7](https://anc.dev/p7) | no `--verbose` / `-v` flag advertised. SHOULD-tier — agents debugging failures need a way to escalate diagnostic detail. |
| SKIP | `--limit` / `--max-results` flag for list operations | [P7](https://anc.dev/p7) | no list-style subcommand detected (list/ls/search/query/find/show/get); vacuous skip for the list-only SHOULD. |
| SKIP | Cursor-based pagination flags for list traversal | [P7](https://anc.dev/p7) | no list-style subcommand detected; vacuous skip for the list-only MAY. |
| WARN | `--help` advertises default values for flags | [P1](https://anc.dev/p1) | no default-value annotations found in --help. SHOULD-tier — agents reading help text need to see what value a flag falls back to when omitted (`[default: <value>]` per clap convention). |
| WARN | Rich-TUI affordance for TTY contexts | [P1](https://anc.dev/p1) | no rich-TUI affordance detected (no `--tui`/`--interactive`/`--ui` flag, no spinner/progress/tui mention in --help). MAY-tier — rich TUI in TTY contexts is a nice-to-have, not required. |
| SKIP | Short `-h` summary differs from `--help` long form | [P3](https://anc.dev/p3) | could not probe both `-h` and `--help` cleanly |
| SKIP | Input-accepting commands read from stdin when no file is given | [P6](https://anc.dev/p6) | no input-accepting subcommand detected (process/parse/convert/transform/analyze/validate/format/lint/audit); vacuous skip for the conditional SHOULD. |
| SKIP | Subcommand naming follows a consistent verb/noun convention | [P6](https://anc.dev/p6) | fewer than 2 user-defined subcommands; vacuous skip for the conditional SHOULD. |
| SKIP | `--timeout` flag for long-running operations | [P7](https://anc.dev/p7) | no long-running subcommand detected (serve/daemon/watch/tail/monitor/follow/run/start/stream); vacuous skip for the conditional SHOULD. |
| WARN | Bad invocation exits with structured usage-error code (2) | [P2](https://anc.dev/p2) | bad invocation exited with code 1. The 0/1/2/77/78 convention reserves code 2 for usage errors; using a different non-zero code (often 1) blurs the distinction between usage errors and general failure. |
| FAIL | Error messages include a hint or remediation phrase | [P4](https://anc.dev/p4) | stderr lacks a hint phrase. Looked for one of: try , use , expected , did you mean, see , run , for more, tip:, help:, hint:, suggestion:, available . Error messages must name what to do next, not just the symptom. |
| SKIP | Errors emit JSON envelope with `error`/`kind`/`message` under `--output json` | [P2](https://anc.dev/p2) | binary does not advertise `--output json` in --help; MUST applies only to CLIs that opt into the JSON contract. |
| SKIP | `--output json` produces JSON-formatted errors | [P4](https://anc.dev/p4) | binary does not advertise `--output json` in --help; SHOULD applies only to CLIs that opt into the JSON contract. |
| SKIP | JSON success and error envelopes share their non-payload key set | [P2](https://anc.dev/p2) | binary does not advertise `--output json` in --help; envelope-consistency only applies to CLIs that opt into the JSON contract. |
| SKIP | Each subcommand's `--help` ships at least one invocation example | [P3](https://anc.dev/p3) | binary has no subcommands; MUST applies conditionally to CLIs that use them. |
| WARN | Help text pairs human and `--output json` example invocations | [P3](https://anc.dev/p3) | no paired text + `--output json` example found within 5 lines in top-level or any subcommand `--help`. Pairing keeps agents from reverse-engineering the JSON invocation from the text one. |
| PASS | Operations are subcommands, not verb-shaped flags | [P6](https://anc.dev/p6) |  |
| SKIP | Destructive subcommands require `--force` or `--yes` | [P5](https://anc.dev/p5) | no destructive subcommands detected; MUST applies conditionally to CLIs with destructive operations. |
| SKIP | Read and write surfaces are both visible in subcommand list | [P5](https://anc.dev/p5) | no recognizable read or write subcommand verbs; the read/write distinction is unobservable from the help surface alone. |
| WARN | Help text advertises TTY-aware verbosity behavior | [P7](https://anc.dev/p7) | no TTY-aware language found in `--help`. MAY-tier — automatic verbosity reduction when stdout is piped or redirected lets agents skip the explicit `--quiet` flag. Behavioral probes cannot simulate a real TTY without a pty crate, so this audit relies on documented intent. |

**Repo:** [tmux/tmux](https://github.com/tmux/tmux)
**Language:** C
**Version scored:** 3.6
**Audit date:** 2026-06-01 17:33:58 UTC
**Duration:** 82ms
**Platform:** `linux/x86_64`
**Mode:** command
**Anc build:** 0.5.0
**Install:** `brew install tmux`

## Reproduce locally

```bash
anc audit --command tmux --audit-profile human-tui --output json
```
