# # uCsim Makefile # # (c) Drotos Daniel, Talker Bt. 1997,99 # STARTYEAR = 1997 SHELL = /bin/sh PRJDIR = . include packages.mk #PKGS = cmd.src sim.src gui.src s51.src avr.src z80.src doc srcdir = . # Compiling entire program or any subproject # ------------------------------------------ all: checkconf $(MAKE) -f main.mk all @for pkg in $(PKGS); do\ cd $$pkg && $(MAKE) $$pkg ; cd ..;\ done $(MAKE) -f main.mk main_app libs: main.mk $(MAKE) -f main.mk libs # Compiling and installing everything and runing test # --------------------------------------------------- .PHONY: install INSTALL Install install: $(MAKE) -f main.mk install @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg install ;\ done # Deleting all the installed files # -------------------------------- uninstall: $(MAKE) -f main.mk uninstall @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg uninstall ;\ done # Deleting all files created by building the program # -------------------------------------------------- clean: $(MAKE) -f clean.mk clean EXEEXT=$(EXEEXT) @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg -f clean.mk clean EXEEXT=$(EXEEXT) ;\ done # Deleting all files created by configuring or building the program # ----------------------------------------------------------------- distclean: clean $(MAKE) -f clean.mk distclean @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg -f clean.mk distclean ;\ done rm -rf doc/*~ doc/*.bak # Like clean but some files may still exist # ----------------------------------------- mostlyclean: clean $(MAKE) -f clean.mk mostlyclean @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg -f clean.mk mostlyclean ;\ done # Deleting everything that can reconstructed by this Makefile. It deletes # everything deleted by distclean plus files created by bison, stc. # ----------------------------------------------------------------------- realclean: distclean $(MAKE) -f clean.mk realclean @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg -f clean.mk realclean ;\ done # Creating distribution # --------------------- dist: distclean @if [ -f devel ]; then\ rm -f devel; mkdist; touch devel;\ else\ mkdist;\ fi # Performing self-test # -------------------- check: $(MAKE) -f main.mk check @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg check ;\ done test: $(MAKE) -f main.mk test @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg test ;\ done # Performing installation test # ---------------------------- installcheck: # Creating dependencies # --------------------- dep: $(MAKE) -f main.mk dep @for pkg in $(PKGS); do\ $(MAKE) -C $$pkg dep ;\ done # My rules # -------- putcopyright: 'put(c)' -s $(STARTYEAR) *.cc *.h *.y *.l start: date '+%Y.%m.%d-%H:%M' >.start newer: distclean @if [ -f .start ]; then \ tar cvf - \ `find . -newer .start -type f -print` |\ gzip -9c >ucsim-newer-`cat .start`_`date '+%Y.%m.%d-%H:%M'`_`hostname`.tgz; \ else \ echo ".start file not found.\n"; \ exit 1; \ fi print-newer: @if [ -f .start ]; then \ find . -newer .start -type f -print ;\ else \ echo ".start file not found.\n" ;\ exit 1 ;\ fi new_files: diff -rNu $$HOME/clean-source/sdcc/sim/ucsim .|\ grep '^diff' | grep -v CVS | awk '{print $$4}' lines: @find . \( -name '*.[ch]' -o -name '*.cc' -o -name '*.hh' \) \ -exec cat {} \; | clines # Remaking configuration # ---------------------- configure: configure.in @$(PRJDIR)/mkecho $(PRJDIR) "RE-CREATING CONFIGURE" autoconf configure.in >configure chmod 755 configure config.status: configure @$(PRJDIR)/mkecho $(PRJDIR) "RE-CHECKING CONFIGURATION (re-creating config.status from configure)" @if [ -x ./config.status ]; then \ ./config.status -recheck;\ else\ if [ -x ./conf ]; then\ ./conf;\ else\ ./configure;\ fi\ fi makefiles: config.status @$(PRJDIR)/mkecho $(PRJDIR) "RE-MAKING MAKEFILES" $(SHELL) ./config.status main.mk: $(srcdir)/main_in.mk config.status @$(PRJDIR)/mkecho $(PRJDIR) "RE-MAKING MAIN.MK" $(SHELL) ./config.status freshconf: echo_freshconf configure main.mk ddconfig.h ddconfig.h: ddconfig_in.h config.status $(SHELL) ./config.status echo_freshconf: @$(PRJDIR)/mkecho $(PRJDIR) "FRESHCONF" checkconf: @$(PRJDIR)/mkecho $(PRJDIR) "CHECKCONF" @if [ -f devel ]; then $(MAKE) freshconf; fi # End of Makefile