7 include $(PRJDIR)/Makefile.common
10 PORT_LIBS = $(PORTS:%=%/port.a)
13 ifeq ($(HAVE_LIBGC), 1)
15 LIBDIRS = -L$(PRJDIR)/support/gc
16 LIBGC = $(PRJDIR)/support/gc/libgc.a
19 OBJECTS = SDCCy.o SDCClex.o SDCCerr.o SDCChasht.o SDCCmain.o \
20 SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
21 SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
22 SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
23 SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o spawn.o
24 SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
26 TARGET = $(PRJDIR)/bin/sdcc
28 # Compiling entire program or any subproject
29 # ------------------------------------------
30 all: ports checkconf $(LIBGC) $(TARGET)
33 for i in $(PORTS); do $(MAKE) -C $$i; done
35 $(PRJDIR)/support/gc/libgc.a:
36 cd $(PRJDIR)/support/gc && $(MAKE)
39 # Compiling and installing everything and runing test
40 # ---------------------------------------------------
41 install: all installdirs
42 $(INSTALL) -s $(TARGET) $(bindir)/sdcc
45 # Deleting all the installed files
46 # --------------------------------
51 # Performing self-test
52 # --------------------
56 # Performing installation test
57 # ----------------------------
61 # Creating installation directories
62 # ---------------------------------
64 $(INSTALL) -d $(bindir)
67 # Creating dependencies
68 # ---------------------
71 Makefile.dep: $(SOURCES) *.h $(PRJDIR)/*.h
72 $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
80 $(TARGET): $(OBJECTS) $(PORT_LIBS)
81 $(CC) -o $@ $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
84 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
89 $(YACC) -d -v -o $@ $<
91 SDCClex.c: SDCC.lex SDCCy.h
94 SDCCpeeph.rul: SDCCpeeph.def
95 $(AWK) -f SDCCpeeph.awk SDCCpeeph.def > SDCCpeeph.rul
108 # Remaking configuration
109 # ----------------------
111 @if [ -f $(PRJDIR)/devel ]; then\
112 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
116 # End of main_in.mk/main.mk