git add remote_使用git管理嵌入式软件版本

ff5e9573a60550f282e2c66acab729e4.gif

点击上方蓝字关注我哦~

你现在的Keil工程的版本控制是怎么管理的?可能有些人的做法是发布一个版本软件后将代码打一个包保存起来,作为此版本的备份。有一种常见的情况,当开始一项新功能的开发,并且最终的效果不理想老板要求回退回去。又恰巧在开发前没有打个包保存一下初始版本,那就需要一处一处回改,这样手工回退后的版本可靠性就下降许多,需要完整的测试才行。为了避免这种尴尬的情况,有必要在keil工程也引入版本控制工具。

Git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds (Linux发明者)为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。这个诞生于2005年并且至今都使得开发者赞不绝口的工具,实际上Linus仅开发了两周并在一个月内就上线用于管理庞大的Linux内核了,不得不赞叹天才的伟大和凡人的不可企及。

时至今日,Git早已在Android开发、Linux开发、web开发等场景成为最通行的版本管理工具,另外一些IDE集成开发环境也加入了Git,例如Android Studio, Intellij IDEA等。嵌入式开发常用的Keil也在keil5.15后也已经集成了版本管理工具,但是本文仍然是就Windows版Git管理Keil工程的示例,方便老版本的keil项目建立git管理。Keil5内集成的git的使用方法有机会再整理出来。

Git的实用性也逐渐带来了git托管平台的流行,如GitHub、GitLab、Bitbucket、Codeing.net、Gitee等。无数崇尚软件开源的开发者挥洒着汗水在这些平台上贡献了数以亿计的开源项目,使得咱们这些普通人可也以参与其中,接触到最前沿的技术、最酷炫的功能。身为一个开发者也要学会在开源代码上汲取这些全球精英所奉献的新知识新技能。

关于Git的使用方法,可以参考廖雪峰的git教程,深入浅出非常实用。在这篇文章中主要讲的是将一个既有的Keil工程加入git管理的方法。

01

安装windows版git

可以去官网下载windows版本的git, https://git-scm.com/downloads

0b4a8256d2c6bcdafcede3294345cd9d.png

安装完成后,在开始菜单内找到Git Bash并启动。启动后的操作窗口类似于windows的cmd窗口。在bash窗口内可以执行Linux的一些shell指令。

b5de76ae8029dc80948a817a80ef54c3.png

安装完成后,还需要设置邮箱地址和用户名,在命令行输入:

$ git config --global user.name "Your Name"$ git config --global user.email "email@example.com"

因为Git是分布式版本控制系统,可以多人在一起开发。所以每次提交,每次上传,都会带有你这台电脑的标记——邮箱地址和用户名。

02

本地建立git库

以/D/PROJ/project的一个keil工程为例。

1.进入工程所在的目录,使用ls指令查看是否正确的进入了目录。

xxxx@DESKTOP-TH28NBD MINGW64 /$ cd /D/PROJ/project/ xxxx@DESKTOP-TH28NBD MINGW64 /D/PROJ/project (master)$ lsinc/  Libraries/  README.en.md  README.md  RVMDK/  src/

2、初始化本地git仓库

git init

f52846ee37b79c37d255dab32796f4e7.png

在project的目录下可以看到.git的目录,该目录包含让 git 能够正常工作所需的所有信息。

03

远程代码托管平台

Github和Gitlab是最流行的托管平台,由于众所周知的原因,这些国外的网站在国内的访问速度很不理想,国内使用推荐gitee码云或coding.net。以Gitee来举例。

Gitee免费版可创建 1000 个仓库,不限制公私有。单仓库大小上限为 500M,单文件最大 50M,用户总仓库容量为 5G。对于一般的keil嵌入式开发,免费版已经绰绰有余了。

1.注册Gitee,根据网站的提示完成注册。

2.配置ssh

本地Git仓库和Gitee仓库之间的传输是通过SSH加密的,所以需要配置ssh,使得托管平台认可你这台电脑的git操作。在Git Bash内执行以下指令创建SSHkey。

ssh-keygen -t rsa -C youremail@example.com

