在Makefile中
通常所謂
CFLAGS
存儲的是頭文件 -I./include
LIBRARY
存儲的是庫文件 -L./lib
LDFLAGS
存儲的是庫文件 選用哪一個庫文件看你自己的喜好
在Makefile 中看調試信息可以使用
$(info $(TARGETS))
第一版:
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文件
注意:
$(LDFLAGS) $(CFLAGS) 加入的位置,編譯 .o 文件沒必要加入庫的路徑.
編譯 可執行文件的時候就比較適合了.
someone does not honour COPTS correctly, passed 0 times
這個表示你的編譯命名覆蓋了官方的命令.
比如使用了 := 之類的.