452bb278a57a63256d0f623d7c6c88d6bbb48639
[fw/sdcc] / device / lib / pic / Makefile.rules
1 ###########################################################
2 ### Makefile.rules for the SDCC/PIC14 Library
3 ###
4 ### Copyright (C) 2005 by Raphael Neider <rneider@web.de>
5 ###
6 ### The library is currently maintained by
7 ###     Raphael Neider <rneider@web.de>
8 ###
9 ### This file may be distributed under the terms of the the
10 ### GNU General Public License (GPL). See GPL for details.
11 ###
12 ### $Id$
13 ###
14
15 # update dependencies
16 $(topsrcdir)/$(builddir)/%.d : %.c
17 ifndef SILENT
18         @echo "[  CPP  ] ==> $(patsubst $(topsrcdir)/%,%,$@)";
19 endif
20         $(Q)$(CPP) $(CPPFLAGS) -o "$@" "$<";
21
22 # assemble
23 $(topsrcdir)/$(builddir)/%.o : %.S
24 ifndef SILENT
25         @echo "[  AS   ] ==> $(patsubst $(topsrcdir)/%,%,$@)";
26 endif
27         $(Q)$(CPP) $(CPPFLAGS) -P -o "$*.Spp" "$<";
28         $(Q)$(AS) $(ASFLAGS) -o "$@" -c "$*.Spp";
29         $(Q)$(RM) "$*.Spp";
30
31 # compile
32 $(topsrcdir)/$(builddir)/%.o : %.c
33 ifndef SILENT
34         @echo "[  CC   ] ==> $(patsubst $(topsrcdir)/%,%,$@)";
35 endif
36         $(Q)$(CC) $(CFLAGS) -o "$@" -c "$<";
37
38 # create library
39 ifneq (,$(strip $(LIB_O)))
40 %.lib : $(LIB_O)
41 ifndef SILENT
42         @echo "[  LIB  ] $(patsubst $(topsrcdir)/%,%,$@) <== $(patsubst $(topsrcdir)/$(builddir)/%,%,$^)";
43 endif
44         $(Q)$(RM) "$@"; $(LIB) $(LIBFLAGS) "$@" $^;
45 else
46 %.lib : recurse
47 ifndef SILENT
48         @echo "[  LIB  ] $(patsubst $(topsrcdir)/%,%,$@) <== **/*.o";
49 endif
50         $(Q)$(RM) "$@"; LIB_O=`find "$(topsrcdir)/$(builddir)" -name "*.o"`; [ "x$${LIB_O}" = "x" ] || $(LIB) $(LIBFLAGS) "$@" $${LIB_O};
51 endif
52
53 .PHONY : recurse force
54
55 # build sub-directories
56 ifneq (,$(strip $(SUBDIRS)))
57 recurse : force
58         $(Q)+for DIR in $(SUBDIRS) ; do \
59                 $(GREP) "^$${ARCH}$$" "$${DIR}.ignore" &> /dev/null || ( \
60                         [ -d "$(topsrcdir)/$(builddir)/$${DIR}" ] || $(MKDIR) "$(topsrcdir)/$(builddir)/$${DIR}"; \
61                         $(MAKE) -C "$${DIR}" builddir="$(builddir)/$${DIR}" $(MAKECMDGOALS); \
62                 ) || exit 1; \
63         done
64 else
65 recurse :
66         @# nothing to do
67 endif
68
69 # target to force remaking of (seemingly) independent targets
70 force :