multiAI Summary Pending
lint-dotnet
Run .NET architecture linter to check for MSBuild/CPM violations
231 stars
Installation
Claude Code / Cursor / Codex
$curl -o ~/.claude/skills/lint-dotnet/SKILL.md --create-dirs "https://raw.githubusercontent.com/aiskillstore/marketplace/main/skills/ancplua/lint-dotnet/SKILL.md"
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/lint-dotnet/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How lint-dotnet Compares
| Feature / Agent | lint-dotnet | Standard Approach |
|---|---|---|
| Platform Support | multi | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Run .NET architecture linter to check for MSBuild/CPM violations
Which AI agents support this skill?
This skill is compatible with multi.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# /lint-dotnet
Run the .NET architecture linter on demand to check for violations.
## Execution
```bash
bash "${CLAUDE_PLUGIN_ROOT}/scripts/lint-dotnet.sh" .
```
## Output Format
```
RULE_X|file
line_number: violation details
```
## Rules
| Rule | Catches | Fix |
|------|---------|-----|
| RULE_A | Hardcoded `Version="1.2.3"` in Directory.Packages.props | Use `$(VariableName)` and define in Version.props |
| RULE_B | Version.props imported outside allowed files | Remove import. Only DPP or eng/DBP allowed. |
| RULE_C | Version.props not a symlink (in consumer repos) | Recreate symlink, never copy the file |
| RULE_G | `<PackageReference Version="...">` in .csproj | Remove Version attr, use CPM |
## Allowed Version.props Import Owners
| File | Purpose |
|------|---------|
| `Directory.Packages.props` | CPM-enabled projects |
| `eng/Directory.Build.props` | CPM-disabled projects |
| `src/Sdk/*/Sdk.props` | SDK entry points (MSBuild auto-imports these) |
| `src/common/*.props` | Shared SDK infrastructure |
All other files importing Version.props = violation.
## Clean Output
```
CLEAN|All rules passed
```
No violations found. Safe to proceed.
## Variable Naming Convention
For unknown packages, generate variable name:
- `Some.Package.Name` -> `SomePackageNameVersion`
- Remove dots and dashes, append "Version"