{"id":47801462,"url":"https://github.com/rldyourmnd/rldyourterm","last_synced_at":"2026-04-03T17:03:22.311Z","repository":{"id":342411224,"uuid":"1165665911","full_name":"rldyourmnd/rldyourterm","owner":"rldyourmnd","description":"Crash-intolerant AI terminal runtime. Optimized for Claude Code, Codex, Gemini CLI.","archived":false,"fork":false,"pushed_at":"2026-03-13T05:55:10.000Z","size":3392,"stargazers_count":0,"open_issues_count":1,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-03-13T06:08:59.762Z","etag":null,"topics":["ai-cli","claude-code","rust","terminal","terminal-emulator","wgpu"],"latest_commit_sha":null,"homepage":null,"language":"Rust","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/rldyourmnd.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":"AGENTS.md","dco":null,"cla":null}},"created_at":"2026-02-24T12:13:49.000Z","updated_at":"2026-03-13T05:48:10.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/rldyourmnd/rldyourterm","commit_stats":null,"previous_names":["rldyourmnd/rldyourterm"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/rldyourmnd/rldyourterm","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rldyourmnd%2Frldyourterm","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rldyourmnd%2Frldyourterm/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rldyourmnd%2Frldyourterm/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rldyourmnd%2Frldyourterm/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/rldyourmnd","download_url":"https://codeload.github.com/rldyourmnd/rldyourterm/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/rldyourmnd%2Frldyourterm/sbom","scorecard":{"id":1244416,"data":{"date":"2026-03-06T01:39:48Z","repo":{"name":"github.com/rldyourmnd/rldyourterm","commit":"99e681e4f0d9df10590213a4fc47600e34e73ccb"},"scorecard":{"version":"v5.3.0","commit":"c22063e786c11f9dd714d777a687ff7c4599b600"},"score":4.4,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/29 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#code-review"}},{"name":"Maintained","score":0,"reason":"project was created within the last 90 days. Please review its contents carefully","details":["Warn: Repository was created within the last 90 days."],"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#maintained"}},{"name":"Dependency-Update-Tool","score":10,"reason":"update tool detected","details":["Info: detected update tool: Dependabot: .github/dependabot.yml:1"],"documentation":{"short":"Determines if the project uses a dependency update tool.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#dependency-update-tool"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#packaging"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#dangerous-workflow"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#binary-artifacts"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: jobLevel 'checks' permission set to 'write': .github/workflows/ci.yml:135","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:136","Info: jobLevel 'contents' permission set to 'read': .github/workflows/ci.yml:169","Info: jobLevel 'actions' permission set to 'read': .github/workflows/scorecard.yml:20","Info: jobLevel 'contents' permission set to 'read': .github/workflows/scorecard.yml:21","Info: topLevel 'contents' permission set to 'read': .github/workflows/ci.yml:14","Info: topLevel 'actions' permission set to 'read': .github/workflows/codeql.yml:15","Info: topLevel 'contents' permission set to 'read': .github/workflows/codeql.yml:16","Warn: topLevel 'security-events' permission set to 'write': .github/workflows/codeql.yml:17","Warn: topLevel 'contents' permission set to 'write': .github/workflows/release.yml:10","Info: topLevel permissions set to 'read-all': .github/workflows/scorecard.yml:13","Info: topLevel 'pull-requests' permission set to 'read': .github/workflows/semantic.yml:11"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#token-permissions"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:172: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:31: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:32: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:91: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:92: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:95: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:148: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:149: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:157: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:158: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:49: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:50: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:51: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:65: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:66: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:69: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:75: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:106: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:107: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:118: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:119: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:122: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:138: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:139: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/codeql.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:27: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/codeql.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/codeql.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/codeql.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/codeql.yml:44: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/codeql.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:46: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:47: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:50: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:63: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:73: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:79: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/scorecard.yml:25: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/scorecard.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/scorecard.yml:30: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/scorecard.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/scorecard.yml:38: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/scorecard.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/semantic.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/rldyourmnd/rldyourterm/semantic.yml/main?enable=pin","Info:   0 out of  21 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of  22 third-party GitHubAction dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#pinned-dependencies"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#cii-best-practices"}},{"name":"SAST","score":7,"reason":"SAST tool detected but not run on all commits","details":["Info: SAST configuration detected: CodeQL","Warn: 0 commits out of 1 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#sast"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#security-policy"}},{"name":"CI-Tests","score":10,"reason":"1 out of 1 merged PRs checked by a CI test -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project runs tests before pull requests are merged.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#ci-tests"}},{"name":"Vulnerabilities","score":9,"reason":"1 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: RUSTSEC-2024-0436"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#vulnerabilities"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'main'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#branch-protection"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#license"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#fuzzing"}},{"name":"Contributors","score":3,"reason":"project has 1 contributing companies or organizations -- score normalized to 3","details":["Info: found contributions from: nddev"],"documentation":{"short":"Determines if the project has a set of contributors from multiple organizations (e.g., companies).","url":"https://github.com/ossf/scorecard/blob/c22063e786c11f9dd714d777a687ff7c4599b600/docs/checks.md#contributors"}}]},"last_synced_at":"2026-03-06T02:24:32.360Z","repository_id":342411224,"created_at":"2026-03-06T02:24:32.360Z","updated_at":"2026-03-06T02:24:32.360Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31364608,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-03T15:19:21.178Z","status":"ssl_error","status_checked_at":"2026-04-03T15:19:20.670Z","response_time":107,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["ai-cli","claude-code","rust","terminal","terminal-emulator","wgpu"],"created_at":"2026-04-03T17:03:21.708Z","updated_at":"2026-04-03T17:03:22.290Z","avatar_url":"https://github.com/rldyourmnd.png","language":"Rust","funding_links":[],"categories":[],"sub_categories":[],"readme":"# rldyourterm\n\n[![CI](https://github.com/rldyourmnd/rldyourterm/actions/workflows/ci.yml/badge.svg)](https://github.com/rldyourmnd/rldyourterm/actions/workflows/ci.yml)\n[![codecov](https://codecov.io/gh/rldyourmnd/rldyourterm/branch/main/graph/badge.svg)](https://codecov.io/gh/rldyourmnd/rldyourterm)\n[![Security](https://github.com/rldyourmnd/rldyourterm/actions/workflows/ci.yml/badge.svg?branch=main\u0026event=audit)](https://github.com/rldyourmnd/rldyourterm/security/overview)\n[![CodeQL](https://github.com/rldyourmnd/rldyourterm/actions/workflows/codeql.yml/badge.svg)](https://github.com/rldyourmnd/rldyourterm/actions/workflows/codeql.yml)\n[![OpenSSF Scorecard](https://api.securityscorecards.dev/projects/github.com/rldyourmnd/rldyourterm/badge)](https://securityscorecards.dev/viewer/?uri=github.com/rldyourmnd/rldyourterm)\n[![License](https://img.shields.io/badge/license-GPL--3.0--only-blue.svg)](LICENSE)\n[![Rust](https://img.shields.io/badge/rust-1.92%2B-orange.svg)](https://www.rust-lang.org/)\n[![crates.io](https://img.shields.io/crates/v/rldyourterm-app.svg)](https://crates.io/crates/rldyourterm-app)\n\nCrash-intolerant AI terminal runtime with v1.0 priorities locked as:\n1. stability,\n2. AI CLI compatibility (`Claude Code`, `Codex`, `Gemini CLI`),\n3. speed.\n\n## MVP runtime status\n\nThis repository now includes a Rust workspace with an MVP bootstrap path:\n- `rldyourterm-app`: CLI bootstrap + shell resolution + diagnostics events.\n- `rldyourterm-ui`: single-window runtime scaffold with command-driven control hooks.\n- `scripts/mvp/*`: executable compatibility harness for Claude/Codex/Gemini scenarios.\n\nSingle-window baseline is explicit and mandatory in v1.0 (`window_count=1`).\n\n## Quick checks\n\n```bash\ncargo check --locked -p rldyourterm-ui\ncargo check --locked -p rldyourterm-app\n```\n\n## Benchmarking\n\n`terminal_benchmark/` now provides two benchmark suites:\n- `canonical-headless` for deterministic CI-safe coverage across `core`, `services/session`, `ui`, `features/settings`, `features/shell-integration`, `features/font`, `features/render-gpu` policy helpers, and `features/render-cpu`\n- `live-display` for real `winit` window plus `wgpu`/`softbuffer` presentation timing on a live display session\n\nThe canonical headless JSON report still marks `app`, `foundation`, `foundation-platform`, and `features/diagnostics` as correctness-only layers. The live-display suite is intentionally local/manual and does not run as a required PR CI gate.\n\nQuick run:\n\n```bash\ncargo run --locked -p rldyourterm-terminal-benchmark -- --scenario all --scale standard\n```\n\nStructured JSON output:\n\n```bash\ncargo run --locked -p rldyourterm-terminal-benchmark -- \\\n  --suite canonical-headless \\\n  --scenario all \\\n  --scale stress \\\n  --format json \\\n  --output /tmp/rldyourterm-terminal-benchmark.json\n```\n\nHeadless CI-parity smoke run:\n\n```bash\nbash scripts/ci/run_terminal_benchmark_smoke.sh\n```\n\nFull benchmark suite:\n\n```bash\nbash scripts/ci/run_terminal_benchmark_full.sh\n```\n\nLive-display local smoke run:\n\n```bash\nbash scripts/ci/run_terminal_display_benchmark_smoke.sh\n```\n\nLive-display local full run:\n\n```bash\nbash scripts/ci/run_terminal_display_benchmark_full.sh\n```\n\nControlled live-display calibration run:\n\n```bash\nbash scripts/ci/run_terminal_display_benchmark_controlled.sh\n```\n\nControlled live-display calibration run with baseline refresh:\n\n```bash\nbash scripts/ci/run_terminal_display_benchmark_calibration.sh \\\n  target/terminal-benchmark/live-display-controlled-report.json \\\n  terminal_benchmark/baselines/live-display.controlled.json \\\n  target/terminal-benchmark/live-display-controlled-calibration.json\n```\n\nUse `TERMINAL_DISPLAY_BENCHMARK_COMPARISON_MODE=enforced` only when you intentionally want the calibrated baseline to become a hard gate.\n\nThere is also a manual self-hosted GitHub workflow for the same controlled calibration flow:\n- `.github/workflows/display-benchmark.yml`\n- runner labels required: `self-hosted`, `display-benchmark`, and the selected OS label\n- it uploads four artifacts: runner readiness report, controlled report, controlled baseline, calibration report\n- artifact upload is `always()`-style, so readiness and partial evidence survive failed calibration attempts\n\nOptional threshold validation against versioned baselines:\n\n```bash\nTERMINAL_BENCHMARK_BASELINE=terminal_benchmark/baselines/canonical-headless.standard.json \\\n  bash scripts/ci/run_terminal_benchmark_full.sh\n\nTERMINAL_DISPLAY_BENCHMARK_BASELINE=terminal_benchmark/baselines/live-display.quick.json \\\n  bash scripts/ci/run_terminal_display_benchmark_smoke.sh\n```\n\nHeadless baselines are enforced. Live-display baselines are advisory by default: regressions are reported to stderr but do not turn the command into a hard failure unless you deliberately promote that policy.\n\nBenchmark baseline scope is fail-closed:\n- `portable-headless` baselines apply only to canonical headless reports\n- `local-display-session` baselines apply only to generic local live-display reports\n- `controlled-display-session` baselines can only be refreshed from, and applied to, monitor-aware controlled live-display reports\n- controlled baselines now also carry exact environment requirements for the calibrated host profile, including display server hint and per-scenario CPU monitor metadata\n\nCanonical local system suite:\n\n```bash\nbash scripts/ci/run_terminal_system_suite.sh\n```\n\nCanonical local system suite with optional live-display coverage:\n\n```bash\nbash scripts/ci/run_terminal_system_suite.sh --with-live-display smoke\n```\n\nCanonical local system suite with controlled live-display validation:\n\n```bash\nbash scripts/ci/run_terminal_system_suite.sh --with-live-display controlled\n```\n\nCanonical local system suite with baselines:\n\n```bash\nbash scripts/ci/run_terminal_system_suite.sh \\\n  --benchmark-baseline terminal_benchmark/baselines/canonical-headless.standard.json \\\n  --with-live-display smoke \\\n  --live-display-baseline terminal_benchmark/baselines/live-display.quick.json\n```\n\nThe system suite emits a machine-readable JSON report and validates the referenced full benchmark report and, when requested, the live-display benchmark report and benchmark baselines before returning success.\n\nCPU live-display reports now include:\n- suite-level environment metadata: `session_type` and `display_server_hint`\n- phase-level timing for `redraw_dispatch`, which captures the wait between `request_redraw` and `RedrawRequested`\n- phase-level timing for `buffer_acquire`, `raster`, and `present`\n- `cpu_buffer_age_counts`, which shows how often the softbuffer framebuffer arrives with `age=0`, `age=1`, `age=2`, or `age\u003e=3`\n- `pacing_mode` and `monitor_refresh_rate_millihz`, which show whether the live run used monitor-driven cadence or the same `event-driven` fallback that production uses when monitor timing is unavailable\n- `monitor_name` and `monitor_scale_factor`, which show whether `winit` exposed concrete monitor metadata for the run\n\nControlled live-display validation adds monitor-aware requirements:\n- `steady-redraw-cpu` and `resize-cycle-cpu` must use `pacing_mode=monitor-cadence`\n- monitor refresh and scale metadata must be present for those scenarios\n- optional session/display-server expectations can be provided through `TERMINAL_DISPLAY_BENCHMARK_REQUIRED_SESSION_TYPE` and `TERMINAL_DISPLAY_BENCHMARK_REQUIRED_DISPLAY_SERVER_HINT`\n\nThat keeps local display regressions explainable before touching production render code. The current CPU display path is explicitly age-aware and replays a two-frame damage history when `softbuffer` returns `age=2`.\n\n## CI/CD profile\n\n- Current PR-visible check suite includes `CI`, `CodeQL`, `ClusterFuzzLite PR fuzzing`, `Scorecard`, `Semantic PR`, and `PR Automation`.\n- `CI` gate is strict for critical fan-out jobs (`check/test/clippy/fmt/msrv/audit/deny` must be `success`); only `coverage` may be `skipped` when disabled.\n- `CodeQL` publishes Rust extraction diagnostics artifact and fails closed when diagnostics telemetry is missing/invalid; actionable diagnostics (`ExtractionErrors \u003e 0` or non-benign extraction warnings) block merges, while known generated build-output warnings remain observable but non-blocking.\n- Release governance remains manual-only (`workflow_dispatch`) with enforced preflight (`terminal system suite`, `security gates`, `AI CLI compatibility matrix`).\n- Weekly non-blocking soak lane: `.github/workflows/soak.yml` runs `scripts/mvp/run_matrix.sh` and publishes artifacts for long-run compatibility evidence.\n\n## Fuzzing\n\nThe repository includes `cargo-fuzz` targets and ClusterFuzzLite workflows.\n\nLocal quick run:\n\n```bash\ncargo install cargo-fuzz\ncargo fuzz run parser_feed -- -max_total_time=30\n```\n\n## Interactive Run\n\nRun the binary directly as the terminal runtime (outside the MVP harness):\n\n```bash\ncargo run -q -p rldyourterm-app -- --mode auto --shell fish --window-count 1\n```\n\nDefault non-harness runtime now launches the GUI window terminal path (single-window MVP baseline).\nIf GUI initialization fails, runtime emits a warning and falls back to TTY mode.\nTo force TTY mode explicitly:\n\n```bash\ncargo run -q -p rldyourterm-app -- --mode auto --shell fish --window-count 1 --tty\n```\n\nOr build once and run the binary directly:\n\n```bash\ncargo build -p rldyourterm-app\n./target/debug/rldyourterm-app --mode auto --shell fish --window-count 1\n```\n\n## MVP compatibility harness\n\nMVP harness scenarios continue to run from `scripts/mvp/*` and do not replace interactive mode.\n\nRequired manual release gate (covers `R-11`, `R-12`, `R-13`):\n\n```bash\nbash scripts/mvp/run_matrix.sh 3\n```\n\nExtended compatibility soak:\n\n```bash\nbash scripts/mvp/run_matrix.sh 5\n```\n\nRun a single profile with optional extra commands:\n\n```bash\nbash scripts/mvp/run_profile.sh codex 3 recoverable:pty-write tick mode:cpu\n```\n\nHarness logs are written to `scripts/mvp/output/`.\nEach required gate run must produce these evidence lines:\n- `MVP_PROFILE_START ... single_window_required=1 release_governance=manual-only ...`\n- `MVP_HARNESS ... single_window_required=1 release_governance=manual-only`\n- `MVP_HARNESS_CMD ... --window-count 1 ...`\n- `MVP_RESULT ... windows=1 ... single_window_required=1 single_window_enforced=yes ... release_governance=manual-only ...`\n- `MVP_GATE_RESULT ... status=pass ...`\n- `MVP_PROFILE_RESULT ... status=pass ...`\n- `MVP_MATRIX_RESULT ... status=pass ...`\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frldyourmnd%2Frldyourterm","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Frldyourmnd%2Frldyourterm","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frldyourmnd%2Frldyourterm/lists"}