7 include $(PRJDIR)/Makefile.common
11 PORTS = $(shell cat ../ports.build)
12 ALLPORTS = $(shell cat ../ports.all)
13 PORT_LIBS = $(PORTS:%=%/port.a)
19 ifdef SDCC_SUB_VERSION
20 CFLAGS += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
23 SLIBOBJS = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o findme.o
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
33 ifeq ($(USE_ALT_LEX), 1)
40 SLIBSOURCES = $(patsubst %.o,$(SLIB)/%.c,$(SLIBOBJS))
41 SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
43 TARGET = $(PRJDIR)/bin/sdcc$(EXEEXT)
45 # Compiling entire program or any subproject
46 # ------------------------------------------
47 all: checkconf version.h $(TARGET)
50 $(MAKE) -C `dirname $@`
54 $(PRJDIR)/support/gc/libgc.a:
55 cd $(PRJDIR)/support/gc && $(MAKE)
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)'`
64 # Deleting all the installed files
65 # --------------------------------
67 rm -f $(DESTDIR)$(bindir)/sdcc$(EXEEXT)
69 # Performing self-test
70 # --------------------
74 # Performing installation test
75 # ----------------------------
79 # Creating installation directories
80 # ---------------------------------
82 $(INSTALL) -d $(DESTDIR)$(bindir)
85 # Creating dependencies
86 # ---------------------
87 dep: version.h Makefile.dep
89 Makefile.dep: version.h $(SOURCES) $(SLIBSOURCES) $(SPECIAL) *.h $(PRJDIR)/*.h
90 $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) $(SLIBSOURCES) >Makefile.dep
98 $(TARGET): $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS)
99 $(CC) $(LDFLAGS) -o $@ $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
102 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
104 $(SLIBOBJS):%.o:$(SLIB)/%.c
105 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
107 reswords.h: reswords.gperf Makefile
108 gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
110 altlex.o: altlex.c SDCCy.h reswords.h
115 $(YACC) -d -v -o $@ $<
117 SDCClex.c: SDCC.lex SDCCy.h
120 version.h: ../ChangeLog
121 $(AWK) -f version.awk $< > $@
134 # Remaking configuration
135 # ----------------------
137 @if [ -f $(PRJDIR)/devel ]; then\
138 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
142 # End of main_in.mk/main.mk