OpenSpace typescript-compile-check-resilient-fallback
A resilient workflow for running TypeScript compile checks (tsc --noEmit) that falls back gracefully when npx or direct binary invocations fail, and distinguishes pre-existing errors from newly introduced ones.
install
source · Clone the upstream repo
git clone https://github.com/HKUDS/OpenSpace
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/HKUDS/OpenSpace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/showcase/skills/typescript-compile-check-resilient-fallback" ~/.claude/skills/hkuds-openspace-typescript-compile-check-resilient-fallback && rm -rf "$T"
manifest:
showcase/skills/typescript-compile-check-resilient-fallback/SKILL.mdsource content
TypeScript Compile-Check Resilient Fallback
Use this workflow whenever you need to verify that TypeScript files compile cleanly after creating or modifying them, especially in environments where
npx or direct ./node_modules/.bin/tsc invocations may return unexpected
errors.
Step 1 — Attempt Primary Invocation
Run the compile check with
run_shell using the standard approach:
npx tsc --noEmit
or, if you already know the project root:
./node_modules/.bin/tsc --noEmit
Evaluate the result:
- If it exits cleanly (exit code 0, no unexpected output) → done.
- If it exits with TypeScript diagnostic errors → proceed to Step 3.
- If it exits with an unknown / tool-level error (e.g.,
not found, permission denied, spawn error, unclear non-zero exit unrelated to TS diagnostics) → proceed to Step 2.npx
Step 2 — Fallback via shell_agent
shell_agentWhen the primary invocation fails with an unknown error, delegate to
shell_agent so it can resolve environment issues automatically:
Task: "From the project directory
, run<PROJECT_DIR>and report all TypeScript diagnostic errors."node node_modules/typescript/bin/tsc --noEmit
Example
shell_agent task string:
From /path/to/project, run: node node_modules/typescript/bin/tsc --noEmit Capture the full stdout/stderr output and return it.
shell_agent will handle PATH issues, working-directory changes, and
retry on transient failures automatically.
Step 3 — Filter Pre-Existing Errors
TypeScript projects frequently have pre-existing errors in files you did not touch. To avoid false regressions:
- Identify the baseline error count for the project (e.g., determined at task start or documented in task context). A common baseline is 11 pre-existing errors in unrelated files.
- Collect the full diagnostic list from tsc output.
- Filter to keep only errors whose file path matches a file you created or modified in this task.
- Evaluate:
- Zero errors in your new/modified files → ✅ no regression introduced.
- One or more errors in your new/modified files → ❌ fix them before proceeding.
Filtering heuristic (pseudocode)
all_errors = parse_tsc_output(tsc_stdout) my_files = [list of files created/modified in this task] new_errors = [e for e in all_errors if e.file in my_files] if len(new_errors) == 0: print("✅ No new TypeScript errors introduced.") else: for err in new_errors: print(f"❌ {err.file}:{err.line} — {err.message}") raise Exception("Fix TypeScript errors before continuing.")
Step 4 — Fix and Re-Run
If new errors are found:
- Fix the errors in your file(s).
- Repeat from Step 1.
Decision Tree Summary
run_shell: npx tsc --noEmit │ ├─ clean exit ──────────────────────────────► ✅ Done │ ├─ TS diagnostic errors ────────────────────► Step 3 (filter) │ └─ unknown/tool error │ └─ shell_agent: node .../tsc --noEmit │ ├─ TS diagnostic errors ────► Step 3 (filter) └─ clean exit ──────────────► ✅ Done
Notes
- Always run tsc from the project root (where
lives).tsconfig.json - The
invocation is the most portable fallback because it bypassesnode node_modules/typescript/bin/tsc
, shell PATH lookups, and binary permission issues entirely.npx - When the baseline error count is unknown, run tsc before making any changes and record the count; that becomes your baseline.
- Only report/act on errors in files you own; never attempt to fix pre-existing errors in third-party or unrelated project files unless explicitly asked.