我的目录A中有与目录b匹配的文件,目录A中可能有其他需要的文件。目录B是一个git repo。

我想克隆目录B到目录A,但是git-clone不允许我这样做,因为目录是非空的。

我希望它只是克隆。git,因为所有的文件匹配我可以从那里去?

我不能克隆到一个空目录,因为我在目录A中有不在目录B中的文件,我想保留它们。

复制.git不是一个选项,因为我想用引用来推/拉,我不想手动设置它们。

有什么办法可以做到吗?

更新:我认为这是有效的,有人能看到任何问题吗?-->

cd a
git clone --no-hardlinks --no-checkout ../b a.tmp 
mv a.tmp/.git .
rm -rf a.tmp
git unstage # apparently git thinks all the files are deleted if you don't do this

当前回答

这招对我很管用:

cd existing_folder
git init
git remote add origin path_to_your_repo.git
git add .
git commit
git push -u origin master

其他回答

另一个简单的方法似乎对我很管用:

git clone --bare $URL .git
git config --unset core.bare

我签出现有文件到目录的主要用例是用Git控制我的Unix dotfiles。在一个新帐户中,主目录中已经有一些文件,甚至可能是我想从Git中获取的文件。

当试图克隆到c/code时,我也遇到了同样的问题

但是这个文件夹里有很多项目。

我在c/code/newproject中创建了一个新文件夹 并将我的克隆体映射到这个文件夹。

Git的桌面,然后问我的用户,然后克隆好。

这是我的工作,但你应该合并远程存储库文件到本地文件:

git init
git remote add origin url-to-git
git branch --set-upstream-to=origin/master master
git fetch
git status

这招对我很管用:

git init
git remote add origin PATH/TO/REPO
git fetch
git reset origin/master  # Required when the versioned files existed in path before "git init" of this repo.
git checkout -t origin/master

注意:-t将为您设置上游分支,如果这是您想要的,而且通常是这样。

警告-这可能会覆盖文件。

git init     
git remote add origin PATH/TO/REPO     
git fetch     
git checkout -t origin/master -f

修改自@cmcginty的回答-没有-f对我来说没用