* Added common.h
[fw/sdcc] / src / Makefile.in
1 #
2 #
3 #
4
5 PRJDIR          = ..
6
7 include $(PRJDIR)/Makefile.common
8
9 PORTS           = mcs51
10 PORT_LIBS       = $(PORTS:%=%/port.a)
11
12 LIBS            = -lgc @LIBS@
13 LIBDIRS         = -L$(PRJDIR)/support/gc
14
15 OBJECTS         = SDCCy.o SDCClex.o SDCCerr.o SDCChasht.o SDCCmain.o \
16                   SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
17                   SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
18                   SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
19                   SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o spawn.o
20 SOURCES         = $(patsubst %.o,%.c,$(OBJECTS))
21
22 TARGET          = $(PRJDIR)/bin/sdcc
23
24 # Compiling entire program or any subproject
25 # ------------------------------------------
26 all: ports checkconf $(PRJDIR)/support/gc/libgc.a $(TARGET)
27
28 ports:
29         for i in $(PORTS); do $(MAKE) -C $$i; done
30
31 $(PRJDIR)/support/gc/libgc.a:
32         cd $(PRJDIR)/support/gc && $(MAKE)
33
34
35 # Compiling and installing everything and runing test
36 # ---------------------------------------------------
37 install: all installdirs
38         $(INSTALL) -s $(TARGET) $(bindir)/sdcc
39
40
41 # Deleting all the installed files
42 # --------------------------------
43 uninstall:
44         rm -f $(bindir)/sdcc
45
46
47 # Performing self-test
48 # --------------------
49 check:
50
51
52 # Performing installation test
53 # ----------------------------
54 installcheck:
55
56
57 # Creating installation directories
58 # ---------------------------------
59 installdirs:
60         $(INSTALL) -d $(bindir)
61
62
63 # Creating dependencies
64 # ---------------------
65 dep: Makefile.dep
66
67 Makefile.dep: $(SOURCES) *.h $(PRJDIR)/*.h
68         $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
69
70 include Makefile.dep
71 include clean.mk
72
73
74 # My rules
75 # --------
76 $(TARGET): $(OBJECTS) $(PORT_LIBS)
77         $(CC) -o $@ $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
78
79 .c.o:
80         $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
81
82 SDCCy.h: SDCCy.c
83
84 SDCCy.c: SDCC.y
85         $(YACC) -d -v -o $@ $<
86
87 SDCClex.c: SDCC.lex SDCCy.h
88         $(LEX) -t $< >$@
89
90 SDCCpeeph.rul: SDCCpeeph.def
91         $(AWK) -f SDCCpeeph.awk SDCCpeeph.def > SDCCpeeph.rul
92
93 .y.c:
94         rm -f $*.cc $*.h
95         $(YACC) -d $<
96         mv y.tab.c $*.cc
97         mv y.tab.h $*.h
98
99 .l.c:
100         rm -f $*.cc
101         $(LEX) -t $< >$*.cc
102
103
104 # Remaking configuration
105 # ----------------------
106 checkconf:
107         @if [ -f $(PRJDIR)/devel ]; then\
108           $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
109           freshconf;\
110         fi
111
112 # End of main_in.mk/main.mk
113