59 |
|
applications/simpleBuilder\ |
60 |
|
applications/staticProps \ |
61 |
|
applications/dynamicProps \ |
62 |
+ |
applications/nanoRodBuilder \ |
63 |
|
|
64 |
|
Samples = \ |
65 |
|
samples/argon \ |
205 |
|
$(LexFiles:%.l= %.c) |
206 |
|
|
207 |
|
OtherTargetFiles = $(OtherSourceFiles:%=$(PackageTargetDir)/%) |
208 |
+ |
|
209 |
+ |
########################################################################### |
210 |
+ |
# |
211 |
+ |
# Figure out the names of the module files based on some work done by |
212 |
+ |
# configure. The tr function below is from John Graham-Cumming |
213 |
+ |
# (http://www.jgc.org). |
214 |
+ |
# |
215 |
+ |
# The tr function. Has three arguments: |
216 |
+ |
# |
217 |
+ |
# $1 The list of characters to translate from |
218 |
+ |
# $2 The list of characters to translate to |
219 |
+ |
# $3 The text to translate |
220 |
+ |
# |
221 |
+ |
# For example, $(call tr,A B C,1 2 3,CAPITAL) becomes 21PIT1L. |
222 |
+ |
|
223 |
+ |
tr = $(eval __t := $3) \ |
224 |
+ |
$(foreach c, \ |
225 |
+ |
$(join $(addsuffix :,$1),$2), \ |
226 |
+ |
$(eval __t := \ |
227 |
+ |
$(subst $(word 1,$(subst :, ,$c)),$(word 2,$(subst :, ,$c)), \ |
228 |
+ |
$(__t))))$(__t) |
229 |
+ |
|
230 |
+ |
# Common character classes for use with the tr function. Each of |
231 |
+ |
# these is actually a variable declaration and must be wrapped with |
232 |
+ |
# $() or ${} to be used. |
233 |
+ |
|
234 |
+ |
[A-Z] := A B C D E F G H I J K L M N O P Q R S T U V W X Y Z # |
235 |
+ |
[a-z] := a b c d e f g h i j k l m n o p q r s t u v w x y z # |
236 |
+ |
[0-9] := 0 1 2 3 4 5 6 7 8 9 # |
237 |
+ |
[A-F] := A B C D E F # |
238 |
+ |
|
239 |
+ |
# Figure out whether we have $(eval) or not (GNU Make 3.80 and above) |
240 |
+ |
# if we do not then we need to use the shell version of tr, and not the |
241 |
+ |
# faster tr function above: |
242 |
+ |
|
243 |
+ |
__have_eval := $(false) |
244 |
+ |
__ignore := $(eval __have_eval := $(true)) |
245 |
|
|
246 |
+ |
ifndef __have_eval |
247 |
+ |
uc = $(shell echo $1 | tr "a-z" "A-Z") |
248 |
+ |
lc = $(shell echo $1 | tr "A-Z" "a-z") |
249 |
+ |
else |
250 |
+ |
uc = $(call tr,$([a-z]),$([A-Z]),$1) |
251 |
+ |
lc = $(call tr,$([A-Z]),$([a-z]),$1) |
252 |
+ |
endif |
253 |
+ |
|
254 |
+ |
# OK, now we can actually use these functions to figure out the names |
255 |
+ |
# of the module files: |
256 |
+ |
|
257 |
+ |
ifneq "$(words $(Modules))" "0" |
258 |
+ |
ifeq "$(ModuleCase)" "UPPER" |
259 |
+ |
MODULES = $(call uc,$(Modules)) |
260 |
+ |
else |
261 |
+ |
ifeq "$(ModuleCase)" "lower" |
262 |
+ |
MODULES = $(call lc,$(Modules)) |
263 |
+ |
else |
264 |
+ |
MODULES = $(Modules) |
265 |
+ |
endif |
266 |
+ |
endif |
267 |
+ |
ModuleFiles = $(MODULES:%= $(PackageTargetDir)/%.$(ModSuffix)) |
268 |
+ |
ParallelModuleFiles = $(MODULES:%= $(PackageParallelTargetDir)/%.$(ModSuffix)) |
269 |
+ |
endif |
270 |
+ |
# |
271 |
+ |
########################################################################### |
272 |
+ |
|
273 |
|
ThirdPartyJarsTmp = $(patsubst %,$(LibDir)/%,$(JavaLibraries)) |
274 |
|
ThirdPartyJars = $(subst $(Space),$(X),$(ThirdPartyJarsTmp)) |
275 |
|
|
686 |
|
$(JarFile) \ |
687 |
|
$(Executable) |
688 |
|
endif |
689 |
+ |
|
690 |
+ |
echo : $(PackageListLoop) |
691 |
+ |
$(Print) Done echo. |
692 |
|
|
693 |
+ |
_echoall : |
694 |
+ |
$(Print) $(Modules) |
695 |
|
|
696 |
|
# make clean |
697 |
|
clean : $(PackageListLoop) |
700 |
|
_cleanall : |
701 |
|
$(Delete) \ |
702 |
|
$(ObjectFiles) \ |
703 |
+ |
$(ModuleFiles) \ |
704 |
|
$(ParallelObjectFiles) \ |
705 |
+ |
$(ParallelModuleFiles) \ |
706 |
|
$(JarFile) \ |
707 |
|
$(SharedLibrary) \ |
708 |
|
$(StaticLibrary) \ |