/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:56:51 UTC
  • Revision ID: edam@waxworlds.org-20090305135651-rycwzitsuwfrd1ee
Tags: 2.3
- optimised dependency generation: generate stub dependencies from the compiler and don't use the sed script where possible
- fix spelling mistake in dependencies
- only generate dependency files in debug mode

Show diffs side-by-side

added added

removed removed

1
1
#_______________________________________________________________________________
2
2
#
3
 
#                       edam's general-purpose makefile
4
 
#_______________________________________________________________________________
5
 
#                                                                    version 3.2
6
 
#
7
 
# Copyright (c) 2008 Tim Marston <edam@waxworlds.org>.
8
 
#
9
 
# Permission is hereby granted, free of charge, to any person obtaining a copy
10
 
# of this software and associated documentation files (the "Software"), to deal
11
 
# in the Software without restriction, including without limitation the rights
12
 
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13
 
# copies of the Software, and to permit persons to whom the Software is
14
 
# furnished to do so, subject to the following conditions:
15
 
#
16
 
# The above copyright notice and this permission notice shall be included in
17
 
# all copies or substantial portions of the Software.
18
 
#
19
 
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20
 
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21
 
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22
 
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23
 
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24
 
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25
 
# THE SOFTWARE.
26
 
#
27
 
#_______________________________________________________________________________
28
 
#
29
 
#
30
 
# This is a general-purpose makefile for use with GNU make. It can be downloaded
31
 
# from http://www.waxworlds.org/edam/software/general-purpose-makefile where you
32
 
# can also find more information/documentation on it's use. The following text
33
 
# can only really be considered a reference to it's use.
34
 
#
35
 
# To use this makefile, put a file named "Makefile" in your project directory.
36
 
# Add all your project's settings to your Makefile and then include this file
37
 
# from it. For example, your Makefile might look something like this:
38
 
#
39
 
#       TARGET = my_program
40
 
#       SOURCES = main.cc foo.cc
41
 
#       LIBRARIES = bar
42
 
#       include ~/src/edam.mk
43
 
#
44
 
# A complete list of all the settings you can use in your Makefile follows. It
45
 
# should be noted, though, that some settings are better defined in the shell's
46
 
# environment and/or specified on the make command line than hard-coded straight
47
 
# in to the Makefile. For example, the "DEBUGMODE" is an ideal candidate for
48
 
# exporting from your shell:
49
 
#       export DEBUGMODE=1
50
 
# and overridding on the command line when necessary:
51
 
#       make DEBUGMODE=
52
 
#
53
 
# It should also be noted that boolean parameters should either be undefined (or
54
 
# defined as an empty string) for "off", and defined as "1" for "on"; as in the
55
 
# above example with setting DEBUGMODE.
56
 
#
57
 
# Here is a list of all configuration parameters:
58
 
#
59
 
# DEBUGMODE    Boolean. Build a debugable version of the target suitable for
60
 
#              debugging with gdb. It's probably better to set this from the
61
 
#              command line or the shell's environment than to hard-code it.
62
 
# PROFILEMODE  Boolean. When set, DEBUGMODE is also implied. Build a profiling
63
 
#              version of the target, for use with gprof. It's probably better
64
 
#              to set this from the command line or the shell's environment
65
 
#              than to hard-code it.
66
 
#
67
 
# LINKSTATIC   Boolean. Set to build a target that staticly links against all
68
 
#              its libraries and doesn't use shared libraries.
69
 
#
70
 
# MKSTATICLIB  Boolean. Target type: Set to build a static library target. If
71
 
#              neither this nor MKSHAREDLIB are set, the target defaults to a
72
 
#              binary executable.
73
 
# MKSHAREDLIB  Boolean. Target type: Set to build a shared library target. If
74
 
#              neither this nor MKSTATICLIB are set, the target defaults to a
75
 
#              binary executable.
76
 
#
77
 
# TARGET       The name of the target file.
78
 
#
79
 
# SOURCES      A list of all source files of whatever language. The language
80
 
#              type is determined by the file extension.
81
 
#
82
 
# LIBRARIES    A list of libraries to link against. Don't include the 'lib'
83
 
#              prefix.
84
 
#
85
 
# SUBDIRS      A list of subdirectories to build before attempting to build the
86
 
#              target. These subdirectories are also included in a clean_all.
87
 
#
88
 
# SUBPROJS     A list of the names of other makefiles to run before attempting
89
 
#              to build the target. This allows you to build multiple targets.
90
 
#              Note that ".mk" is appended to the subproject names. These
91
 
#              subprojects are also included in a clean_all.
92
 
#
93
 
# CPPFLAGS     Flags to give to the C and C++ compilers
94
 
# CFLAGS       Flags to give to the C compiler
95
 
# CXXFLAGS     Flags to give to the C++ compiler
96
 
# DFLAGS       Flags to give to the D compiler
97
 
# ASFLAGS      Flags to give to the assembler
98
 
# LDFLAGS      Flags to give to the linker before librarys
99
 
# LDPOSTFLAGS  Flags to give to the linker after libraries
100
 
#
101
 
# This general-purpose makefile also defines the following goals for use on the
102
 
# command line when you run make:
103
 
#
104
 
# all          This is the default if no goal is specified. It builds subdirs
105
 
#              and subprojects first and then the target.
106
 
#
107
 
# subdirs      Goes through the list of specified subdirectories, changing to
108
 
#              them, and runs make there.
109
 
#
110
 
# subproj      Goes through the list of specified subprojects, running the
111
 
#              makefiles for each of them.
112
 
#
113
 
# target       Builds the target of your Makefile.
114
 
