検索

ホームページ  >  に質問  >  本文

github - 修改一个文件并提交,整个项目的git log是有该次提交记录的,但是那个文件的git log没有提交记录

一个项目,fork 出来,修改了其中一个文件,git commit & push,然后获取上游的更新,并和自己的代码 merge,merge 后我对原来那个文件的修改被合并,变成上游的代码,现在我想把该文件回退到之前我修改并提交的状态,但是我用 git log 查看的时候出现了标题说明的问题…十分不理解…
(图里,我是 hyzhang)

项目在这里

PHP中文网PHP中文网2835日前987

全員に返信(3)返信します

  • 習慣沉默

    習慣沉默2017-04-24 16:02:42

    を使用したため、完全な履歴を確認し、復元したいバージョンを見つけて確認し、コミットします。 -2呀,然后合并来的上游修改比你的新,所以你自己的修改排在前2之外了。不要用-2

    返事
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-04-24 16:02:42

    git extras をインストールしてから git revert を実行すると、すべてが自動的に処理されます

    返事
    0
  • 黄舟

    黄舟2017-04-24 16:02:42

    git log --pretty=oneline modules.rst を試してくださいgit log --pretty=oneline modules.rst

    看到这个界面,我还是要再推荐下 tig

    clone 了你的库,然后我分别 checkout 到你之前的 commit 上然后创建新的分支,再进行 diff 操作,以下是结果:

    fix typo and translationMerge...modules.rst 的修改记录

    add...fix typo and translation 仍然无 modules.rst 的修改记录

    fix typoadd... 终于出现了 modules.rst 的修改记录

    所以很明显 gitlog 记录没有错,你最近的几次 commit 并没有修改 modules.rst 文件,它又怎么会出现在 log 中呢?

    最近的四次 commit 记录:

    根据 git diff 的结果,可以确定从 fix typoadd... 的这次提交中是对 modules.rst 最近的操作,所以查看 modules.rstlog 肯定只显示到 add... 这次 commit了。

    输入 git log --merges 命令,显示用于 mergecommit

    发现了吗?与之前的 merge 相比,你这次 merge 是存在 conflict 的,而且这个 conflict 和你的问题文件 modules.rst 还有关,所以我分析这应该就是问题所在,应该是你的文件产生了冲突,但是你没有解决冲突,而又 merge 成功,这些冲突不知道什么原因被忽略,所以它们不会作为 commit 的一部分进入 log

    このインターフェースを見た後でも、私は tig をお勧めします🎜 🎜ライブラリを clone し、以前の commitcheckout して新しいブランチを作成し、 diff を実行します。 > 操作の結果は次のとおりです: 🎜 🎜🎜 🎜 fix typo and translation から Merge... までの modules.rst の変更記録はありません🎜 🎜🎜 🎜 add... から fix typo and translation まで、modules.rst の変更記録はまだありません🎜 🎜🎜 🎜 fix typo から add... まで、最後に modules.rst の変更記録が表示されます🎜 🎜つまり、gitlog レコードが正しいことは明らかです。最近の commitmodules.rst を変更しませんでした。 > ファイルを log に表示するにはどうすればよいですか? 🎜 🎜最後の 4 つの commit レコード:
    🎜 🎜 git diff の結果によると、fix typo から add... への送信は に対するものであると判断できます。 rst の最新の操作であるため、modules.rstlog を確認すると、add... のみが表示されます。 > 今回は コミット します。 🎜 🎜 git log --merges コマンドを入力して、merge に使用される commit を表示します。 🎜 🎜🎜 🎜見つけましたか?以前の merge と比較すると、今回の merge には conflict があり、この merge は、以前の merge とは異なります。問題ファイル modules.rst はまだ関連しているため、これが問題であると分析しました。ファイルが競合しているはずですが、競合を解決せず、merge を実行しました。 > 成功した場合、これらの競合は不明な理由で無視されるため、commit の一部として log の履歴には記録されません。さて、お休みの時間です。回答が質問者様のお役に立てば幸いです。 :)🎜

    返事
    0
  • キャンセル返事