Improvements
This commit is contained in:
		
							parent
							
								
									c47420b706
								
							
						
					
					
						commit
						5ba6b6c0b4
					
				
							
								
								
									
										35
									
								
								Dockerfile
								
								
								
								
							
							
						
						
									
										35
									
								
								Dockerfile
								
								
								
								
							|  | @ -1,32 +1,15 @@ | ||||||
| FROM debian:trixie-slim AS build | FROM debian:trixie-slim | ||||||
| RUN apt-get update && apt-get install -y gcc make git chicken-bin | RUN apt-get update && apt-get install -y gcc make git libffi-dev | ||||||
| RUN chicken-install r7rs |  | ||||||
| 
 |  | ||||||
| WORKDIR /build | WORKDIR /build | ||||||
| RUN git clone https://github.com/ashinn/chibi-scheme.git --depth=1 chibi | RUN git clone https://github.com/ashinn/chibi-scheme.git --depth=1 chibi | ||||||
| 
 |  | ||||||
| WORKDIR /build/chibi | WORKDIR /build/chibi | ||||||
| RUN make DESTDIR=/opt/compile-r7rs | RUN make | ||||||
| RUN make DESTDIR=/opt/compile-r7rs install | RUN make install | ||||||
| 
 | RUN mkdir -p ${HOME}/.snow && echo "()" > ${HOME}/.snow/config.scm | ||||||
| RUN mkdir -p /opt/compile-r7rs/bin | RUN snow-chibi install --impls=chibi --always-yes "(foreign c)" | ||||||
| RUN echo "#!/bin/sh" > /opt/compile-r7rs/bin/snow-chibi | RUN snow-chibi install --impls=chibi --always-yes "(srfi 170)" | ||||||
| RUN echo "PATH=/opt/compile-r7rs/usr/local/bin:${PATH} LD_LIBRARY_PATH=/opt/compile-r7rs/usr/local/lib:/opt/compile-r7rs/usr/local/lib/chibi CHIBI_MODULE_PATH=/opt/compile-r7rs/usr/local/share/chibi:/opt/compile-r7rs/usr/local/lib/chibi /opt/compile-r7rs/usr/local/bin/chibi-scheme -I /opt/compile-r7rs/usr/local/share/chibi -I /opt/compile-r7rs/usr/local/lib/chibi -I /opt/compile/snow -mchibi.snow.commands -mchibi.snow.interface -mchibi.snow.package -mchibi.snow.utils /opt/compile-r7rs/usr/local/bin/snow-chibi.scm \"\$@\"" >> /opt/compile-r7rs/bin/snow-chibi |  | ||||||
| RUN chmod +x /opt/compile-r7rs/bin/snow-chibi |  | ||||||
| ENV PATH=/opt/compile-r7rs/bin:${PATH} |  | ||||||
| 
 |  | ||||||
| WORKDIR /build |  | ||||||
| RUN snow-chibi install --impls=chicken --always-yes "(foreign c)" |  | ||||||
| RUN snow-chibi install --impls=chicken --always-yes "(srfi 170)" |  | ||||||
| COPY Makefile . | COPY Makefile . | ||||||
| COPY compile-r7rs.scm . | COPY compile-r7rs.scm . | ||||||
| COPY libs libs | COPY libs libs | ||||||
| RUN make build-chicken | RUN make build-chibi | ||||||
| RUN make PREFIX=/opt/compile-r7rs install | RUN make install | ||||||
| 
 |  | ||||||
| FROM debian:trixie-slim |  | ||||||
| RUN apt-get update && apt-get install -y \ |  | ||||||
|     build-essential libffi-dev docker.io make cmake |  | ||||||
| COPY --from=build /opt/compile-r7rs /opt/compile-r7rs |  | ||||||
| ENV PATH=/opt/compile-r7rs/bin:${PATH} |  | ||||||
| RUN mkdir -p ${HOME}/.snow && echo "()" > ${HOME}/.snow/config.scm |  | ||||||
|  |  | ||||||
|  | @ -1,24 +0,0 @@ | ||||||
| FROM alpine AS build |  | ||||||
| RUN apk add make gcc chicken git |  | ||||||
| RUN chicken-install r7rs |  | ||||||
| 
 |  | ||||||
| WORKDIR /build |  | ||||||
| RUN git clone https://github.com/ashinn/chibi-scheme.git --depth=1 chibi |  | ||||||
| 
 |  | ||||||
| WORKDIR /build/chibi |  | ||||||
| RUN make |  | ||||||
| RUN make install |  | ||||||
| 
 |  | ||||||
| WORKDIR /build |  | ||||||
| RUN mkdir -p ${HOME}/.snow && echo "()" > ${HOME}/.snow/config.scm |  | ||||||
| RUN snow-chibi install --always-yes --impls=chicken "(foreign c)" |  | ||||||
| RUN snow-chibi install --always-yes --impls=chicken "(srfi 170)" |  | ||||||
| COPY Makefile . |  | ||||||
| COPY compile-r7rs.scm . |  | ||||||
| COPY libs ./libs |  | ||||||
| RUN make PREFIX=/opt/compile-r7rs build-chicken |  | ||||||
| RUN make PREFIX=/opt/compile-r7rs install |  | ||||||
| 
 |  | ||||||
| FROM alpine |  | ||||||
| COPY --from=build /opt/compile-r7rs /opt/compile-r7rs |  | ||||||
| ENV PATH=/opt/compile-r7rs/bin:${PATH} |  | ||||||
|  | @ -1,21 +1,23 @@ | ||||||
| ARG SCHEME=chibi | ARG SCHEME=chibi | ||||||
| ARG IMAGE=chibi:head | ARG IMAGE=chibi:head | ||||||
| FROM debian:trixie AS build | FROM debian:bookworm AS cache | ||||||
| RUN apt-get update && apt-get install -y \ | RUN apt-get update && apt-get install -y gcc make git | ||||||
|     --download-only \ | WORKDIR /cache | ||||||
|     --no-install-recommends \ | RUN git clone https://github.com/ashinn/chibi-scheme.git --depth=1 | ||||||
|     --no-install-suggests \ | WORKDIR /cache/chibi-scheme | ||||||
|     build-essential \ | RUN make | ||||||
|     make \ |  | ||||||
|     libffi-dev \ |  | ||||||
|     ca-certificates \ |  | ||||||
|     git \ |  | ||||||
|     cmark |  | ||||||
| 
 | 
 | ||||||
