.PHONY: all check default CFLAGS:=-std=c99 -O3 -finline-functions #CFLAGS:=-std=c99 -g COND:=0 ifeq ($(COND),1) CONDIF:=cond else CONDIF:=if endif CFLAGS+=-DCOND=$(COND) default: all all: mes mes: mes.c mes.h mes.h: mes.c GNUmakefile ( echo '#if MES_C'; echo '#if MES_FULL' 1>&2;\ grep -E '^(scm [*])*[a-z0-9_]+ \(.*\)( {|$$)' $< | grep -Ev '\(.*(char |bool |int )' | sed -e 's,^scm [*],,' | sort |\ while read f; do\ fun=$$(echo $$f | sed -e 's,^scm [*],,' -e 's,{.*,,');\ name=$$(echo $$fun | sed -e 's,^scm [\*],,' | grep -o '^[^ ]*');\ scm_name=$$(echo $$name | sed -e 's,_to_,->,' -e 's,_p$$,?,' -e 's,_x$$,!,' -e 's,^builtin_,,' -re 's,(.*)_$$,c:\1,' | sed \ -e 's,^divide$$,/,'\ -e 's,^is?$$,=,'\ -e 's,^greater?$$,>,'\ -e 's,^less?$$,<,'\ -e 's,^minus$$,-,'\ -e 's,^multiply$$,*,'\ -e 's,^plus$$,+,'\ -e 's,_,-,g');\ args=$$(echo $$fun | grep -o 'scm [\*]' | wc -l);\ [ "$$(echo $$fun | fgrep -o ... )" = "..." ] && args=n;\ echo "scm *$$fun;";\ echo "scm scm_$$name = {FUNCTION$$args, .name=\"$$scm_name\", .function$$args=&$$name};";\ echo "a = add_environment (a, \"$$scm_name\", &scm_$$name);" 1>&2;\ done; echo '#endif'; echo '#endif' 1>&2) > $@ 2>environment.i check: all guile-check # ./mes.test # ./mes.test ./mes cat base0.mes base0-$(CONDIF).mes base.mes lib/test.mes test/base.test | ./mes cat base0.mes base0-$(CONDIF).mes base.mes lib/test.mes test/closure.test | ./mes cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes lib/test.mes test/quasiquote.test | ./mes cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes lib/test.mes test/let.test | ./mes cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes lib/srfi/srfi-0.scm scm.mes lib/test.mes test/scm.test | ./mes guile-check: guile -s <(cat base.mes lib/test.mes test/base.test) guile -s <(cat base.mes lib/test.mes test/closure.test) guile -s <(cat base.mes lib/test.mes test/quasiquote.test) guile -s <(cat quasiquote.mes lib/test.mes test/quasiquote.test) # guile -s <(cat base.mes quasiquote.mes let.mes lib/test.mes test/let.test) # guile -s <(cat base.mes let.mes test/foo.test) # exit 1 guile -s <(cat lib/test.mes test/base.test) guile -s <(cat lib/test.mes test/quasiquote.test) guile -s <(cat lib/test.mes test/let.test) guile -s <(cat quasiquote.mes lib/test.mes test/base.test) guile -s <(cat quasiquote.mes lib/test.mes test/quasiquote.test) guile -s <(cat lib/test.mes test/scm.test) run: all cat scm.mes test.mes | ./mes psyntax: all cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes psyntax.mes psyntax.pp psyntax2.mes | ./mes syntax: all cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes scm.mes syntax-cond.mes syntax-test.mes | ./mes syntax.test: syntax-cond.mes syntax-test.mes cat $^ > $@ guile-syntax: syntax.test guile -s $^ syntax-case: all cat scm.mes syntax-cond.mes syntax-case-lib.mes syntax-case.mes syntax-case-after.mes syntax-case-test.mes | ./mes syntax-case.test: syntax-cond.mes syntax-case-lib.mes syntax-case.mes syntax-case-after.mes syntax-case-test.mes cat $^ > $@ guile-syntax-case: syntax-case.test guile -s $^ macro: all cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes scm.mes macro.mes | ./mes peg: all cat scm.mes syntax-cond.mes syntax-case-lib.mes syntax-case.mes syntax-case-after.mes peg.mes peg/codegen.scm peg/string-peg.scm peg/simplify-tree.scm peg/using-parsers.scm peg/cache.scm peg-test.mes | ./mes peg.test: peg/pmatch.scm peg.mes peg/codegen.scm peg/string-peg.scm peg/simplify-tree.scm peg/using-parsers.scm peg/cache.scm peg-test.mes cat $^ | sed 's,\(;; Packages the results of a parser\),(when (guile?) (set! compile-peg-pattern (@@ (ice-9 peg codegen) compile-peg-pattern)))\n\1,' > $@ guile-peg: peg.test # guile -s peg-test.mes # @echo "=======================================" guile -s $^ clean: rm -f mes environment.i mes.h peg.test syntax.test record: all cat scm.mes syntax-cond.mes lib/record.mes lib/record.scm lib/srfi/srfi-9.scm record.mes |./mes paren: all echo -e 'EOF\n___P((()))' | cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes scm.mes syntax-cond.mes lib/srfi/srfi-0.scm lib/record.mes lib/record.scm lib/srfi/srfi-9.scm lib/lalr.mes lib/lalr.scm paren.scm - | ./mes paren.test: lib/lalr.scm paren.scm cat $^ > $@ guile-paren: paren.test echo '___P((()))' | guile -s $^ mescc: all echo ' EOF ' | cat base0.mes base0-$(CONDIF).mes base.mes quasiquote.mes let.mes scm.mes syntax-cond.mes lib/srfi/srfi-0.scm lib/record.mes lib/record.scm lib/srfi/srfi-9.scm lib/lalr.mes lib/lalr.scm c-lexer.scm mescc.scm - main.c | ./mes > a.out chmod +x a.out mescc.test: lib/lalr.scm c-lexer.scm mescc.scm cat $^ > $@ guile-mescc: mescc.test cat main.c | guile -s $^ hello.o: hello.S as --32 -march=i386 -o $@ $^ hello: hello.o ld -A i386 -m elf_i386 -nostdlib -nodefaultlibs -A i386 -o $@ $^ # ld -A i386 -m elf_i386 -A i386 -o $@ $^ a.out: elf.mes cat base0.mes base0-if.mes base.mes elf.mes | ./mes > a.out chmod +x a.out