1、功能应用背景和开发思路
(1)应用背景:当程序出错时,我们想要知道库的版本信息,这样有助于定位错误是哪个版本引入的,缩小排查的范围;就算程序没有出错,能知道库的版本,也方便知道程序的版本;
(2)思路:在编译源码时,获取svn版本和编译时间并编译进源码,在库的初始化函数里将svn版本和编译时间打印出来;
2、获取svn版本号
[aston]$ svn info
Path: .
Working Copy Root Path: xxxxxx
URL: xxxxxxxxxxxxxxxx
Relative URL: xxxxxxxxxxxxxx
Repository Root: xxxxxxxxxxxxxxxxxxxx
Repository UUID: 0191c7e8-835f-43ee-9283-22566a29a934
Revision: 1804
Node Kind: directory
Schedule: normal
Last Changed Author: xxxxx
Last Changed Rev: 1069
Last Changed Date: 2022-09-08 16:24:59 +0800 (Thu, 08 Sep 2022)
使用"svn info"命令可以查看当前库的svn信息,其中就包括版本信息,比如从上面的信息里可知当前版本号是1069,我们需要做的就是在编译程序时通过脚本来自动获取svn版本号;
3、修改Makefile获取svn版本
#获取svn版本号
SVN_NUM := $(shell svn info ../ \
| sed -n '/.*-*:*:*+./{g;1!p;};h' \
| grep -oP "\d+")
# It use default value -1 when there was no svn.
ifeq ($(SVN_NUM),)
$(warning No svn in the code, using value -1 as svn number !)
SVN_NUM := -1
endif
#添加SVN_NUM宏
CFLAGS += -DSVN_NUM=$(SVN_NUM)
4、打印svn版本和时间
printf("-----------------------------------------------------------\n");
printf("libxxx Build on %s at %s.\n", __DATE__, __TIME__);
printf("==========SVN NUM: %d.\n", SVN_NUM);
printf("-----------------------------------------------------------\n");
(1)__DATE__和__TIME__是两个编译宏,能自动获取时间,使用十分简单;
(2)DATE:当前的编译日期,TIME:当前编译时间;
5、实现效果
-----------------------------------------------------------
libxxx Build on Mar 11 2023 at 10:18:18.
==========SVN NUM: 1069.
-----------------------------------------------------------