gitweb on Svarog
projekti pod git sistemom za održavanje verzija -- projects under the git version control systemdiff --git a/build.xml b/build.xml
--- a/build.xml
+++ b/build.xml
<property name="res.dir" value="res" />
+ <property name="compiler.class.jar" value="lib/mj.jar" />
<property name="compiler.class.dir" value="lib/compiler-bin" />
<property name="compiler.src.dir" value="lib/compiler-src" />
<property name="compiler.classname.compiler" value="MJ.Compiler" />
<target name="init-time">
<tstamp>
- <format property="time" pattern="(yy-MM-dd)-(HH-mm-ss)"/>
+ <format property="time" pattern="yy-MM-dd--HH-mm-ss"/>
</tstamp>
</target>
<fileset dir="${log.dir}"/>
</delete>
</target>
+
+ <!-- version tasks
+ based on ideas by Jesper Öqvist http://llbit.se/?p=1876 -->
+ <!-- this target is only run if the 'version' property is undefined -->
+
+ <target name="update-version-string" unless="version">
+ <!-- get a new version string using git describe if possible -->
+ <echo message="Updating version string..."/>
+ <exec executable="git" outputproperty="version"
+ failifexecutionfails="false">
+ <arg value="describe"/>
+ </exec>
+ <antcall target="-store-version-string"/>
+ <!-- ensure version is defined even if git was not available -->
+ <property file="${res.dir}/version.properties"/>
+ </target>
+ <target name="-store-version-string" if="version">
+ <!-- store the new version string in the correct property file -->
+ <echo message="version=${version}"/>
+ <propertyfile file="${res.dir}/version.properties">
+ <entry key="version" value="${version}"/>
+ </propertyfile>
+ <exec executable="git" failifexecutionfails="false">
+ <arg value="update-index"/>
+ <arg value="--assume-unchanged"/>
+ <arg value="${res.dir}/version.properties"/>
+ </exec>
+ </target>
+
<!-- mjc2wsl related tasks -->
- <target name="build" depends="init" description="build the mjc2wsl tool">
+ <target name="build" depends="init,update-version-string" description="build the mjc2wsl tool">
<javac srcdir="${mjc2wsl.src.dir}" destdir="${mjc2wsl.class.dir}" includeAntRuntime='no' />
</target>
<target name="mjc2wsl">
<echo message="${filename}" />
- <java classpath="${mjc2wsl.class.dir}:${res.dir}" classname="mjc2wsl">
+ <java classpath="${mjc2wsl.class.dir}:${res.dir}" classname="com.quemaster.transformations.mjc2wsl.mjc2wsl">
<arg line="${mjc2wsl.options}" />
<arg value="${filename}" />
</java>
<target name="mj-compile" description="compile a MJ into obj file; given ${filename}">
<echo message="${filename}" />
- <java classpath="${compiler.class.dir}" classname="${compiler.classname.compiler}">
+ <java classpath="${compiler.class.dir}:${compiler.class.jar}" classname="${compiler.classname.compiler}">
<arg value="${filename}" />
</java>
</target>
- <target name="mj-samples" depends="mj-build" description="run the mj compiler on the samples">
+ <target name="mj-samples" description="run the mj compiler on the samples" depends="init">
<foreach param="filename" target="mj-compile">
<path>
<fileset dir='${samples.temp.dir}'>
<target name="mj-decode" description="decode a MJ obj file given in ${filename}">
<echo message="${filename}" />
- <java classpath="${compiler.class.dir}" classname="${compiler.classname.decoder}">
+ <java classpath="${compiler.class.dir}:${compiler.class.jar}" classname="${compiler.classname.decoder}">
<arg value="${filename}" />
</java>
</target>
- <target name="mj-decode-samples" depends="mj-build" description="decode all of the compiled samples and save into file 'decoded.txt'">
+ <target name="mj-decode-samples" description="decode all of the compiled samples and save into file 'decoded.txt'">
<record name="${samples.temp.dir}/decoded.txt" emacsmode="true" loglevel="info"/>
<foreach param="filename" target="mj-decode">
<path>
<target name="mj-run" description="run a MJ obj file given in ${filename} with ${inputstring}">
<echo message="${filename}" />
- <java classpath="${compiler.class.dir}" classname="${compiler.classname.interpreter}" inputstring="${inputstring}">
+ <java classpath="${compiler.class.dir}:${compiler.class.jar}" classname="${compiler.classname.interpreter}" inputstring="${inputstring}">
<arg value="${filename}" />
</java>
</target>
<target name="wsl-run" >
<exec executable="${fermat.dir}/bin/wsl" inputstring="${inputstring}">
- <env key="PATH" path="${env.PATH}:${fermat.dir}/bin"/>
+ <env key="PATH" path="${fermat.dir}/bin:${env.PATH}"/>
<env key="FermaT" path="${fermat.dir}" />
<env key="SCHEME_LIBRARY_PATH" path="${fermat.dir}/slib/" />
- <env key="SCM_INIT_PATH" path="${fermat.dir}/scm/Init5e5.scm" />
+ <env key="SCM_INIT_PATH" path="${fermat.dir}/scm/Init5e7.scm" />
<arg value="${filename}"/>
</exec>
</target>
<antcall target="wsl-run">
<param name="filename" value="${transf.wsl.file}" />
</antcall>
- <record name="${log.file.transformations}${time}" action="stop" />
+ <record name="${log.file.transformations}${time}.txt" action="stop" />
<copy file="${log.file.transformations}${time}.txt" tofile="${log.file.transformations}.txt"/>
</target>
<target name="test-run"
description="run .obj .wsl _t.wsl, given are ${file.dir}, ${file.name} (no extension) and an ${inputstring}">
- <antcall target="mj-run">
+ <record name="${file.dir}/${file.name}.out1" emacsmode="true" />
+ <antcall target="mj-run">
<param name="filename" value="${file.dir}/${file.name}.obj" />
<param name="inputstring" value="${inputstring}" />
</antcall>
+ <record name="${file.dir}/${file.name}.out1" action="stop" />
+ <record name="${file.dir}/${file.name}.out2" emacsmode="true" />
<antcall target="wsl-run">
<param name="filename" value="${file.dir}/${file.name}.wsl" />
<param name="inputstring" value="${inputstring}" />
</antcall>
+ <record name="${file.dir}/${file.name}.out2" action="stop" />
+ <record name="${file.dir}/${file.name}.out3" emacsmode="true" />
<antcall target="wsl-run">
<param name="filename" value="${file.dir}/${file.name}_t.wsl" />
<param name="inputstring" value="${inputstring}" />
</antcall>
+ <record name="${file.dir}/${file.name}.out3" action="stop" />
</target>
<target name="test-run-samples-dir"
<param name="file.dir" value="${samples.temp.dir}"/>
</antcall>
</target>
-
+
+ <!-- output serveral versions of files -->
+
+ <target name="output-all-versions"
+ description="generate variations on the translations in the 'local' folder and tar them">
+ <antcall>
+ <target name="mj-samples"/>
+ <target name="mjc2wsl-samples"/>
+ <param name="samples.temp.dir" value="local/out/headTail-proc"/>
+ <param name="mjc2wsl.options" value=""/>
+ </antcall>
+ <antcall>
+ <target name="mj-samples"/>
+ <target name="mjc2wsl-samples"/>
+ <param name="samples.temp.dir" value="local/out/headTail-inline"/>
+ <param name="mjc2wsl.options" value="--genInlinePrint"/>
+ </antcall>
+ <antcall>
+ <target name="mj-samples"/>
+ <target name="mjc2wsl-samples"/>
+ <param name="samples.temp.dir" value="local/out/popPush-inline"/>
+ <param name="mjc2wsl.options" value="--genPopPush --genInlinePrint"/>
+ </antcall>
+ <antcall>
+ <target name="mj-samples"/>
+ <target name="mjc2wsl-samples"/>
+ <param name="samples.temp.dir" value="local/out/popPush-proc"/>
+ <param name="mjc2wsl.options" value="--genPopPush"/>
+ </antcall>
+ <antcall>
+ <target name="mj-samples"/>
+ <target name="mjc2wsl-samples"/>
+ <param name="samples.temp.dir" value="local/out/popPush-glob"/>
+ <param name="mjc2wsl.options" value="--genPopPush --genGlobalVars"/>
+ </antcall>
+ <tar basedir="local/out" compression="gzip"
+ destfile="local/mjc2wsl-samples.tgz"
+ includes="*/*.wsl"/>
+ </target>
+
<!-- jedit specific flags; needs to be the first or the last 10 lines
:noTabs=true:
-->