* device/lib/pic16/Makefile.common.in: added $(MM) to fix `make clean`
[fw/sdcc] / src / Makefile.in
1 #
2 #
3 #
4
5 PRJDIR          = ..
6
7 include $(PRJDIR)/Makefile.common
8
9 USE_ALT_LEX     = 0
10
11 PORTS           = $(shell cat ../ports.build)
12 ALLPORTS        = $(shell cat ../ports.all)
13 PORT_LIBS       = $(PORTS:%=%/port.a)
14
15 LIBS            = -lm @LIBS@
16
17 #CFLAGS          += -Werror
18
19 ifdef SDCC_SUB_VERSION
20 CFLAGS          += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
21 endif
22
23 SLIBOBJS        = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o findme.o
24
25 OBJECTS         = SDCCy.o SDCChasht.o SDCCmain.o \
26                   SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
27                   SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
28                   SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
29                   SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o \
30                   asm.o SDCCmacro.o SDCCutil.o SDCCdebug.o cdbFile.o SDCCdwarf2.o
31
32 SPECIAL         = SDCCy.h 
33 ifeq ($(USE_ALT_LEX), 1)
34 OBJECTS         += altlex.o
35 SPECIAL         += reswords.h
36 else
37 OBJECTS         += SDCClex.o
38 endif
39
40 SLIBSOURCES     = $(patsubst %.o,$(SLIB)/%.c,$(SLIBOBJS))
41 SOURCES         = $(patsubst %.o,%.c,$(OBJECTS))
42
43 TARGET          = $(PRJDIR)/bin/sdcc$(EXEEXT)
44
45 # Compiling entire program or any subproject
46 # ------------------------------------------
47 all: checkconf version.h $(TARGET)
48
49 $(PORT_LIBS): FORCE 
50         $(MAKE) -C `dirname $@`
51  
52 FORCE:
53
54 $(PRJDIR)/support/gc/libgc.a:
55         cd $(PRJDIR)/support/gc && $(MAKE)
56
57 # Compiling and installing everything and runing test
58 # ---------------------------------------------------
59 install: all installdirs
60         $(INSTALL) $(TARGET) `echo $(DESTDIR)$(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
61         $(STRIP) `echo $(DESTDIR)$(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
62
63
64 # Deleting all the installed files
65 # --------------------------------
66 uninstall:
67         rm -f $(DESTDIR)$(bindir)/sdcc$(EXEEXT)
68
69 # Performing self-test
70 # --------------------
71 check:
72
73
74 # Performing installation test
75 # ----------------------------
76 installcheck:
77
78
79 # Creating installation directories
80 # ---------------------------------
81 installdirs:
82         $(INSTALL) -d $(DESTDIR)$(bindir)
83
84
85 # Creating dependencies
86 # ---------------------
87 dep: version.h Makefile.dep
88
89 Makefile.dep: version.h $(SOURCES) $(SLIBSOURCES) $(SPECIAL) *.h $(PRJDIR)/*.h
90         $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) $(SLIBSOURCES) >Makefile.dep
91
92 include Makefile.dep
93 include clean.mk
94
95
96 # My rules
97 # --------
98 $(TARGET): $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS)
99         $(CC) $(LDFLAGS) -o $@ $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
100
101 .c.o:
102         $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
103
104 $(SLIBOBJS):%.o:$(SLIB)/%.c
105         $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
106
107 reswords.h: reswords.gperf Makefile
108         gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
109
110 altlex.o: altlex.c SDCCy.h reswords.h
111
112 SDCCy.h: SDCCy.c
113
114 SDCCy.c: SDCC.y
115         $(YACC) -d -v -o $@ $<
116
117 SDCClex.c: SDCC.lex SDCCy.h
118         $(LEX) -t $< >$@
119
120 version.h: ../ChangeLog
121         $(AWK) -f version.awk $< > $@
122
123 .y.c:
124         rm -f $*.cc $*.h
125         $(YACC) -d $<
126         mv y.tab.c $*.cc
127         mv y.tab.h $*.h
128
129 .l.c:
130         rm -f $*.cc
131         $(LEX) -t $< >$*.cc
132
133
134 # Remaking configuration
135 # ----------------------
136 checkconf:
137         @if [ -f $(PRJDIR)/devel ]; then\
138           $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
139           freshconf;\
140         fi
141
142 # End of main_in.mk/main.mk