/make/edam-mk

To get this branch, use:
bzr branch http://bzr.ed.am/make/edam-mk

« back to all changes in this revision

Viewing changes to Makefile

  • Committer: edam
  • Date: 2009-03-05 13:47:12 UTC
  • Revision ID: edam@waxworlds.org-20090305134712-grzh787t06ojomf8
Tags: 2.0
- smartened up comments
- added PROFILEMODE
- renamed STATICLIBS to LINKSTATIC
- renamed lib target switched to MKSHAREDLIB and MKSTATICLIB
- added setting of software variables
- added debug & profile suffixes
- added dependency file generation system
- added rules to build various source types and added dependency generation

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
#                                                       Edam's Makefile v1.5
2
 
#___________________________________________________________________________
3
 
#                                                            S E T T I N G S
4
 
 
5
 
# Target binary
6
 
TARGET          = helloworld
7
 
 
8
 
# All source files
9
 
CC_SRCS         = helloworld.cc
10
 
C_SRCS          = 
11
 
S_SRCS          = 
12
 
 
13
 
# Libraries
14
 
LIBRARIES       = 
15
 
 
16
 
# Uncomment for debug-build
17
 
DEBUG           = 1
18
 
 
19
 
#___________________________________________________________________________
20
 
#                                                                    M E A T
21
 
 
22
 
# Software
23
 
AS=nasm
24
 
 
25
 
ifdef DEBUG
26
 
 
27
 
# Debug build flags
28
 
CPPFLAGS        = -g -D DEBUG
29
 
ASFLAGS         = -f elf -g -dDEBUG
30
 
LDFLAGS         = -Wall
31
 
 
32
 
else
33
 
 
34
 
# Release build flags
35
 
CPPFLAGS        = -O2
36
 
ASFLAGS         = -f elf -O2
37
 
LDFLAGS         = -Wall -s
38
 
 
39
 
endif
40
 
 
41
 
# More variables...
42
 
DEPFILE         = Depends
43
 
_SRCS           = $(CC_SRCS) $(C_SRCS) $(S_SRCS)
44
 
_OBJS           = $(addsuffix .o,$(basename $(_SRCS)))
45
 
LDLIBS          = $(addprefix -l,$(LIBRARIES))
46
 
 
47
 
# Main rule...
48
 
$(TARGET): $(_OBJS)
49
 
        g++ -o $(TARGET) $(LDFLAGS) $(_OBJS) $(LDLIBS)
50
 
 
51
 
#___________________________________________________________________________
52
 
#                                                                  R U L E S
53
 
 
54
 
.PHONY: all clean run depend dep
55
 
 
56
 
all:    clean depend $(TARGET)
 
1
#_______________________________________________________________________________
 
2
#
 
3
#                                       edam's general-purpose makefile v2.0
 
4
#_______________________________________________________________________________
 
5
#                                                                COMMON SETTINGS
 
6
 
 
7
#
 
8
# overridable options
 
9
# (better to specify in environment/command line)
 
10
#
 
11
#export DEBUGMODE       := 1
 
12
#export PROFILEMODE := 1
 
13
#export LINKSTATIC      := 1
 
14
 
 
15
#
 
16
# target binary/library
 
17
#
 
18
#MKSTATICLIB    := 1
 
19
#MKSHAREDLIB    := 1
 
20
TARGET          := tim
 
21
 
 
22
#
 
23
# all source files
 
24
#
 
25
SOURCES         := tim.cc
 
26
 
 
27
#
 
28
# libraries to link against
 
29
#
 
30
LIBRARIES       := 
 
31
 
 
32
#
 
33
# subdirectories to make first
 
34
#
 
35
SUBDIRS         := 
 
36
 
 
37
#
 
38
# additional build flags
 
39
#
 
40
CPPFLAGS        := 
 
41
CFLAGS          := 
 
42
CXXFLAGS        := 
 
