update-existing-branch
Update Existing Branch
Use this skill when the milestone branch already exists and contains drafted
markdown, features.json, reviewer comments, or human edits.
This is the incremental rerun stage of the release-notes pipeline. It is the
branch-maintenance equivalent of what editorial-scoring is for scoring: the
canonical place to describe how follow-up runs should behave.
Purpose
Treat the existing branch as the working baseline, not as a blank slate.
The goal is to:
- refresh shipped-change data only when the preview actually moved forward
- score and write the delta, not the whole release again
- preserve human edits and reviewer-driven rewrites
- integrate new material into the current story cleanly
Inputs
Read these before making changes:
- the current milestone branch and PR
- the existing
changes.json,features.json, and markdown files build-metadata.json, if present- unresolved PR review comments and discussion threads
Process
1. Check whether the preview moved forward
Determine whether later dotnet/dotnet codeflow commits landed for the same
preview branch or tag since the last run.
If the relevant VMR ref moved forward, regenerate changes.json. If it did not,
keep the current file and focus on editorial fixes and comment responses.
Typical signals:
- later commits on
dotnet/dotnetforrelease/<major>.0.1xx-previewN - a newer release-branch head than the one captured in
build-metadata.json - new source-manifest commits for a component already discussed in the draft
2. Compute a delta from the existing files
If you refreshed changes.json, compare the old and new files by stable id.
Classify changes as:
- added — new shipped items not seen in the last run
- changed — same
id, but new evidence, labels, revert state, or reviewer context changes the treatment - removed or superseded — no longer relevant to the current build story, or later evidence shows the original interpretation was wrong
- unchanged — keep the prior editorial work
Do not treat a refreshed changes.json as permission to restart the whole
release from zero.
3. Merge into the existing features.json
When features.json already exists, use it as the editorial baseline and merge
the delta into it.
Preserve prior annotations for unchanged entries, including:
scorescore_reasonscore_breakdownbreaking_changesreverted_by/reverts- useful human notes or hand-tuned annotations
Only rescore:
- newly added entries
- materially changed entries
- earlier entries that reviewers explicitly questioned or that new evidence disproved
This should feel like a delta merge, not a full rescore.
4. Update markdown in place
Use the current draft as the starting point. Prefer integration over duplication.
Examples:
- add a new GC item into an existing Garbage Collection Performance Improvements section
- extend an existing Unsafe Evolution block instead of creating a second heading
- move a newly demoted item into Bug fixes instead of deleting the story without explanation
Keep the existing structure when it still works. Add a new top-level section only when the delta introduces a genuinely new story.
5. Treat review comments as required inputs
Unresolved PR comments are part of the spec for the next run.
- read them before rewriting anything
- answer factual questions with evidence from
changes.json, VMR refs, API verification, or the final build - update the markdown when the reviewer is right
- if the reviewer is directionally right but the current build still contains the feature, explain the milestone and branch context clearly
6. Default outcome
For an existing release-notes branch, the normal loop is:
- refresh
changes.jsononly if the preview moved forward - merge the delta into
features.json - update the existing markdown in place
- respond to comments and questions
- push a follow-up commit to the same PR
This keeps the branch stable for reviewers and avoids throwing away already curated editorial work.