安装后需要重启Visual Studio,之后就可以在【已安装】中看到这个插件。或者,在Visual Studio 2015和2017版本的安装程序中,直接勾选这个插件安装。
插件安装后就可以在【视图】-【团队资源管理器】中打开GitHub管理工具。
现在我们创建一个演示解决方案,注意勾选“为解决方案创建目录”和“新建GIT存储库”。
需要注意的是,这里的“新建GIT存储库”是指本地GIT仓库。并非我们将要把代码push(推送)出去的远程仓库。
接下来安装Git for Windows这个工具,安装步骤在我们这里没那么多讲究,下载后全程下一步就好,在此不再赘述。安装后就能看到这个工具
现在我们需要构建一个远程仓库,笔者已经习惯Bash了,就用Git Bash来说明。利用OneDrive目录自动同步的特性,我们可以构建一个远程仓库。首先我们在OneDrive下新建一个目录作为远程仓库目录DemoRepo。
之后运行Git Bash,使用cd命令切换工作目录到刚刚建的DemoRepo下:
$ cd OneDrive/PrivateRepos/DemoRepo
然后使用git init命令将目录初始化为git仓库:
$ git init
之后使用ls -al命令就会发现多了一个.git目录,说明git仓库初始化完成。
现在这个仓库仅仅是最简单的仓库。我们要对这个git仓库做一些配置,才能成为我们想要的“远程仓库”。
使用vim编辑器修改./git下的config配置文件:
$ vim .git/conf
按i进入编辑模式,
加上如下字段,然后按【ESC】退出编辑模式,wq!保存并推出:
[receive] DenyCurrentBranch = ignore
如下图:
TIP:若以上步骤未做,在提交代码时会报错。
之后我们需要配置自动监视脚本,事实上并不需要我们自己写这个脚本,只需要启用就可以。使用cd命令进入..git/hooks目录下:
$ cd hooks
现在我们看到了很多后缀为sample的脚本,启用脚本只需要将文件名后的sample去掉就行。这里我们需要用mv命令重命名post-update.sample文件,如下图:
$ mv post-update.sample post-update
之后再次使用vim编辑器,编辑post-update脚本,使用#注释掉exec git update-server-info这行,然后在后面加上下面的代码保存:
unset GIT_DIR cd .. git checkout -f
TIP:注意cd和..之间有空格。
TIP:若以上步骤未做,可以正常推送代码到这个仓库,但在该目录下无法看到文件。
现在远程仓库也完成了,我们试着写几行代码推送出去。在IDE的右下角有一个箭头图标和一个铅笔图标,点击铅笔图标即可推送代码到本地git仓库。
输入提交日志后就可以提交代码了,下面列出了本次更改的文件。
提交成功后会提示你需要将代码同步到远程仓库,但是我们还没有在IDE里指定要推送的远程仓库目录。
现在回到【团队资源管理器】的主页,单击【设置】配置远程存储库。
选择【存储库设置】。
添加远程。
这里的远程origin名要与之前配置的一致,这里为“origin”,然后将提取和推送的目录指定为刚才已经配置好的远程库目录。
完成。
现在点击右下角的箭头图标,将代码从本地git库推送到远程git库。
同步完成。
在.git目录下可以查到之前的推送日志和已经同步来的源文件。
最后我们就可以在另一台登录了自己OneDrive的电脑上将这个远程的仓库克隆下来了,操作方法同样是打开【团队资源管理器】,然后选择【克隆】,指定源路径(OneDrive上)和本地路径,最后点击【克隆】就行。
总结
最后总结一下实现的思路。我们利用了OneDrive两个重要的特性:一是目录可以自动同步——意味着我们只要把git仓库放到OneDrive同步目录下,就能自动同步到云端;二是OneDrive目录又可以像本地目录一样直接使用cmd、bash等对其进行操作,因此我们又能轻易将其初始化为git仓库(这点很关键,想象一下,你想把度娘云盘上的目录用bash初始化为git仓库,在不开通超级会员的情况下这是不能实现的)。我简单画了个草图来描述这个过程:
由于本地OneDrive目录会自动和云端同步,因此这个图等效为直接将本地git库同步到了云端,实现了免费的私有git仓库。事实上,只要OneDrive端远程仓库构建好之后,无论使用何种IDE,都可以实现整个过程。
广告声明:文内含有的对外跳转链接(包括不限于超链接、二维码、口令等形式),用于传递更多信息,节省甄选时间,结果仅供参考,IT之家所有文章均包含本声明。