把邮件地址换成你自己的邮件地址,然后回车一路使用默认值即可。完成后在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以发送给他人。

df7f9dec33ab4c77108427b9104d9140.png

Windows的目录在c盘的用户目录内。

e732a863abf653e4f166e1c880d23505.png

3.上传ssh公钥到码云

点击右上角的用户头像,选择设置。然后在设置页面的左侧功能栏选择SSH公钥。将刚才生成的id_rsd.pub的内容拷贝进公钥内容框内,标题随意填写。

3ce7c1f55562af234eaf551c17285d99.png570d468dbe4121eeafe23ee443bec13e.png

4.创建项目仓库

点击页面右上角的加号,并选择新建仓库。

b4157b5063926031d1b2bba9ad4fc18a.png

04

本地提交代码与推送远程库

1.添加远端地址

git remote add origin ssh地址如 git remote add origin git@gitee.com:xxxx/xxxx.git

ssh地址在gitee仓库页面点击“克隆/下载”按钮获取。

47e1d11e3e6d646c963fed29d24950ad.png

可以通过 git remote -v指令查看远端的连接。

$ git remote -vorigin  git@gitee.com:xxxx/PROJECTTEST.git (fetch)origin  git@gitee.com:xxxx/PROJECTTEST.git (push)

2.拉取远端版本到本地

git pull origin master$ git pull origin masterremote: Enumerating objects: 4, done.remote: Counting objects: 100% (4/4), done.remote: Compressing objects: 100% (4/4), done.remote: Total 4 (delta 0), reused 0 (delta 0), pack-reused 0Unpacking objects: 100% (4/4), done.From gitee.com:xxxx/PROJECTTEST * branch            master     -> FETCH_HEAD * [new branch]      master     -> origin/master

拉取成功后,本地目录可以看到刚才创建gitee仓库时创建的Readme文件。

3.本地提交代码

将project内原有的代码,inc/ src/目提交到本地仓库。

git add src/git add inc/git commit -m “first commit”

注意不要讲编译生成的文件add进去,只将代码add进仓库。因为编译生成的文件每次编译都会变化,这样每次的版本提交都包含了这些非代码改变的提交,不仅会使得版本很混乱也会占用很多远程仓库的空间。当然这也可以通过增加gitignore文件的方法来处理。

4.推送本地仓库到远端

git push origin master$ git push origin masterEnumerating objects: 32, done.Counting objects: 100% (32/32), done.Delta compression using up to 8 threadsCompressing objects: 100% (31/31), done.Writing objects: 100% (31/31), 22.22 KiB | 2.78 MiB/s, done.Total 31 (delta 12), reused 0 (delta 0)remote: Powered by GITEE.COM [GNK-5.0]To gitee.com:xxxx/PROJECTTEST.git   4d112e2..ebaf8bd  master -> master

直接git push会提示警告

$ git pushfatal: The current branch mater has no upstream branch.To push the current branch and set the remote as upstream, usegit push --set-upstream origin master

按照提示执行git push --set-upstream origin master,以后再推送版本,只需要输入git push就可以了。

至此,将一个现有的keil工程加入git管理,并在远端托管平台备份的操作都完成了,后面在这个工程上做开发并提交版本,就按照常规的git操作 git add、git commit、git push就可以了。本文开始提出的版本回退问题,只需要执行git reset –hard的指令,代码就自动回退到指定的提交点了。更多的git功能,开发者可以在后续的实际开发中不断学习完善,

/ The End /

本文系嵌入式案例Show原创出品,未经许可,请勿转载。

bb1a7e1a6821758022a174806c311a4d.gif

扫码关注我们

看更多嵌入式案例

9ed7f2266ef20c216fdb6a979d32c2cb.png

喜欢本篇内容请给我们点个在看

01695c4db2df68f8e1092e28c77d2cee.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472571.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

xshell 6 连接debian系统拒绝了密码_Xshell中操作Linux的常用命令,你知道几个?

作为IT人员,想必都知道Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Xshell作为专业的终端模拟器,可以用来登录Linux,从而通过命令来控制Linux系统&…

