'Does running git init twice initialize a repository or reinitialize an existing repo?
What happens to an existing git repository when you issue git init again?
I created a repository with git init. Created a file, add, commit. Check the status (nothing to commit). Then created another file, check the status and I can see it's untracked as expected.
Then, say by mistake, I run git init again and I get Reinitialise existing Git repository message.
Tried git status, but it shows the same. So what really happens?
Can reinitialising an existing git repository this way be harmful or helpful? Why can we git init inside an existing repository?
Solution 1:[1]
It seems safe and should not overwrite anything important.
Quoted from the git init documentation:
Running git init in an existing repository is safe. It will not overwrite things that are already there. The primary reason for rerunning git init is to pick up newly added templates.
Solution 2:[2]
Since v1.7.5 (b57fb80a7), git init in an existing repo has also allowed moving the .git directory:
The primary reason for rerunning 'git init' is to pick up newly added templates (or to move the repository to another place if --separate-git-dir is given).
'Picking up newly-added templates' means that any templates which have not already been copied from the template directory will now be copied into the existing git directory.
'Moving the repository to another place' means that, if --separate-git-dir points to somewhere else, the existing .git directory will be moved there and replaced by a link.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | mit |
| Solution 2 | Joe |
