@hasna/terminal 2.2.0 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +29 -12
- package/package.json +1 -1
- package/src/ai.ts +50 -36
- package/src/cli.tsx +29 -12
- package/src/context-hints.ts +89 -0
- package/src/discover.ts +238 -0
- package/src/economy.ts +53 -0
- package/src/output-store.ts +65 -0
- package/src/providers/index.ts +4 -4
- package/src/sessions-db.ts +81 -0
- package/temp/rtk/.claude/agents/code-reviewer.md +221 -0
- package/temp/rtk/.claude/agents/debugger.md +519 -0
- package/temp/rtk/.claude/agents/rtk-testing-specialist.md +461 -0
- package/temp/rtk/.claude/agents/rust-rtk.md +511 -0
- package/temp/rtk/.claude/agents/technical-writer.md +355 -0
- package/temp/rtk/.claude/commands/diagnose.md +352 -0
- package/temp/rtk/.claude/commands/test-routing.md +362 -0
- package/temp/rtk/.claude/hooks/bash/pre-commit-format.sh +16 -0
- package/temp/rtk/.claude/hooks/rtk-rewrite.sh +70 -0
- package/temp/rtk/.claude/hooks/rtk-suggest.sh +152 -0
- package/temp/rtk/.claude/rules/cli-testing.md +526 -0
- package/temp/rtk/.claude/skills/issue-triage/SKILL.md +348 -0
- package/temp/rtk/.claude/skills/issue-triage/templates/issue-comment.md +134 -0
- package/temp/rtk/.claude/skills/performance.md +435 -0
- package/temp/rtk/.claude/skills/pr-triage/SKILL.md +315 -0
- package/temp/rtk/.claude/skills/pr-triage/templates/review-comment.md +71 -0
- package/temp/rtk/.claude/skills/repo-recap.md +206 -0
- package/temp/rtk/.claude/skills/rtk-tdd/SKILL.md +78 -0
- package/temp/rtk/.claude/skills/rtk-tdd/references/testing-patterns.md +124 -0
- package/temp/rtk/.claude/skills/security-guardian.md +503 -0
- package/temp/rtk/.claude/skills/ship.md +404 -0
- package/temp/rtk/.github/workflows/benchmark.yml +34 -0
- package/temp/rtk/.github/workflows/dco-check.yaml +12 -0
- package/temp/rtk/.github/workflows/release-please.yml +51 -0
- package/temp/rtk/.github/workflows/release.yml +343 -0
- package/temp/rtk/.github/workflows/security-check.yml +135 -0
- package/temp/rtk/.github/workflows/validate-docs.yml +78 -0
- package/temp/rtk/.release-please-manifest.json +3 -0
- package/temp/rtk/ARCHITECTURE.md +1491 -0
- package/temp/rtk/CHANGELOG.md +640 -0
- package/temp/rtk/CLAUDE.md +605 -0
- package/temp/rtk/CONTRIBUTING.md +199 -0
- package/temp/rtk/Cargo.lock +1668 -0
- package/temp/rtk/Cargo.toml +64 -0
- package/temp/rtk/Formula/rtk.rb +43 -0
- package/temp/rtk/INSTALL.md +390 -0
- package/temp/rtk/LICENSE +21 -0
- package/temp/rtk/README.md +386 -0
- package/temp/rtk/README_es.md +159 -0
- package/temp/rtk/README_fr.md +197 -0
- package/temp/rtk/README_ja.md +159 -0
- package/temp/rtk/README_ko.md +159 -0
- package/temp/rtk/README_zh.md +167 -0
- package/temp/rtk/ROADMAP.md +15 -0
- package/temp/rtk/SECURITY.md +217 -0
- package/temp/rtk/TEST_EXEC_TIME.md +102 -0
- package/temp/rtk/build.rs +57 -0
- package/temp/rtk/docs/AUDIT_GUIDE.md +432 -0
- package/temp/rtk/docs/FEATURES.md +1410 -0
- package/temp/rtk/docs/TROUBLESHOOTING.md +309 -0
- package/temp/rtk/docs/filter-workflow.md +102 -0
- package/temp/rtk/docs/images/gain-dashboard.jpg +0 -0
- package/temp/rtk/docs/tracking.md +583 -0
- package/temp/rtk/hooks/opencode-rtk.ts +39 -0
- package/temp/rtk/hooks/rtk-awareness.md +29 -0
- package/temp/rtk/hooks/rtk-rewrite.sh +61 -0
- package/temp/rtk/hooks/test-rtk-rewrite.sh +442 -0
- package/temp/rtk/install.sh +124 -0
- package/temp/rtk/release-please-config.json +10 -0
- package/temp/rtk/scripts/benchmark.sh +592 -0
- package/temp/rtk/scripts/check-installation.sh +162 -0
- package/temp/rtk/scripts/install-local.sh +37 -0
- package/temp/rtk/scripts/rtk-economics.sh +137 -0
- package/temp/rtk/scripts/test-all.sh +561 -0
- package/temp/rtk/scripts/test-aristote.sh +227 -0
- package/temp/rtk/scripts/test-tracking.sh +79 -0
- package/temp/rtk/scripts/update-readme-metrics.sh +32 -0
- package/temp/rtk/scripts/validate-docs.sh +73 -0
- package/temp/rtk/src/aws_cmd.rs +880 -0
- package/temp/rtk/src/binlog.rs +1645 -0
- package/temp/rtk/src/cargo_cmd.rs +1727 -0
- package/temp/rtk/src/cc_economics.rs +1157 -0
- package/temp/rtk/src/ccusage.rs +340 -0
- package/temp/rtk/src/config.rs +187 -0
- package/temp/rtk/src/container.rs +855 -0
- package/temp/rtk/src/curl_cmd.rs +134 -0
- package/temp/rtk/src/deps.rs +268 -0
- package/temp/rtk/src/diff_cmd.rs +367 -0
- package/temp/rtk/src/discover/mod.rs +274 -0
- package/temp/rtk/src/discover/provider.rs +388 -0
- package/temp/rtk/src/discover/registry.rs +2022 -0
- package/temp/rtk/src/discover/report.rs +202 -0
- package/temp/rtk/src/discover/rules.rs +667 -0
- package/temp/rtk/src/display_helpers.rs +402 -0
- package/temp/rtk/src/dotnet_cmd.rs +1771 -0
- package/temp/rtk/src/dotnet_format_report.rs +133 -0
- package/temp/rtk/src/dotnet_trx.rs +593 -0
- package/temp/rtk/src/env_cmd.rs +204 -0
- package/temp/rtk/src/filter.rs +462 -0
- package/temp/rtk/src/filters/README.md +52 -0
- package/temp/rtk/src/filters/ansible-playbook.toml +34 -0
- package/temp/rtk/src/filters/basedpyright.toml +47 -0
- package/temp/rtk/src/filters/biome.toml +45 -0
- package/temp/rtk/src/filters/brew-install.toml +37 -0
- package/temp/rtk/src/filters/composer-install.toml +40 -0
- package/temp/rtk/src/filters/df.toml +16 -0
- package/temp/rtk/src/filters/dotnet-build.toml +64 -0
- package/temp/rtk/src/filters/du.toml +16 -0
- package/temp/rtk/src/filters/fail2ban-client.toml +15 -0
- package/temp/rtk/src/filters/gcc.toml +49 -0
- package/temp/rtk/src/filters/gcloud.toml +22 -0
- package/temp/rtk/src/filters/hadolint.toml +24 -0
- package/temp/rtk/src/filters/helm.toml +29 -0
- package/temp/rtk/src/filters/iptables.toml +27 -0
- package/temp/rtk/src/filters/jj.toml +28 -0
- package/temp/rtk/src/filters/jq.toml +24 -0
- package/temp/rtk/src/filters/make.toml +41 -0
- package/temp/rtk/src/filters/markdownlint.toml +24 -0
- package/temp/rtk/src/filters/mix-compile.toml +27 -0
- package/temp/rtk/src/filters/mix-format.toml +15 -0
- package/temp/rtk/src/filters/mvn-build.toml +44 -0
- package/temp/rtk/src/filters/oxlint.toml +43 -0
- package/temp/rtk/src/filters/ping.toml +63 -0
- package/temp/rtk/src/filters/pio-run.toml +40 -0
- package/temp/rtk/src/filters/poetry-install.toml +50 -0
- package/temp/rtk/src/filters/pre-commit.toml +35 -0
- package/temp/rtk/src/filters/ps.toml +16 -0
- package/temp/rtk/src/filters/quarto-render.toml +41 -0
- package/temp/rtk/src/filters/rsync.toml +48 -0
- package/temp/rtk/src/filters/shellcheck.toml +27 -0
- package/temp/rtk/src/filters/shopify-theme.toml +29 -0
- package/temp/rtk/src/filters/skopeo.toml +45 -0
- package/temp/rtk/src/filters/sops.toml +16 -0
- package/temp/rtk/src/filters/ssh.toml +44 -0
- package/temp/rtk/src/filters/stat.toml +34 -0
- package/temp/rtk/src/filters/swift-build.toml +41 -0
- package/temp/rtk/src/filters/systemctl-status.toml +33 -0
- package/temp/rtk/src/filters/terraform-plan.toml +35 -0
- package/temp/rtk/src/filters/tofu-fmt.toml +16 -0
- package/temp/rtk/src/filters/tofu-init.toml +38 -0
- package/temp/rtk/src/filters/tofu-plan.toml +35 -0
- package/temp/rtk/src/filters/tofu-validate.toml +17 -0
- package/temp/rtk/src/filters/trunk-build.toml +39 -0
- package/temp/rtk/src/filters/ty.toml +50 -0
- package/temp/rtk/src/filters/uv-sync.toml +37 -0
- package/temp/rtk/src/filters/xcodebuild.toml +99 -0
- package/temp/rtk/src/filters/yamllint.toml +25 -0
- package/temp/rtk/src/find_cmd.rs +598 -0
- package/temp/rtk/src/format_cmd.rs +386 -0
- package/temp/rtk/src/gain.rs +723 -0
- package/temp/rtk/src/gh_cmd.rs +1651 -0
- package/temp/rtk/src/git.rs +2012 -0
- package/temp/rtk/src/go_cmd.rs +592 -0
- package/temp/rtk/src/golangci_cmd.rs +254 -0
- package/temp/rtk/src/grep_cmd.rs +288 -0
- package/temp/rtk/src/gt_cmd.rs +810 -0
- package/temp/rtk/src/hook_audit_cmd.rs +283 -0
- package/temp/rtk/src/hook_check.rs +171 -0
- package/temp/rtk/src/init.rs +1859 -0
- package/temp/rtk/src/integrity.rs +537 -0
- package/temp/rtk/src/json_cmd.rs +231 -0
- package/temp/rtk/src/learn/detector.rs +628 -0
- package/temp/rtk/src/learn/mod.rs +119 -0
- package/temp/rtk/src/learn/report.rs +184 -0
- package/temp/rtk/src/lint_cmd.rs +694 -0
- package/temp/rtk/src/local_llm.rs +316 -0
- package/temp/rtk/src/log_cmd.rs +248 -0
- package/temp/rtk/src/ls.rs +324 -0
- package/temp/rtk/src/main.rs +2482 -0
- package/temp/rtk/src/mypy_cmd.rs +389 -0
- package/temp/rtk/src/next_cmd.rs +241 -0
- package/temp/rtk/src/npm_cmd.rs +236 -0
- package/temp/rtk/src/parser/README.md +267 -0
- package/temp/rtk/src/parser/error.rs +46 -0
- package/temp/rtk/src/parser/formatter.rs +336 -0
- package/temp/rtk/src/parser/mod.rs +311 -0
- package/temp/rtk/src/parser/types.rs +119 -0
- package/temp/rtk/src/pip_cmd.rs +302 -0
- package/temp/rtk/src/playwright_cmd.rs +479 -0
- package/temp/rtk/src/pnpm_cmd.rs +573 -0
- package/temp/rtk/src/prettier_cmd.rs +221 -0
- package/temp/rtk/src/prisma_cmd.rs +482 -0
- package/temp/rtk/src/psql_cmd.rs +382 -0
- package/temp/rtk/src/pytest_cmd.rs +384 -0
- package/temp/rtk/src/read.rs +217 -0
- package/temp/rtk/src/rewrite_cmd.rs +50 -0
- package/temp/rtk/src/ruff_cmd.rs +402 -0
- package/temp/rtk/src/runner.rs +271 -0
- package/temp/rtk/src/summary.rs +297 -0
- package/temp/rtk/src/tee.rs +405 -0
- package/temp/rtk/src/telemetry.rs +248 -0
- package/temp/rtk/src/toml_filter.rs +1655 -0
- package/temp/rtk/src/tracking.rs +1416 -0
- package/temp/rtk/src/tree.rs +209 -0
- package/temp/rtk/src/tsc_cmd.rs +259 -0
- package/temp/rtk/src/utils.rs +432 -0
- package/temp/rtk/src/verify_cmd.rs +47 -0
- package/temp/rtk/src/vitest_cmd.rs +385 -0
- package/temp/rtk/src/wc_cmd.rs +401 -0
- package/temp/rtk/src/wget_cmd.rs +260 -0
- package/temp/rtk/tests/fixtures/dotnet/build_failed.txt +11 -0
- package/temp/rtk/tests/fixtures/dotnet/format_changes.json +31 -0
- package/temp/rtk/tests/fixtures/dotnet/format_empty.json +1 -0
- package/temp/rtk/tests/fixtures/dotnet/format_success.json +12 -0
- package/temp/rtk/tests/fixtures/dotnet/test_failed.txt +18 -0
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
use serde::Serialize;
|
|
2
|
+
|
|
3
|
+
/// RTK support status for a command.
|
|
4
|
+
#[derive(Debug, Serialize, Clone, Copy, PartialEq, Eq)]
|
|
5
|
+
pub enum RtkStatus {
|
|
6
|
+
/// Dedicated handler with filtering (e.g., git status → git.rs:run_status())
|
|
7
|
+
Existing,
|
|
8
|
+
/// Works via external_subcommand passthrough, no filtering (e.g., cargo fmt → Other)
|
|
9
|
+
Passthrough,
|
|
10
|
+
/// RTK doesn't handle this command at all
|
|
11
|
+
NotSupported,
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
impl RtkStatus {
|
|
15
|
+
pub fn as_str(&self) -> &'static str {
|
|
16
|
+
match self {
|
|
17
|
+
RtkStatus::Existing => "existing",
|
|
18
|
+
RtkStatus::Passthrough => "passthrough",
|
|
19
|
+
RtkStatus::NotSupported => "not-supported",
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/// A supported command that RTK already handles.
|
|
25
|
+
#[derive(Debug, Serialize)]
|
|
26
|
+
pub struct SupportedEntry {
|
|
27
|
+
pub command: String,
|
|
28
|
+
pub count: usize,
|
|
29
|
+
pub rtk_equivalent: &'static str,
|
|
30
|
+
pub category: &'static str,
|
|
31
|
+
pub estimated_savings_tokens: usize,
|
|
32
|
+
pub estimated_savings_pct: f64,
|
|
33
|
+
pub rtk_status: RtkStatus,
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/// An unsupported command not yet handled by RTK.
|
|
37
|
+
#[derive(Debug, Serialize)]
|
|
38
|
+
pub struct UnsupportedEntry {
|
|
39
|
+
pub base_command: String,
|
|
40
|
+
pub count: usize,
|
|
41
|
+
pub example: String,
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/// Full discover report.
|
|
45
|
+
#[derive(Debug, Serialize)]
|
|
46
|
+
pub struct DiscoverReport {
|
|
47
|
+
pub sessions_scanned: usize,
|
|
48
|
+
pub total_commands: usize,
|
|
49
|
+
pub already_rtk: usize,
|
|
50
|
+
pub since_days: u64,
|
|
51
|
+
pub supported: Vec<SupportedEntry>,
|
|
52
|
+
pub unsupported: Vec<UnsupportedEntry>,
|
|
53
|
+
pub parse_errors: usize,
|
|
54
|
+
pub rtk_disabled_count: usize,
|
|
55
|
+
pub rtk_disabled_examples: Vec<String>,
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
impl DiscoverReport {
|
|
59
|
+
pub fn total_saveable_tokens(&self) -> usize {
|
|
60
|
+
self.supported
|
|
61
|
+
.iter()
|
|
62
|
+
.map(|s| s.estimated_savings_tokens)
|
|
63
|
+
.sum()
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
pub fn total_supported_count(&self) -> usize {
|
|
67
|
+
self.supported.iter().map(|s| s.count).sum()
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/// Format report as text.
|
|
72
|
+
pub fn format_text(report: &DiscoverReport, limit: usize, verbose: bool) -> String {
|
|
73
|
+
let mut out = String::with_capacity(2048);
|
|
74
|
+
|
|
75
|
+
out.push_str("RTK Discover -- Savings Opportunities\n");
|
|
76
|
+
out.push_str(&"=".repeat(52));
|
|
77
|
+
out.push('\n');
|
|
78
|
+
out.push_str(&format!(
|
|
79
|
+
"Scanned: {} sessions (last {} days), {} Bash commands\n",
|
|
80
|
+
report.sessions_scanned, report.since_days, report.total_commands
|
|
81
|
+
));
|
|
82
|
+
out.push_str(&format!(
|
|
83
|
+
"Already using RTK: {} commands ({}%)\n",
|
|
84
|
+
report.already_rtk,
|
|
85
|
+
if report.total_commands > 0 {
|
|
86
|
+
report.already_rtk * 100 / report.total_commands
|
|
87
|
+
} else {
|
|
88
|
+
0
|
|
89
|
+
}
|
|
90
|
+
));
|
|
91
|
+
|
|
92
|
+
if report.supported.is_empty() && report.unsupported.is_empty() {
|
|
93
|
+
out.push_str("\nNo missed savings found. RTK usage looks good!\n");
|
|
94
|
+
return out;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Missed savings
|
|
98
|
+
if !report.supported.is_empty() {
|
|
99
|
+
out.push_str("\nMISSED SAVINGS -- Commands RTK already handles\n");
|
|
100
|
+
out.push_str(&"-".repeat(72));
|
|
101
|
+
out.push('\n');
|
|
102
|
+
out.push_str(&format!(
|
|
103
|
+
"{:<24} {:>5} {:<18} {:<13} {:>12}\n",
|
|
104
|
+
"Command", "Count", "RTK Equivalent", "Status", "Est. Savings"
|
|
105
|
+
));
|
|
106
|
+
|
|
107
|
+
for entry in report.supported.iter().take(limit) {
|
|
108
|
+
out.push_str(&format!(
|
|
109
|
+
"{:<24} {:>5} {:<18} {:<13} ~{}\n",
|
|
110
|
+
truncate_str(&entry.command, 23),
|
|
111
|
+
entry.count,
|
|
112
|
+
entry.rtk_equivalent,
|
|
113
|
+
entry.rtk_status.as_str(),
|
|
114
|
+
format_tokens(entry.estimated_savings_tokens),
|
|
115
|
+
));
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
out.push_str(&"-".repeat(72));
|
|
119
|
+
out.push('\n');
|
|
120
|
+
out.push_str(&format!(
|
|
121
|
+
"Total: {} commands -> ~{} saveable\n",
|
|
122
|
+
report.total_supported_count(),
|
|
123
|
+
format_tokens(report.total_saveable_tokens()),
|
|
124
|
+
));
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Unhandled
|
|
128
|
+
if !report.unsupported.is_empty() {
|
|
129
|
+
out.push_str("\nTOP UNHANDLED COMMANDS -- open an issue?\n");
|
|
130
|
+
out.push_str(&"-".repeat(52));
|
|
131
|
+
out.push('\n');
|
|
132
|
+
out.push_str(&format!(
|
|
133
|
+
"{:<24} {:>5} {}\n",
|
|
134
|
+
"Command", "Count", "Example"
|
|
135
|
+
));
|
|
136
|
+
|
|
137
|
+
for entry in report.unsupported.iter().take(limit) {
|
|
138
|
+
out.push_str(&format!(
|
|
139
|
+
"{:<24} {:>5} {}\n",
|
|
140
|
+
truncate_str(&entry.base_command, 23),
|
|
141
|
+
entry.count,
|
|
142
|
+
truncate_str(&entry.example, 40),
|
|
143
|
+
));
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
out.push_str(&"-".repeat(52));
|
|
147
|
+
out.push('\n');
|
|
148
|
+
out.push_str("-> github.com/rtk-ai/rtk/issues\n");
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// RTK_DISABLED bypass warning
|
|
152
|
+
if report.rtk_disabled_count > 0 {
|
|
153
|
+
out.push_str(&format!(
|
|
154
|
+
"\nRTK_DISABLED BYPASS -- {} commands ran without filtering\n",
|
|
155
|
+
report.rtk_disabled_count
|
|
156
|
+
));
|
|
157
|
+
out.push_str(&"-".repeat(72));
|
|
158
|
+
out.push('\n');
|
|
159
|
+
out.push_str("These commands used RTK_DISABLED=1 unnecessarily:\n");
|
|
160
|
+
if !report.rtk_disabled_examples.is_empty() {
|
|
161
|
+
out.push_str(&format!(" {}\n", report.rtk_disabled_examples.join(", ")));
|
|
162
|
+
}
|
|
163
|
+
out.push_str("-> Remove RTK_DISABLED=1 to recover token savings\n");
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
out.push_str("\n~estimated from tool_result output sizes\n");
|
|
167
|
+
|
|
168
|
+
if verbose && report.parse_errors > 0 {
|
|
169
|
+
out.push_str(&format!("Parse errors skipped: {}\n", report.parse_errors));
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
out
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
/// Format report as JSON.
|
|
176
|
+
pub fn format_json(report: &DiscoverReport) -> String {
|
|
177
|
+
serde_json::to_string_pretty(report).unwrap_or_else(|_| "{}".to_string())
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
fn format_tokens(tokens: usize) -> String {
|
|
181
|
+
if tokens >= 1_000_000 {
|
|
182
|
+
format!("{:.1}M tokens", tokens as f64 / 1_000_000.0)
|
|
183
|
+
} else if tokens >= 1_000 {
|
|
184
|
+
format!("{:.1}K tokens", tokens as f64 / 1_000.0)
|
|
185
|
+
} else {
|
|
186
|
+
format!("{} tokens", tokens)
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
fn truncate_str(s: &str, max: usize) -> String {
|
|
191
|
+
if s.len() <= max {
|
|
192
|
+
s.to_string()
|
|
193
|
+
} else {
|
|
194
|
+
// UTF-8 safe truncation: collect chars up to max-2, then add ".."
|
|
195
|
+
let truncated: String = s
|
|
196
|
+
.char_indices()
|
|
197
|
+
.take_while(|(i, _)| *i < max.saturating_sub(2))
|
|
198
|
+
.map(|(_, c)| c)
|
|
199
|
+
.collect();
|
|
200
|
+
format!("{}..", truncated)
|
|
201
|
+
}
|
|
202
|
+
}
|