43
ASFLAGS         := 
 
44
LDFLAGS         := 
 
45
LDPOSTFLAGS     := 
 
46
 
 
47
#_______________________________________________________________________________
 
48
#                                                                 OTHER SETTINGS
 
49
 
 
50
# set debug mode if profiling
 
51
ifdef PROFILEMODE
 
52
export DEBUGMODE := 1
 
53
endif
 
54
 
 
55
# software
 
56
AS                      := nasm
 
57
CC                      := gcc
 
58
CXX                     := g++
 
59
LD                      := g++
 
60
AR                      := ar
 
61
MAKE            := make
 
62
 
 
63
# build flags
 
64
CPPFLAGS        := $(if $(PROFILEMODE),-pg -D PROFILE) $(CPPFLAGS)
 
65
CPPFLAGS        := $(if $(DEBUGMODE),-g -D DEBUG,-O2) $(CPPFLAGS)
 
66
ASFLAGS         := -f elf $(if $(DEBUGMODE),-g -dDEBUG,-O2) $(ASFLAGS)
 
67
LDFLAGS         := $(if $(PROFILEMODE),-pg,$(if $(DEBUGMODE),,-s)) $(LDFLAGS)
 
68
LDFLAGS         := -Wall $(if $(LINKSTATIC),-static) $(LDFLAGS)
 
69
LDPOSTFLAGS := $(addprefix -l,$(LIBRARIES)) $(LDPOSTFLAGS)
 
70
 
 
71
#_______________________________________________________________________________
 
72
 
 
73
# object debug/profile suffix
 
74
BUILDSUFFIX     := $(if $(PROFILEMODE),_p,$(if $(DEBUGMODE),_d))
 
75
 
 
76
# files
 
77
OBJECTS         := $(addsuffix $(BUILDSUFFIX).o,$(basename $(SOURCES)))
 
78
DEPFILES        := $(addsuffix .d,$(basename $(SOURCES)))
 
79
 
 
80
# fixup target
 
81
ifdef TARGET
 
82
TARGET          := $(basename $(TARGET))$(BUILDSUFFIX)$(suffix $(TARGET))
 
83
TARGET          := $(patsubst %.so,%,$(patsubst %.a,%,$(TARGET)))
 
84
TARGET          := $(TARGET)$(if $(MKSHAREDLIB),.so,$(if $(MKSTATICLIB),.a))
 
85
endif
 
86
 
 
87
# Set up dependancy generation build flags and a commands to be executed after
 
88
# generating any dependancy file. The commands append the names of all the
 
89
# depended-on files in the dependancy file to the end of the dependancy file as
 
90
# empty rules with no prerequesits or commands. This causes make not to fail if
 
91
# one of these files becomes non-existant, but causes files dependant on these
 
92
# files to be rebuilt (and thus also have their dependancies regenerated).
 
93
ifdef DEBUGMODE
 
94
ifndef PROFILEMODE
 
95
FIXUP_DEPENDANCY_FILES = \
 
96
        sed 's/\#.*//;s/^[^:]*://;s/^[ \t]*//;s/ *\\$$//;/^$$/d;s/$$/:/' < \
 
97
                $(basename $<).d > .$$$$~; cat .$$$$~ >> $(basename $<).d; rm .$$$$~;
 
98
DEPFLAGS        = -MD -MF $(basename $<).d
 
99
endif
 
100
endif
 
101
 
 
102
# include dependancies
 
103
ifneq "$(MAKECMDGOALS)" "clean"
 
104
ifneq "$(MAKECMDGOALS)" "clean_all"
 
105
-include $(DEPFILES)
 
106
endif
 
107
endif
 
108
 
 
109
# default rule
 
110
.DEFAULT_GOAL := all
 
111
 
 
112
#_______________________________________________________________________________
 
113
#                                                                          RULES
 
114
 
 
115
.PHONY: all subdirs target clean clean_all run depend dep $(SUBDIRS)
 
