-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
81 lines (57 loc) · 1.28 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# New Makefile that automatically depends itself
#
# $Id: Makefile,v 1.3 1996/12/17 19:52:37 chase Exp $
#
IFLAGS =
DFLAGS =
CXX = g++
CC = $(GCC)
GCC = g++
LD = $(CXX)
LIBS =
WFLAGS = -Wall
SYMFLAGS = #-g
PROFILE = #-pg
OPTFLAGS =#-O
CFLAGS = $(OPTFLAGS) $(PROFILE) $(WFLAGS) $(IFLAGS) $(SYMFLAGS)
#CFLAGS = $(OPTFLAGS) $(PROFILE) $(WFLAGS) $(IFLAGS) -o3
CXXFLAGS = $(CFLAGS)
CPPFLAGS = $(IFLAGS) $(DFLAGS)
LDFLAGS = $(PROFILE) -g
PROGRAM = proj5
#CXXSRCS = Source.cpp
CXXSRCS = $(shell ls *.cpp)
SRCS = $(CXXSRCS)
OBJS = $(CXXSRCS:.cpp=.o)
all: $(PROGRAM)
$(PROGRAM): $(OBJS)
$(LD) -o $@ $(LDFLAGS) $(OBJS) $(LIBS)
test: $(PROGRAM)
./$(PROGRAM)
clean:
-rm -f $(OBJS) $(PROGRAM)
tidy:
-rm -f *.BAK *.bak *.CKP
undepend:
-rm -f $(OBJS:%.o=.%.d)
spotless: tidy clean undepend
.y.cpp:
$(BISON) $(BISONFLAGS) -o $@ $<
mv [email protected] $*.h
mv [email protected] $*.output
.l.cpp:
$(FLEX) ${FLEXFLAGS} -t $< > $@
# auto depend stuff for GNU make only
depend: undepend
@echo ""
@echo "Dependences are handled automatically, just \"make\""
ifneq ($(strip $(CSRCS)),)
.%.d: %.c
$(SHELL) -ec '$(GCC) -MM $(CPPFLAGS) $< > $@'
include $(CSRCS:%.c=.%.d)
endif
ifneq ($(strip $(CXXSRCS)),)
.%.d: %.cpp
$(SHELL) -ec '$(GCC) -MM $(CPPFLAGS) $< > $@'
include $(CXXSRCS:%.cpp=.%.d)
endif