#
#
+CFLAGS+=-g
+
SHELL = /bin/sh
AUTOCONF = autoconf
PRJDIR = .
-PKGS = support/gc support/cpp \
- src as/mcs51 debugger/mcs51 \
- device/include device/lib
-PRJS = simulator/mcs51
-
srcdir = .
+include $(srcdir)/Makefile.common
+SDCC_MISC = debugger/mcs51 sim/ucsim
+SDCC_LIBS = support/cpp
+SDCC_ASLINK = as/mcs51 as link
+SDCC_PACKIHX = packihx
+
+PKGS = src $(SDCC_ASLINK) $(SDCC_PACKIHX) $(SDCC_MISC) \
+ $(SDCC_LIBS) device/include device/lib
+PKGS_TINI = $(SDCC_LIBS) $(SDCC_ASLINK) \
+ src device/include $(SDCC_PACKIHX)
+PORTS = $(shell cat ports.build)
+ALLPORTS = $(shell cat ports.all)
# Compiling entire program or any subproject
# ------------------------------------------
-all: checkconf
- for pkg in $(PKGS); do $(MAKE) -C $$pkg; done
+all: checkconf sdcc
+
+tini: checkconf sdcc-tini
+
+sdcc-libs:
+ for lib in $(SDCC_LIBS); do $(MAKE) -C $$lib; done
+
+sdcc-cc: sdcc-libs
+ $(MAKE) -C src
+
+sdcc-aslink:
+ for as in $(SDCC_ASLINK); do $(MAKE) -C $$as; done
+
+sdcc-misc:
+ for misc in $(SDCC_MISC); do $(MAKE) -C $$misc; done
+
+sdcc-packihx:
+ $(MAKE) -C $(SDCC_PACKIHX)
+
+sdcc-device:
+ $(MAKE) -C device/include
+ $(MAKE) -C device/lib
+
+sdcc-device-tini:
+ $(MAKE) -C device/include
+ $(MAKE) -C device/lib modelDS390
+
+sdcc: sdcc-cc sdcc-aslink sdcc-misc sdcc-device sdcc-packihx
$(MAKE) -f main.mk all
+sdcc-tini: sdcc-cc sdcc-aslink sdcc-device-tini sdcc-packihx
+ $(MAKE) -f main.mk all
+
+# Some interesting sub rules
+sdcc-bin: sdcc-cc sdcc-aslink sdcc-misc
+
+sdcc-base: sdcc-cc sdcc-aslink
# Compiling and installing everything and runing test
# ---------------------------------------------------
install:
$(MAKE) -f main.mk install
@for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) install; cd ..;\
+ $(MAKE) -C $$pkg install ;\
done
+install-tini:
+ $(MAKE) -f main.mk install
+ @for pkg in $(PKGS_TINI); do\
+ $(MAKE) -C $$pkg install ;\
+ done
+ $(MAKE) -C device/lib installDS390
+
+
# Deleting all the installed files
# --------------------------------
uninstall:
$(MAKE) -f main.mk uninstall
@for pkg in $(PKGS); do\
- cd cmd && $(MAKE) uninstall; cd ..;\
+ $(MAKE) -C $$pkg uninstall ;\
done
# Deleting all files created by building the program
# --------------------------------------------------
clean:
+ @echo "+ Cleaning root of the project..."
$(MAKE) -f clean.mk clean
- @for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) -f clean.mk clean; cd ..;\
- done
- @for prj in $(PRJS); do\
- cd $$prj && $(MAKE) clean; cd ..;\
+ @echo "+ Cleaning packages in their directories..."
+ for pkg in $(PKGS); do\
+ $(MAKE) PORTS="$(PORTS)" -C $$pkg clean ;\
done
-
+
# Deleting all files created by configuring or building the program
# -----------------------------------------------------------------
-distclean: clean
+distclean:
+ @echo "+ DistCleaning root of the project..."
$(MAKE) -f clean.mk distclean
- @for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) -f clean.mk distclean; cd ..;\
+ @echo "+ DistCleaning packages using clean.mk..."
+ for pkg in $(PKGS); do\
+ $(MAKE) -C $$pkg -f clean.mk PORTS="$(PORTS)" distclean ;\
done
- @for prj in $(PRJS); do\
- cd $$prj && $(MAKE) distclean; cd ..;\
- done
-
+
# Like clean but some files may still exist
# -----------------------------------------
mostlyclean: clean
$(MAKE) -f clean.mk mostlyclean
- @for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) -f clean.mk mostlyclean; cd ..;\
- done
- @for prj in $(PRJS); do\
- cd $$prj && $(MAKE) mostlyclean; cd ..;\
+ for pkg in $(PKGS); do\
+ $(MAKE) -C $$pkg -f clean.mk PORTS="$(PORTS)" mostlyclean ;\
done
# -----------------------------------------------------------------------
realclean: distclean
$(MAKE) -f clean.mk realclean
- @for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) -f clean.mk realclean; cd ..;\
- done
- @for prj in $(PRJS); do\
- cd $$prj && $(MAKE) realclean; cd ..;\
+ for pkg in $(PKGS); do\
+ $(MAKE) -C $$pkg -f clean.mk PORTS="$(PORTS)" realclean ;\
done
dep:
$(MAKE) -f main.mk dep
@for pkg in $(PKGS); do\
- cd $$pkg && $(MAKE) dep; cd ..;\
+ $(MAKE) -C $$pkg dep ;\
done
# My rules
# --------
+newer: distclean
+ @if [ -f start ]; then \
+ tar cvf - \
+ `find . -newer start -type f -print` |\
+ gzip -9c >`date '+%m%d%H%M'`.tgz; \
+ else \
+ echo "start file not found.\n"; \
+ exit 1; \
+ fi
putcopyright:
'put(c)' -s $(STARTYEAR) *.cc *.h *.y *.l