在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
這個表示你的編譯命名覆蓋了官方的命令.
好比使用了 := 之類的.調試