c - 使用 makefile 进行多次编译

标签 c makefile multiple-makefiles

我在使用 Makefiles 时遇到了严重的问题,我正在尝试在其中运行这些命令,到目前为止,我所做的大部分更改都导致“无论我更改行,“全部”都无济于事” ,它就是行不通。例如,PROG4 应该可以在下面工作,但它表示无需执行任何操作。

BIN_DIR = bin
LEX_DIR = lexyacc-code
LIB_DIR = lib
SRC_DIR = src
OBJ_DIR = obj

CC = gcc
BS = bison
FX = flex
CFLAGS = -I$(LIB_DIR)

SRCS = $(wildcard $(LEX_DIR)/calc3b.c)
SRCS2 = $(wildcard $(LEX_DIR)/calc3.y)
SRCS3 = $(wildcard $(LEX_DIR)/calc3.l)
SRCS4 = $(wildcard $(OBJ_DIR)/y.tab.c)
SRCS5 = $(wildcard $(OBJ_DIR)/lex.yy.c)

OBJS = $(patsubst $(LEX_DIR)/%.c,$(OBJ_DIR)/%.o,$(SRCS))


PROG = calc3b
PROG2 = y.tab
RM = rm -f

MVV="$(shell mv y.tab.c obj)"; echo $MVV


all: $(PROG2) $(PROG4) 


$(PROG): $(OBJS)
    $(CC) $^ -o $(PROG)

$(PROG2):
    $(BS) -y -d $(SRCS2)  

$(PROG4): $(CC) -c $(SRCS4) $(SRCS5) $(CFLAGS)


$(OBJ_DIR)/%.o: $(LEX_DIR)/%.c
    $(CC) $(CFLAGS) -c $< -o $@


clean:
    $(RM) $(PROG) $(OBJS)

只有 PROG2 可以工作,基本上为了结果,我有头文件和源文件,我尝试移动特定文件夹,但最终我用“mv”命令完成了它(我知道它是针对 Makefile 的)。

命令如下:

bison -y -d calc3.y
flex calc3.l
gcc -c y.tab.c lex.yy.c
gcc y.tab.o lex.yy.o calc3b.c -o calc3b.exe

第一个命令,我有一个 header 和源结果。

第二,我因此有了一个来源。

第三,我有 2 个对象文件。

第四,我将有一个可执行文件。

因此,我还需要将这些文件移动到其特定文件夹中。

有人可以帮我解决这个问题吗?谢谢。

最佳答案

我认为 $(PROG4) 的问题是您忘记将命令放在带有制表符的新行上。在上面所示的内容中,整行命令都放置在应该是依赖项而不是命令的位置。因此,makefile 不会对 $(PROG4) 执行任何命令。

关于c - 使用 makefile 进行多次编译,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40488168/

相关文章:

c - 下面程序中的 & 和 && 运算符有什么用?

vim - E488 : Trailing characters in Vim mapping

c - scanf 之后 fgets 不起作用

c - Dev-C++ 和 xcode 编译器的不同输出

linux - VPATH 在 makefile 中不起作用

linux - 远程开发 - 在 Windows 上编辑并在 Linux 上构建

ubuntu - 在 Linux 上安装 WordNet (Ubuntu trusty)

makefile - Makefile 中的 "heritage"

安卓NDK : build after added a new library module directly under jni/folder

c - 使用 C 将结构写入文本文件