我试图在GitHub上添加一个分支到主分支,并将一个文件夹推到该分支上。

分支的文件夹结构看起来像- SocialApp/SourceCode/DevTrunk/SocialApp和所有源代码文件都在最后一个文件夹中。

我正在使用以下Git命令:

git add *
git commit -m with the message
git push

这只是将第一个文件夹“SocialApp”推到GitHub上,而忽略了文件夹内的文件夹SourceCode。我怎么解决这个问题?


当前回答

我简单地用了这个:

git add app/src/release/*

您只需要指定要添加的文件夹,然后使用*递归地添加其中的所有内容。

其他回答

我遇到了这个问题,花费了我一点时间,然后我想起git不会存储空文件夹。请记住,如果您有一个想要存储的文件夹树,请至少将一个文件放在该树最深的文件夹中,例如一个名为“”的文件。Gitkeep”,只是为了影响git的存储。

从top directory调用“git add *”和“git add SocialApp”都应该递归添加所有目录。

可能你在SocialApp/SourceCode/DevTrunk/SocialApp中没有文件,这就是原因。

尝试调用touch SocialApp/SourceCode/DevTrunk/SocialApp/。临时的”(并检查。gitignore),然后再次尝试git add。

导航到文件夹,你有你的文件,如果你是在windows机器上,你将需要启动git bash,从中你将得到一个命令行界面,然后使用这些命令

git init   //this initializes a .git  repository in your working directory

git remote add origin <URL_TO_YOUR_REPO.git> // this points to correct repository where files will be uploaded

git add *   // this adds all the files to the initialialized git repository

如果您在将文件合并到主文件之前对其进行了任何更改,则必须通过执行提交更改

git commit -m "applied some changes to the branch"

在这之后,将分支签出到主分支

在我的例子中,子目录中有一个.git文件夹,因为我之前在那里初始化了一个git repo。当我添加子目录时,它只是将其作为子项目添加,而不添加任何包含的文件。

我通过从子目录中删除git存储库,然后重新添加文件夹来解决这个问题。

如果子目录被忽略,检查.gitignore文件。

然后再试一次

git add --all
git commit -am "<commit message>"
git push