LeetCode 1798. 你能构造出连续值的最大数目

文章目录1. 题目2. 解题1. 题目 给你一个长度为 n 的整数数组 coins ,它代表你拥有的 n 个硬币。 第 i 个硬币的值为 coins[i] 。如果你从这些硬币中选出一部分硬币,它们的和为 x ,那么称,你可以 构造 出 x 。 请返回从 0 开始&…

分别用邻接矩阵和邻接表实现图的深度优先遍历和广度优先遍历_数据结构与算法学习笔记:图...

图:图结构区别于线性结构和树型结构,区别可见下图逻辑上的图(graph)结构由顶点(vertex)和边(edge)组成。一个图结构G包含顶点集合V和边集合E,任何两个顶点之间可以有一个边表示两者的关系。对于一个存在的G,V不可以为空集&#xf…

人类附身机器人获得永生_脑机接口先驱尼古莱利斯:人类无法实现数字永生

科幻作品中的意念控制、心灵感应,甚至数字“永生”,会通过脑机接口技术得以实现吗?脑机接口技术先驱者之一、杜克大学神经工程学教授米格尔尼古莱利斯(Miguel Nicolelis)表示,不可能。近日,尼古莱利斯在巴西家中与北京…

linux内核分成如下五个子系统,linux内核主要由5个子系统 Linux内核由哪几个子系统组成?...

1, Linux内核由哪几个子系统组成?Linux内核主要由五个子系统组成:进程调度,内存管理,虚拟文件系统,网络接口,进程间通信。1.进程调度(SCHED):控制进程对CPU的访问。当需要选择下一个进程运行时&…

LeetCode 1799. N 次操作后的最大分数和(回溯 / 状态压缩DP)

文章目录1. 题目2. 解题2.1 错误解2.2 回溯超时解2.3 回溯通过2.4 状态压缩DP1. 题目 给你 nums ,它是一个大小为 2 * n 的正整数数组。 你必须对这个数组执行 n 次操作。 在第 i 次操作时(操作编号从 1 开始),你需要&#xff1…

pytorch argmax_轻松学Pytorch使用ResNet50实现图像分类

点击上方蓝字关注我们微信公众号:OpenCV学堂关注获取更多计算机视觉与深度学习知识Hello大家好,这篇文章给大家详细介绍一下pytorch中最重要的组件torchvision,它包含了常见的数据集、模型架构与预训练模型权重文件、常见图像变换、计算机视觉…

LeetCode 1800. 最大升序子数组和

文章目录1. 题目2. 解题1. 题目 给你一个正整数组成的数组 nums &#xff0c;返回 nums 中一个 升序 子数组的最大可能元素和。 子数组是数组中的一个连续数字序列。 已知子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;若对所有 i&#xff08;l < i < r&a…

html使用js的变量_2、温故而知新,再学一遍JavaScript-html中如何使用JS

温故而知新&#xff0c;再学一遍JavaScripthtml中使用JavaScript有两种方式&#xff1a;通过中使用src属性引入外部JS文件,同时又在其内部嵌入JavaScript 代码&#xff0c;则嵌入的代码会被忽略。关于”字符串当浏览器遇到字符串""时就会认为代码块已经结束&#xff…

修改字段类型_PostgreSQL 关于字段类型的修改 谣言与止谣

​PostgreSQL 在9.2 之前是要面临一个指责&#xff0c;就是在更改字段类型的时候带来的不堪&#xff0c;假象你有100万行的数据&#xff0c;其中一个字段是varchar(20) ,你想将其更改为 varhcar(30), 这可能就要造成一个灾难&#xff0c;熟悉postgresql 原理的人们&#xff0c;…

用户 'IIS APPPOOL\***' 登录失败(转载)

用户 IIS APPPOOL\DefaultAppPool 登录失败。 我在windows8中安装了iis之后添加了我做的网站打开之后提示用户 IIS APPPOOL\DefaultAppPool 登录失败。 我再vs2010中能正常运行 最佳答案 这是设置iis应用程序池的设置问题。我就遇到了这样的问题。 比如我的网站取名myweb…

