簡體   English   中英

如何將文件還原為先前的提交但保留其他文件為最新的提交

[英]How to revert files to a previous commit but keep other files to latest commit

假設我有這些提交(字母是哈希數):

-a(initial commit)
-b(implemented feature request affected foo.php and bar.php)
-c(someone else's commit)
-d(someone experimented on foo.php/bar.php and forgot to discard changes)
-e(another commit)
-f(latest commit)

如何將foo.php和bar.php更改為提交“ c”期間的狀態。 到目前為止,我已經嘗試了git reset cgit reset --hard c但是它改變了整個存儲庫。

到目前為止,我嘗試過的另一種方法是對存儲庫進行另一個克隆並reset --hard c ,然后將粘貼的foo.php和bar.php手動復制到我的工作副本中,然后我上演並將更改推送到遠程。

只需將文件還原到該舊提交,然后提交更改即可。

git checkout <old_commit_id> file_path

例如 -

git checkout <hash_of_c> foo.php
git checkout <hash_of_c> bar.php
git add -u
git commit -m "revert foo and boo"

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM