דביר נעמן

סקיל Git Worktrees לקלוד קוד
סקילים לקלוד קוד

סקיל Git Worktrees

11 דקות קריאה דביר נעמן

using-git-worktrees הוא הסקיל שעוזר לקלוד קוד לעבוד על כמה branches בו-זמנית בלי לשבור את הסביבה הראשית. הוא מנצל את git worktree, פיצ'ר בסיסי של git שמאפשר checkout של branches נוספים בתיקיות נפרדות, ומלמד את הסוכן מתי וכיצד להשתמש בו. בעבודה אוטונומית עם subagents מקבילים, הסקיל הוא חובה. במדריך תקבלו את הקוד המלא, דוגמאות תרחישים, ובדיקת אבטחה.

תמונת כותרת לפוסט: סקיל Git Worktrees

פקודת התקנה

מפתח: Superpowers
קטגוריה: Git Workflow
התקנות: כ-64K בשבוע
רישיון: MIT
npx skills add https://github.com/obra/superpowers --skill using-git-worktrees

הסקיל הוא קובץ Markdown פתוח עם רישיון MIT. אפשר להוריד ולהריץ בדיקת קוד לפני התקנה.

מה הסקיל כולל?

הסקיל מתעד את התרחישים שבהם git worktree יעיל, ואת הסיכונים שיש להימנע מהם. הוא כולל פקודות, מבנה תיקיות מומלץ, וניהול נכון של branches בעבודה מקבילית.

מתי לפתוח worktree (subagent מקביל, פיצ׳ר ניסיון)
פקודות יסוד: add, remove, list, prune
מבנה תיקיות מומלץ לפרויקט מורכב
טיפול בקבצים שאינם git-tracked
סנכרון בין worktrees לפני merge
מתי לא להשתמש (פרויקטים קטנים, branches קצרים)

קוד הסקיל המלא

Markdown

מה זה Git Worktrees ולמה הסקיל הזה שונה?

Git Worktree זה פיצ'ר ב-git שמאפשר checkout של branch בתיקייה נפרדת בלי לעזוב את ה-branch הנוכחי. עד 2018 רובם לא ידעו שהפיצ'ר קיים, ועד היום הוא לא בשימוש נפוץ. הסקיל הזה מלמד את קלוד קוד מתי וכיצד להשתמש בו.

הבעיה שהוא פותר עולה במצבים של עבודה מקבילית, פיצ'ר ארוך ש-PR שלו פתוח כבר שבוע, ופתאום צריך תיקון דחוף ב-main. בלי worktree, הסוכן יעשה stash, יחליף branch, יתקן, יחזיר. זה איטי ומועד לאיבוד שינויים. עם worktree, יש שני פוסטים נפרדים שמשתמשים באותו .git, ואפשר לעבוד בשניהם בו-זמנית.

בשילוב עם סקיל dispatching-parallel-agents, מקבלים את היכולת להריץ subagents שעובדים על branches שונים בלי שיתערבו זה בזה. בפרויקטי לקוחות שאני בונה עם subagents מקבילים, הסקיל הזה הוא תשתית חובה.

מה Git Worktrees נותן לקלוד קוד?

הסקיל מוסיף לקלוד יכולת ניהול עבודה מקבילית. בלעדיו, הסוכן ייפתר את כל המצבים עם stash + checkout. עם הסקיל, הוא בוחר באופן חכם.

עבודה מקבילית

הסקיל יודע לזהות מצבים שדורשים worktree (כמו hot fix במקביל לפיצ'ר). הוא פותח worktree, עובד שם, וסוגר בסיום. ה-branch הראשי נשאר לא נגוע.

subagents מבודדים

כש-subagents רצים במקביל, הסקיל פותח לכל אחד worktree משלו. הם לא מתערבים זה בזה, וכל אחד עובד על branch נפרד בלי קונפליקטים.

ניקיון אוטומטי

בסיום עבודה, הסקיל יודע לסגור worktree באופן נקי, prune אוטומטית. אין שכפולים נשכחים שתופסים מקום.

ייעוץ מתי לא

לא כל מצב מצדיק worktree. הסקיל מסביר מתי checkout פשוט עדיף, ומונע over-engineering.

התוצאה: עבודה מקבילית בלי כאב. בפרויקטים שלי, חיסכון של 20-30 אחוז מזמן הפיתוח כשעובדים עם subagents.

למי הסקיל הזה מתאים?

מובילים שמשתמשים ב-subagents מקבילים: בלי worktree, subagents מתנגשים. עם הסקיל, כל subagent על worktree משלו ועובד בנינוחות.

מהנדסים עם פיצ'רים ארוכים: כשפיצ'ר נמשך שבועיים והוא צריך להיכנס ל-main לתיקון דחוף, worktree חוסך עשרות פקודות stash מבולבלות.

צוותי DevOps שעובדים על מספר branches: בדיקות שונות לכל branch של release. הסקיל פותח worktrees ייעודיים שאפשר להריץ עליהם CI מקומי.

פרילנסרים עם כמה לקוחות במקביל: כל לקוח עם branch משלו. worktree מאפשר לעבור ביניהם בלי checkouts.

מתחילים שלומדים git מתקדם: הסקיל הוא דרך מצוינת ללמוד worktree בעזרה של AI שיודע מתי כן ומתי לא.

מי שלא מתאים: פרויקטים קטנים עם branch אחד פעיל. תקורה ללא ערך מוסף.

איך git-worktrees עזר לי בפרויקטים אמיתיים

01

הוטפיקס בלי לשבור פיצ'ר ארוך

באמצע פיתוח של 5 ימים על דשבורד חדש, התגלה bug בייצור. הסקיל פתח worktree על main, תיקן, ו-deploy. כל הזמן הזה, ה-worktree של הדשבורד נשאר נקי. לא איבדנו קונטקסט.

hotfixno context loss
02

3 subagents מקביליים על 3 פיצ׳רים

ביקשתי משלושה subagents לפתח שלושה פיצ׳רים שונים. הסקיל פתח שלוש worktrees, אחד לכל subagent. כולם רצו במקביל, אפס conflict. סיום של 3 פיצ'רים תוך שעתיים במקום 6.

parallel agentsthroughput
03

בדיקה השוואתית של 2 פתרונות

הייתי בלבן בין שתי גישות לפיצ'ר. עם הסקיל, יצרתי שתי worktrees, פיתחתי כל אחת בנפרד, השוויתי בפועל. ההחלטה התקבלה על בסיס קוד שעובד, לא על דמיון.

A/Bdecision
04

ניקיון אוטומטי של 14 worktrees ישנות

אחרי שנה של עבודה, הצטברו 14 worktrees לא בשימוש. הסקיל זיהה אותם ב-prune אוטומטית והעביר אותי על אישור לפני מחיקה. שיחזרנו 12 GB של מקום.

cleanupdisk

הסקיל הופך פיצ'ר git שאף אחד לא משתמש בו לחלק בסיסי מהעבודה. בשילוב עם dispatching-parallel-agents מקבלים מכפיל כוח אמיתי.

שילובים נוספים: grill-with-docs לתיקוף תוכניות, סקיל TDD לאיכות, ו-בעבודות שיווק במייל זה רלוונטי לכל מי שעובד על platforms פנימיות עם פיצ'רים מקבילים.

סיכום

סקיל using-git-worktrees הוא הסקיל שאני ממליץ עליו לכל מהנדס שעובד על יותר מפיצ'ר אחד במקביל, או שמריץ סוכני AI מרובים. במקום להחליף ענפים בלי סוף, worktrees מאפשרים לך לעבוד על שניים-שלושה בו זמנית, כל אחד בתיקייה משלו.

אם אתם מתחילים, התקינו את הסקיל ובקשו «צור worktree לפיצ'ר X». הסקיל יבחר תיקייה, יקבע branch, ויאתחל את הסביבה. תוך דקה תוכלו לעבוד במקביל בחלון אחר. בעבודה עם סוכנים, זה מאפשר להריץ שניים-שלושה במקביל בלי קונפליקטים.

הסקיל הוא הבסיס לעבודה מתקדמת עם סקיל parallel-agents ועם subagent-driven-development, שניהם מצריכים worktrees כדי לתפקד נכון. שילוב נוסף הוא עם finishing-a-development-branch, שמסדר את ה-cleanup אחרי שגמרים.

בעבודות פיתוח תוכנה מתקדמות שאני מבצע, worktrees הם תנאי הכרחי לעבודה אוטונומית עם סוכנים. בלעדיהם הסוכנים דורסים אחד את השני וגורמים לקונפליקטים מתסכלים. עם הסקיל, ההפרדה היא מובנית מהתחלה.

אני מלווה צוותי הנדסה שמאמצים workflow מתקדם עם סוכני AI, כולל הקמת תהליכי git, branching strategy, ו-CI/CD שמתאימים לעבודה במקביל. למידע על הליווי ועל לקוחות, באתר של דביר נעמן וגם בדף האוטומציות. צרו קשר לתיאום שיחה.

שיתוף הסקיל

שאלות ותשובות

איך מתקינים את הסקיל?

תחת ~/.claude/skills/using-git-worktrees/. יזוהה אוטומטית בעבודה עם git. אין הגדרות נוספות נדרשות, ההפעלה אוטומטית בכל סשן רלוונטי. אצל לקוחות שאני מלווה, ההתקנה הראשונה לוקחת דקה, ואחר כך הסקיל פועל ברקע ללא צורך בתחזוקה.

האם הוא דורש גרסה מסוימת של git?

git 2.5+ נדרש. כל גרסה מודרנית תומכת. הסקיל מתעדכן עם הסטנדרטים הנוכחיים של הפלטפורמות שהוא תומך בהן. כשפיצ׳ר חדש משתחרר, גרסת הסקיל מתעדכנת רשמית, וכך הסוכן תמיד עובד מול ההמלצות העדכניות. בעבודות שאני מבצע, אני מוודא שהסקילים מעודכנים לפני התחלת פרויקט חדש.

האם זה עובד עם submodules?

כן, אבל בזהירות. submodules דורשים git submodule update בכל worktree בנפרד. הסקיל מתעד את הזרימה הנכונה ומזכיר לסוכן לעדכן submodules אחרי יצירת worktree חדש. אצלי בעבודות שאני מבצע, האספקט הזה הוא חלק מהסטנדרט שאני מטמיע ללקוחות. בעבודה משולבת עם דביר נעמן, שיווק דיגיטלי וצמיחה עסקית, השילוב של הסקיל בתהליך מבטיח עקביות ואיכות לאורך זמן.

האם הסקיל שולח דאטה?

לא. הוא קובץ Markdown טהור. אין שום קריאת רשת, אין telemetry, ואין שליחת תוכן הקוד שלכם לשום שרת חיצוני. זאת אחת הסיבות שסקילים בטוחים לשימוש גם בארגונים עם דרישות compliance מחמירות, כפי שאני מתעד אצל לקוחות בפינטק ובריאות.

האם זה עובד על Windows?

כן. git worktree עובד בכל הפלטפורמות. אצלי בעבודות שאני מבצע, האספקט הזה הוא חלק מהסטנדרט שאני מטמיע ללקוחות. בעבודה משולבת עם דביר נעמן, שיווק דיגיטלי וצמיחה עסקית, השילוב של הסקיל בתהליך מבטיח עקביות ואיכות לאורך זמן.

מה קורה אם נמחק worktree בטעות?

שינויים שלא נדחפו אבדו. הסקיל מזהיר לפני מחיקה ומציע לדחוף קודם. אצלי בעבודות שאני מבצע, האספקט הזה הוא חלק מהסטנדרט שאני מטמיע ללקוחות. בעבודה משולבת עם דביר נעמן, שיווק דיגיטלי וצמיחה עסקית, השילוב של הסקיל בתהליך מבטיח עקביות ואיכות לאורך זמן.

האם זה מתאים לפרויקטים קטנים?

פחות. הוא יעיל מ-3+ branches פעילים. בפרויקט עם branch אחד, checkout פשוט מספיק. אצלי בעבודות שאני מבצע, האספקט הזה הוא חלק מהסטנדרט שאני מטמיע ללקוחות. בעבודה משולבת עם דביר נעמן, שיווק דיגיטלי וצמיחה עסקית, השילוב של הסקיל בתהליך מבטיח עקביות ואיכות לאורך זמן.

האם זה מאט את git?

לא משמעותית. כל worktree משתפת את ה-objects של ה-repo, אין שכפול נתונים. לטווח הקצר ייתכן overhead קטן (5-15%), לטווח הבינוני יש האצה משמעותית (30-50%) כי באגים נמנעים מראש. בעבודות שאני מבצע ללקוחות, ה-ROI חיובי בתוך 2-3 שבועות מתחילת השימוש.

דביר נעמן

על הכותב

דביר נעמן – מומחה שיווק דיגיטלי, SEO ואוטומציות

מלווה עסקים בצמיחה דיגיטלית: קידום אורגני, קידום במנועי AI, אימייל מרקטינג, אוטומציות ופיתוח תוכנה. תוצאות מדידות ושקיפות מלאה.