完全相同的4个小矩形如图所示放置_吸睛!矩形在PPT中的创意表现

如何在PPT中表现出光效来&#xff1f;这是很多人在制作PPT时都可能会面临的问题&#xff0c;大多数人的常规做法就是在许多素材网站中直接寻找&#xff0c;比如在花瓣中直接搜索"光效"&#xff0c;我们可以得到以下结果&#xff1a;这些光效PNG文件可以直接用在我们的…

LeetCode 1801. 积压订单中的订单总数(map)

文章目录1. 题目2. 解题1. 题目 给你一个二维整数数组 orders &#xff0c;其中每个 orders[i] [pricei, amounti, orderTypei] 表示有 amounti 笔类型为 orderTypei 、价格为 pricei 的订单。 订单类型 orderTypei 可以分为两种&#xff1a; 0 表示这是一批采购订单 buy1 …

quantaxis 云服务器_量化金融策略开源框架:QUANTAXIS

简介&#xff1a; QUANTAXIS量化金融策略框架,是一个面向中小型策略团队的量化分析解决方案&#xff0c;是一个从数据爬取、清洗存储、分析回测、可视化、交易复盘的本地一站式解决方案。QUANTAXIS量化金融策略框架,是一个面向中小型策略团队的量化分析解决方案&#xff0c;是一…

listrecord根据某个属性去重_去哪网开发实战记录(9):城市选择页(中)

兄弟组件之间的联动所谓的兄弟组件之间的联动&#xff0c;其实就是实现点击右侧的字母就能跳转至对应的首字母城市&#xff0c;因此列表组件需要知道右侧的字母列表的点击事件所对应的元素字母&#xff0c;这就需要兄弟组件间的数据传递了(Alphabet组件与List组件之间的通信)&a…

写接口是什么意思啊_科普贴:果汁包装上写NFC到底是什么意思?

比起水果&#xff0c;果汁省去了繁杂的处理步骤&#xff0c;选对了能更快地补充营养。今天麦德龙美厨课堂就为大家推荐METRO Chef NFC100%果汁系列&#xff0c;给你真材实料、原汁原味的营养美味。NFC果汁&#xff1a;真材实料 原汁原味如今果汁饮品市场上品类繁杂&#xff0c;…

LeetCode 1802. 有界数组中指定下标处的最大值(思维题)

文章目录1. 题目2. 解题1. 题目 给你三个正整数 n、index 和 maxSum 。 你需要构造一个同时满足下述所有条件的数组 nums&#xff08;下标 从 0 开始 计数&#xff09;&#xff1a; nums.length nnums[i] 是 正整数 &#xff0c;其中 0 < i < nabs(nums[i] - nums[i1]…

Linux单用户能做什么,Linux单用户模式详解 及应用场景

一、单用户模式简介二、进入单用户模式修改密码1、Centos6进入单用户修改密码1、重启系统&#xff0c;进入系统欢迎界面按上下左右键进入GRUB界面&#xff1b;2、在GRUB界面选择内核版本&#xff0c;按下e键&#xff1b;3、在此界面可以进行编辑&#xff0c;在最后输入single再…

简单阻容降压电路图_升压降压芯片电路

升压与降压一般是指电源电路的工作模式&#xff0c;有些电源IC可以同时支持升压和降压模式。降压模式——Bust mode&#xff0c;这个大家比较熟悉的&#xff0c;用的也比较多&#xff0c;比如5V-》3.3V稳压&#xff0c;对应的芯片很多大家上网搜一下就有了&#xff0c;有LDO模式…

linux终端分辨率对应表,Linux下设置终端分辨率,最全的VGA代码和分辨率对照表...

一般安装完linux后默认的kernel给的tty分辨率是非常有限的,解决的方法就是给kernel传递VGA参数。对应的要修改的配置文件为 /etc/grub.conf,(或者 /boot/grub/grub.conf)就是在grub.conf启动列表的kernel最后添加vga参数 vgaxxxx, 这个在网上大家列出的解决方案都是大同小异&…