最近学习到的传参过程,感觉很实用,稍加拓展可以实现一些有用的功能。建立测试用例建立一个文件夹,命名:zgftestzgftest中包含的文件:makefile、mk.sh、rules
最近学习到的传参过程,感觉很实用,稍加拓展可以实现一些有用的功能。
建立测试用例
建立一个文件夹,命名:zgftest
zgftest中包含的文件:makefile、mk.sh、rules.make、zgftest.c
以下分别是每个文件下的测试代码:
rules.make
ZGF_INFO = -DZGF_TEST_INFO=\"$(ZGF_TEST_INFO)\"
GLOBAL_FLAG = $(ZGF_INFO)
mk.sh
#!/bin/sh
#功能函数,用来为inputinfo赋值,这段代码测试时也可以写在main中
function input_zgf_info()
{
local lINFO="zhaoguanfeng666"
inputinfo="ZGF_TEST_INFO=${lINFO}"
}
#main中为make传递ZGF_TEST_INFO参数的值
function main()
{
echo "$0"
input_zgf_info
echo "input_zgf_info"
#inputinfo不加括号和加大括号均可以实现变量替换
make $inputinfo
# make ${inputinfo}
echo "$inputinfo"
}
main $@
zgftest.c
#include <stdio.h>
//简单测试ZGF_TEST_INFO宏是否传递成功
int main(int arGC,char **argv)
{
fprintf(stdout,"%s\n",ZGF_TEST_INFO);
return 0;
}
makefile
#!/bin/bash
include ./rules.make
CC =gcc
VERSION :=1.1
VPATH =.
#获取所有的.c文件
SOURCE =$(foreach dir,$(VPATH),$(wildcard $(dir)/*.c))
#将source中所有.c文件变为.o文件
OBJ = $(patsubst %.c, %.o, $(SOURCE))
GLOBAL_FLAG ?=ERROR
ifeq ($(GLOBAL_FLAG), ERROR)
$(error make error! GLOBAL_FLAG not defined,"rules.make" must be wrong!!!)
endif
CFLAGS = $(GLOBAL_FLAG)
TARGET = main
$(TARGET) :$(OBJ)
@echo "删除output文件夹"
rm -rf ./output
@echo "重建output文件夹"
mkdir ./output
@echo "开始链接......"
$(CC) $(OBJ) -o ./output/$@.$(VERSION)
@echo "编译链接完成"
%.o: %.c
@echo "开始编译......"
#在编译时将CFLAGS所代表的变量传递给C
$(CC) $(CFLAGS) -c $< -o $@ $(INCLUDES)
.PHONY :clean
clean :
@echo "开始删除......"
rm -rf $(OBJ) ./output
@echo "删除完成"
代码总体实现流程:
首先是在rules.make文件中,ZGF_INFO = -DZGF_TEST_INFO=*****这句代码就是通过make向C传递ZGF_TEST_INFO的意思,只是目前-DZGF_TEST_INFO=*****语句还只是赋值给了ZGF_INFO。然后将ZGF_INFO赋值给了GLOBAL_FLAG。
makefile中,包含了rules.make文件,并将GLOBAL_FLAG赋值给了CFLAGS,最终在$(CC) $(CFLAGS) -c $< -o $@ $(INCLUDES) 语句中,CFLAGS会展开,-DZGF_TEST_INFO=*****语句就会被放置到make后面,最终将ZGF_TEST_INFO变量作为宏传递给C。
但是实际上当前的ZGF_TEST_INFO变量里面是没有值的,因为还没有赋值,实际的赋值操作是在mk.sh中被实现的,通过脚本中的函数function input_zgf_info(),为ZGF_TEST_INFO赋值为zhaoguanfeng666,并在脚本的main函数中,执行make时,将ZGF_TEST_INFO作为make的输入参数传递给makefile,从而实现了为makefile中的ZGF_TEST_INFO变量赋值。最终ZGF_TEST_INFO的值被传递进了C中。
编译运行结果:
从编译结果可以看出,ZGF_TEST_INFO已经被顺利传递进了makefile,如果传递失败的话,第一个红框中的ZGF_TEST_INFO后面是没有值的。第二个红框表示ZGF_TEST_INFO变量在脚本中被赋值成功。
c文件运行结果,成功打印出传递进来的宏的值。
到此这篇关于shell 通过makefile传参给C语言的实现示例的文章就介绍到这了,更多相关shell 通过makefile传参给c内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: shell通过makefile传参给c语言的实现示例
本文链接: https://lsjlt.com/news/200944.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0