116
 
 
117
all: subdirs target
 
118
 
 
119
subdirs: $(SUBDIRS)
 
120
 
 
121
target: $(TARGET)
57
122
 
58
123
clean:
59
 
        rm -f core $(DEPFILE) $(_OBJS)
60
 
        rm -f *~
61
 
 
62
 
run:    $(TARGET)
 
124
ifdef SUBDIRS
 
125
ifneq "$(MAKECMDGOALS)" "clean_all"
 
126
        @echo "NOT RECURSING: use 'make clean_all' to clean subdirectories as well."
 
127
endif
 
128
endif
 
129
        rm -f $(OBJECTS) $(TARGET) core
 
130
 
 
131
clean_all: subdirs clean
 
132
 
 
133
ifndef MKSTATICLIB
 
134
ifndef MKSHAREDLIB
 
135
run: target
63
136
        ./$(TARGET)
64
 
 
65
 
depend dep:
66
 
#       makedepend -f- -- $(CPPFLAGS) -- $(_SRCS) > $(DEPFILE)
67
 
 
68
 
#___________________________________________________________________________
69
 
#include $(DEPFILE)
 
137
endif
 
138
endif
 
139
 
 
140
$(SUBDIRS):
 
141
        @$(MAKE) -C $@ $(filter-out $(SUBDIRS),$(MAKECMDGOALS))
 
142
        @echo
 
143
 
 
144
$(TARGET): $(OBJECTS)
 
145
ifdef MKSTATICLIB
 
146
        $(AR) rcs $(TARGET) $(OBJECTS)
 
147
else
 
148
        $(LD) $(if $(MKSHAREDLIB),-shared) -o $(TARGET) $(LDFLAGS) $(OBJECTS) $(LDPOSTFLAGS) 
 
149
endif
 
150
 
 
151
%.o %_d.o %_p.o: %.c
 
152
        $(CC) -c $(CPPFLAGS) $(DEPFLAGS) $(CFLAGS) -o $@ $<
 
153
        $(FIXUP_DEPENDANCY_FILES)
 
154
 
 
155
%.o %_d.o %_p.o: %.cc
 
156
        $(CXX) -c $(CPPFLAGS) $(DEPFLAGS) $(CXXFLAGS) -o $@ $<
 
157
        $(FIXUP_DEPENDANCY_FILES)
 
158
%.o %_d.o %_p.o: %.C
 
159
        $(CXX) -c $(CPPFLAGS) $(DEPFLAGS) $(CXXFLAGS) -o $@ $<
 
160
        $(FIXUP_DEPENDANCY_FILES)
 
161
%.o %_d.o %_p.o: %.cpp
 
162
        $(CXX) -c $(CPPFLAGS) $(DEPFLAGS) $(CXXFLAGS) -o $@ $<
 
163
        $(FIXUP_DEPENDANCY_FILES)
 
164
 
 
165
%.o %_d.o %_p.o: %.s
 
166
        $(AS) $(ASFLAGS) -o $@ $<
 
167
%.o %_d.o %_p.o: %.S
 
168
        $(AS) $(ASFLAGS) -o $@ $<
 
169
%.o %_d.o %_p.o: %.asm
 
170
        $(AS) $(ASFLAGS) -o $@ $<
 
171
 
 
172
%.d: %.s
 
173
        $(AS) $(ASFLAGS) -M $< > $@
 
174
        $(FIXUP_DEPENDANCY_FILES)
 
175
%.d: %.S
 
176
        $(AS) $(ASFLAGS) -M $< > $@
 
177
        $(FIXUP_DEPENDANCY_FILES)
 
178
%.d: %.asm
 
179
        $(AS) $(ASFLAGS) -M $< > $@
 
180
        $(FIXUP_DEPENDANCY_FILES)
 
181
 
 
182
#_______________________________________________________________________________