Dotnet-skills dotnet-resharper-clt
Use the free official JetBrains ReSharper Command Line Tools for .NET repositories. Use when a repo wants powerful `jb inspectcode` inspections, `jb cleanupcode` cleanup profiles, solution-level `.DotSettings` enforcement, or a stronger CLI quality gate for C# than the default SDK analyzers alone.
install
source · Clone the upstream repo
git clone https://github.com/managedcode/dotnet-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/managedcode/dotnet-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/catalog/Tools/ReSharper-CLT/skills/dotnet-resharper-clt" ~/.claude/skills/managedcode-dotnet-skills-dotnet-resharper-clt && rm -rf "$T"
manifest:
catalog/Tools/ReSharper-CLT/skills/dotnet-resharper-clt/SKILL.mdsource content
ReSharper Command Line Tools
Trigger On
- the repo uses or wants ReSharper Command Line Tools
- the team wants
orjb inspectcodejb cleanupcode - the user asks for stronger C# inspections, cleanup profiles, or ReSharper-based CI gates
Value
- produce a concrete project delta: code, docs, config, tests, CI, or review artifact
- reduce ambiguity through explicit planning, verification, and final validation skills
- leave reusable project context so future tasks are faster and safer
Do Not Use For
- replacing tests with inspection output
- ad-hoc formatting-only work when the repo intentionally standardizes on another formatter
- repos that do not want JetBrains settings or CLT-based gates in their workflow
Inputs
- the nearest
AGENTS.md - the target
,.sln
, or bounded file set.csproj - repo-root
.editorconfig - solution shared settings such as
YourSolution.sln.DotSettings
Quick Start
- Read the nearest
and confirm scope and constraints.AGENTS.md - Run this skill's
through theWorkflow
until outcomes are acceptable.Ralph Loop - Return the
with concrete artifacts and verification evidence.Required Result Format
Workflow
- Prefer solution-level runs when possible so ReSharper can resolve references and apply full inspections.
- Build the solution before
when working at solution scope.jb cleanupcode - Use
first to surface issues before editing anything broad.jb inspectcode - Treat surfaced issues as mandatory fixes when this gate is enabled for the repo; do not just dump a report and stop.
- Use
with an explicit cleanup profile:jb cleanupcodeBuilt-in: Full CleanupBuilt-in: Reformat CodeBuilt-in: Reformat & Apply Syntax Style- or a checked-in custom profile
- Keep durable ReSharper settings in the team-shared solution layer and commit the solution
file when policy changes..DotSettings - Re-run
after cleanup or fixes, then run the repo's normal quality pass and tests.jb inspectcode
Bootstrap When Missing
If ReSharper Command Line Tools are not available yet:
- Detect current state:
rg --files -g '.config/dotnet-tools.json' -g '*.sln.DotSettings'dotnet tool list --localdotnet tool list --globalcommand -v jb
- Choose the install path deliberately:
- preferred repo-local install for reproducible CI:
(if missing)dotnet new tool-manifestdotnet tool install JetBrains.ReSharper.GlobalTools
- global fallback:
dotnet tool install --global JetBrains.ReSharper.GlobalTools
- preferred repo-local install for reproducible CI:
- Verify the installed commands resolve correctly:
jb inspectcode --helpjb cleanupcode --help
- Record exact commands in
, for example:AGENTS.mddotnet build MySolution.sln -c Releasejb inspectcode MySolution.sln -o=artifacts/inspectcode.sarifjb cleanupcode MySolution.sln --profile="Built-in: Full Cleanup"
- If the repo needs stable settings, save them into the solution team-shared layer and commit
.YourSolution.sln.DotSettings - Run
once, fix or triage the surfaced issues, rerun it, and returnjb inspectcode
orstatus: configured
.status: improved - If the repo intentionally excludes ReSharper CLT from its toolchain, return
.status: not_applicable
Deliver
- explicit
andjb inspectcode
commandsjb cleanupcode - durable ReSharper settings in shared solution config
- a quality gate that surfaces issues which are then fixed, not ignored
Validate
- the target solution or project builds before solution-wide cleanup
output is reviewed and acted onjb inspectcode- cleanup profiles and shared settings are explicit
- tests and the wider quality pass still run after ReSharper-driven fixes
Ralph Loop
Use the Ralph Loop for every task, including docs, architecture, testing, and tooling work.
- Plan first (mandatory):
- analyze current state
- define target outcome, constraints, and risks
- write a detailed execution plan
- list final validation skills to run at the end, with order and reason
- Execute one planned step and produce a concrete delta.
- Review the result and capture findings with actionable next fixes.
- Apply fixes in small batches and rerun the relevant checks or review steps.
- Update the plan after each iteration.
- Repeat until outcomes are acceptable or only explicit exceptions remain.
- If a dependency is missing, bootstrap it or return
with explicit reason and fallback path.status: not_applicable
Required Result Format
:status
|complete
|clean
|improved
|configured
|not_applicableblocked
: concise plan and current iteration stepplan
: concrete changes madeactions_taken
: final skills run, or skipped with reasonsvalidation_skills
: commands, checks, or review evidence summaryverification
: top unresolved items orremainingnone
For setup-only requests with no execution, return
status: configured and exact next commands.
Load References
references/resharper-clt.mdreferences/commands.mdreferences/config.md
Example Requests
- "Add ReSharper CLI inspections to this .NET repo."
- "Run InspectCode and fix what it finds."
- "Set up CleanupCode with a shared profile."
- "Use JetBrains ReSharper command line tools in CI."