Dotnet-skills dotnet-analyzer-config
Use a repo-root `.editorconfig` to configure free .NET analyzer and style rules. Use when a .NET repo needs rule severity, code-style options, section layout, or analyzer ownership made explicit. Nested `.editorconfig` files are allowed when they serve a clear subtree-specific purpose.
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/Analyzer-Config/skills/dotnet-analyzer-config" ~/.claude/skills/managedcode-dotnet-skills-dotnet-analyzer-config && rm -rf "$T"
manifest:
catalog/Tools/Analyzer-Config/skills/dotnet-analyzer-config/SKILL.mdsource content
.NET Analyzer Configuration
Trigger On
- the repo needs a root
.editorconfig - analyzer severity and style ownership are unclear
- the team wants one source of truth for rule configuration
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
- choosing analyzers with no config change
- formatting-only execution with no config ownership question
Inputs
- the nearest
AGENTS.md - current
.editorconfig - any
overridesDirectory.Build.props
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 one repo-root
with.editorconfig
.root = true - Add nested
files when a subtree has a clear scoped purpose, such as stricter rules, different generated-code handling, or a different policy for tests or legacy code..editorconfig - Keep severity in
, not scattered through IDE settings..editorconfig - Write the file as real EditorConfig, not as a made-up
variant:.NET- lowercase filename
.editorconfig
in the preambleroot = true- no inline comments
- forward slashes in globs
- lowercase filename
- Keep bulk switches such as
in MSBuild files, not inEnableNETAnalyzers
..editorconfig - Treat
as an exceptional case, not the normal repo setup..globalconfig
Bootstrap When Missing
If analyzer configuration is requested but not structured yet:
- Detect current state:
rg --files -g '.editorconfig' -g '.globalconfig'rg -n "EnableNETAnalyzers|AnalysisLevel|AnalysisMode" -g '*.csproj' -g 'Directory.Build.*' .
- Create or normalize one repo-root
with.editorconfig
.root = true - Move rule severity into
and keep bulk analyzer switches in project or MSBuild config..editorconfig - Add nested
files only when a subtree really needs different scoped policy..editorconfig - Run
and returndotnet build SOLUTION_OR_PROJECT
orstatus: configured
.status: improved - If the repo intentionally uses another documented analyzer-config ownership model, return
.status: not_applicable
Deliver
- one explicit analyzer configuration ownership model
- a root
layout that agents can extend safely.editorconfig
Validate
- rule severity is reproducible in local and CI builds
- IDE-only settings do not silently override repo policy
- the default path is a root
, not a surprise alternative.editorconfig
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/analyzer-config.mdreferences/template.mdreferences/rules.md
Example Requests
- "Make
the source of truth.".editorconfig - "Write a proper root
for this repo.".editorconfig - "Fix conflicting analyzer severities in this .NET repo."