EXEEXT introduces to solve Cygwin problems
[fw/sdcc] / src / Makefile.in
index bcdf6eccead99c002478967bc50bb64f2a05a7ac..1c3d85b228c96532283b58d587ed26dcfd5f3c0e 100644 (file)
@@ -2,73 +2,68 @@
 #
 #
 
-# Version
-VERSION         = @VERSION@
-VERSIONHI       = @VERSIONHI@
-VERSIONLO       = @VERSIONLO@
-VERSIONP        = @VERSIONP@
-
-# Programs
-SHELL          = /bin/sh
-CC             = @CC@
-CPP            = @CPP@
-RANLIB         = @RANLIB@
-INSTALL                = @INSTALL@
-YACC            = @YACC@ 
-LEX             = @LEX@ 
-AWK             = @AWK@
-# Directories
 PRJDIR         = ..
 
-prefix          = @prefix@
-exec_prefix     = @exec_prefix@
-bindir          = @bindir@
-libdir          = @libdir@
-datadir         = @datadir@
-includedir      = @includedir@
-mandir          = @mandir@
-man1dir         = $(mandir)/man1
-man2dir         = $(mandir)/man2
-infodir         = @infodir@
-srcdir          = @srcdir@
-
-# Flags
-DEFS            = $(subs -DHAVE_CONFIG_H,,@DEFS@)
-CPPFLAGS        = @CPPFLAGS@ -I$(PRJDIR) -I$(PRJDIR)/support
-CFLAGS          = @CFLAGS@ -Wall
-M_OR_MM         = @M_OR_MM@
-LIBS           = -lgc @LIBS@
-LIBDIRS                = -L$(PRJDIR)/support/gc
-
-OBJECTS        = SDCCy.o SDCClex.o SDCCerr.o SDCChasht.o SDCCmain.o \
+include $(PRJDIR)/Makefile.common
+
+USE_ALT_LEX    = 0
+
+PORTS          = $(shell cat ../ports.build)
+ALLPORTS       = $(shell cat ../ports.all)
+PORT_LIBS      = $(PORTS:%=%/port.a)
+
+LIBS           = -lm @LIBS@
+
+#CFLAGS          += -Werror
+
+ifdef SDCC_SUB_VERSION
+CFLAGS         += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
+endif
+
+SLIBOBJS       = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o
+
+OBJECTS        = SDCCy.o SDCChasht.o SDCCmain.o \
                  SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
-                 SDCCralloc.o SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
+                 SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
                  SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
-                 SDCClrange.o SDCCptropt.o SDCCgen51.o SDCCpeeph.o SDCCglue.o spawn.o
-SOURCES                = $(patsubst %.o,%.c,$(OBJECTS))
+                 SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o \
+                 asm.o SDCCmacro.o SDCCutil.o SDCCdebug.o cdbFile.o
 
-TARGET         = $(PRJDIR)/bin/sdcc
+SPECIAL                = SDCCy.h 
+ifeq ($(USE_ALT_LEX), 1)
+OBJECTS                += altlex.o
+SPECIAL                += reswords.h
+else
+OBJECTS                += SDCClex.o
+endif
+
+SOURCES                = $(patsubst %.o,%.c,$(OBJECTS))
 
+TARGET         = $(PRJDIR)/bin/sdcc$(EXEEXT)
 
 # Compiling entire program or any subproject
 # ------------------------------------------
-all: checkconf $(PRJDIR)/support/gc/libgc.a $(TARGET)
+all: checkconf $(TARGET)
+
+$(PORT_LIBS): FORCE 
+       $(MAKE) -C `dirname $@`
+FORCE:
 
 $(PRJDIR)/support/gc/libgc.a:
        cd $(PRJDIR)/support/gc && $(MAKE)
 
-
 # Compiling and installing everything and runing test
 # ---------------------------------------------------
 install: all installdirs
-       $(INSTALL) -s $(TARGET) $(bindir)/sdcc
+       $(INSTALL) $(TARGET) `echo $(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
+       $(STRIP) `echo $(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
 
 
 # Deleting all the installed files
 # --------------------------------
 uninstall:
-       rm -f $(bindir)/sdcc
-
+       rm -f $(bindir)/sdcc$(EXEEXT)
 
 # Performing self-test
 # --------------------
@@ -90,7 +85,7 @@ installdirs:
 # ---------------------
 dep: Makefile.dep
 
-Makefile.dep: $(SOURCES) *.h $(PRJDIR)/*.h
+Makefile.dep: $(SOURCES) $(SPECIAL) *.h $(PRJDIR)/*.h
        $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
 
 include Makefile.dep
@@ -99,21 +94,28 @@ include clean.mk
 
 # My rules
 # --------
-$(TARGET): $(OBJECTS)
-       $(CC) -o $@ $(OBJECTS) $(LIBDIRS) $(LIBS)
+$(TARGET): $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS)
+       $(CC) $(LDFLAGS) -o $@ $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
 
 .c.o:
        $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
 
+$(SLIBOBJS):%.o:$(SLIB)/%.c
+       $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
+
+reswords.h: reswords.gperf Makefile
+       gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
+
+altlex.o: altlex.c SDCCy.h reswords.h
+
+SDCCy.h: SDCCy.c
+
 SDCCy.c: SDCC.y
        $(YACC) -d -v -o $@ $<
 
 SDCClex.c: SDCC.lex SDCCy.h
        $(LEX) -t $< >$@
 
-SDCCpeeph.rul: SDCCpeeph.def
-       $(AWK) -f SDCCpeeph.awk SDCCpeeph.def > SDCCpeeph.rul
-
 .y.c:
        rm -f $*.cc $*.h
        $(YACC) -d $<
@@ -134,4 +136,3 @@ checkconf:
        fi
 
 # End of main_in.mk/main.mk
-