Removing '.git' directory from git repo?

后端 未结 5 1967
名媛妹妹
名媛妹妹 2020-12-09 16:06

I\'m trying to migrate a git repo from Kiln to Github. I can add the new remote just fine, but when I try to push master to the new remote, I get the following error:

<
相关标签:
5条回答
  • 2020-12-09 16:46

    As of git 2.2.22 the way to do this is with the git-filter-repo tool.

    Easy and fast:

    git filter-repo --force --invert-paths --path-glob '*/.git' --path '.git'
    
    0 讨论(0)
  • 2020-12-09 16:55

    As I understand it kiln will let you clone a repository as either git or Mercurial these days, so clone it as mercurial, use the mercurial filemap solution you already found push that Mercurial repo as a new repo to Kiln and then clone it down as git. Then you'll have a git repo you can push to github.

    0 讨论(0)
  • 2020-12-09 16:59

    Have you tried with the following command ?

    git filter-branch --tree-filter 'rm -Rf .git' HEAD
    

    git filter-branch documentation indicates that this would be slower than --index-filter, but it could do the job.

    0 讨论(0)
  • 2020-12-09 17:01

    Another way to handle the case where a Mercurial (Hg) repo has a .git folder embedded in it is to first "fix" the Hg repo before exporting to Git. @laurens-holst has a great way of doing this.

    If the .git folder was in the root of your project, then your create a text file, my-filemap that looks like:

    exclude ".git"
    

    Enable the Convert extension in your .hgrc file:

    [extensions]
    convert =
    

    Then filter out the .git folder using the Hg convert extension:

    hg convert --filemap my-filemap originalrepo newrepo
    

    Now you can export from newrepo and won't have the issue of the embedded .git folder.

    You can also use git fsck to make sure the new Git repo is ok before pushing it.

    0 讨论(0)
  • 2020-12-09 17:03

    Use the BFG Repo-Cleaner, a simpler, faster alternative to git-filter-branch specifically designed for removing files from Git history.

    Carefully follow the steps here: https://rtyley.github.io/bfg-repo-cleaner/#usage - but the core bit is just this: download the BFG jar (requires Java 8 or above) and run this command:

    $ java -jar bfg.jar --delete-folders .git --delete-files .git --no-blob-protection my-repo.git
    

    Your entire repository history will be scanned, and any file or folder named .git will be removed. I've tested this against a specially-constructed test repo containing a .git folder, and it worked just fine.

    Thanks to Michel Jouvin for reminding me that files named '.git' are also illegal in Git (and the error message reported by Git doesn't make it immediately obvious that they are files, rather than folders), I've updated this answer to reflect that.

    Full disclosure: I'm the author of the BFG Repo-Cleaner.

    0 讨论(0)
提交回复
热议问题