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

在上一篇文章中,我们学习了如何获取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,进入如下界面

RT-Thread 学习笔记(二)---配置github代码版本控制工具_第1张图片

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

RT-Thread 学习笔记(二)---配置github代码版本控制工具_第2张图片

3  安装Github for Windows

下载地址: https://windows.github.com/ ,下载完毕后开始安装,第一次安装会出现如下界面
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第3张图片
这时需要打开控制面板→ Internet 选项→“安全”选项卡,然后选择“受信任的站点”→点击“站点”按钮。并按下图输入"  https://github-windows.s3.amazonaws.com"
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第4张图片
然后在前面图中点击安装按钮开始安装,如下图。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第5张图片

等待几分钟,安装完毕,自动打开如下界面。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第6张图片
分别在上面信息栏中输入用户名和密码,如果没有需要到 www.github.com官网上注册一个,然后点击Log in 按钮,进入下图。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第7张图片
点击Continue,提示没有找到本地的Repositories,如下图
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第8张图片
点击Skip按钮跳过,出现如下界面。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第9张图片
点击右上角的设置->options,在Clone path 栏选择 Browse 按钮定位到项目代码所在位置,然后点击Update确认,如下图。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第10张图片

然后在上面图中单击左上角的+号,出现如下界面
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第11张图片

选中之前创建的仓库,然后点击Clone按钮弹出如下如下对话框,选中自己代码所在位置目录点击确认。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第12张图片

然后开始从服务器中的apingrtt仓库中下载代码,如下图。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第13张图片
这个持续过程需要根据代码量大小确定,下载完成后如下图。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第14张图片

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

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

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

    $ 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 的执行过程。

RT-Thread 学习笔记(二)---配置github代码版本控制工具_第15张图片

下面是执行结果。

RT-Thread 学习笔记(二)---配置github代码版本控制工具_第16张图片

git 更多命令可参考GitHub详细教程和其他一些相关教程。



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

git远程操作的示意图如下。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第17张图片
在操作的过程中我误将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 //推送到远程端
结果如下。
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第18张图片

如果操作不当,会出现,无法提交的错误,如下图:
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第19张图片
有网友给出解决办法:
我操作的是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终端操作的结果如下图:
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第20张图片
在经历两次失败后,操作成功。
然后进入到bsp目录下面,执行git  add ./stm32f103ze-ek/*,出现一些告警,如下图
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第21张图片
然后执行git status 查看下
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第22张图片 RT-Thread 学习笔记(二)---配置github代码版本控制工具_第23张图片
可以看到,更改后的目录下所有文件被加入到了index列表,

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

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

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

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

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

然后可以提交到数据仓库中了,执行如下命令:git commit -m 'rename the dirctionary into stm32f103ze-ek', RT-Thread 学习笔记(二)---配置github代码版本控制工具_第24张图片
然后推送到远程端:git push origin master
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第25张图片

在远程端可以看到如下结果:
RT-Thread 学习笔记(二)---配置github代码版本控制工具_第26张图片
实际上,如果在git中进行文件或目录管理,根本不用上面那么麻烦,在提交命令git commit -a-m 'rm/或mvdir 文件或目录‘ '就可以了,然后再推送到远程端。

你可能感兴趣的:(RT-Thread 学习笔记(二)---配置github代码版本控制工具)