كيفية الجمع بين التزاماتك الأخيرة في N Git

Git Commands

إتقان الالتزام بالسحق في Git:

عند العمل على مشروع ما، يمكن أن يصبح سجل الالتزام الخاص بك مزدحمًا بالعديد من الالتزامات الصغيرة. قد تؤدي هذه الالتزامات البسيطة إلى صعوبة مراجعة التغييرات وفهم تاريخ المشروع.

في Git، يمكنك سحق آخر N التزاماتك في التزام واحد، مما يؤدي إلى إنشاء سجل أنظف وأكثر قابلية للإدارة. سيرشدك هذا الدليل عبر الخطوات اللازمة لتحقيق ذلك، مما يجعل التحكم في الإصدار الخاص بك أكثر كفاءة.

يأمر وصف
git rebase -i HEAD~N يبدأ عملية إعادة قاعدة تفاعلية لآخر عمليات تنفيذ N.
pick يحافظ على الالتزام كما هو أثناء عملية إعادة الأساس التفاعلية.
squash يجمع الالتزام مع الالتزام السابق أثناء عملية إعادة قاعدة تفاعلية.
sed -i '1!s/pick/squash/' .git/rebase-merge/git-rebase-todo يستبدل "الاختيار" تلقائيًا بـ "الاسكواش" للجميع باستثناء الالتزام الأول في قائمة المهام التي يجب إعادة تعيينها.
git rebase --continue يستمر في عملية إعادة الأساس بعد حل التعارضات.
git rebase --abort إحباط عملية إعادة الأساس والعودة إلى الحالة قبل بدء إعادة الأساس.
HEAD~N يشير إلى أماكن الالتزام N قبل الرأس الحالي.

فهم سحق ارتكاب Git

يستخدم البرنامج النصي الأول لبدء عملية إعادة قاعدة تفاعلية لآخر عمليات تنفيذ N. في الشاشة التفاعلية، يمكنك استبدال كلمة "pick" بكلمة "squash" للالتزامات التي تريد دمجها. تساعد هذه العملية على دمج العديد من الالتزامات الصغيرة في عملية واحدة، مما يجعل سجل الالتزام الخاص بك أكثر وضوحًا وأسهل في الإدارة. بعد التحرير، احفظ وأغلق المحرر. إذا كانت هناك تعارضات، يمكنك حلها والمتابعة .

البرنامج النصي الثاني هو برنامج نصي Bash يقوم بأتمتة عملية السحق. يبدأ الأمر بالتحقق من توفير عدد من الالتزامات (N). ثم يتم تشغيله والاستخدامات لاستبدال "الاختيار" بـ "الاسكواش" للجميع باستثناء الالتزام الأول في قائمة المهام التي يجب إعادة تعيينها. وهذا يجعل من السهل سحق عمليات الالتزام المتعددة دون تحرير الملف يدويًا. وأخيرا، فإنه يستمر في عملية إعادة الأساس مع ، والتعامل مع أي قرارات تعارض ضرورية تلقائيًا.

قم بسحق الالتزامات المتعددة في واحدة باستخدام Git Rebase

أوامر جيت

git rebase -i HEAD~N
# Replace N with the number of commits you want to squash
# In the interactive rebase screen that appears, change 'pick' to 'squash' (or 's') for the commits you want to squash
# Save and close the editor
# Edit the commit message if needed, then save and close the editor again
# If there are conflicts, resolve them and then run
git rebase --continue
# Your last N commits are now squashed into one commit

أتمتة عملية السحق باستخدام برنامج Shell النصي

سكريبت باش

#!/bin/bash
if [ -z "$1" ]
then
  echo "Usage: ./squash_commits.sh <N>"
  exit 1
fi
git rebase -i HEAD~$1
# Automatically replace 'pick' with 'squash' for all but the first commit
sed -i '1!s/pick/squash/' .git/rebase-merge/git-rebase-todo
git rebase --continue

تقنيات سحق Git المتقدمة

هناك جانب آخر مهم لسحق الالتزامات في Git وهو التعامل مع تعارضات الدمج التي قد تنشأ أثناء العملية. عند الجمع بين التزامات متعددة، قد تتعارض التغييرات من التزامات مختلفة مع بعضها البعض. لحل هذه التعارضات، يوفر Git أوامر مثل لمعرفة الملفات المتعارضة و لوضع علامة عليها على أنها تم حلها. بعد حل التعارضات، يمكنك الاستمرار في إعادة القاعدة باستخدام .

من المفيد أيضًا معرفة كيفية إلغاء عملية إعادة الأساس إذا ساءت الأمور. الامر يوقف عملية إعادة الأساس ويعيد مستودعك إلى حالته السابقة قبل بدء إعادة الأساس. وهذا يضمن أنه يمكنك التراجع بأمان عن أي تغييرات تم إجراؤها أثناء عملية إعادة الأساس. يمكن أن يؤدي فهم هذه الأوامر إلى تحسين قدرتك بشكل كبير على إدارة سجلات Git المعقدة بكفاءة.

  1. ماذا يعني سحق الالتزامات؟
  2. يعني سحق الالتزامات الجمع بين الالتزامات المتعددة في التزام واحد لتبسيط سجل الالتزام.
  3. لماذا يجب أن أمارس رياضة الاسكواش؟
  4. يمكن أن يؤدي سحق الالتزامات إلى جعل سجل مشروعك أكثر وضوحًا وأسهل في القراءة، خاصة عند استخدام العديد من الالتزامات الصغيرة.
  5. كيف أبدأ إعادة قاعدة تفاعلية؟
  6. استخدم الأمر ، مع استبدال N بعدد الالتزامات التي تريد سحقها.
  7. ماذا يعني "الاختيار" و"الاسكواش" في إعادة البناء التفاعلي؟
  8. يحافظ "الاختيار" على الالتزام كما هو، بينما يجمعه "الاسكواش" مع الالتزام السابق.
  9. كيف يمكنني حل التعارضات أثناء عملية إعادة الأساس؟
  10. يستخدم لتحديد التعارضات وحلها يدويًا ثم استخدامها و .
  11. هل يمكنني إلغاء عملية إعادة الأساس إذا حدث خطأ ما؟
  12. نعم، يمكنك استخدام لإيقاف rebase والعودة إلى الحالة السابقة.
  13. ما فائدة استخدام برنامج Bash النصي لسحق الالتزامات؟
  14. يقوم برنامج Bash النصي بأتمتة العملية، مما يوفر الوقت ويقلل من مخاطر الأخطاء اليدوية.
  15. هل هناك طريقة لسحق الالتزامات تلقائيًا في إعادة الأساس؟
  16. نعم، باستخدام برنامج نصي لتعديل قائمة المهام التي يجب إعادة تعيينها باستخدامها ، يمكنك تغيير "اختيار" إلى "اسكواش" تلقائيًا.

اختتام جيت ارتكاب سحق

يعد سحق الالتزامات في Git أسلوبًا قويًا للحفاظ على سجل مشروع نظيف وقابل للقراءة. سواء كنت تستخدم إعادة الأساس التفاعلي أو التشغيل الآلي باستخدام برنامج Bash النصي، يمكنك دمج عمليات الالتزام المتعددة في عملية واحدة، مما يجعل إدارة السجل أسهل. إن فهم كيفية حل التعارضات وإلغاء عملية إعادة الأساس يزيد من كفاءتك في استخدام Git، مما يضمن قدرتك على التعامل مع أي مشكلات قد تنشأ. سيؤدي إتقان هذه الأوامر والأساليب إلى تحسين ممارسات التحكم في الإصدار بشكل كبير.