在Makefile中
一般所谓
CFLAGS
存储的是头文件 -I./include
LIBRARY
存储的是库文件 -L./lib
LDFLAGS
存储的是库文件 选用哪个库文件看你本身的喜爱linux
在Makefile 中看调试信息能够使用
$(info $(TARGETS))web
LOCAL_LIBRARY += -L./lib -lpal #LIBRARY += -Wl,-rpath . -lpthread -ldl LOCAL_LDFLAGS += -lopus -lpthread -ldl LOCAL_CFLAGS += -I./include SRCS = $(wildcard *.c) OBJS = $(patsubst %.c, %.o, $(SRCS)) #TARGETS = $(SRCS:%.c=%) TARGETS = pal_sample opus_test libwebsockets_test cJson CFLAGS += $(LOCAL_CFLAGS) LDFLAGS += $(LOCAL_LIBRARY) $(LOCAL_LDFLAGS) $(info $(OBJS)) $(info $(TARGETS)) #CC:=arm-openwrt-linux-gcc #all : $(TARGETS) all: opus_test #$(TARGETS): %: %.o # $(CC) -o $@ $< $(LOCAL_LDFLAGS) $(LIBRARY) #pal_sample:pal_sample.o platform_linux.o # $(CC) -o $@ platform_linux.o $(LIBRARY) pal_sample.o $(LOCAL_LDFLAGS) opus_test:opus_test.o platform_linux.o $(CC) -o $@ platform_linux.o opus_test.o $(LDFLAGS) opus_test.o:opus_test.c $(CC) -o $@ $(CFLAGS) -c opus_test.c #$(OBJS) : %.o: %.c # $(CC) -c $(CFLAGS) $< -o $@ $(LOCAL_LDFLAGS) $(LIBRARY) platform_linux.o:platform_linux.c $(CC) -o $@ -c $(CFLAGS) platform_linux.c clean : @rm -rf $(TARGETS) $(OBJS) #.SUFFIXES: .PHONY : all clean
LOCAL_LIBRARY += -L./lib -lpal LOCAL_LDFLAGS += -lm -lopus -lwebsockets -lpthread -ldl LOCAL_CFLAGS += -I./include TARGETS1 = air_opus SRCS1 = opus_test.c platform_linux.c cJSON.c OBJS1 = $(patsubst %.c, %.o, $(SRCS1)) CFLAGS += $(LOCAL_CFLAGS) LDFLAGS += $(LOCAL_LIBRARY) $(LOCAL_LDFLAGS) $(info $(OBJS)) $(info $(TARGETS)) all: $(TARGETS1) $(TARGETS1):$(OBJS1) $(CC) -o $@ $^ $(LDFLAGS) $(CFLAGS) $(OBJS1): %.o:%.c $(CC) -c $< -o $@ $(CFLAGS) clean : @rm -rf $(TARGETS1) $(OBJS1) #.SUFFIXES: .PHONY : all clean
为何改为这一版本呢??
首先这样能够
$^:全部的 .o
$<:全部的依赖项目 .c 第一个的依赖,因此特别适合用来编译 .o文件websocket
$(LDFLAGS) $(CFLAGS) 加入的位置,编译 .o 文件不必加入库的路径.
编译 可执行文件的时候就比较适合了.socket
这个表示你的编译命名覆盖了官方的命令.
好比使用了 := 之类的.调试