#
115
 
# run          Builds the target of your Makefile and, if successful, runs it.
116
 
#              This is not available if you're building a library of some kind.
117
 
#
118
 
# clean        Deletes temporary files.
119
 
#
120
 
# clean_all    Deletes temporary files and then goes through then project's
121
 
#              subdirectories doing the same.
122
 
#
123
 
# <subdir>     Builds the specified subdirectory from those that are listed for
124
 
#              the project.
125
 
#
126
 
# <subproj>    Builds the specified subproject from those listed for the
127
 
#              project.
128
 
#
129
 
# <file>       Builds the specified file, either an object file or the target,
130
 
#              from those that that would be built for the project.
131
 
#
132
 
# Please report any problems to Tim Marston <edam@waxworlds.org>
133
 
#
134
 
# Known shortcommings:
135
 
# - Using C is probably broken because g++ is currently used for linking. We
136
 
#   should be using ld and specifying the crt libs as required by the sources.
137
 
#
138
 
#_______________________________________________________________________________
139
 
#
 
3
#                       edam's general-purpose makefile                     v2.3
 
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
DFLAGS          := 
 
44
ASFLAGS         := 
 
45
LDFLAGS         := 
 
46
LDPOSTFLAGS     := 
 
47
 
 
48
#_______________________________________________________________________________
 
49
#                                                                 OTHER SETTINGS
140
50
 
141
51
# set debug mode if profiling
142
52
ifdef PROFILEMODE
154
64
 
155
65
# debug/profile build flags
156
66
CPPFLAGS        := $(if $(PROFILEMODE),-pg -D PROFILE) $(CPPFLAGS)
157
 
CPPFLAGS        := $(if $(DEBUGMODE),-g -D DEBUG -Wall,-D NDEBUG -O2) $(CPPFLAGS)
 
67
CPPFLAGS        := $(if $(DEBUGMODE),-g -D DEBUG -Wall,-O2) $(CPPFLAGS)
158
68
DFLAGS          := $(if $(DEBUGMODE),,-frelease)
159
 
ASFLAGS         := -f elf $(if $(DEBUGMODE),-g -dDEBUG,-dNDEBUG -O2) $(ASFLAGS)
 
69
ASFLAGS         := -f elf $(if $(DEBUGMODE),-g -dDEBUG,-O2) $(ASFLAGS)
160
70
LDFLAGS         := $(if $(PROFILEMODE),-pg) $(LDFLAGS)
161
71
LDFLAGS         := $(if $(or $(PROFILEMODE), $(DEBUGMODE)),,-Wl,-S) $(LDFLAGS)
162
72
 
219
129
#_______________________________________________________________________________
220
130
#                                                                          RULES
221
131
 
222
 
.PHONY: all subdirs subprojs target clean clean_all run depend dep $(SUBDIRS) $(SUBPROJS)
 
132
.PHONY: all subdirs target clean clean_all run depend dep $(SUBDIRS)
223
133
 
224
 
all: subdirs subprojs target
 
134
all: subdirs target
225
135
 
226
136
subdirs: $(SUBDIRS)
227
137
 
228
 
subprojs: $(SUBPROJS)
229
 
 
230
138
target: $(TARGET)
231
139
 
232
140
clean:
233
 
ifneq ($(or $(SUBDIRS),$(SUBPROJS)),)
 
141
ifdef SUBDIRS
234
142
ifneq "$(MAKECMDGOALS)" "clean_all"
235
 
        @echo "NOT RECURSING - use 'make clean_all' to clean subdirs and " \
236
 
                "subprojs as well"
237
 
endif
238
 
endif
239
 
        rm -f $(OBJECTS) $(TARGET) $(DEPFILES) core
 
143
        @echo "NOT RECURSING: use 'make clean_all' to clean subdirectories as well."
 
144
endif
 
145
endif
 
146
        rm -f $(OBJECTS) $(TARGET) *.dep core
240
147
 
241
 
clean_all: subdirs subprojs clean
 
148
clean_all: subdirs clean
242
149
 
243
150
ifndef MKSTATICLIB
244
151
ifndef MKSHAREDLIB
247
154
endif
248
155
endif
249
156
 
250
 
$(SUBDIRS) $(SUBPROJS):
251
 
        @if [ "$@" = "$(firstword $(SUBDIRS) $(SUBPROJS))" ]; then echo; fi
252
 
        @$(MAKE) $(if $(filter $@,$(SUBDIRS)),-C $@,-f $@.mk) \
253
 
                $(filter-out $(SUBDIRS) $(SUBPROJS) subdirs subprojs,$(MAKECMDGOALS))
 
157
$(SUBDIRS):
 
158
        @if [ "$@" = "$(firstword $(SUBDIRS))" ]; then echo; fi
 
159
        @$(MAKE) -C $@ $(filter-out $(SUBDIRS),$(MAKECMDGOALS))
254
160
        @echo
255
161
 
256
162
$(TARGET): $(OBJECTS)
257
163
ifdef MKSTATICLIB
258
164
        $(AR) rcs $(TARGET) $(OBJECTS)
259
165
else
260
 
        $(LD) $(if $(MKSHAREDLIB),-shared) -o $(TARGET) $(LDFLAGS) $(OBJECTS) $(LDPOSTFLAGS)
 
166
        $(LD) $(if $(MKSHAREDLIB),-shared) -o $(TARGET) $(LDFLAGS) $(OBJECTS) $(LDPOSTFLAGS) 
261
167
endif
262
168
 
263
169
%.o %_d.o %_p.o: %.c
293
199
endif
294
200
 
295
201
#_______________________________________________________________________________
296