කෙටි පිළිතුර:
git log --full-history -- your_file
ඔබගේ රෙපෝ ඉතිහාසයේ ස්පර්ශක ඒකාබද්ධ කිරීමේ කොමිස් ඇතුළු සියලු කැපවීම් ඔබට පෙන්වනු ඇත your_file
. අන්තිම (ඉහළ) ගොනුව මකා දැමූ එකකි.
සමහර පැහැදිලි කිරීම්:
මෙහි --full-history
ධජය වැදගත් ය. එය නොමැතිව, ඔබ ගොනුවක ලොගය ඉල්ලා සිටින විට Git "ඉතිහාසය සරල කිරීම" සිදු කරයි. මෙය හරියටම ක්රියාත්මක වන්නේ කෙසේද යන්න පිළිබඳ තොරතුරු ලේඛනයෙහි සැහැල්ලු වන අතර එය ප්රභව කේතයෙන් සොයා ගැනීමට උත්සාහ කිරීමට අවශ්ය ධෛර්යය හා ධෛර්යය මට නැත, නමුත් git-log ලියකියවිලි වලට මෙය කීමට බොහෝ දේ ඇත:
පෙරනිමි ප්රකාරය
ගසෙහි අවසාන තත්වය පැහැදිලි කරමින් ඉතිහාසය සරලම ඉතිහාසයට සරල කරයි. සරලම දෙය නම් අවසාන ප්රති result ලය සමාන නම් සමහර පැති අතු කප්පාදු කිරීමයි (එනම් එකම අන්තර්ගතය සමඟ ශාඛා ඒකාබද්ධ කිරීම)
මෙම කාගේ ඉතිහාසය අපට අවශ්ය ගොනුව විට ගැන නිසැකව ම මකා දමන යම් මකා ගොනු අවසන් රාජ්ය පැහැදිලි සරල ඉතිහාසය නිසා, කිසිදු ඉතිහාසය . බව අවදානමක් පවතින git log
තොරව --full-history
හුදෙක් ගොනුව නිර්මාණය කවදාවත් බව කියා ඇත? අවාසනාවට ඔව්. මෙන්න නිරූපණයක්:
mark@lunchbox:~/example$ git init
Initialised empty Git repository in /home/mark/example/.git/
mark@lunchbox:~/example$ touch foo && git add foo && git commit -m "Added foo"
[master (root-commit) ddff7a7] Added foo
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 foo
mark@lunchbox:~/example$ git checkout -b newbranch
Switched to a new branch 'newbranch'
mark@lunchbox:~/example$ touch bar && git add bar && git commit -m "Added bar"
[newbranch 7f9299a] Added bar
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 bar
mark@lunchbox:~/example$ git checkout master
Switched to branch 'master'
mark@lunchbox:~/example$ git rm foo && git commit -m "Deleted foo"
rm 'foo'
[master 7740344] Deleted foo
1 file changed, 0 insertions(+), 0 deletions(-)
delete mode 100644 foo
mark@lunchbox:~/example$ git checkout newbranch
Switched to branch 'newbranch'
mark@lunchbox:~/example$ git rm bar && git commit -m "Deleted bar"
rm 'bar'
[newbranch 873ed35] Deleted bar
1 file changed, 0 insertions(+), 0 deletions(-)
delete mode 100644 bar
mark@lunchbox:~/example$ git checkout master
Switched to branch 'master'
mark@lunchbox:~/example$ git merge newbranch
Already up-to-date!
Merge made by the 'recursive' strategy.
mark@lunchbox:~/example$ git log -- foo
commit 77403443a13a93073289f95a782307b1ebc21162
Author: Mark Amery
Date: Tue Jan 12 22:50:50 2016 +0000
Deleted foo
commit ddff7a78068aefb7a4d19c82e718099cf57be694
Author: Mark Amery
Date: Tue Jan 12 22:50:19 2016 +0000
Added foo
mark@lunchbox:~/example$ git log -- bar
mark@lunchbox:~/example$ git log --full-history -- foo
commit 2463e56a21e8ee529a59b63f2c6fcc9914a2b37c
Merge: 7740344 873ed35
Author: Mark Amery
Date: Tue Jan 12 22:51:36 2016 +0000
Merge branch 'newbranch'
commit 77403443a13a93073289f95a782307b1ebc21162
Author: Mark Amery
Date: Tue Jan 12 22:50:50 2016 +0000
Deleted foo
commit ddff7a78068aefb7a4d19c82e718099cf57be694
Author: Mark Amery
Date: Tue Jan 12 22:50:19 2016 +0000
Added foo
mark@lunchbox:~/example$ git log --full-history -- bar
commit 873ed352c5e0f296b26d1582b3b0b2d99e40d37c
Author: Mark Amery
Date: Tue Jan 12 22:51:29 2016 +0000
Deleted bar
commit 7f9299a80cc9114bf9f415e1e9a849f5d02f94ec
Author: Mark Amery
Date: Tue Jan 12 22:50:38 2016 +0000
Added bar
කෙසේ දැනුම් git log -- bar
ඉහත වචනාර්ථයෙන් කිසිම ප්රතිදානය ප්රතිඵලයක් පර්යන්තය කසල; Git යනු ඉතිහාසය bar
කිසි විටෙකත් නොතිබූ ප්රබන්ධයක් දක්වා “සරල කිරීම” ය . git log --full-history -- bar
, අනෙක් අතට, නිර්මාණය bar
කළ කැපවීම සහ එය මකා දැමූ කැපවීම අපට ලබා දෙයි .
පැහැදිලිව කිවහොත්: මෙම ප්රශ්නය හුදෙක් න්යායාත්මක නොවේ. මම ලියකියවිලි දෙස බලා --full-history
ධජය සොයාගත්තේ git log -- some_file
මකා දැමූ ගොනුවක් ලුහුබැඳීමට උත්සාහ කරන සැබෑ ගබඩාවක මා අසමත් වූ බැවිනි . දැනට පවතින ගොනුවක් එහි වර්තමාන තත්වයට පත්වූයේ කෙසේද යන්න තේරුම් ගැනීමට ඔබ උත්සාහ කරන විට ඉතිහාසය සරල කිරීම සමහර විට ප්රයෝජනවත් වනු ඇත, නමුත් ලිපිගොනු මකාදැමීමක් සොයා ගැනීමට උත්සාහ කරන විට ඔබ සැලකිලිමත් වන කැපවීම සඟවා ගැනීමෙන් ඔබව රවටා ගැනීමට වැඩි ඉඩක් ඇත. . --full-history
මෙම භාවිත අවස්ථාව සඳහා සෑම විටම ධජය භාවිතා කරන්න.