你现在的Keil工程的版本控制是怎么管理的?可能有些人的做法是发布一个版本软件后将代码打一个包保存起来,作为此版本的备份。有一种常见的情况,当开始一项新功能的开发,并且最终的效果不理想老板要求回退回去。又恰巧在开发前没有打个包保存一下初始版本,那就需要一处一处回改,这样手工回退后的版本可靠性就下降许多,需要完整的测试才行。为了避免这种尴尬的情况,有必要在keil工程也引入版本控制工具。 ( X, e: e# T; b% N
Git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds (Linux发明者)为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。这个诞生于2005年并且至今都使得开发者赞不绝口的工具,实际上Linus仅开发了两周并在一个月内就上线用于管理庞大的Linux内核了,不得不赞叹天才的伟大和凡人的不可企及。
- n% L$ |' b- \% C0 K: ]! a时至今日,Git早已在Android开发、Linux开发、web开发等场景成为最通行的版本管理工具,另外一些IDE集成开发环境也加入了Git,例如Android Studio, Intellij IDEA等。嵌入式开发常用的Keil也在keil5.15后也已经集成了版本管理工具,但是本文仍然是就Windows版Git管理Keil工程的示例,方便老版本的keil项目建立git管理。Keil5内集成的git的使用方法有机会再整理出来。
. Z- w6 M& I6 iGit的实用性也逐渐带来了git托管平台的流行,如GitHub、GitLab、Bitbucket、Codeing.net、Gitee等。无数崇尚软件开源的开发者挥洒着汗水在这些平台上贡献了数以亿计的开源项目,使得咱们这些普通人可也以参与其中,接触到最前沿的技术、最酷炫的功能。身为一个开发者也要学会在开源代码上汲取这些全球精英所奉献的新知识新技能。 关于Git的使用方法,可以参考廖雪峰的git教程,深入浅出非常实用。在这篇文章中主要讲的是将一个既有的Keil工程加入git管理的方法。 01 安装windows版git 0 r4 m& `1 n0 @$ m7 H+ v% y
安装完成后,在开始菜单内找到Git Bash并启动。启动后的操作窗口类似于windows的cmd窗口。在bash窗口内可以执行Linux的一些shell指令。
安装完成后,还需要设置邮箱地址和用户名,在命令行输入: - : j) z8 R; j" I0 K& V& h) X
- $ git config --global user.name "Your Name" n" p' s2 t4 |8 p" W
- $ git config --global user.email "email@example.com"
3 v% y( o) M) n" o5 K7 j
复制代码 " F( ^, e- o& ~: Z/ f& X! G
因为Git是分布式版本控制系统,可以多人在一起开发。所以每次提交,每次上传,都会带有你这台电脑的标记——邮箱地址和用户名。 02 本地建立git库 1 F+ I+ s3 Q6 I5 P4 s3 l
以/D/PROJ/project的一个keil工程为例。 1.进入工程所在的目录,使用ls指令查看是否正确的进入了目录。 - - [) k+ j5 c' o" t: z
- xxxx@DESKTOP-TH28NBD MINGW64 /
9 k/ G" d/ l9 s0 n; c7 A: J - $ cd /D/PROJ/project/
0 ?7 {2 R! J7 _1 ]8 q -
1 F! h& K1 ^! U2 \: {& c - xxxx@DESKTOP-TH28NBD MINGW64 /D/PROJ/project (master)
) C u3 U# f6 X9 R- Z5 L; l - $ ls
: v; J- ^2 l, p$ S6 ? - inc/ Libraries/ README.en.md README.md RVMDK/ src/
4 @7 s1 L5 G5 _; ^# d f
复制代码2、初始化本地git仓库 git init
在project的目录下可以看到.git的目录,该目录包含让 git 能够正常工作所需的所有信息。 03 远程代码托管平台 Github和Gitlab是最流行的托管平台,由于众所周知的原因,这些国外的网站在国内的访问速度很不理想,国内使用推荐gitee码云或coding.net。以Gitee来举例。
; ~9 e: T9 t: [) g# ]8 g# U# }Gitee免费版可创建 1000 个仓库,不限制公私有。单仓库大小上限为 500M,单文件最大 50M,用户总仓库容量为 5G。对于一般的keil嵌入式开发,免费版已经绰绰有余了。 1.注册Gitee,根据网站的提示完成注册。 2.配置ssh 5 t/ N& ?0 w# ?9 ^$ T
本地Git仓库和Gitee仓库之间的传输是通过SSH加密的,所以需要配置ssh,使得托管平台认可你这台电脑的git操作。在Git Bash内执行以下指令创建SSHkey。 - 3 _1 `9 y7 s% U! u) Y# _
- ssh-keygen -t rsa -C youremail@example.com) f3 R; x3 |( ~$ u8 } z- N4 v' k
复制代码 3 l% v0 v8 N1 N
把邮件地址换成你自己的邮件地址,然后回车一路使用默认值即可。完成后在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以发送给他人。
Windows的目录在c盘的用户目录内。
7 S4 n5 a5 G @3 @! ] G1 `# y
3.上传ssh公钥到码云 点击右上角的用户头像,选择设置。然后在设置页面的左侧功能栏选择SSH公钥。将刚才生成的id_rsd.pub的内容拷贝进公钥内容框内,标题随意填写。
4.创建项目仓库 点击页面右上角的加号,并选择新建仓库。
04 本地提交代码与推送远程库
$ {" x3 `9 |* i) f1.添加远端地址 - <font face="Tahoma"><font color="black">; q( s( w& Q( W( c I
- git remote add origin ssh地址
1 m2 \$ ?9 U. H - 如 git remote add origin git@gitee.com:xxxx/xxxx.git</font></font>
I, _! E( v$ O( G$ R/ t5 J
复制代码 V* W! k: a! k
ssh地址在gitee仓库页面点击“克隆/下载”按钮获取。
可以通过 git remote -v指令查看远端的连接。 - <font face="Tahoma"><font color="black">) z$ x' S( R; b5 P5 K
- $ git remote -v8 @' V$ |- X% a9 O. Y5 ]5 g* W
- origin git@gitee.com:xxxx/PROJECTTEST.git (fetch)' C, e3 ^3 Z' x* l
- origin git@gitee.com:xxxx/PROJECTTEST.git (push)</font></font>
- [" e* M6 ]7 w; v) U3 P
复制代码2.拉取远端版本到本地 - <font face="Tahoma"><font color="black">8 h/ m9 t( d, K: L/ d
- git pull origin master
, Z- `5 s# M. |8 t
7 P* e( y) G2 G' `5 C' J- $ git pull origin master
" c Z$ o2 z6 t$ ~- ~$ g" N - remote: Enumerating objects: 4, done.
/ [- x0 c, i) Z: c2 f - remote: Counting objects: 100% (4/4), done.
& p( Z2 v' G- V: M& @. n$ R- ^ - remote: Compressing objects: 100% (4/4), done.
- j( t4 B; |" @$ z7 M2 J( r - remote: Total 4 (delta 0), reused 0 (delta 0), pack-reused 0" Z7 n( \# R2 p+ J: z, F$ J) E/ ~
- Unpacking objects: 100% (4/4), done.7 X& l( p1 P3 m% Y
- From gitee.com:xxxx/PROJECTTEST
& {$ G* r$ m/ F- y8 D# x - * branch master -> FETCH_HEAD* I0 u2 F0 O ~/ L
- * [new branch] master -> origin/master</font></font>( G5 M# r6 ^+ G$ g
复制代码拉取成功后,本地目录可以看到刚才创建gitee仓库时创建的Readme文件。 3.本地提交代码 将project内原有的代码,inc/ src/目提交到本地仓库。
, @. B0 P8 [2 G ]* m, j- git add src/1 y7 E. c+ z# U( Y& P
- git add inc/, L3 H) F2 ]0 S% K0 H
- git commit -m “first commit”
W% g% t: d7 o @% X9 v
复制代码 & Y% K: E; @& G, x8 S0 l
注意不要讲编译生成的文件add进去,只将代码add进仓库。因为编译生成的文件每次编译都会变化,这样每次的版本提交都包含了这些非代码改变的提交,不仅会使得版本很混乱也会占用很多远程仓库的空间。当然这也可以通过增加gitignore文件的方法来处理。 4.推送本地仓库到远端 - <font face="Tahoma"><font color="black">
$ Y; Y2 Q0 W. z" {: t - git push origin master
1 K! Y6 j/ ~6 H - $ git push origin master
; P2 x& F/ G" ` - Enumerating objects: 32, done.
1 h$ |% C* ^. @ P, b3 [ D- N - Counting objects: 100% (32/32), done.
7 j& B* f6 U. z2 s# {- c - Delta compression using up to 8 threads
9 J4 r" M: a( @ - Compressing objects: 100% (31/31), done.4 [! D( r& S, W3 _
- Writing objects: 100% (31/31), 22.22 KiB | 2.78 MiB/s, done.
8 g6 v! {; C( [( \; x% k) {$ t; E - Total 31 (delta 12), reused 0 (delta 0)8 N/ j, @9 e4 W" B0 ~, u
- remote: Powered by GITEE.COM [GNK-5.0]
5 @9 j( r/ b1 [, B8 i& l - To gitee.com:xxxx/PROJECTTEST.git- b$ Z3 F8 H6 z9 q- R5 i& x4 {
- 4d112e2..ebaf8bd master -> master</font></font>
( h2 t6 w$ O j3 R$ X; k: y
复制代码 8 m; M' V- P: t2 c) U
直接git push会提示警告
$ p4 V8 g+ a6 Q# ~0 T- $ git push# J: s- P8 o4 u1 Y' p' D$ B1 i3 c
- fatal: The current branch mater has no upstream branch.
8 d2 x' i* o' y" F; a6 `& e' m - To push the current branch and set the remote as upstream, use) L. I# L P% h5 r9 q
6 h! i; D% X0 X
- d0 A, I, l: g# J& E- git push --set-upstream origin master
复制代码
$ j. {1 g8 h9 B9 g- w3 F按照提示执行git push --set-upstream origin master,以后再推送版本,只需要输入git push就可以了。
2 v# C3 U2 x" b: u4 _至此,将一个现有的keil工程加入git管理,并在远端托管平台备份的操作都完成了,后面在这个工程上做开发并提交版本,就按照常规的git操作 git add、git commit、git push就可以了。本文开始提出的版本回退问题,只需要执行git reset –hard的指令,代码就自动回退到指定的提交点了。更多的git功能,开发者可以在后续的实际开发中不断学习完善。 & v- {" [& L- E9 _: E
|