7 include $(PRJDIR)/Makefile.common
9 LIBS = $(PORT)/port.a -lgc @LIBS@
10 LIBDIRS = -L$(PRJDIR)/support/gc
12 OBJECTS = SDCCy.o SDCClex.o SDCCerr.o SDCChasht.o SDCCmain.o \
13 SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
14 SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
15 SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
16 SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o spawn.o
17 SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
19 TARGET = $(PRJDIR)/bin/sdcc
22 # Compiling entire program or any subproject
23 # ------------------------------------------
24 all: port checkconf $(PRJDIR)/support/gc/libgc.a $(TARGET)
29 $(PRJDIR)/support/gc/libgc.a:
30 cd $(PRJDIR)/support/gc && $(MAKE)
33 # Compiling and installing everything and runing test
34 # ---------------------------------------------------
35 install: all installdirs
36 $(INSTALL) -s $(TARGET) $(bindir)/sdcc
39 # Deleting all the installed files
40 # --------------------------------
45 # Performing self-test
46 # --------------------
50 # Performing installation test
51 # ----------------------------
55 # Creating installation directories
56 # ---------------------------------
58 $(INSTALL) -d $(bindir)
61 # Creating dependencies
62 # ---------------------
65 Makefile.dep: $(SOURCES) *.h $(PRJDIR)/*.h
66 $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
75 $(CC) -o $@ $(OBJECTS) $(LIBDIRS) $(LIBS)
78 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
81 $(YACC) -d -v -o $@ $<
83 SDCClex.c: SDCC.lex SDCCy.h
86 SDCCpeeph.rul: SDCCpeeph.def
87 $(AWK) -f SDCCpeeph.awk SDCCpeeph.def > SDCCpeeph.rul
100 # Remaking configuration
101 # ----------------------
103 @if [ -f $(PRJDIR)/devel ]; then\
104 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
108 # End of main_in.mk/main.mk