| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 | #定义 伪目标.PHONY: all lib script close clean cleanall#设置生成的可执行程序名TARGET = xinyun_mqtt_alarm.svr######################### 以下内容一般无需修改 ##########################设置默认编译器CC = gccINCLUDE_PATH = -Iinclude  -Icore -Ipaho.mqtt.c/src  -I.#编译参数#-Wall: 启用大多数警告信息 -W: 启用额外的警告 -O2: 启用优化级别2 -g: 生成调试信息 -Wpointer-arith: 启用指针算术警告 -Wstrict-prototypes: 启用严格的函数原型声明CFLAGS = -Wall -W -O2 -g -Wpointer-arith -Wstrict-prototypes $(INCLUDE_PATH)#这个 -Wl,-E 不能少 要不然脚本里require *.so 会报错#-Wl,-E 传递-E选项给链接器,这可以用于各种目的,包括从生成的共享对象中导出所有符号。#-lrt:链接到实时库 -lpthread:链接到线程库 -lm:链接到数学库 -lz:链接到压缩库 -ldl:链接到动态连接库# -L/usr/lib64/mysql:指定 MySQL 客户端库所在的目录。# -lmysqlclient:链接到 MySQL 客户端库。#-Lsolib:指定其他共享库所在的目录。#-Wl,-rpath=solib:设置运行时库搜索路径,包括指定的目录(在这里是 solib)。这确保程序在运行时在该目录中查找共享库。MYLIBS = -Wl,-E  -lrt -lpthread -lm -lz -ldl  -L/usr/lib64/mysql  -lmysqlclient -Lsolib -Wl,-rpath=solibSO_LIB=solibPWD_PATH =$(shell pwd)#通用lib库COMMON_LIB =   libcommon.a   COMMON_LIB_PATH = lib/#核心库lib库CORE_LIB = libcore.soCORE_LIB_PATH = core/#MQTT 相关库的源代码路径MQTT_LIB = libpaho-mqtt3a.soMQTT_LIB_SRC = paho.mqtt.cMQTT_LIB_PATH = paho.mqtt.c/src/#设置生成可执行文件的存放路径RUN_PATH = bin/#自定义命令名CP = cp -rfRM = rm -rf#默认的make目标all:  lib $(TARGET) $(MQTT_LIB) $(CORE_LIB)  #进入 lib 目录并执行 make 命令#如果存在main.c则需要重新编译lib:	cd lib && $(MAKE)ifneq (,$(wildcard ./src/main.c))	@#如果存在main.c则需要清除及重新编译	cd src && $(MAKE)endif#目标 生成主程序 并附带copy一些脚本#./src/main.o、$(MQTT_LIB)、$(CORE_LIB) 是依赖项。表示在执行该目标之前需要完成这些依赖项的构建#$(wildcard $(CORE_LIB_PATH)/*.c) $(wildcard $(CORE_LIB_PATH)/*.h) 是通配符,表示匹配所有.c 和.h 文件$(TARGET): ./src/main.o $(MQTT_LIB) $(CORE_LIB)  $(wildcard $(CORE_LIB_PATH)/*.c) $(wildcard $(CORE_LIB_PATH)/*.h) 	@# 后面的lib库在调整先后位置后可能导致编译出错哦	$(CP) $(CORE_LIB_PATH)$(CORE_LIB) $(SO_LIB)	$(CP) $(MQTT_LIB_PATH)$(MQTT_LIB) $(SO_LIB)	@# 使用 gcc 编译器将目标文件、通用库、库路径和其他选项链接为最终的可执行程序	$(CC) $(CFLAGS) ./src/main.o $(COMMON_LIB_PATH)$(COMMON_LIB)  $(MYLIBS)  $(SO_LIB)/$(CORE_LIB)  $(SO_LIB)/$(MQTT_LIB)  -o $(TARGET)	@# 将生成的可执行程序复制到运行目录	$(CP) $(TARGET) $(RUN_PATH)	@# 删除临时目录下的 lib 目录,并将 lib 目录复制到运行目录	$(RM) $(RUN_PATH)/$(SO_LIB) && $(CP)   $(SO_LIB) $(RUN_PATH)	@# 删除当前目录下生成的可执行程序	$(RM) $(TARGET)	@echo -e "\\033[32m $(TARGET) is OK and Move to DIR: $(RUN_PATH)  \\033[0m"# MQTT_LIB 的生成方法# 获取指定路径下所有的 .c 文件和 .h 文件# 进入 $(MQTT_LIB_SRC) 目录,然后执行 make 命令$(MQTT_LIB): $(wildcard $(MQTT_LIB_SRC)/src/*.c) $(wildcard $(MQTT_LIB_SRC)/src/*.h)		cd $(MQTT_LIB_SRC)  && $(MAKE) # CORE_LIB 的生成方法# 获取指定路径下所有的 .c 文件和 .h 文件# 进入 $(CORE_LIB_PATH) 目录,然后执行 make 命令。$(CORE_LIB): $(wildcard $(CORE_LIB_PATH)/*.c) $(wildcard $(CORE_LIB_PATH)/*.h)		cd $(CORE_LIB_PATH) && $(MAKE)#普通清理clean:	cd lib && $(MAKE) clean	-$(RM) $(SO_LIB)/*.so	-$(RM) $(TARGET)ifneq (,$(wildcard ./src/main.c))	@#如果存在main.c则需要清除及重新编译	cd src && $(MAKE) cleanendif	cd $(CORE_LIB_PATH)  && $(MAKE) clean	cd $(MQTT_LIB_SRC) && $(MAKE) clean#深度清理cleanall: clean	cd lib && $(MAKE) cleanall	cd $(MQTT_PATH)  && $(MAKE) clean	$(RM) $(TARGET)ifneq (,$(wildcard src/main.c))	@#如果src 目录下有文件 main.c 才能进去啊	cd src && $(MAKE) cleanendif	@#如果是 bighead 的目录 则还多做点事情ifeq "$(HOME)" "/home/bighead"	find . -name cscope\.*  -exec rm -f {} \;	find . -name tags -exec rm -f {} \;endif
 |