我的Makefile看起来像这样:
all:main.cpp
g++ -I../../DrAPI/ -Wl,--no-as-needed -ldl -lrt -o SampleApp01 $<
clean:
rm -f SampleApp01
如果没有Makefile,我会这样做:
gcc main.cpp -o test $(pkg-config --cflags --libs libmongoc-1.0)
现在因为导入DrAPI我必须使用Makefile来包含该API,但是如果没有pkg-config,我会丢失libmongoc-1.0。在这种情况下,我应该如何将$(pkg-config --cflags --libs libmongoc-1.0)添加到我的Makefile中以便它可以工作?
答案 0 :(得分:1)
all:main.cpp
g++ -I../../DrAPI/ `pkg-config --cflags --libs libmongoc-1.0` -Wl,--no-as-needed -ldl -lrt -o SampleApp01 $<
clean:
rm -f SampleApp01
答案 1 :(得分:0)
当我使用GTK +库编译我的C代码时,我创建一个名为GTK
的变量并将其设置为pkg-config
,如下所示:
GTK = `pkg-config --cflags --libs gtk+-3.0`
使用以下代码编译代码:
$(CC) $(CFLAGS) $(OBJECTS) $(GTK) -o $@
CC = gcc
,CFLAGS
是其他编译器标志(如-I ../../DrAPI
)和OBJECTS
是源文件和目标文件。
这样你的makefile看起来像这样:
DRAPI = `pkg-config --cflags --libs libmongoc-1.0`
all:main.cpp
g++ -I../../DrAPI/ -Wl,--no-as-needed -ldl -lrt $(DRAPI) -o SampleApp01 $<
clean:
rm -f SampleApp01
编辑:忘了这个。使用CFLAGS
变量并存储pkg-config --cflags [some library, eg. gtk+-3.0]
和LIBS
变量来存储pkg-config --libs [some library again]
。现在你的makefile看起来像这样:
CFLAGS = -I../../DrAPI/ -Wl,--no-as-needed -ldl -lrt `pkg-config --cflags libmongoc-1.0`
LIBS = `pkg-config --libs libmongoc-1.0`
all:main.cpp
g++ $(CFLAGS) $(LIBS) -o SampleApp01 $<
clean:
rm -f SampleApp01
希望这有帮助!
答案 2 :(得分:0)
我本可以制作一个Makefile
,看起来像这样,所以它使用
make(1)
中已经存在的规则。
尝试make -f /dev/null --print-data-base
查看它们。建议grep
-ing COMPILE.c
和LINK.c
以获取重要内容。 COMPILE.cpp
,COMPILE.C
和COMPILE.cxx
适用于c ++,COMPILE.c
适用于c。
#!/bin/make
# Makefile
# 2020-02-10 Anders Jackson
# Basic setup
CXX = g++
CXXFLAGS = -c -g -Wall -Wextra
CXXFLAGS += -I../../DrAPI/
LDFLAGS =
LDLIBS = -ldl -lrt
# `pkg-config --list-all | grep -e mongo` will find if installed
# Here is the libmongoc-1.0 setup.
CXXFLAGS += `pkg-config --cflags libmongoc-1.0`
LDFLAGS += `pkg-config --libs-only-L libmongoc-1.0`
LDLIBS += `pgk-config --libs-only-other libmongoc-1.0`
LDLIBS += `pkg-config --libs-only-l libmongoc-1.0`
# Adjusting for this project
SOURCES = main.cpp
OBJECTS = $(SOURCES:.cpp=.o)
EXECS = main
all: $(EXECS) # Link exec from objects
$(OBJECTS): # Make all .o from .cpp (no local header files)
clean:
-rm $(OBJECTS)
-rm $(EXECS)
# eof
请注意,此处目标文件仅依赖于源文件。如果源文件具有某些本地头文件依赖项,则需要手动添加它们。
此文件还可以看到链接时,这些-L
开关位于目标文件之前,-l
开关位于目标文件之后。
如果您尝试仅在pkg-config --libs
中使用一个LDFLAGS
,则将无法使用。
我也只是在+=
的时候向变量中添加了一件事,就像LDLIBS
一样,因为这样可以更容易地看到添加的内容。
内置规则是:
OUTPUT_OPTION = -o $@
# Compilation for C and C++
COMPILE.c = $(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $(OUTPUT_OPTION) $<
COMPILE.cpp = $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c $(OUTPUT_OPTION) $<
# Linking for C and C++
LINK.c = $(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) $^ $(LOADLIBES) $(LDLIBS) -o $@
LINK.cpp = $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) $^ $(LOADLIBES) $(LDLIBS) -o $@
它有助于了解哪个变量在哪里。