Zurück zu Fähigkeiten

resolve-git-conflicts

pjt222
Aktualisiert 2 days ago
1 Ansichten
17
2
17
Auf GitHub ansehen
Designaiapidesign

Über

Dieses Claude Skill unterstützt Entwickler bei der Lösung von Git-Merge-, Rebase- und Cherry-Pick-Konflikten, indem es Konfliktquellen identifiziert, Marker ausliest und Lösungsstrategien auswählt. Es bietet sichere Wiederherstellungsoptionen, einschließlich der Fortsetzung von Operationen oder des Abbruchs fehlgeschlagener Merges/Rebases. Nutzen Sie es, wenn Git-Befehle Konflikte melden oder wenn Sie fehlgeschlagene Versionskontrolloperationen sicher neu starten müssen.

Schnellinstallation

Claude Code

Empfohlen
Primär
npx skills add pjt222/agent-almanac -a claude-code
Plugin-BefehlAlternativ
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativ
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/resolve-git-conflicts

Kopieren Sie diesen Befehl und fügen Sie ihn in Claude Code ein, um diese Fähigkeit zu installieren

Dokumentation

Resolve Git Conflicts

Identify, resolve, recover from merge and rebase conflicts.

When Use

  • git merge or git rebase reports conflicts
  • git cherry-pick cannot apply cleanly
  • git pull results in conflicting changes
  • git stash pop conflicts with current working tree

Inputs

  • Required: Repository with active conflicts
  • Optional: Preferred resolution strategy (ours, theirs, manual)
  • Optional: Context about which changes should take priority

Steps

Step 1: Identify Conflict Source

Determine what operation caused conflict:

# Check current status
git status

# Look for indicators:
# "You have unmerged paths" — merge conflict
# "rebase in progress" — rebase conflict
# "cherry-pick in progress" — cherry-pick conflict

Status output tells you which files have conflicts and what operation in progress.

Got: git status shows files listed under "Unmerged paths" and indicates active operation.

If fail: git status shows clean tree but you expected conflicts? Operation may have already been completed or aborted. Check git log for recent activity.

Step 2: Read Conflict Markers

Open each conflicting file. Locate conflict markers:

<<<<<<< HEAD
// Your current branch's version
const result = calculateWeightedMean(data, weights);
=======
// Incoming branch's version
const result = computeWeightedAverage(data, weights);
>>>>>>> feature/rename-functions
  • <<<<<<< HEAD to =======: Your current branch (or branch you are rebasing onto)
  • ======= to >>>>>>>: Incoming changes (branch being merged or commit being applied)

Got: Each conflicting file contains one or more blocks with <<<<<<<, =======, >>>>>>> markers.

If fail: No markers found but files show as conflicting? Conflict may be binary file or deleted-vs-modified conflict. Check git diff --name-only --diff-filter=U for full list.

Step 3: Choose Resolution Strategy

Manual merge (most common): Edit file to combine both changes logically. Then remove all conflict markers.

Accept ours (keep current branch version):

# For a single file
git checkout --ours path/to/file.R
git add path/to/file.R

# For all conflicts
git checkout --ours .
git add -A

Accept theirs (keep incoming branch version):

# For a single file
git checkout --theirs path/to/file.R
git add path/to/file.R

# For all conflicts
git checkout --theirs .
git add -A

Got: After resolution, file contains correct merged content with no remaining conflict markers.

If fail: Chose wrong side? Re-read conflicting version from merge base. During merge, git checkout -m path/to/file re-creates conflict markers so you can try again.

Step 4: Mark Files as Resolved

After editing each conflicting file:

# Stage the resolved file
git add path/to/resolved-file.R

# Check remaining conflicts
git status

Repeat for every file listed under "Unmerged paths".

Got: All files move from "Unmerged paths" to "Changes to be committed". No conflict markers remain in any file.

If fail: git add fails or markers remain? Re-open file and ensure all <<<<<<<, =======, >>>>>>> lines removed.

Step 5: Continue the Operation

Once all conflicts resolved:

For merge:

git commit
# Git auto-populates the merge commit message

For rebase:

git rebase --continue
# May encounter more conflicts on subsequent commits — repeat steps 2-4

For cherry-pick:

git cherry-pick --continue

For stash pop:

# Stash pop conflicts don't need a continue — just commit or reset
git add .
git commit -m "Apply stashed changes with conflict resolution"

Got: Operation completes. git status shows clean working tree (or moves to next commit during rebase).

