开发者

Git diff without checkout branch

开发者 https://www.devze.com 2023-02-20 12:17 出处:网络
As an example: In the kernel source code, it has a lot of tags. I can diff them, such as: git diff v2.6.37-rc3 v2.6.38-rc4

As an example:

In the kernel source code, it has a lot of tags. I can diff them, such as:

git diff v2.6.37-rc3 v2.6.38-rc4

and I get the right output.

Now I copy .git directory to another place, and in this new .git directory, I can also use

git diff v2.6.37-rc3 v2.6.38-rc4

to get the right output.

But, I have another branch such as "mydev". I can't checkout to this mydev branch, and do the git diff v2.6.37-r开发者_JAVA百科c3 v2.6.38-rc4 commmand.

How can I do it?


You can' t just copy the .git directory of a non-bare GIT repository and expect to be able to checkout branches. When non-bare, the repository has an index and needs a corresponding working directory. Note that some GIT commands and arguments (like 'diff' with two commits) operate only on the repository objects/commits and thus don't need a working directory - hence they work, as you've seen. But other commands (like 'diff' between on commit and the working directory) need the working directory.


You should get the same output as before. Having a branch in the repository should not matter.

0

精彩评论

暂无评论...
验证码 换一张
取 消