Marketplace lint-dotnet
Run .NET architecture linter to check for MSBuild/CPM violations
install
source · Clone the upstream repo
git clone https://github.com/aiskillstore/marketplace
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/aiskillstore/marketplace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/ancplua/lint-dotnet" ~/.claude/skills/aiskillstore-marketplace-lint-dotnet && rm -rf "$T"
manifest:
skills/ancplua/lint-dotnet/SKILL.mdsource content
/lint-dotnet
Run the .NET architecture linter on demand to check for violations.
Execution
bash "${CLAUDE_PLUGIN_ROOT}/scripts/lint-dotnet.sh" .
Output Format
RULE_X|file line_number: violation details
Rules
| Rule | Catches | Fix |
|---|---|---|
| RULE_A | Hardcoded in Directory.Packages.props | Use 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 | in .csproj | Remove Version attr, use CPM |
Allowed Version.props Import Owners
| File | Purpose |
|---|---|
| CPM-enabled projects |
| CPM-disabled projects |
| SDK entry points (MSBuild auto-imports these) |
| 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.NameSomePackageNameVersion- Remove dots and dashes, append "Version"