If fail: Continue command fails? Check git status for remaining unresolved files. All conflicts must be resolved before continue.

Step 6: Abort if Needed

Resolution too complex or chose wrong approach? Abort safely:

# Abort merge
git merge --abort

# Abort rebase
git rebase --abort

# Abort cherry-pick
git cherry-pick --abort

Got: Repository returns to state before operation started. No data loss.

If fail: Abort fails (rare)? Check git reflog to find commit before operation. Then git reset --hard <commit> to restore it. Use with caution — discards uncommitted changes.

Step 7: Verify Resolution

After operation completes:

# Verify clean working tree
git status

# Check that the merge/rebase result is correct
git log --oneline -5
git diff HEAD~1

# Run tests to confirm nothing is broken
# (language-specific: devtools::test(), npm test, cargo test, etc.)

Got: Clean working tree, correct merge history, tests pass.

If fail: Tests fail after resolution? Merge may have introduced logical errors even though syntax conflicts resolved. Review diff careful and fix.

Checks

  • No conflict markers (<<<<<<<, =======, >>>>>>>) remain in any file
  • git status shows clean working tree
  • Merge/rebase history correct in git log
  • Tests pass after conflict resolution
  • No unintended changes introduced

Pitfalls

  • Blindly accept one side: --ours or --theirs discards other side entirely. Only use when certain one version completely correct.
  • Leave conflict markers in code: Always search entire file for remaining markers after editing. Partial resolution breaks the code.
  • Amend during rebase: During interactive rebase, do not --amend unless rebase step specifically calls for it. Use git rebase --continue instead.
  • Lose work on abort: git rebase --abort and git merge --abort discard all resolution work. Only abort if want to start over.
  • No test after resolution: Syntactically clean merge can still be logically wrong. Always run tests.
  • Force-push after rebase: After rebasing shared branch, coordinate with collaborators before force-pushing — it rewrites history.

See Also

  • commit-changes - committing after conflict resolution
  • manage-git-branches - branch workflows that lead to conflicts
  • configure-git-repository - repository setup and merge strategies

GitHub Repository

pjt222/agent-almanac
Pfad: i18n/caveman/skills/resolve-git-conflicts
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Verwandte Skills

executing-plans

Design

Verwenden Sie die Fähigkeit "executing-plans", wenn Sie einen vollständigen Implementierungsplan zur Ausführung in kontrollierten Batches mit Überprüfungspunkten vorliegen haben. Sie lädt den Plan und überprüft ihn kritisch, führt dann Aufgaben in kleinen Batches (standardmäßig 3 Aufgaben) aus und meldet den Fortschritt zwischen jedem Batch zur Überprüfung durch den Architekten. Dies gewährleistet eine systematische Implementierung mit integrierten Qualitätskontrollpunkten.

Skill ansehen

requesting-code-review

Design

Diese Fähigkeit sendet einen Unteragenten für Code-Review, um Codeänderungen anhand der Anforderungen zu analysieren, bevor fortgefahren wird. Sie sollte nach dem Abschließen von Aufgaben, der Implementierung größerer Funktionen oder vor dem Zusammenführen in den Hauptzweig verwendet werden. Die Überprüfung hilft dabei, Probleme frühzeitig zu erkennen, indem die aktuelle Implementierung mit dem ursprünglichen Plan verglichen wird.

Skill ansehen

connect-mcp-server

Design

Diese Fähigkeit bietet Entwicklern eine umfassende Anleitung, um MCP-Server über HTTP-, stdio- oder SSE-Transports mit Claude Code zu verbinden. Sie behandelt Installation, Konfiguration, Authentifizierung und Sicherheit für die Integration externer Dienste wie GitHub, Notion und benutzerdefinierter APIs. Nutzen Sie sie beim Einrichten von MCP-Integrationen, bei der Konfiguration externer Tools oder bei der Arbeit mit Claude's Model Context Protocol.

Skill ansehen

web-cli-teleport

Design

Diese Fähigkeit unterstützt Entwickler bei der Wahl zwischen Claude Code Web- und CLI-Schnittstellen basierend auf Aufgabenanalysen und ermöglicht nahtloses Session-Teleporting zwischen diesen Umgebungen. Sie optimiert den Workflow, indem sie den Sitzungsstatus und Kontext beim Wechsel zwischen Web, CLI oder Mobilgeräten verwaltet. Nutzen Sie sie für komplexe Projekte, die in verschiedenen Phasen unterschiedliche Werkzeuge erfordern.

Skill ansehen