| ARG SCHEME=chibi | ARG SCHEME=chibi | ||||||
| ENV COMPILE_R7RS=${SCHEME} | ARG IMAGE=chibi:head | ||||||
| FROM schemers/${IMAGE} | FROM schemers/${IMAGE} | ||||||
| COPY --from=build /var/cache/apt/archives /debs | RUN apt-get update && apt-get install -y make gcc libffi-dev unzip | ||||||
| RUN dpkg -i /debs/*.deb | COPY --from=cache /cache /cache | ||||||
| COPY --from=local-build-compile-r7rs /opt/compile-r7rs /opt/compile-r7rs | WORKDIR /cache/chibi-scheme | ||||||
| ENV PATH=/opt/compile-r7rs/bin:${PATH}:/opt/compile-r7rs/snow-chibi/bin | RUN make install | ||||||
|  | WORKDIR / | ||||||
|  | RUN snow-chibi install --always-yes "(foreign c)" | ||||||
|  | RUN snow-chibi install --always-yes "(srfi 170)" | ||||||
|  | COPY Makefile . | ||||||
|  | COPY libs libs/ | ||||||
|  | COPY compile-r7rs.scm . | ||||||
|  | RUN make build-chibi && make install | ||||||
|  |  | ||||||
|  | @ -1,32 +1,28 @@ | ||||||
| pipeline { | pipeline { | ||||||
| 
 | 
 | ||||||
|     agent { |     agent { | ||||||
|  |         docker { | ||||||
|             label 'docker-x86_64' |             label 'docker-x86_64' | ||||||
|  |             image 'schemers/chibi:head' | ||||||
|  |             args '--user=root --privileged -v /var/run/docker.sock:/var/run/docker.sock' | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     options { |     options { | ||||||
|         disableConcurrentBuilds() |         disableConcurrentBuilds() | ||||||
|         buildDiscarder(logRotator(numToKeepStr: '10', artifactNumToKeepStr: '10')) |         buildDiscarder(logRotator(numToKeepStr: '10', artifactNumToKeepStr: '10')) | ||||||
|         timeout(time: 1, unit: 'HOURS') |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     parameters { |  | ||||||
|         booleanParam(name: 'DOCKER', defaultValue: false, description: 'Build and push docker image') |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     stages { |     stages { | ||||||
|         stage('Build') { |         stage('Build and install') { | ||||||
|             steps { |             steps { | ||||||
|                 sh "docker build -f Dockerfile --tag=local-build-compile-r7rs ." |                 sh "apt-get install -y make" | ||||||
|             } |                 sh "make build-chibi" | ||||||
|         } |                 sh "make install" | ||||||
| 
 |  | ||||||
|         stage('Warm up cache') { |  | ||||||
|             steps { |  | ||||||
|                 sh "docker build -f Dockerfile.test --build-arg IMAGE=chibi:head --build-arg SCHEME=chibi --tag=compile-r7rs-test-chibi ." |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         /* | ||||||
|         stage('Test R6RS implementations') { |         stage('Test R6RS implementations') { | ||||||
|             steps { |             steps { | ||||||
|                 script { |                 script { | ||||||
|  | @ -72,54 +68,6 @@ pipeline { | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 |         */ | ||||||
|         stage('Docker build/login/push x84-64') { |  | ||||||
|             agent { |  | ||||||
|                 label 'linux-x86_64' |  | ||||||
|             } |  | ||||||
|             when { |  | ||||||
|                 allOf { |  | ||||||
|                     branch 'main' |  | ||||||
|                     expression { |  | ||||||
|                         return params.DOCKER |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             steps { |  | ||||||
|                 catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') { |  | ||||||
|                     sh 'docker build . --tag=retropikzel1/compile-r7rs' |  | ||||||
|                     sh 'docker login -u ${DOCKER_HUB_USERNAME} -p ${DOCKER_HUB_TOKEN}' |  | ||||||
|                     sh 'docker push retropikzel1/compile-r7rs' |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         stage('Docker build/login/push arm') { |  | ||||||
|             agent { |  | ||||||
|                 label 'linux-arm' |  | ||||||
|             } |  | ||||||
|             when { |  | ||||||
|                 allOf { |  | ||||||
|                     branch 'main' |  | ||||||
|                     expression { |  | ||||||
|                         return params.DOCKER |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             steps { |  | ||||||
|                 catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') { |  | ||||||
|                     sh 'docker build . --tag=retropikzel1/compile-r7rs' |  | ||||||
|                     sh 'docker login -u ${DOCKER_HUB_USERNAME} -p ${DOCKER_HUB_TOKEN}' |  | ||||||
|                     sh 'docker push retropikzel1/compile-r7rs' |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         stage('Docker logout') { |  | ||||||
|             steps { |  | ||||||
|                 sh 'docker logout' |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										58
									
								
								Makefile
								
								
								
								
							
							
						
						
									
										58
									
								
								Makefile
								
								
								
								
							|  | @ -6,12 +6,15 @@ DOCKERIMG=${SCHEME}:head | ||||||
| ifeq "${SCHEME}" "chicken" | ifeq "${SCHEME}" "chicken" | ||||||
| DOCKERIMG="chicken:5" | DOCKERIMG="chicken:5" | ||||||
| endif | endif | ||||||
| 
 |  | ||||||
| STATIC_LIBS=libs.util.a libs.library-util.a libs.data.a libs.srfi-64-util.a | STATIC_LIBS=libs.util.a libs.library-util.a libs.data.a libs.srfi-64-util.a | ||||||
| 
 | 
 | ||||||
|  | all: | ||||||
|  | 	echo "HERE!" | ||||||
|  | 
 | ||||||
| build-chibi: | build-chibi: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "chibi-scheme -A ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | 	echo "chibi-scheme -A ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | ||||||
|  | 	chmod +x compile-r7rs | ||||||
| 
 | 
 | ||||||
| build-chicken: | build-chicken: | ||||||
| 	csc -R r7rs -X r7rs -static -c -J -unit libs.util -o libs.util.o libs/util.sld | 	csc -R r7rs -X r7rs -static -c -J -unit libs.util -o libs.util.o libs/util.sld | ||||||
|  | @ -32,14 +35,17 @@ build-chicken: | ||||||
| build-gauche: | build-gauche: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "gosh -r -I ${PREFIX}/lib/compile-r7rs -I ${PREFIX}/lib/compile-r7rs/libs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | 	echo "gosh -r -I ${PREFIX}/lib/compile-r7rs -I ${PREFIX}/lib/compile-r7rs/libs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | ||||||
|  | 	chmod +x compile-r7rs | ||||||
| 
 | 
 | ||||||
| build-guile: | build-guile: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "guile --r7rs --auto-compile -I -q -L ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\" 2> /dev/null" >> compile-r7rs | 	echo "guile --r7rs --auto-compile -I -q -L ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\" 2> /dev/null" >> compile-r7rs | ||||||
|  | 	chmod +x compile-r7rs | ||||||
| 
 | 
 | ||||||
| build-kawa: | build-kawa: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "kawa -J--add-exports=java.base/jdk.internal.foreign.abi=ALL-UNNAMED -J--add-exports=java.base/jdk.internal.foreign.layout=ALL-UNNAMED -J--add-exports=java.base/jdk.internal.foreign=ALL-UNNAMED -J--enable-native-access=ALL-UNNAMED -Dkawa.import.path=/usr/local/share/kawa/lib/*.sld:${PREFIX}/lib/compile-r7rs/*.sld --r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\" 2> /dev/null" >> compile-r7rs | 	echo "kawa -J--add-exports=java.base/jdk.internal.foreign.abi=ALL-UNNAMED -J--add-exports=java.base/jdk.internal.foreign.layout=ALL-UNNAMED -J--add-exports=java.base/jdk.internal.foreign=ALL-UNNAMED -J--enable-native-access=ALL-UNNAMED -Dkawa.import.path=/usr/local/share/kawa/lib/*.sld:${PREFIX}/lib/compile-r7rs/*.sld --r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\" 2> /dev/null" >> compile-r7rs | ||||||
|  | 	chmod +x compile-r7rs | ||||||
| 
 | 
 | ||||||
| #build-racket:
 | #build-racket:
 | ||||||
| 	#echo "#!/bin/sh" > compile-r7rs | 	#echo "#!/bin/sh" > compile-r7rs | ||||||
|  | @ -48,24 +54,12 @@ build-kawa: | ||||||
| build-sagittarius: | build-sagittarius: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "sash -A ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | 	echo "sash -A ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | ||||||
|  | 	chmod +x compile-r7rs | ||||||
| 
 | 
 | ||||||
| build-stklos: | build-stklos: | ||||||
| 	echo "#!/bin/sh" > compile-r7rs | 	echo "#!/bin/sh" > compile-r7rs | ||||||
| 	echo "stklos -I ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | 	echo "stklos -I ${PREFIX}/lib/compile-r7rs ${PREFIX}/lib/compile-r7rs/compile-r7rs.scm \"\$$@\"" >> compile-r7rs | ||||||
| 
 | 	chmod +x compile-r7rs | ||||||
| docker-images: build-docker-image-debian build-docker-image-alpine |  | ||||||
| 
 |  | ||||||
| docker-image-debian: |  | ||||||
| 	docker build . -f Dockerfile --tag=retropikzel1/compile-r7rs:latest |  | ||||||
| 
 |  | ||||||
| docker-image-debian-push: |  | ||||||
| 	docker push retropikzel1/compile-r7rs:latest |  | ||||||
| 
 |  | ||||||
| docker-image-alpine: |  | ||||||
| 	docker build . -f Dockerfile.alpine --tag=retropikzel1/compile-r7rs:alpine-latest |  | ||||||
| 
 |  | ||||||
| docker-image-alpine-push: |  | ||||||
| 	docker push retropikzel1/compile-r7rs:alpine-latest |  | ||||||
| 
 | 
 | ||||||
| install: | install: | ||||||
| 	mkdir -p ${PREFIX}/bin | 	mkdir -p ${PREFIX}/bin | ||||||
|  | @ -81,39 +75,26 @@ uninstall: | ||||||
| test-r6rs: | test-r6rs: | ||||||
| 	rm -rf ${R6RSTMP} | 	rm -rf ${R6RSTMP} | ||||||
| 	mkdir -p ${R6RSTMP} | 	mkdir -p ${R6RSTMP} | ||||||
| 	mkdir -p ${R6RSTMP}/libs | 	cp -r r6rs-testfiles/* ${R6RSTMP}/ | ||||||
| 	mkdir -p ${R6RSTMP}/libs/foo |  | ||||||
| 	printf "#!r6rs\n(library (foo bar) (export baz) (import (rnrs)) (define baz (lambda () (display \"Test successfull\") (newline))))" > ${R6RSTMP}/libs/foo/bar.sls |  | ||||||
| 	printf "#!r6rs\n(import (rnrs) (foo bar)) (baz)" > ${R6RSTMP}/main.sps |  | ||||||
| 	cd ${R6RSTMP} && COMPILE_R7RS=${SCHEME} compile-r7rs -I ./libs -o main main.sps | 	cd ${R6RSTMP} && COMPILE_R7RS=${SCHEME} compile-r7rs -I ./libs -o main main.sps | ||||||
| 	-cd ${R6RSTMP} && ./main > compile-r7rs-test-result.txt 2>&1 | 	cd ${R6RSTMP} && ./main 1 2 3 > test-result.txt | ||||||
| 	@grep "Test successfull" ${R6RSTMP}/compile-r7rs-test-result.txt || (echo "Test failed, output: " && cat ${R6RSTMP}/compile-r7rs-test-result.txt && exit 1) | 	@grep "Test successfull (\"1\" \"2\" \"3\")" ${R6RSTMP}/test-result.txt || (echo "Test failed, output: " && cat ${R6RSTMP}/test-result.txt && exit 1) | ||||||
| 
 | 
 | ||||||
| test-r6rs-docker: build-local-docker | test-r6rs-docker: | ||||||
| 	docker build -f Dockerfile.test --build-arg IMAGE=${DOCKERIMG} --build-arg SCHEME=${SCHEME} --tag=compile-r7rs-test-${SCHEME} . | 	docker build -f Dockerfile.test --build-arg IMAGE=${DOCKERIMG} --build-arg SCHEME=${SCHEME} --tag=compile-r7rs-test-${SCHEME} . | ||||||
| 	docker run -v "${PWD}":/workdir -w /workdir -t compile-r7rs-test-${SCHEME} sh -c "make && make install && make SCHEME=${SCHEME} test-r6rs" | 	docker run -v "${PWD}":/workdir -w /workdir -t compile-r7rs-test-${SCHEME} sh -c "make SCHEME=${SCHEME} test-r6rs" | ||||||
| 
 | 
 | ||||||
| test-r7rs: | test-r7rs: | ||||||
| 	rm -rf ${R7RSTMP} | 	rm -rf ${R7RSTMP} | ||||||
| 	mkdir -p ${R7RSTMP} | 	mkdir -p ${R7RSTMP} | ||||||
| 	mkdir -p ${R7RSTMP}/libs | 	cp -r r7rs-testfiles/* ${R7RSTMP}/ | ||||||
| 	mkdir -p ${R7RSTMP}/libs/foo |  | ||||||
| 	mkdir -p ${R7RSTMP}/libs/hello |  | ||||||
| 	echo "(import (scheme base) (foo bar) (hello world) (other hellolib)) (baz) (hello-world) (over-9000)" > ${R7RSTMP}/main.scm |  | ||||||
| 	echo "(define baz (lambda () (display \"Test successfull\") (newline)))" > ${R7RSTMP}/libs/foo/bar.scm |  | ||||||
| 	echo "(define-library (foo bar) (import (scheme base) (scheme write) (hello world)) (export baz) (include \"bar.scm\"))" > ${R7RSTMP}/libs/foo/bar.sld |  | ||||||
| 	echo "(define hello-world (lambda () (+ 1 1)))" > ${R7RSTMP}/libs/hello/world.scm |  | ||||||
| 	echo "(define-library (hello world) (import (scheme base) (scheme write)) (export hello-world) (include \"world.scm\"))" > ${R7RSTMP}/libs/hello/world.sld |  | ||||||
| 	mkdir -p ${R7RSTMP}/libs/other |  | ||||||
| 	echo "(define over-9000 (lambda () (+ 1 1)))" > ${R7RSTMP}/libs/other/hellolib.scm |  | ||||||
| 	echo "(define-library (other hellolib) (import (scheme base) (scheme write)) (export over-9000) (include \"hellolib.scm\"))" > ${R7RSTMP}/libs/other/hellolib.sld |  | ||||||
| 	cd ${R7RSTMP} && COMPILE_R7RS=${SCHEME} compile-r7rs -I ./libs -o main main.scm | 	cd ${R7RSTMP} && COMPILE_R7RS=${SCHEME} compile-r7rs -I ./libs -o main main.scm | ||||||
| 	-cd ${R7RSTMP} && ./main > compile-r7rs-test-result.txt 2>&1 | 	-cd ${R7RSTMP} && ./main 1 2 3 > test-result.txt 2>&1 | ||||||
| 	@grep "Test successfull" ${R7RSTMP}/compile-r7rs-test-result.txt || (echo "Test failed, output: " && cat ${R7RSTMP}/compile-r7rs-test-result.txt && exit 1) | 	@grep "Test successfull (\"1\" \"2\" \"3\")" ${R7RSTMP}/test-result.txt || (echo "Test failed, output: " && cat ${R7RSTMP}/test-result.txt && exit 1) | ||||||
| 
 | 
 | ||||||
| test-r7rs-docker: build-local-docker | test-r7rs-docker: | ||||||
| 	docker build -f Dockerfile.test --build-arg IMAGE=${DOCKERIMG} --build-arg SCHEME=${SCHEME} --tag=compile-r7rs-test-${SCHEME} . | 	docker build -f Dockerfile.test --build-arg IMAGE=${DOCKERIMG} --build-arg SCHEME=${SCHEME} --tag=compile-r7rs-test-${SCHEME} . | ||||||
| 	docker run -v "${PWD}":/workdir -w /workdir -t compile-r7rs-test-${SCHEME} sh -c "make && make install && make SCHEME=${SCHEME} test-r7rs" | 	docker run -it -v "${PWD}":/workdir -w /workdir -t compile-r7rs-test-${SCHEME} sh -c "make SCHEME=${SCHEME} test-r7rs" | ||||||
| 
 | 
 | ||||||
| clean: | clean: | ||||||
| 	rm -rf test-r7rs | 	rm -rf test-r7rs | ||||||
|  | @ -125,6 +106,7 @@ clean: | ||||||
| 	find . -name "*.link" -delete | 	find . -name "*.link" -delete | ||||||
| 	find . -name "*.meta" -delete | 	find . -name "*.meta" -delete | ||||||
| 	find . -name "*.import.*" -delete | 	find . -name "*.import.*" -delete | ||||||
|  | 	rm -rf libs.library-util.c | ||||||
| 	rm -rf dist | 	rm -rf dist | ||||||
| 	rm -rf deps | 	rm -rf deps | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -151,13 +151,13 @@ | ||||||
| (define scheme-type (cdr (assoc 'type (cdr (assoc scheme data))))) | (define scheme-type (cdr (assoc 'type (cdr (assoc scheme data))))) | ||||||
| 
 | 
 | ||||||
| (define scheme-command | (define scheme-command | ||||||
|   (string-append (apply (cdr (assoc 'command (cdr (assoc scheme data)))) |   (apply (cdr (assoc 'command (cdr (assoc scheme data)))) | ||||||
|          (list (if input-file input-file "") |          (list (if input-file input-file "") | ||||||
|                (if output-file output-file "") |                (if output-file output-file "") | ||||||
|                prepend-directories |                prepend-directories | ||||||
|                append-directories |                append-directories | ||||||
|                library-files |                library-files | ||||||
|                               r6rs?)))) |                r6rs?))) | ||||||
| 
 | 
 | ||||||
| (define scheme-library-command | (define scheme-library-command | ||||||
|   (lambda (library-file) |   (lambda (library-file) | ||||||
|  | @ -198,16 +198,18 @@ | ||||||
|                (display "Compiling library ") |                (display "Compiling library ") | ||||||
|                (display file) |                (display file) | ||||||
|                (newline) |                (newline) | ||||||
|                (display "With command      ") |                (for-each | ||||||
|                (display library-command) |                  (lambda (command) | ||||||
|  |                    (display "Running   ") | ||||||
|  |                    (write command) | ||||||
|                    (newline) |                    (newline) | ||||||
|                    (display "Exit code ") |                    (display "Exit code ") | ||||||
|                (let ((output (c-system (string->c-utf8 library-command)))) |                    (let ((exit-code (c-system (string->c-utf8 command)))) | ||||||
|                  (when (not (= output 0)) |                      (display exit-code) | ||||||
|                    (error "Problem compiling libraries, exiting" output)) |  | ||||||
|                  (display output)) |  | ||||||
|                      (newline) |                      (newline) | ||||||
|                (newline))) |                      (when (not (= exit-code 0)) | ||||||
|  |                        (exit exit-code)))) | ||||||
|  |                  library-command))) | ||||||
|            library-files)) |            library-files)) | ||||||
|         (else |         (else | ||||||
|           (display "Implementation has no library build command, skipping library compilation.") |           (display "Implementation has no library build command, skipping library compilation.") | ||||||
|  | @ -217,32 +219,33 @@ | ||||||
| (when (and (equal? scheme-type 'interpreter) input-file) | (when (and (equal? scheme-type 'interpreter) input-file) | ||||||
|   (when (and output-file (file-exists? output-file)) |   (when (and output-file (file-exists? output-file)) | ||||||
|     (delete-file output-file)) |     (delete-file output-file)) | ||||||
|  |   (let ((shebang-line (string-append | ||||||
|  |                         (cond ((string=? compilation-target "unix") | ||||||
|  |                                "#!/usr/bin/env -S ") | ||||||
|  |                               ((string=? compilation-target "windows") | ||||||
|  |                                (string-append | ||||||
|  |                                  "@echo off" | ||||||
|  |                                  (string #\newline) | ||||||
|  |                                  "start"))) | ||||||
|  |                         scheme-command)) | ||||||
|  |         (scheme-program (slurp input-file))) | ||||||
|     (display "Creating startup script    ") |     (display "Creating startup script    ") | ||||||
|     (display output-file) |     (display output-file) | ||||||
|     (newline) |     (newline) | ||||||
|     (display "Containing command         ") |     (display "Starting with              ") | ||||||
|     (display scheme-command) |     (display shebang-line) | ||||||
|     (newline) |     (newline) | ||||||
|     (with-output-to-file |     (with-output-to-file | ||||||
|       (if (string=? compilation-target "windows") |       (if (string=? compilation-target "windows") | ||||||
|         (string-append output-file ".bat") |         (string-append output-file ".bat") | ||||||
|         output-file) |         output-file) | ||||||
|       (lambda () |       (lambda () | ||||||
|         (cond ((string=? compilation-target "unix") |         (display shebang-line) | ||||||
|                (display "#!/bin/sh") |  | ||||||
|                (newline)) |  | ||||||
|               ((string=? compilation-target "windows") |  | ||||||
|                (display "@echo off") |  | ||||||
|         (newline) |         (newline) | ||||||
|                (display "start"))) |         (display scheme-program) | ||||||
|         (display scheme-command) |  | ||||||
|         (cond ((string=? compilation-target "unix") |  | ||||||
|                (display " \"") |  | ||||||
|                (display "$@") |  | ||||||
|                (display "\""))) |  | ||||||
|         (newline))) |         (newline))) | ||||||
|     (cond ((string=? compilation-target "unix") |     (cond ((string=? compilation-target "unix") | ||||||
|          (c-system (string->c-utf8 (string-append "chmod +x " output-file)))))) |            (c-system (string->c-utf8 (string-append "chmod +x " output-file))))))) | ||||||
| 
 | 
 | ||||||
| (when (and (equal? scheme-type 'compiler) input-file) | (when (and (equal? scheme-type 'compiler) input-file) | ||||||
|   (when (and output-file (file-exists? output-file)) |   (when (and output-file (file-exists? output-file)) | ||||||
|  | @ -250,10 +253,17 @@ | ||||||
|   (display "Compiling file    ") |   (display "Compiling file    ") | ||||||
|   (display input-file) |   (display input-file) | ||||||
|   (newline) |   (newline) | ||||||
|   (display "With command      ") |   (for-each | ||||||
|   (display scheme-command) |     (lambda (command) | ||||||
|  |       (display "Running   ") | ||||||
|  |       (write command) | ||||||
|       (newline) |       (newline) | ||||||
|       (display "Exit code ") |       (display "Exit code ") | ||||||
|   (display (c-system (string->c-utf8 scheme-command))) |       (let ((exit-code (c-system (string->c-utf8 command)))) | ||||||
|  |         (display exit-code) | ||||||
|  |         (newline) | ||||||
|  |         (when (not (= exit-code 0)) | ||||||
|  |           (exit exit-code)))) | ||||||
|  |     scheme-command) | ||||||
|   (newline)) |   (newline)) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										578
									
								
								libs/data.sld
								
								
								
								
							
							
						
						
									
										578
									
								
								libs/data.sld
								
								
								
								
							|  | @ -12,20 +12,23 @@ | ||||||
|       `((chezscheme |       `((chezscheme | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  |                         (let ((separator (cond-expand (windows ";") (else ":")))) | ||||||
|                           (apply string-append |                           (apply string-append | ||||||
|                          `("scheme" |                                  `("chezscheme " | ||||||
|                              " " |  | ||||||
|                                    ,(util-getenv "COMPILE_R7RS_CHEZSCHEME") |                                    ,(util-getenv "COMPILE_R7RS_CHEZSCHEME") | ||||||
|                                    " " |                                    " " | ||||||
|                              "--quiet" |                                    ,(if (and (null? prepend-directories) | ||||||
|                              " " |                                              (null? append-directories)) | ||||||
|                              ,@(map (lambda (item) |                                       "" | ||||||
|                                      (string-append "--libdirs " " " item ":")) |                                       (apply string-append | ||||||
|                                  (append prepend-directories append-directories)) |                                              (list "--libdirs " | ||||||
|                              " " |                                                    "\"" | ||||||
|                              "--program" |                                                    (apply string-append | ||||||
|                              " " |                                                           (map (lambda (item) | ||||||
|                              ,input-file))))) |                                                                  (string-append item separator)) | ||||||
|  |                                                                (append prepend-directories append-directories))) | ||||||
|  |                                                    "\""))) | ||||||
|  |                                    " --program ")))))) | ||||||
|         (chibi |         (chibi | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  | @ -40,8 +43,7 @@ | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A" " " item " ")) |                                           (string-append "-A" " " item " ")) | ||||||
|                               append-directories) |                                         append-directories)))))) | ||||||
|                           ,input-file))))) |  | ||||||
|         (chicken |         (chicken | ||||||
|           (type . compiler) |           (type . compiler) | ||||||
|           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|  | @ -56,88 +58,76 @@ | ||||||
|                                                                    (string-replace (string-cut-from-end library-file 4) #\/ #\-) |                                                                    (string-replace (string-cut-from-end library-file 4) #\/ #\-) | ||||||
|                                                                    (string-replace (string-cut-from-end library-file 4) #\/ #\.)) |                                                                    (string-replace (string-cut-from-end library-file 4) #\/ #\.)) | ||||||
|                                                                  ".a"))) |                                                                  ".a"))) | ||||||
|                            (apply string-append `("csc -R r7rs -X r7rs" |                                   `(,(string-append "csc -R r7rs -X r7rs " | ||||||
|                                                   " " |                                                     (util-getenv "COMPILE_R7RS_CHICKEN") | ||||||
|                                                   ,(util-getenv "COMPILE_R7RS_CHICKEN") |  | ||||||
|                                                     " -static -c -J -o " |                                                     " -static -c -J -o " | ||||||
|                                                   ,out |                                                     out | ||||||
|                                                     " " |                                                     " " | ||||||
|                                                   ,(search-library-file (append prepend-directories append-directories) library-file) |                                                     (search-library-file (append prepend-directories append-directories) library-file) | ||||||
|                                                     " " |                                                     " " | ||||||
|                                                   ,@(map (lambda (item) |                                                     (apply string-append | ||||||
|  |                                                            (map (lambda (item) | ||||||
|                                                                   (string-append "-I " item " ")) |                                                                   (string-append "-I " item " ")) | ||||||
|                                                                 (append append-directories |                                                                 (append append-directories | ||||||
|                                                        prepend-directories)) |                                                                         prepend-directories))) | ||||||
|                                                     "-unit " |                                                     "-unit " | ||||||
|                                                   ,unit |                                                     unit) | ||||||
|  |                                      ,(string-append "ar rcs " static-out " " out))))) | ||||||
|  |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  |                         `(,(string-append "csc -R r7rs -X r7rs " | ||||||
|  |                                           (util-getenv "COMPILE_R7RS_CHICKEN") | ||||||
|  |                                           " -static " | ||||||
|                                           " " |                                           " " | ||||||
|                                                   "&&" |                                           (apply string-append | ||||||
|                                                   " " |                                                  (map (lambda (item) | ||||||
|                                                   "ar" |  | ||||||
|                                                   " " |  | ||||||
|                                                   "rcs" |  | ||||||
|                                                   " " |  | ||||||
|                            ,static-out |  | ||||||
|                            " " |  | ||||||
|     ,out))))) |  | ||||||
| (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |  | ||||||
|              (apply string-append `("csc -R r7rs -X r7rs" |  | ||||||
|                                     " " |  | ||||||
|                                     ,(util-getenv "COMPILE_R7RS_CHICKEN") |  | ||||||
|                                     " " |  | ||||||
|                                     "-static" |  | ||||||
|                                     " " |  | ||||||
|                                     ,@(map (lambda (item) |  | ||||||
|                                                         (string-append "-I " item " ")) |                                                         (string-append "-I " item " ")) | ||||||
|                                         (append append-directories prepend-directories)) |                                                       (append append-directories prepend-directories))) | ||||||
|                                     ,@(map (lambda (library-file) |                                           (apply string-append | ||||||
|  |                                                  (map (lambda (library-file) | ||||||
|                                                        (string-append "-uses " |                                                        (string-append "-uses " | ||||||
|                                                                       (if (string-starts-with? library-file "srfi") |                                                                       (if (string-starts-with? library-file "srfi") | ||||||
|                                                                         (string-replace (string-cut-from-end library-file 4) #\/ #\-) |                                                                         (string-replace (string-cut-from-end library-file 4) #\/ #\-) | ||||||
|                                                                         (string-replace (string-cut-from-end library-file 4) #\/ #\.)) |                                                                         (string-replace (string-cut-from-end library-file 4) #\/ #\.)) | ||||||
|                                                                       " ")) |                                                                       " ")) | ||||||
|                                         library-files) |                                                  library-files)) | ||||||
| 
 |                                           " -output-file " | ||||||
|                                     "-output-file" |                                           output-file | ||||||
|                                           " " |                                           " " | ||||||
|                                     ,output-file |                                           input-file))))) | ||||||
|                                     " " |  | ||||||
|              ,input-file))))) |  | ||||||
|         (cyclone |         (cyclone | ||||||
|           (type . compiler) |           (type . compiler) | ||||||
|           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|  |                                 `(,(string-append "cyclone " | ||||||
|  |                                                   (util-getenv "COMPILE_R7RS_CYCLONE") | ||||||
|  |                                                   " " | ||||||
|                                                   (apply string-append |                                                   (apply string-append | ||||||
|                            `("cyclone" |                                                          (map (lambda (item) (string-append "-I " item " ")) prepend-directories)) | ||||||
|                                " " |                                                   (apply string-append | ||||||
|                                ,(util-getenv "COMPILE_R7RS_CYCLONE") |                                                          (map (lambda (item) (string-append "-A " item " ")) append-directories)) | ||||||
|                                " " |                                                   (search-library-file (append prepend-directories | ||||||
|                                ,@(map (lambda (item) (string-append "-I " item " ")) prepend-directories) |  | ||||||
|                                ,@(map (lambda (item) (string-append "-A " item " ")) append-directories) |  | ||||||
|                                ,(search-library-file (append prepend-directories |  | ||||||
|                                                                                append-directories) |                                                                                append-directories) | ||||||
|                                                                        library-file))))) |                                                                        library-file))))) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                   (apply string-append |                         `(,(string-append "cyclone " | ||||||
|                    `("cyclone " |                                           (util-getenv "COMPILE_R7RS_CYCLONE") | ||||||
|                        ,(util-getenv "COMPILE_R7RS_CYCLONE") |  | ||||||
|                                           " " |                                           " " | ||||||
|                        ,@(map (lambda (item) (string-append "-I " item " ")) prepend-directories) |                                           (apply string-append | ||||||
|                        ,@(map (lambda (item) (string-append "-A " item " ")) append-directories) |                                                  (map (lambda (item) (string-append "-I " item " ")) prepend-directories)) | ||||||
|                        ,input-file |                                           (apply string-append | ||||||
|                        ,(if (not (string=? (string-cut-from-end input-file 4) output-file)) |                                                  (map (lambda (item) (string-append "-A " item " ")) append-directories)) | ||||||
|  |                                           input-file) | ||||||
|  |                            ,(string-append (if (not (string=? (string-cut-from-end input-file 4) output-file)) | ||||||
|                                              (string-append |                                              (string-append | ||||||
|                             " && " |  | ||||||
|                                                "mv " |                                                "mv " | ||||||
|                                                (string-cut-from-end input-file 4) |                                                (string-cut-from-end input-file 4) | ||||||
|                                                " " |                                                " " | ||||||
|                                                output-file) |                                                output-file) | ||||||
|                            "")))))) |                                              "sleep 0")))))) | ||||||
|         (foment |         (foment | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("foment" |                                `("foment " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_FOMENT") |                                  ,(util-getenv "COMPILE_R7RS_FOMENT") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|  | @ -145,121 +135,99 @@ | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A" " " item " ")) |                                           (string-append "-A" " " item " ")) | ||||||
|                            append-directories) |                                         append-directories)))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (gambit |         (gambit | ||||||
|           (type . compiler) |           (type . compiler) | ||||||
|           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|                           (apply string-append `("gsc -:r7rs -obj " |                                 `(,(string-append "gsc " | ||||||
|                                                  ,@(map (lambda (item) |                                                   (apply string-append | ||||||
|  |                                                          (map (lambda (item) | ||||||
|                                                                 (string-append item "/ ")) |                                                                 (string-append item "/ ")) | ||||||
|                                                               (append prepend-directories |                                                               (append prepend-directories | ||||||
|                                                       append-directories)) |                                                                       append-directories))) | ||||||
|                                                  ,(search-library-file (append append-directories |                                                   (search-library-file (append append-directories | ||||||
|                                                                                prepend-directories) |                                                                                prepend-directories) | ||||||
|                                                                        library-file))))) |                                                                        library-file))))) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                   (let ((real |                         (let ((output-tmp-file (string-append output-file ".tmp"))) | ||||||
|                          (string-append (string-cut-from-end input-file 4) |                         `(,(string-append "echo \"#!/usr/bin/env gsi -:r7rs,search=" | ||||||
|                           "-real"))) |                                           (apply string-append | ||||||
|                    (apply |                                                  (map (lambda (item) | ||||||
|                     string-append |                                                         (string-append item "/ ")) | ||||||
|                     `("gsc -o " ,real |                                                       (append prepend-directories | ||||||
|  |                                                               append-directories))) | ||||||
|  |                                           "\" > " output-tmp-file) | ||||||
|  |                           ,(string-append "cat " input-file " >> " output-tmp-file) | ||||||
|  |                           ,(string-append "gsc " | ||||||
|  |                                           (apply string-append | ||||||
|  |                                                  (map (lambda (item) | ||||||
|  |                                                         (string-append item "/ ")) | ||||||
|  |                                                       (append prepend-directories | ||||||
|  |                                                               append-directories))) | ||||||
|  |                                           " -o " output-file | ||||||
|                                           " -exe -nopreload " |                                           " -exe -nopreload " | ||||||
|                         ,@(map (lambda (item) |                                           output-tmp-file)))))) | ||||||
|                                 (string-append item "/ ")) |  | ||||||
|                             (append prepend-directories |  | ||||||
|                              append-directories)) |  | ||||||
|                         ,input-file |  | ||||||
|                         " && " |  | ||||||
|                         "printf '#!/bin/sh\\n./" ,real |  | ||||||
|                         " -:r7rs,search=" |  | ||||||
|                         ,@(map (lambda (item) |  | ||||||
|                                 (string-append item "/ ")) |  | ||||||
|                             (append prepend-directories |  | ||||||
|                              append-directories)) |  | ||||||
|                         "" |  | ||||||
|                         "\\n" |  | ||||||
|                         "'" |  | ||||||
|                         " > " ,output-file |  | ||||||
|                         " && " |  | ||||||
|                         "chmod +x " ,output-file)))))) |  | ||||||
|         (gauche |         (gauche | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("gosh" |                                `("gosh " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_GAUCHE") |                                  ,(util-getenv "COMPILE_R7RS_GAUCHE") | ||||||
|                        " " |                                  " -r7 " | ||||||
|                        "-r7" |  | ||||||
|                        " " |  | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-I" " " item " ")) |                                           (string-append "-I" " " item " ")) | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A" " " item " ")) |                                           (string-append "-A" " " item " ")) | ||||||
|                            append-directories) |                                         append-directories)))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (guile |         (guile | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|      (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|  |                                 (let ((library-path (search-library-file (append append-directories | ||||||
|  |                                                                                prepend-directories) | ||||||
|  |                                                                        library-file))) | ||||||
|  |                                 `(,(string-append "guild compile " | ||||||
|  |                                                   (if r6rs? " --r6rs -x .sls " " --r7rs -x .sld ") | ||||||
|  |                                                   " -O0 " | ||||||
|                                                   (apply string-append |                                                   (apply string-append | ||||||
|                    `("guile" |                                                          (map (lambda (item) | ||||||
|                        " " |  | ||||||
|                        ,(util-getenv "COMPILE_R7RS_GUILE") |  | ||||||
|                        " " |  | ||||||
|                        ,(if r6rs? "--r6rs" "--r7rs") |  | ||||||
|                        " " |  | ||||||
|                        ,@(map (lambda (item) |  | ||||||
|                                                                 (string-append "-L" " " item " ")) |                                                                 (string-append "-L" " " item " ")) | ||||||
|                                                               (append prepend-directories |                                                               (append prepend-directories | ||||||
|                             append-directories)) |                                                                       append-directories))) | ||||||
|                        " " |                                                   " -o " | ||||||
|                        ,input-file))))) |                                                   (string-append | ||||||
|     (husk |                                                     (string-cut-from-end library-path 4) | ||||||
|      (type . compiler) |                                                     ".go") | ||||||
|  |                                                   library-path))))) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("huskc" |                                `("guile " | ||||||
|                        " " |                                  ,(util-getenv "COMPILE_R7RS_GUILE") | ||||||
|                        ,(util-getenv "COMPILE_R7RS_HUSK") |                                  ,(if r6rs? " --r6rs -x .sls " " --r7rs -x .sld ") | ||||||
|                        " " |                                  ,@(map (lambda (item) | ||||||
|                        "-o" |                                           (string-append "-L " item " " | ||||||
|                        " " |                                                          "-L " (dirname item) " ")) | ||||||
|                        ,output-file |                                         (append prepend-directories | ||||||
|                        " " |                                                 append-directories)) | ||||||
|                        ;,@(map (lambda (item) (string-append "-L" " " item " ")) prepend-directories) |                                  " -s" | ||||||
|                        ;,@(map (lambda (item) (string-append "-L" " " item " ")) append-directories) |                                  ,(string #\newline) | ||||||
|                        " " |                                  "!#"))))) | ||||||
|                        ,input-file))))) |  | ||||||
|         (ikarus |         (ikarus | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("export IKARUS_LIBRARY_PATH=" |                                `( "IKARUS_LIBRARY_PATH=" | ||||||
|                        ,@(map (lambda (item) |                                   ,@(map (lambda (item) (string-append item ":")) prepend-directories) | ||||||
|                                (string-append item ":")) |                                   ,@(map (lambda (item) (string-append item ":")) append-directories) | ||||||
|                            prepend-directories) |                                   " ikarus " | ||||||
|                        ,@(map (lambda (item) |  | ||||||
|                                (string-append item ":")) |  | ||||||
|                            append-directories) |  | ||||||
|                        "\n" |  | ||||||
|                        "ikarus" |  | ||||||
|                        " " |  | ||||||
|                                   ,(util-getenv "COMPILE_R7RS_IKARUS") |                                   ,(util-getenv "COMPILE_R7RS_IKARUS") | ||||||
|                        " " |                                   " --r6rs-script" | ||||||
|                        "--r6rs-script" |                                   ))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (ironscheme |         (ironscheme | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("ironscheme" |                                `("ironscheme " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_IRONSCHEME") |                                  ,(util-getenv "COMPILE_R7RS_IRONSCHEME") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|  | @ -267,91 +235,143 @@ | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-I \"" item "\" ")) |                                           (string-append "-I \"" item "\" ")) | ||||||
|                            append-directories) |                                         append-directories)))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (kawa |         (kawa | ||||||
|      (type . interpreter) |           (type . compiler) | ||||||
|      (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|                   (apply string-append |                                 (let* ((load-paths (apply string-append | ||||||
|                    `("kawa" |                                                           (append (list "-Dkawa.import.path=") | ||||||
|                        " " |                                                                   (map (lambda (item) | ||||||
|                        ,(util-getenv "COMPILE_R7RS_KAWA") |  | ||||||
|                        " -J--add-exports=java.base/jdk.internal.foreign.abi=ALL-UNNAMED " |  | ||||||
|                        " -J--add-exports=java.base/jdk.internal.foreign.layout=ALL-UNNAMED " |  | ||||||
|                        " -J--add-exports=java.base/jdk.internal.foreign=ALL-UNNAMED " |  | ||||||
|                        " -J--enable-native-access=ALL-UNNAMED " |  | ||||||
|                        "-Dkawa.import.path=\"" |  | ||||||
|                        ,@(map (lambda (item) |  | ||||||
|                                                                          (string-append item "/*.sld:")) |                                                                          (string-append item "/*.sld:")) | ||||||
|                                                                        (append prepend-directories |                                                                        (append prepend-directories | ||||||
|                             append-directories |                                                                                append-directories))))) | ||||||
|                             (list "/usr/local/share/kawa/lib"))) |                                        (library-file-path (search-library-file (append prepend-directories | ||||||
|                        "\" " |                                                                                        append-directories) | ||||||
|                        "--r7rs" |                                                                                library-file)) | ||||||
|  |                                        (output-dir | ||||||
|  |                                          (let ((output-dir ".")) | ||||||
|  |                                            (for-each | ||||||
|  |                                              (lambda (dir) | ||||||
|  |                                                (when (string-starts-with? library-file-path | ||||||
|  |                                                                           dir) | ||||||
|  |                                                  (set! output-dir dir))) | ||||||
|  |                                              (append prepend-directories | ||||||
|  |                                                      append-directories)) | ||||||
|  |                                            output-dir)) | ||||||
|  |                                        (classpath | ||||||
|  |                                          (apply | ||||||
|  |                                            string-append | ||||||
|  |                                            (map (lambda (dir) | ||||||
|  |                                                   (string-append dir ":")) | ||||||
|  |                                                 (append prepend-directories append-directories))))) | ||||||
|  |                                   `(,(string-append | ||||||
|  |                                        "CLASSPATH=" | ||||||
|  |                                        classpath | ||||||
|  |                                        " kawa " | ||||||
|  |                                        (util-getenv "COMPILE_R7RS_KAWA") | ||||||
|                                        " " |                                        " " | ||||||
|                        ,input-file))))) |                                        load-paths | ||||||
|  |                                        " -d " output-dir | ||||||
|  |                                        " " | ||||||
|  |                                        load-paths | ||||||
|  |                                        " -C " | ||||||
|  |                                        library-file-path))))) | ||||||
|  |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  |                         (let ((output-jar (string-append output-file ".jar")) | ||||||
|  |                               (main-class | ||||||
|  |                                 (string-append (string-cut-from-end (path->filename input-file) | ||||||
|  |                                                                     4))) | ||||||
|  |                               (kawa-jar-path "/usr/local/share/kawa/lib/kawa.jar") | ||||||
|  |                               (classpath | ||||||
|  |                                 (apply | ||||||
|  |                                   string-append | ||||||
|  |                                   (map (lambda (dir) | ||||||
|  |                                          (string-append dir " ")) | ||||||
|  |                                        (append prepend-directories append-directories)))) | ||||||
|  |                               (import-paths | ||||||
|  |                                 (apply | ||||||
|  |                                   string-append | ||||||
|  |                                   `("-Dkawa.import.path=" | ||||||
|  |                                     ,@(map (lambda (dir) | ||||||
|  |                                              (string-append dir "/*.sld:")) | ||||||
|  |                                            (append prepend-directories append-directories)) | ||||||
|  |                                     "*.sld"))) | ||||||
|  |                               (class-files | ||||||
|  |                                 (apply | ||||||
|  |                                   string-append | ||||||
|  |                                   (map | ||||||
|  |                                     (lambda (lib) | ||||||
|  |                                       (string-append | ||||||
|  |                                         (string-cut-from-end | ||||||
|  |                                           (search-library-file (append prepend-directories | ||||||
|  |                                                                        append-directories) | ||||||
|  |                                                                lib) | ||||||
|  |                                           4) | ||||||
|  |                                         ".class ")) | ||||||
|  |                                     library-files)))) | ||||||
|  |                           `(,(string-append | ||||||
|  |                                "unzip -d . " kawa-jar-path) | ||||||
|  |                              ,(string-append | ||||||
|  |                                 "echo 'Main-Class: " main-class "\nClass-Path: . " classpath "' > MANIFEST.mf") | ||||||
|  |                              ,(string-append "kawa " import-paths " --main -C " input-file) | ||||||
|  |                              ,(string-append "jar cfm " output-jar " MANIFEST.mf gnu kawa " class-files " " main-class ".class") | ||||||
|  |                              ,(string-append "printf '#!/bin/sh\nMYSELF=$(which \"$0\" 2>/dev/null)\n[ $? -gt 0 -a -f \"$0\" ] && MYSELF=\"./$0\"\njava=java\nif test -n \"$JAVA_HOME\"; then\n java=\"$JAVA_HOME/bin/java\"\nfi\nexec \"$java\" --add-exports=java.base/jdk.internal.foreign.abi=ALL-UNNAMED --add-exports=java.base/jdk.internal.foreign.layout=ALL-UNNAMED --add-exports=java.base/jdk.internal.foreign=ALL-UNNAMED --enable-native-access=ALL-UNNAMED --enable-preview -jar $MYSELF \"$@\"\nexit 1\n' > " output-file) | ||||||
|  |                              ,(string-append "cat " output-jar " >> " output-file) | ||||||
|  |                              ,(string-append "chmod +x " output-file)))))) | ||||||
|         (larceny |         (larceny | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("larceny" |                                `("sh" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "filename=\"$(basename ${0})\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "tmpfile=\"/tmp/larceny.${filename}\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "tail -n+8 \"${0}\" > \"${tmpfile}\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "larceny -nobanner -quiet -utf8 " | ||||||
|  |                                  ,(if r6rs? " -r6 " " -r7 ") | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_LARCENY") |                                  ,(util-getenv "COMPILE_R7RS_LARCENY") | ||||||
|                                  " " |                                  " " | ||||||
|                        "-nobanner" |  | ||||||
|                        " " |  | ||||||
|                        "-quiet" |  | ||||||
|                        " " |  | ||||||
|                        "-utf8" |  | ||||||
|                        " " |  | ||||||
|                        ,(if r6rs? "-r6rs" "-r7rs") |  | ||||||
|                        " " |  | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-I " item " ")) |                                           (string-append "-I " item " ")) | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A " item " ")) |                                           (string-append "-A " item " ")) | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                        " " |                                  " -program \"${tmpfile}\" -- \"$@\"" | ||||||
|                        "-program" |                                  ,(string #\newline) | ||||||
|                        " " |                                  "rm -rf \"${tmpfile}\"" | ||||||
|                        ,input-file))))) |                                  ,(string #\newline) | ||||||
|  |                                  "exit"))))) | ||||||
|         (loko |         (loko | ||||||
|           (type . compiler) |           (type . compiler) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (let ((out (string-cut-from-end input-file 4))) |                         (let ((out (string-cut-from-end input-file 4))) | ||||||
|  |                           `(,(string-append "LOKO_LIBRARY_PATH=" | ||||||
|                                             (apply string-append |                                             (apply string-append | ||||||
|                     `("LOKO_LIBRARY_PATH=" |                                                    (map (lambda (item) | ||||||
|                         ,@(map (lambda (item) |  | ||||||
|                                                           (string-append item ":")) |                                                           (string-append item ":")) | ||||||
|                             prepend-directories) |                                                         prepend-directories)) | ||||||
|                         ,@(map (lambda (item) |                                             (apply string-append | ||||||
|  |                                                    (map (lambda (item) | ||||||
|                                                           (string-append item ":")) |                                                           (string-append item ":")) | ||||||
|                             append-directories) |                                                         append-directories)) | ||||||
|  |                                             " loko " | ||||||
|  |                                             (util-getenv "COMPILE_R7RS_LOKO") | ||||||
|                                             " " |                                             " " | ||||||
|                         "loko " |                                             (if r6rs? "-std=r6rs" "-std=r7rs") | ||||||
|                         " " |  | ||||||
|                         ,(util-getenv "COMPILE_R7RS_LOKO") |  | ||||||
|                         " " |  | ||||||
|                         ,(if r6rs? "-std=r6rs" "-std=r7rs") |  | ||||||
|                                             " " |                                             " " | ||||||
|                                             "--compile" |                                             "--compile" | ||||||
|                                             " " |                                             " " | ||||||
|                         ,input-file |                                             input-file) | ||||||
|                         " " |                              ,(string-append "mv " out " " output-file)))))) | ||||||
|                         "&&" |  | ||||||
|                         " " |  | ||||||
|                         "mv" |  | ||||||
|                     " " |  | ||||||
|                     ,out |  | ||||||
|                     " " |  | ||||||
|                     ,output-file)))))) |  | ||||||
|         (meevax |         (meevax | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("meevax" |                                `("meevax " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_MEEVAX") |                                  ,(util-getenv "COMPILE_R7RS_MEEVAX") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|  | @ -361,15 +381,20 @@ | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A" " " item " ")) |                                           (string-append "-A" " " item " ")) | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                        ,input-file))))) |                                  ))))) | ||||||
|         (mit-scheme |         (mit-scheme | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("mit-scheme" |                                `(,"sh" | ||||||
|                        " " |                                   ,(string #\newline) | ||||||
|                        ,(util-getenv "COMPILE_R7RS_MIT_SCHEME") |                                   "filename=\"$(basename ${0})\"" | ||||||
|                        " " |                                   ,(string #\newline) | ||||||
|  |                                   "tmpfile=\"/tmp/mit-scheme.${filename}\"" | ||||||
|  |                                   ,(string #\newline) | ||||||
|  |                                   "tail -n+8 \"${0}\" > \"${tmpfile}\"" | ||||||
|  |                                   ,(string #\newline) | ||||||
|  |                                   "mit-scheme --batch-mode --no-init-file " | ||||||
|                                   ,@(map |                                   ,@(map | ||||||
|                                       (lambda (item) |                                       (lambda (item) | ||||||
|                                         (string-append "--load " |                                         (string-append "--load " | ||||||
|  | @ -378,39 +403,21 @@ | ||||||
|                                                                             item) |                                                                             item) | ||||||
|                                                        " ")) |                                                        " ")) | ||||||
|                                       library-files) |                                       library-files) | ||||||
|                        " " |                                   " --load \"${tmpfile}\" --eval \"(exit 0)\" --args \"$@\"" | ||||||
|                        "--load" |                                   ,(string #\newline) | ||||||
|                        " " |                                   "rm -rf \"${tmpfile}\"" | ||||||
|                        ,input-file |                                   ,(string #\newline) | ||||||
|                        " " |                                   "exit" | ||||||
|                        "--eval \"(exit 0)\""))))) |                                   ,(string #\newline)))))) | ||||||
|         (mosh |         (mosh | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("mosh" |                                `("mosh " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_MOSH") |                                  ,(util-getenv "COMPILE_R7RS_MOSH") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) (string-append "--loadpath=" item " ")) |                                  ,@(map (lambda (item) (string-append "--loadpath=" item " ")) | ||||||
|                            (append append-directories prepend-directories)) |                                         (append append-directories prepend-directories))))))) | ||||||
|                        ;" " |  | ||||||
|                        ,input-file))))) |  | ||||||
|     (picrin |  | ||||||
|      (type . interpreter) |  | ||||||
|      (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |  | ||||||
|                   (apply string-append |  | ||||||
|                    `("picrin" |  | ||||||
|                        " " |  | ||||||
|                        ,(util-getenv "COMPILE_R7RS_PICRIN") |  | ||||||
|                        " " |  | ||||||
|                        ,@(map (lambda (item) |  | ||||||
|                                (string-append "-l " item " ")) |  | ||||||
|                            library-files) |  | ||||||
|                        " " |  | ||||||
|                        "-e" |  | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (racket |         (racket | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) |           (library-command . ,(lambda (library-file prepend-directories append-directories r6rs?) | ||||||
|  | @ -419,55 +426,27 @@ | ||||||
|                                                                        library-file)) |                                                                        library-file)) | ||||||
|                                        (library-rkt-file (change-file-suffix full-path ".rkt"))) |                                        (library-rkt-file (change-file-suffix full-path ".rkt"))) | ||||||
|                                   (if r6rs? |                                   (if r6rs? | ||||||
|                             (apply string-append |                                     `(,(string-append "plt-r6rs --compile " library-file)) | ||||||
|                              `("plt-r6rs" |                                     `(,(string-append "printf " | ||||||
|                                  " " |  | ||||||
|                                  "--compile" |  | ||||||
|                                  " " |  | ||||||
|                                  ,library-file)) |  | ||||||
|                             (apply string-append |  | ||||||
|                              `("printf" |  | ||||||
|                                  " " |  | ||||||
|                                                       "'#lang r7rs\\n" |                                                       "'#lang r7rs\\n" | ||||||
|                                                       "(import (except (scheme base) let let-values let*-values string-copy string-copy! string-for-each string-map string-fill! string->list))\\n" |                                                       "(import (except (scheme base) let let-values let*-values string-copy string-copy! string-for-each string-map string-fill! string->list))\\n" | ||||||
|                                  "(include \"" |                                                       "(include \"" (path->filename library-file) "\")\\n' > " | ||||||
|                                  ,(path->filename library-file) |                                                       library-rkt-file)))))) | ||||||
|                                  "\")\\n" |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                                  "'" |  | ||||||
|                                  " " |  | ||||||
|                                  ">" |  | ||||||
|                                  " " |  | ||||||
|                                  ,library-rkt-file)))))) |  | ||||||
| (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |  | ||||||
|                         (let ((rkt-input-file (if (string=? input-file "") |                         (let ((rkt-input-file (if (string=? input-file "") | ||||||
|                                                 "" |                                                 "" | ||||||
|                                                 (change-file-suffix input-file ".rkt")))) |                                                 (change-file-suffix input-file ".rkt")))) | ||||||
|               (when (not r6rs?) |  | ||||||
|                (when (not (string=? rkt-input-file "")) |  | ||||||
|                 (when (file-exists? rkt-input-file) |  | ||||||
|                  (delete-file rkt-input-file)) |  | ||||||
|                 (with-output-to-file |  | ||||||
|                  rkt-input-file |  | ||||||
|                  (lambda () |  | ||||||
|                   (display "#lang r7rs") |  | ||||||
|                   (newline) |  | ||||||
|                   (display "(import (except (scheme base) let let-values let*-values string-copy string-copy! string-for-each string-map string-fill! string->list))") |  | ||||||
|                   (newline) |  | ||||||
|                   (display "(include \"") |  | ||||||
|                   (display (path->filename input-file)) |  | ||||||
|                   (display "\")") |  | ||||||
|                   (newline))))) |  | ||||||
|                           (apply string-append |                           (apply string-append | ||||||
|                                  `("racket " |                                  `("racket " | ||||||
|                                    ,(util-getenv "COMPILE_R7RS_RACKET") |                                    ,(util-getenv "COMPILE_R7RS_RACKET") | ||||||
|                                    " " |                                    " " | ||||||
|                    ;"-I " ,(if r6rs? "r6rs " "r7rs ") |  | ||||||
|                                    ,@(map (lambda (item) |                                    ,@(map (lambda (item) | ||||||
|                                             (string-append "-S " item " ")) |                                             (string-append "-S " item " ")) | ||||||
|                                           (append prepend-directories |                                           (append prepend-directories | ||||||
|                                                   append-directories)) |                                                   append-directories)) | ||||||
|                    " " |                                    ,(if r6rs? | ||||||
|                    ,(if r6rs? input-file rkt-input-file))))))) |                                       "" | ||||||
|  |                                       (string-append (string #\newline) "#lang r7rs")))))))) | ||||||
|         (sagittarius |         (sagittarius | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  | @ -480,15 +459,20 @@ | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append " -A " item " ")) |                                           (string-append " -A " item " ")) | ||||||
|                            append-directories) |                                         append-directories)))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (skint |         (skint | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("skint" |                                `("sh" | ||||||
|                        " " |                                  ,(string #\newline) | ||||||
|  |                                  "filename=\"$(basename ${0})\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "tmpfile=\"/tmp/skint.${filename}\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "tail -n+8 \"${0}\" > \"${tmpfile}\"" | ||||||
|  |                                  ,(string #\newline) | ||||||
|  |                                  "skint " | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_SKINT") |                                  ,(util-getenv "COMPILE_R7RS_SKINT") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|  | @ -497,26 +481,17 @@ | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A " item "/ ")) |                                           (string-append "-A " item "/ ")) | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                        " " |                                  " --program=\"${tmpfile}\" \"$@\"" | ||||||
|                        ,input-file))))) |                                  ,(string #\newline) | ||||||
|     (stak |                                  "rm -rf \"${tmpfile}\"" | ||||||
|      (type . interpreter) |                                  ,(string #\newline) | ||||||
|      (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |                                  "exit" | ||||||
|                   (apply string-append |                                  ,(string #\newline)))))) | ||||||
|                    `("stak" |  | ||||||
|                        " " |  | ||||||
|                        ,(util-getenv "COMPILE_R7RS_STAK") |  | ||||||
|                        " " |  | ||||||
|                        ;,@(map (lambda (item) (string-append "-I " item " ")) prepend-directories) |  | ||||||
|                        ;,@(map (lambda (item) (string-append "-A " item " ")) append-directories) |  | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (stklos |         (stklos | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("stklos" |                                `("stklos " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_STKLOS") |                                  ,(util-getenv "COMPILE_R7RS_STKLOS") | ||||||
|                                  " " |                                  " " | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|  | @ -524,9 +499,7 @@ | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "-A " item " ")) |                                           (string-append "-A " item " ")) | ||||||
|                            append-directories) |                                         append-directories)))))) | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (tr7 |         (tr7 | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  | @ -538,12 +511,8 @@ | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append item ":")) |                                           (string-append item ":")) | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                        " " |                                  " tr7i " | ||||||
|                        "tr7i" |                                  ,(util-getenv "COMPILE_R7RS_TR7")))))) | ||||||
|                        " " |  | ||||||
|                        ,(util-getenv "COMPILE_R7RS_TR7") |  | ||||||
|                        " " |  | ||||||
|                        ,input-file))))) |  | ||||||
|         (vicare |         (vicare | ||||||
|           (type . compiler) |           (type . compiler) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|  | @ -560,29 +529,20 @@ | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                                  " " |                                  " " | ||||||
|                                  "--compile-program" |                                  "--compile-program" | ||||||
|                        " " |  | ||||||
|                                  ,input-file))))) |                                  ,input-file))))) | ||||||
|         (ypsilon |         (ypsilon | ||||||
|           (type . interpreter) |           (type . interpreter) | ||||||
|           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) |           (command . ,(lambda (input-file output-file prepend-directories append-directories library-files r6rs?) | ||||||
|                         (apply string-append |                         (apply string-append | ||||||
|                    `("ypsilon" |                                `("ypsilon " | ||||||
|                        " " |  | ||||||
|                                  ,(util-getenv "COMPILE_R7RS_YPSILON") |                                  ,(util-getenv "COMPILE_R7RS_YPSILON") | ||||||
|                        " " |                                  ,(if r6rs? " --r6rs " " --r7rs ") | ||||||
|                        ,(if r6rs? "--r6rs" "--r7rs") |                                  " --mute" | ||||||
|                        " " |                                  " --quiet " | ||||||
|                        "--mute" |  | ||||||
|                        " " |  | ||||||
|                        "--quiet" |  | ||||||
|                        " " |  | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "--sitelib=" item " ")) |                                           (string-append "--sitelib=" item " ")) | ||||||
|                                         prepend-directories) |                                         prepend-directories) | ||||||
|                                  ,@(map (lambda (item) |                                  ,@(map (lambda (item) | ||||||
|                                           (string-append "--sitelib=" item " ")) |                                           (string-append "--sitelib=" item " ")) | ||||||
|                                         append-directories) |                                         append-directories) | ||||||
|                        " " |                                  " --top-level-program"))))))))) | ||||||
|                        "--top-level-program" |  | ||||||
|                        " " |  | ||||||
|                        ,input-file))))))))) |  | ||||||
|  |  | ||||||
|  | @ -0,0 +1,2 @@ | ||||||
|  | #!r6rs | ||||||
|  | (library (foo bar) (export baz) (import (rnrs)) (define baz (lambda () (display "Test successfull ")))) | ||||||
|  | @ -0,0 +1,6 @@ | ||||||
|  | #!r6rs | ||||||
|  | (import (rnrs) | ||||||
|  |         (rnrs programs) | ||||||
|  |         (foo bar)) | ||||||
|  | (baz) | ||||||
|  | (write (list-tail (command-line) 1)) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define baz (lambda () (display "Test successfull "))) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define-library (foo bar) (import (scheme base) (scheme write) (hello world)) (export baz) (include "bar.scm")) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define hello-world (lambda () (+ 1 1))) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define-library (hello world) (import (scheme base) (scheme write)) (export hello-world) (include "world.scm")) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define over-9000 (lambda () (+ 1 1))) | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | (define-library (other hellolib) (import (scheme base) (scheme write)) (export over-9000) (include "hellolib.scm")) | ||||||
|  | @ -0,0 +1,23 @@ | ||||||
|  | (import (scheme base) | ||||||
|  |         (scheme write) | ||||||
|  |         (scheme process-context) | ||||||
|  |         (foo bar) | ||||||
|  |         (hello world) | ||||||
|  |         (other hellolib)) | ||||||
|  | (baz) | ||||||
|  | (hello-world) | ||||||
|  | 
 | ||||||
|  | (define l (list "1" "2" "3")) | ||||||
|  | (cond-expand | ||||||
|  |   ;; Meevax gives too much args | ||||||
|  |   ;; For this test for now this is okay | ||||||
|  |   (meevax (when (> (length (command-line)) 3) (write l))) | ||||||
|  |   ;; mit-scheme gives too much args | ||||||
|  |   ;; For this test for now this is okay | ||||||
|  |   (mit (when (> (length (command-line)) 3) (write l))) | ||||||
|  |   ;; tr7 gives too much args | ||||||
|  |   ;; For this test for now this is okay | ||||||
|  |   (tr7 (when (> (length (command-line)) 3) (write l))) | ||||||
|  |   (else (write (list-tail (command-line) 1)))) | ||||||
|  | 
 | ||||||
|  | (over-9000) | ||||||
		Loading…
	
		Reference in New Issue