2009-11-16 61 views
3

我想只需鍵入「讓所有」,並有下面的Makefile盡一切應該做的:如何將全部規則添加到此Makefile?

LEX = lex 
YACC = yacc 
CC = gcc 

calcu: y.tab.o lex.yy.o 
    $(CC) -o calcu y.tab.o lex.yy.o -ly -lfl 

y.tab.c y.tab.h: parser.y 
    $(YACC) -d parser.y 

y.tab.o: y.tab.c parser.h 
    $(CC) -c y.tab.c 

lex.yy.o: y.tab.h lex.yy.c 
    $(CC) -c lex.yy.c 

lex.yy.c: calclexer.l parser.h 
    $(LEX) calclexer.l 

clean: 
    rm *.o 
    rm *.c 
    rm calcu 
+1

我看到了這個:) – 2009-11-16 00:51:28

+0

請指定「make」標記而不是「makefile」。更多信息:http://meta.stackexchange.com/questions/24030/why-do-they-specify-makefile-tag-instead-of-make/26567#26567 – 2009-11-18 06:44:57

回答

4

什麼都被它應該做什麼?如果你只是想要它建立calcu,你所要做的就是輸入make,它會使它與它所依賴的一切一起,因爲它是文件中的第一條規則。

如果您仍然想制定all規則,可以這樣做。我建議把這一點放在其他所有規則之上,這樣你只需鍵入make而不是make all

all: calcu 
+2

.PHONY:全部 這告訴讓你不要指望在構建之後實際上有一個名爲「all」的文件。 – 2009-11-16 01:12:03