Skills resolve-project-references
Guide for interpreting ResolveProjectReferences time in MSBuild performance summaries. Only activate in MSBuild/.NET build context. Activate when ResolveProjectReferences appears as the most expensive target and developers are trying to optimize it directly. Explains that the reported time includes wait time for dependent project builds and is misleading. Guides users to focus on task self-time instead. Do not activate for general build performance -- use build-perf-diagnostics instead.
git clone https://github.com/dotnet/skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/dotnet/skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/dotnet-msbuild/skills/resolve-project-references" ~/.claude/skills/dotnet-skills-resolve-project-references && rm -rf "$T"
plugins/dotnet-msbuild/skills/resolve-project-references/SKILL.mdMisleading ResolveProjectReferences Time
Prevent misguided optimization of
ResolveProjectReferences by explaining that its reported time is wall-clock wait time, not CPU work.
When to Use
appears as the most expensive target in the Target Performance SummaryResolveProjectReferences- A developer is trying to optimize
directlyResolveProjectReferences - Build performance analysis shows a single target consuming 50-80% of total build time
When Not to Use
- General build performance optimization (use
instead)build-perf-diagnostics - The bottleneck is clearly a different target (e.g.,
,Csc
)ResolveAssemblyReference - The user has not yet captured a binlog or performance summary
Inputs
| Input | Required | Description |
|---|---|---|
| Build log or binlog | Yes | A diagnostic build log or binlog containing the Target Performance Summary |
Workflow
Step 1: Confirm the misleading symptom
Verify that
ResolveProjectReferences appears as the top target in the Target Performance Summary. This is the misleading metric.
Step 2: Explain why it is misleading
The reported time includes waiting for dependent projects to build while the MSBuild node is yielded (see dotnet/msbuild#3135). During this wait, the node may be doing useful work on other projects. The target itself does very little work.
Step 3: Redirect to task self-time
Guide the user to use the Task Performance Summary instead:
dotnet msbuild build.binlog -noconlog -fl "-flp:v=diag;logfile=full.log;performancesummary" grep "Task Performance Summary" -A 50 full.log
Focus on self-time of actual tasks:
- Csc: see
skill (Section 2: Roslyn Analyzers)build-perf-diagnostics - ResolveAssemblyReference: see
skill (Section 1: RAR)build-perf-diagnostics - Copy: see
skill (Section 4: File I/O)build-perf-diagnostics - Serialization bottlenecks: see
skillbuild-parallelism
Validation
- Task Performance Summary was used instead of Target Performance Summary
-
was not set as the optimization targetResolveProjectReferences - A concrete task (e.g.,
,Csc
,Copy
) was identified as the true bottleneckResolveAssemblyReference