6 top_srcdir = @top_srcdir@
7 top_builddir = @top_builddir@
10 include $(top_builddir)/Makefile.common
14 PORTS = $(shell cat ../ports.build)
15 ALLPORTS = $(shell cat ../ports.all)
16 PORT_LIBS = $(PORTS:%=%/port.a)
21 CPPFLAGS += -I$(srcdir)
24 ifdef SDCC_SUB_VERSION
25 CFLAGS += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
28 SLIBOBJS = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o dbuf_string.o findme.o
30 OBJECTS = SDCCy.o SDCChasht.o SDCCmain.o \
31 SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
32 SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
33 SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
34 SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o \
35 asm.o SDCCmacro.o SDCCutil.o SDCCdebug.o cdbFile.o SDCCdwarf2.o
38 ifeq ($(USE_ALT_LEX), 1)
45 SLIBSOURCES = $(patsubst %.o,$(SLIB)/%.c,$(SLIBOBJS))
46 SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
48 TARGET = $(top_builddir)/bin/sdcc$(EXEEXT)
50 # Compiling entire program or any subproject
51 # ------------------------------------------
52 all: checkconf version.h $(TARGET)
59 $(top_builddir)/support/gc/libgc.a:
60 $(MAKE) -C $(top_builddir)/support/gc
62 # Compiling and installing everything and runing test
63 # ---------------------------------------------------
64 install: all installdirs
65 $(INSTALL) $(TARGET) `echo $(DESTDIR)$(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
66 $(STRIP) `echo $(DESTDIR)$(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
69 # Deleting all the installed files
70 # --------------------------------
72 rm -f $(DESTDIR)$(bindir)/sdcc$(EXEEXT)
74 # Performing self-test
75 # --------------------
79 # Performing installation test
80 # ----------------------------
84 # Creating installation directories
85 # ---------------------------------
87 $(INSTALL) -d $(DESTDIR)$(bindir)
90 # Creating dependencies
91 # ---------------------
92 dep: version.h Makefile.dep
94 Makefile.dep: version.h $(SOURCES) $(SLIBSOURCES) $(SPECIAL)
95 $(CPP) $(CPPFLAGS) $(M_OR_MM) $(filter %.c,$^) >Makefile.dep
97 # don't include Makefile.dep for the listed targets:
98 ifeq "$(findstring $(MAKECMDGOALS),uninstall check installcheck installdirs checkconf \
99 clean distclean mostlyclean realclean)" ""
100 -include Makefile.dep
102 include $(srcdir)/clean.mk
107 $(TARGET): $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS)
108 $(CC) $(LDFLAGS) -o $@ $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
111 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
113 $(SLIBOBJS):%.o:$(SLIB)/%.c
114 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
116 reswords.h: reswords.gperf Makefile
117 gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
119 altlex.o: altlex.c SDCCy.h reswords.h
124 $(YACC) -d -v -o $@ $<
126 SDCClex.c: SDCC.lex SDCCy.h
129 version.h: ../ChangeLog
130 $(AWK) -f $(srcdir)/version.awk $< > $@
143 # Remaking configuration
144 # ----------------------
146 @if [ -f $(top_builddir)/devel ]; then\
147 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" \
151 # End of main_in.mk/main.mk