您的位置:首页 > 编程语言

RT-Thread 学习笔记(二)---配置github代码版本控制工具

2014-08-21 15:48 246 查看
在上一篇文章中,我们学习了如何获取RT-Thread源码,以及如何构建一个自己想要的开发环境,用版本控制工具软件SVN创建一个自己的分支,这一节还要引入另一个版本控制工具软件git。因为git有着众多的优点,促使我想要尝试去学习和使用它。

1参考文章:

http://www.open-open.com/lib/view/open1332904495999.html

Github for Windows——来自Github官方的Git客户端

GitHub详细教程

github版本库使用详细教程(命令行及图形界面版)

2 建立自己的代码仓库

登录www.github.com网站,输入自己的用户名和密码,然后点击登录的用户名后面的“+”号下拉列表中的New repository,进入如下界面



在上面的编辑栏中分别输入仓库的名称和描述,当然可以勾选"Initialize this repository with a README",然后点击Create repository 按钮完成仓库创建,如下图。



3 安装Github for Windows

下载地址:https://windows.github.com/ ,下载完毕后开始安装,第一次安装会出现如下界面



[align=left]这时需要打开控制面板→ Internet 选项→“安全”选项卡,然后选择“受信任的站点”→点击“站点”按钮。并按下图输入" https://github-windows.s3.amazonaws.com"[/align]



[align=left]然后在前面图中点击安装按钮开始安装,如下图。[/align]



[align=left]等待几分钟,安装完毕,自动打开如下界面。[/align]



[align=left]分别在上面信息栏中输入用户名和密码,如果没有需要到www.github.com官网上注册一个,然后点击Log in 按钮,进入下图。[/align]



[align=left]点击Continue,提示没有找到本地的Repositories,如下图[/align]



[align=left]点击Skip按钮跳过,出现如下界面。[/align]



[align=left]点击右上角的设置->options,在Clone path 栏选择 Browse 按钮定位到项目代码所在位置,然后点击Update确认,如下图。[/align]



[align=left]然后在上面图中单击左上角的+号,出现如下界面[/align]



[align=left]选中之前创建的仓库,然后点击Clone按钮弹出如下如下对话框,选中自己代码所在位置目录点击确认。[/align]



[align=left][/align]
然后开始从服务器中的apingrtt仓库中下载代码,如下图。



[align=left]这个持续过程需要根据代码量大小确定,下载完成后如下图。[/align]



[align=left]这样就在所在的位置目录下成功复制成了一个代码仓库,这里是E:/RTT/apingrtt.然后就可以在apingrtt目录下加入自己的项目代码了。[/align]

4 使用git在本地创建一个项目的过程

[align=left]如果您的电脑配置不太高,而且代码量有比较大话,使用git 图形界面虽然方便但太耗内存,我的电脑配置有些低,对于有几千个文件的项目来说,GitHub图形界面程序内存吃紧,无法完成sync操作,下面只能给出在gti-shell创建本地项目过程和步骤。[/align]
[align=left] $ makdir RTT //创建一个根目录RTT[/align]
[align=left] $ cd RTT //进入RTT这个目录[/align]

$ makdir apingrtt //创建一个项目目录apingrtt

$ cd apingrtt //进入这个项目apingrtt

//如果您按前面的步骤做了,那么上面几步操作不必执行

$ git init //初始化

$ touch README.txt //您可用编辑器打开并输入相关描述

$ git add README.txt //更新README文件

$ git commit -m 'commit info' //提交更新,并注释信息“commit info”

$ git remote add origin https://github.com/username/projectname.git//连接远程github项目是远程username下的projectname项目

//如果您已经建立了和github远程服务器的连接,这步执行后会提示fatal: remote origin already exists.

$ git push origin master //将本地项目中被git add进提交列表中内容更新到github项目的默认分支master上去,其命令格式为

//git push [remote-name] [branch-name]

这里提示一点:在正常开发过程中,git init 和 git remote add origin ...一个工作过程启用一次就可以了,用的较多就是git mommit 和 git push。

下面是我用git add .和git push origin master 的执行过程。



下面是执行结果。



git 更多命令可参考GitHub详细教程和其他一些相关教程。
[align=left][/align]

5 如何删除已经提交并push远程机当中的文件夹

git远程操作的示意图如下。



在操作的过程中我误将RTT_1.2.1当成最新版推送到远程机当中,现在又把它删除,在把目前最新版RTT_1.2.2推送到远程机当中,操作如下:

git commit -a -m 'rm -rf RT-Thread_1.2.1' //注意单引号,删除本地的文件夹,参数-a告诉Git提交全部修改过的文件。
git push origin master //更新到远程端

然后再把rt-thread_1.2.2代码加进来
git add .

git commit -m 'original code of rtt_v1.2.2'//提交
git push origin master //推送到远程端
结果如下。





如果操作不当,会出现,无法提交的错误,如下图:



有网友给出解决办法:
我操作的是ubuntu环境。window远程

1 若在window下远程打开操作窗口(不是console),进入.git目录删除index.lock文件,删除后再commit会自动再次生成index.lock。无法提交。

2 使用putty console下操作,进入.git目录执行 rm -f index.lock 删除index.lock 虽然能删除,但是也是每次都会再生成。无法提交

3 在.git同级目录,执行rm -f .git/index.lock (或者rm -f git/index.lock) 删除后可提交。成功!

在Git的power shell终端操作的结果如下图:



在经历两次失败后,操作成功。
然后进入到bsp目录下面,执行git add ./stm32f103ze-ek/*,出现一些告警,如下图



然后执行git status 查看下





可以看到,更改后的目录下所有文件被加入到了index列表,

Git有三个地方可以存放代码。

第一个地方是工作目录树,编辑文件时可以直接在这里操作;

第二个是索引(index),也就是暂存区(staging area)。暂存区是工作目录树和版本库之间的缓冲区。

第三个,也就是最终的一个,是版本库。

命令git add,可以暂存对文件刚做的修改。它跟前面添加一个新文件时使用的是同一个命令,只不过,这次它告诉Git要跟踪的是一个新的修改而非新的文件。

然后可以提交到数据仓库中了,执行如下命令:git commit -m 'rename the dirctionary into stm32f103ze-ek',


然后推送到远程端:git push origin master



在远程端可以看到如下结果:



实际上,如果在git中进行文件或目录管理,根本不用上面那么麻烦,在提交命令git commit -a-m 'rm/或mvdir 文件或目录‘ '就可以了,然后再推送到远程端。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: