قد تود بعد القيام بعمليات إيداع عدّة، أو بعد استنساخ Cloning مستودع Repository يحوي سجلا للإداعات، النظر إلى ماضي الإيداعات لرؤية مالذي كان يحصُل. أمر git log
أيسر طريقة وأكثرها فعالية لهذا الغرض.
تستخدم الأمثلة المقدّمة هنا مشروع simplegit-progit
الذي يمكن الحصول عليه بتنفيذ الأمر التالي:
git clone https://github.com/schacon/simplegit-progit
نفذ أمر git log
بعد الدخول إلى مجلد المشروع:
git log
ستحصل على مخرجات على النحو التالي:
commit ca82a6dff817ec66f44342007202690a93763949 Author: Scott Chacon <schacon@gee-mail.com> Date: Mon Mar 17 21:52:11 2008 -0700 changed the version number commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 Author: Scott Chacon <schacon@gee-mail.com> Date: Sat Mar 15 16:40:33 2008 -0700 removed unnecessary test commit a11bef06a3f659402fe7563abf99ad00de2209e6 Author: Scott Chacon <schacon@gee-mail.com> Date: Sat Mar 15 10:31:28 2008 -0700 first commit
يسرُد أمر git log
- إن استخدِم دون خيارات - الإيداعات التي حدثت حسب ترتيب زمني عكسي، أي الإيداع الأحدث أولا. تمكن ملاحظة أنه مع كل إيداع يظهر مجموع التدقيق Checksum الخاص به، اسم من كاتب الإيداع وعنوانها البريدي، تاريخ الإيداع ورسالة الإيداع.
توجد الكثير من الخيارات للاستخدام مع أمر git log
من أجل إظهار ما تريده بالضبط. سنعرِض هنا لأكثرها شعبية.
-
يعرض خيار
p-
عند استخدامه مع أمرgit log
الفروقات ضمن كل إيداع. تمكن إضافة عدد لتحديد المخرجات. يعرض المثال التالي آخر إيداعيْن مع إظهار الفروق:
git log -p -2
النتيجة:
commit ca82a6dff817ec66f44342007202690a93763949 Author: Scott Chacon <schacon@gee-mail.com> Date: Mon Mar 17 21:52:11 2008 -0700 changed the version number diff --git a/Rakefile b/Rakefile index a874b73..8f94139 100644 --- a/Rakefile +++ b/Rakefile @@ -5,7 +5,7 @@ require 'rake/gempackagetask' spec = Gem::Specification.new do |s| s.platform = Gem::Platform::RUBY s.name = "simplegit" - s.version = "0.1.0" + s.version = "0.1.1" s.author = "Scott Chacon" s.email = "schacon@gee-mail.com" s.summary = "A simple gem for using Git in Ruby code." commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 Author: Scott Chacon <schacon@gee-mail.com> Date: Sat Mar 15 16:40:33 2008 -0700 removed unnecessary test diff --git a/lib/simplegit.rb b/lib/simplegit.rb index a0a60ae..47c6340 100644 --- a/lib/simplegit.rb +++ b/lib/simplegit.rb @@ -18,8 +18,3 @@ class SimpleGit end end - -if $0 == __FILE__ - git = SimpleGit.new - puts git.show -end \ No newline at end of file
يعرض الخيار p-
نفس المعلومات التي يعرضها الأمر بدون خيارات، مع إضافة الفروق بالنسبة لكل مُخرَج (إيداع). يفيد هذا الأمر كثيرا عند مراجعة الشفرة البرمجية أو للتصفح السريع لما جرى خلال سلسلة من عمليات الإيداع التي أجراها أحد أعضاء الفريق مثلا.
-
يمكن أيضا استخدام خيارات للتلخيص مع الأمر
git log
. إن أردت مثلا إحصاءات ملخَّصة لكلّ إيداع فيمكنك استخدام خيارstat--
:
git log --stat
النتيجة:
commit ca82a6dff817ec66f44342007202690a93763949 Author: Scott Chacon <schacon@gee-mail.com> Date: Mon Mar 17 21:52:11 2008 -0700 changed the version number Rakefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 Author: Scott Chacon <schacon@gee-mail.com> Date: Sat Mar 15 16:40:33 2008 -0700 removed unnecessary test lib/simplegit.rb | 5 ----- 1 file changed, 5 deletions(-) commit a11bef06a3f659402fe7563abf99ad00de2209e6 Author: Scott Chacon <schacon@gee-mail.com> Date: Sat Mar 15 10:31:28 2008 -0700 first commit README | 6 ++++++ Rakefile | 23 +++++++++++++++++++++++ lib/simplegit.rb | 25 +++++++++++++++++++++++++ 3 files changed, 54 insertions(+)
يظهر خيار stat--
تحت كل إيداع قائمة بالملفات التي عُدلت في الإيداع، عددها وعدد الأسطر التي أُضيفت أو حُذفت. يضيف الخيار أيضا ملخصًا للتعديلات تحت كل إيداع.
-
إن أردت تغيير الصيغة التي تظهر بها مخرجات السجل فيمكنك استخدام الخيار
pretty--
. توجد صيغ معدّة سلفا للاستخدام؛ عند إعطاء القيمةoneline
لخيارpretty--
فإن كل إيداع يظهر في سطر واحد، وهو ما سيكون مفيدا إن كانت لديك الكثير من الإيداعات للنظر فيه.
git log --pretty=oneline
النتيجة:
ca82a6dff817ec66f44342007202690a93763949 changed the version number 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7 removed unnecessary test a11bef06a3f659402fe7563abf99ad00de2209e6 first commit
تعدّ قيمة format
من أكثر قيم pretty--
أهمية. تعطي هذه القيمة عند استخدامها مع الخيار إمكانية تحديد صيغة مخصَّصة لمخرجات السجلات. يساعد هذا الأمر كثيرا إن كنت تريد تهيئة المخرجات لتحليلها آليا:
git log --pretty=format:"%h - %an, %ar : %s"
مثال على النتيجة:
ca82a6d - Scott Chacon, 6 years ago : changed the version number 085bb3b - Scott Chacon, 6 years ago : removed unnecessary test a11bef0 - Scott Chacon, 6 years ago : first commit
توجد في الجدول أدناه قائمة بالخيارات التي يمكن استخدامها لتهيئة مخرجات format.
الخيار | الوصف |
---|---|
H% | مجموع التدقيق |
h% | الصيغة المختصرة لمجموع التدقيق |
T% | مجموع التدقيق لكامل الشجرة Tree |
t% | مجموع التدقيق المختصَر للشجرة |
P% | مجموعات التدقيق للعنصر الأب |
an% | اسم كاتب الإيداع |
ae% | البريد الإلكتروني لكاتب الإيداع |
ad% | تاريخ إنشاء الإيداع (Author date) |
ar% | التاريخ النسبي لإنشاء الإيداع (قبل كذا من الزمن) |
cn% | اسم صاحب الإيداع Commiter |
ce% | البريد الإلكتروني لصاحب الإيداع |
cd% | تاريخ الإيداع |
cr% | التاريخ النسبي للإيداع |
s% | الموضوع |
ملحوظة: ربما تتساءل عن الفرق بين كاتب الإيداع وصاحب الإيداع؛ كاتب الإيداع هو الشخص الذي كتب العمل بينما صاحب الإيداع هو آخر شخص أضاف العمل إلى المستودع. نفرض مثلا أنك أرسلت ترقيعا لمشروع برمجي، ثم أضافه أحد مطوري المشروع إلى المستودع. يُعزَى لكل منكما في السجل؛ أنت بوصفك كاتب الترقيع وهو بوصفه صاحب الإيداع.
-
يفيد خيارا
oneline
وformat
كثيرًا عند استخدامهما مع خيارgraph--
الذي يعرض مخطط ASCII لسجل التفرع Branch والدمج Merge.
git log --pretty=format:"%h %s" --graph
مثال على النتيجة:
* 2d3acf9 ignore errors from SIGCHLD on trap * 5e3ee11 Merge branch 'master' of git://github.com/dustin/grit |\ | * 420eac9 Added a method for getting the current branch. * | 30e367c timeout code and tests * | 5a09431 add timeout protection to grit * | e1193f8 support for heads with slashes in them |/ * d6016bc require time for xmlschema * 11d191e Merge branch 'defunkt' into local
يفيد خيار graph--
كثيرا عند استخدام التفريع والدمج في مستودعات git.
توجد الكثير من الخيارات الأخرى للعمل مع أمر git log
. يسرد الجدول التالي قائمة بخيارات تعمل مع git log
إضافة لخيارات تهيئة أخرى قد تجدها مفيدة.
الخيار |
الوصف |
---|---|
p- | إظهار الترقيع المصاحب لكل إيداع |
stat-- | إظهار إحصاءات الملفات المعدّل عليها في كل إيداع |
shortstat-- |
قصر النتائج الظاهر من نتيجة stat-- على الأسطر المعدّل عليها، المضافة أو المحذوفة |
name-only-- | عرض قائمة بالملفات المعدّل عليها بعد معلومات الإيداع |
name-status-- | عرض قائمة بالملفات التي أضيفت إليها معلومات، عدلت معلوماتها أو حذفت |
abbrev-commit-- |
عرض المحارف الأولى من مجموع التحقق من الإيداع، بدلا من كامل المجموع (40 محرفا) |
relative-date-- | عرض التواريخ بصيغة نسبية ("قبل يومين" مثلا) بدلا من الصيغة الكاملة |
graph-- | عرض مخطّط ASCII لسجل التفريع والدمج بجانب مخرجات أمر log |
pretty-- |
عرض الإيداعات بصيغة بديلة، يمكن للخيار أن يأخذ إحدى القيم
|
تحديد مخرجات أمر git log
يقبل أمر git log
خيارات لتحديد المخرجات الظاهرة في نتيجة الأمر، فلا يُعرَض سوى عدد محدّد منها. رأينا أعلاه خيار 2-
الذي يعرض فقط الإيداعين الأخيرين. يمكن استخدام الخيار n-
حيث n
عدد طبيعي لإظهار العدد الموافق من الإيداعات (آخر 5 أو 10 إيداعات مثلا).
عمليا، قد لا تستخدم هذه الخيارات كثيرا؛ عكسَ خيارات التحديد المتعلقة بالزمن مثل since--
أو until--
التي يكثر استخدامها. مثلا يسرد الأمر التالي قائمة بالإيداعات التي أضيفت خلال الأسبوعين الأخيرين:
git log --since=2.weeks
يمكن استخدام since--
مع الكثير من الصيغ؛ تحديد التاريخ 15-01-2016
مثلا، أو تاريخ نسبي (قبل 3 سنوات ويوم و3 دقائق):
3 years 1 day 3 minutes ago
يمكنك أيضا ترشيح المخرجات لتطابق معايير بحث تحدّدها. يسمح خيار author--
بالترشيح حسب كاتب الإيداع، في ما يتيح خيار grep--
البحث حسب كلمات مفتاحية ضمن رسائل الإيداع (إن كنت ترغب باستخدام خياري author--
وgrep--
معا فيجب أن تضيف all-match--
إلى الأمر).
يعد خيار S-
من الخيارات المفيدة كثيرا، حيث يسمح بالبحث عن الإيداعات التي أضافت أو حذفت سلسلة محارف معيّنة. إن أردت على سبيل المثال البحث عن آخر إيداع أضاف أو حذف دالة باسم function_name
فيمكن استخدام الأمر التالي:
git log -Sfunction_name
توجد أيضا إمكانية قصر نتائج أمر git log
على الإيداعات التي أجرت تغييرات على ملفات أو مجلدات معينة بذكر مسار الملفات أو المجلدات. يجب أن تكون المسارات هي آخر عنصر في أمر git log
ويُنصح أن تسبقها شرطتان --
لفصلها عن بقية الخيارات.
يعرض الجدول التالي أهم الخيارات المستخدمة في تحديد مخرجات الأمر git log
.
الخيار | الوصف |
---|---|
n- | تحديد عدد الإيداعات المراد عرضها |
since, --after-- | عرض الإيداعات التي أضيفت بعد التاريخ المحدد |
until, --before-- | عرض الإيداعات التي أضيفت قبل التاريخ المحدد |
author-- |
عرض الإيداعات التي يوافق حقل الكاتب فيها سلسلة المحارف المعيّنة |
committer-- |
عرض الإيداعات التي يوافق حقل صاحب الإيداع فيها سلسلة المحارف المعيّنة |
grep-- |
عرض الإيداعات التي تحوي الرسائل المصاحبة لها سلسلة المحارف المذكورة |
S- |
عرض الإيداعات التي أضافت أو حذفت سلسلة المحارف المعيَّنة |
يعرض الأمر التالي الإيداعات التي كتبها gitster في الشفرة المصدرية لـGit والتي لم تُدمَج Merge في شهر أكتوبر 2008:
git log --pretty="%h - %s" --author=gitster --since="2008-10-01" \ --before="2008-11-01" --no-merges -- t/
مثال على النتيجة:
5610e3b - Fix testcase failure when extended attributes are in use acd3b9e - Enhance hold_lock_file_for_{update,append}() API f563754 - demonstrate breakage of detached checkout with symbolic link HEAD d1a43f2 - reset --hard/read-tree --reset -u: remove unmerged new paths 51a94af - Fix "checkout --track -b newbranch" on detached HEAD b0ad11e - pull: allow "git pull origin $something:$current_branch" into an unborn branch
من بين 40 ألف إيداع في سجل الشفرة المصدرية لـGit أظهر الأمر الإيداعات الستة التي توافق المعايير المذكورة أعلاه.
ترجمة -وبتصرّف- للفصل Git Basics - Viewing the Commit History من كتاب Pro Git لصاحبه Scott Chacon.
أفضل التعليقات
لا توجد أية تعليقات بعد
انضم إلى النقاش
يمكنك أن تنشر الآن وتسجل لاحقًا. إذا كان لديك حساب، فسجل الدخول الآن لتنشر باسم حسابك.