diff options
author | Gilles Dubochet <gilles.dubochet@epfl.ch> | 2008-05-09 15:47:25 +0000 |
---|---|---|
committer | Gilles Dubochet <gilles.dubochet@epfl.ch> | 2008-05-09 15:47:25 +0000 |
commit | f02cc551dcd5228ebb463be80c63c796c6f4a8cc (patch) | |
tree | 02f86a93446408c9ebb697c08c68d93fb60baec9 /src/build | |
parent | 4d07c3dac6fee9afa1c3eb3ab246c339a703f740 (diff) | |
download | scala-f02cc551dcd5228ebb463be80c63c796c6f4a8cc.tar.gz scala-f02cc551dcd5228ebb463be80c63c796c6f4a8cc.tar.bz2 scala-f02cc551dcd5228ebb463be80c63c796c6f4a8cc.zip |
Added “fourfour” targets to SuperSabbus for tes...
Added “fourfour” targets to SuperSabbus for testing JVM 1.4 builds
with a 1.4 JVM. Removed obsolete build files.
Diffstat (limited to 'src/build')
-rw-r--r-- | src/build/addcolon.awk | 13 | ||||
-rw-r--r-- | src/build/build-android.xml | 195 | ||||
-rw-r--r-- | src/build/build-cldc.xml | 249 | ||||
-rw-r--r-- | src/build/build-imports.xml | 589 | ||||
-rw-r--r-- | src/build/build-jvm14.xml | 346 | ||||
-rw-r--r-- | src/build/build-jvm15.xml | 302 | ||||
-rw-r--r-- | src/build/build-msil.xml | 198 | ||||
-rw-r--r-- | src/build/four.xml | 43 | ||||
-rw-r--r-- | src/build/old_sabbus.xml | 2012 |
9 files changed, 2053 insertions, 1894 deletions
diff --git a/src/build/addcolon.awk b/src/build/addcolon.awk deleted file mode 100644 index be25fde6f1..0000000000 --- a/src/build/addcolon.awk +++ /dev/null @@ -1,13 +0,0 @@ -#!/bin/awk -f -# -# buraq: this awk script was used to add a colon to .neg files in test suite. -# though it might be useful to have it somewhere for non-awk users as a reference. -# -{ i = match ($0, /scala:[0-9]+/); - if(i == 0) { - print $0 - } else { - sub(/scala:[0-9]+/, "&:") - print $0 - } -} diff --git a/src/build/build-android.xml b/src/build/build-android.xml deleted file mode 100644 index 25d24c1186..0000000000 --- a/src/build/build-android.xml +++ /dev/null @@ -1,195 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="scala-android" basedir="../.." default="build"> - -<!-- =========================================================================== -PROPERTIES -============================================================================ --> - - <import file="build-jvm15.xml"/> - - <!-- Loads custom properties definitions --> - <property file="${basedir}/scripts/build-android.properties"/> - - <!-- Sets location of build folders --> - <property name="build.dir" value="${basedir}/build"/> - <property name="android.dir" value="${build.dir}/android"/> - <property name="dist.dir" value="${basedir}/dists"/> - -<!-- =========================================================================== -SETUP -============================================================================ --> - - <target name="android.init" depends="init"> - <condition property="android.home" value="${unix.android.home}"> - <and><os family="unix"/><isset property="unix.android.home"/></and> - </condition> - <condition property="android.home" value="${win.android.home}"> - <and><os family="windows"/><isset property="win.android.home"/></and> - </condition> - <property name="android.home" value="${env.ANDROID_HOME}"/> - - <fail message="Android home is not set or could not find android.jar in ${android.home}"> - <condition><not><and> - <available file="${android.home}/android.jar"/> - <available file="${android.home}/tools/lib/dx.jar"/> - </and></not></condition> - </fail> - <property name="android.jar" value="${android.home}/android.jar"/> - <property name="tools.lib.dir" value="${android.home}/tools/lib"/> - <property name="dx.jar" value="${tools.lib.dir}/dx.jar"/> - <property file="${number.file}"/> - <property - name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> - <echo level="verbose" message="${version.number}"/> - </target> - - <target name="android.sources" depends="android.init" - description="Create the source directory for Android library" - > - <mkdir dir="${android.dir}/src"/> - <copy todir="${android.dir}/src"> - <fileset dir="${src.dir}/library" - includes="**/*.scala, **/*.java" - excludes="scala/reflect/ScalaBeanInfo.scala"> - <not> - <present targetdir="${src.dir}/android-library"/> - </not> - </fileset> - </copy> - - <copy todir="${android.dir}/src"> - <fileset dir="${src.dir}/android-library"> - <include name="**/*.scala"/> - <include name="**/*.java"/> - </fileset> - </copy> - </target> - - <target name="android.libraries" depends="android.sources" - description="Builds the Scala library for Android"> - <antcall target="build.quick"/> - <property name="quick.dir" value="${build.dir}/quick"/> - <path id="quick.classpath"> - <pathelement location="${quick.dir}/lib/library"/> - <pathelement location="${quick.dir}/lib/compiler"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - </path> - <taskdef - name="quick" classname="scala.tools.ant.Scalac" - classpathref="quick.classpath"/> - <mkdir dir="${android.dir}/lib/library"/> - <javac - srcdir="${android.dir}/src" - destdir="${android.dir}/lib/library" - deprecation="${jc.deprecation}" - > - <bootclasspath> - <pathelement location="${android.jar}"/> - </bootclasspath> - <include name="**/*.java"/> - </javac> - - <quick - srcdir="${android.dir}/src" - destdir="${android.dir}/lib/library" - usepredefs="no" - deprecation="yes" unchecked="yes" - addparams="${nsc.params}" - extdirs="" - scalacdebugging="${nsc.log-files}" - > - <bootclasspath> - <pathelement location="${android.jar}"/> - </bootclasspath> - <include name="scala/Predef.scala"/> - </quick> - - <quick - srcdir="${android.dir}/src" - destdir="${android.dir}/lib/library" - deprecation="yes" unchecked="yes" - extdirs="" - addparams="${nsc.params}" - scalacdebugging="${nsc.log-files}" - > - <bootclasspath> - <pathelement location="${android.jar}"/> - </bootclasspath> - <classpath> - <pathelement location="${android.dir}"/> - </classpath> - <include name="**/*.scala"/> - <exclude name="scala/Predef.scala"/> - <excludesfile name="${nsc.excludes}" if="excludes.avail"/> - </quick> - </target> - - <target name="android.build" depends="android.libraries" - description="Convert this project's .class files into .dex files"> - <java jar="${dx.jar}" fork="true" failonerror="true"> - <jvmarg value="-Djava.ext.dirs=${tools.lib.dir}"/> - <jvmarg value="-Xmx384M"/> - <arg value="--dex"/> - <arg value="--output=${android.dir}/lib/scala.dex"/> - <arg value="--locals=full"/> - <arg value="--positions=lines"/> - <arg value="${android.dir}/lib/library"/> - </java> - <jar - destfile="${android.dir}/lib/scala-dex.jar" - basedir="${android.dir}/lib" - includes="scala.dex" - /> - <jar - destfile="${android.dir}/lib/scala-android.jar" - basedir="${android.dir}/lib/library" - includes="scala/**/*.class" - /> - </target> - - <target name="android.dist" depends="android.build"> - <antcall target="binaries"/> - <property name="dist.current.dir" value="${dist.dir}/scala-android-${version.number}"/> - <mkdir dir="${dist.current.dir}"/> -<!-- - <copy todir="${dist.current.dir}/bin"> - <fileset dir="${dist.dir}/latest/bin"/> - </copy> - <chmod perm="ugo+rx" dir="${dist.current.dir}/bin"/> - <copy todir="${dist.current.dir}/lib"> - <fileset dir="${lib.dir}" includes="cldc*.jar,midp*.jar"/> - </copy> ---> - <!-- Recreate the 'latest' link to point to this distribution --> - <if><isset property="os.win"/> - <then> - <copy todir="${dist.dir}/latest-android"> - <fileset dir="${dist.current.dir}"/> - </copy> - </then> - <else> - <symlink - link="${dist.dir}/latest-android" - resource="${dist.current.dir}" - overwrite="yes" failonerror="no"/> - </else> - </if> - </target> - -<!-- =========================================================================== -CLEAN -============================================================================ --> - - <target name="android.clean" depends="ant-init"> - <remove dir="${build.dir}/android"/> - <delete includeemptydirs="true" quiet="yes" failonerror="no"> - <fileset dir="@{dist.dir}" includes="**/scala-android*"/> - </delete> - <delete file="${dist.dir}/latest-android" quiet="yes" failonerror="no"/> - </target> - -</project> diff --git a/src/build/build-cldc.xml b/src/build/build-cldc.xml deleted file mode 100644 index 7f9964af57..0000000000 --- a/src/build/build-cldc.xml +++ /dev/null @@ -1,249 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="scala-cldc" basedir="../.." default="build"> - -<!-- =========================================================================== -PROPERTIES -============================================================================ --> - - <import file="build-jvm14.xml"/> - - <!-- Loads custom properties definitions --> - <property file="${scripts.dir}/scripts/build-cldc.properties"/> - - <!-- Sets location of build folders --> - <property name="build.dir" value="${basedir}/build"/> - <property name="cldc.dir" value="${build.dir}/cldc"/> - <property name="dist.dir" value="${basedir}/dists"/> - - <property name="cldcapi.jar" value="${lib.dir}/cldcapi10.jar"/> - <property name="midpapi.jar" value="${lib.dir}/midpapi10.jar"/> - -<!-- =========================================================================== -SETUP -============================================================================ --> - - <target name="cldc.init" depends="init"> - <!-- Sets preverify command (Java WTK) --> - <condition property="preverify.cmd" value="${unix.wtk.home}/bin/preverify"> - <and> - <os family="unix"/><isset property="unix.wtk.home"/> - <available file="${unix.wtk.home}/bin/preverify"/> - </and> - </condition> - <condition property="preverify.cmd" value="${win.wtk.home}/preverify"> - <and> - <os family="windows"/><isset property="win.wtk.home"/> - <available file="${win.wtk.home}/bin/preverify.exe"/> - </and> - </condition> - <echo level="verbose" message="Found: ${preverify.cmd}"/> - <condition property="preverify.cmd" value="preverify"> - <and><available file="preverify" filepath="${env.PATH}"/></and> - </condition> - <fail message="Command 'preverify' not found"> - <condition><not><isset property="preverify.cmd"/></not></condition> - </fail> - <property file="${number.file}"/> - <property - name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> - <echo level="verbose" message="${version.number}"/> - </target> - - <target name="cldc.sources" depends="cldc.init" - description="Create the source directory for the J2ME (CLDC) library" - > - <mkdir dir="${cldc.dir}/src"/> - - <copy todir="${cldc.dir}/src"> - <fileset dir="${src.dir}/library" includes="**/*.scala, **/*.java"> - <not> - <present targetdir="${src.dir}/cldc-library"/> - </not> - <exclude name="**/jcl/**"/> - <exclude name="**/ref/**"/> - <exclude name="**/compat/**"/> - <exclude name="**/concurrent/**"/> - <exclude name="**/runtime/RichFloat.scala"/> - <exclude name="**/runtime/RichDouble.scala"/> - <exclude name="**/util/**"/> - <exclude name="**/xml/**"/> - </fileset> - </copy> - - <copy todir="${cldc.dir}/src"> - <fileset dir="${src.dir}/cldc-library"> - <include name="**/*.scala"/> - <include name="**/*.java"/> - </fileset> - </copy> - - </target> - - <target name="cldc.libraries" depends="cldc.sources" - description="Builds the Scala library for J2ME (CLDC)" - > - <antcall target="build.quick"/> - <mkdir dir="${cldc.dir}/lib/library"/> - <!-- javac versions > 1.4 do not support 1.1 target anymore --> - <javac - srcdir="${cldc.dir}/src" - destdir="${cldc.dir}/lib/library" - compiler="javac1.4" - source="1.1" - target="1.1" - deprecation="${jc.deprecation}" - > - <bootclasspath> - <pathelement location="${cldcapi.jar}"/> - </bootclasspath> - <include name="**/*.java"/> - <exclude name="scala/runtime/FloatRef.java"/> - <exclude name="scala/runtime/DoubleRef.java"/> - </javac> - <property name="quick.dir" value="${build.dir}/quick"/> - <path id="quick.classpath"> - <pathelement location="${quick.dir}/lib/library"/> - <pathelement location="${quick.dir}/lib/compiler"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - </path> - <taskdef - name="quick" classname="scala.tools.ant.Scalac" - classpathref="quick.classpath"/> - <quick - srcdir="${cldc.dir}/src" - destdir="${cldc.dir}/lib/library" - usepredefs="no" - addparams="${nsc.params}" - target="cldc" - scalacdebugging="${nsc.log-files}" - > - <bootclasspath> - <pathelement location="${cldcapi.jar}"/> - </bootclasspath> - <classpath> - <pathelement location="${cldc.dir}"/> - </classpath> - <include name="scala/Predef.scala"/> - </quick> - <quick - srcdir="${cldc.dir}/src" - destdir="${cldc.dir}/lib/library" - target="cldc" - addparams="${nsc.params}" - scalacdebugging="${nsc.log-files}" - > - <bootclasspath> - <pathelement location="${cldcapi.jar}"/> - </bootclasspath> - <classpath> - <pathelement location="${cldc.dir}"/> - </classpath> - <include name="**/*.scala"/> - <exclude name="scala/Predef.scala"/> - <exclude name="scala/BigDecimal.scala"/> - <exclude name="scala/BigInt.scala"/> - <exclude name="scala/collection/mutable/JavaMapAdaptor.scala"/> - <exclude name="scala/collection/mutable/JavaSetAdaptor.scala"/> - <exclude name="scala/collection/mutable/LinkedHashSet.scala"/> - <exclude name="scala/util/Fluid.scala"/> - <exclude name="scala/runtime/BoxedFloatArray.scala"/> - <exclude name="scala/runtime/BoxedDoubleArray.scala"/> - <exclude name="scala/io/**"/> - <exclude name="scala/mobile/**"/> - <exclude name="scala/reflect/**"/> - <exclude name="scala/text/**"/> - <exclude name="scala/testing/**"/> - <exclude name="scala/xml/**"/> - <excludesfile name="${nsc.excludes}" if="excludes.avail"/> - </quick> - <macrodef name="preverify"> - <attribute name="srcdir"/> - <attribute name="destdir"/> - <sequential> - <exec executable="${preverify.cmd}" failonerror="false"> - <arg line="-classpath ${cldcapi.jar}${path.separator}${midpapi.jar}"/> - <arg line="-target cldc1.0"/> - <arg line="-d @{destdir}"/> - <arg value="@{srcdir}"/> - </exec> - </sequential> - </macrodef> - <mkdir dir="${cldc.dir}/lib/preverified"/> - <preverify - srcdir="${cldc.dir}/lib/library" - destdir="${cldc.dir}/lib/preverified" - /> - <jar - destfile="${cldc.dir}/lib/scalaapi10-unverified.jar" - basedir="${cldc.dir}/lib/library" - includes="scala/**/*.class"> - <manifest> - <attribute name="Created-By" value="${version.number} (${vendor.name})"/> - </manifest> - </jar> - <!-- see http://java.sun.com/j2me/docs/uei_specs.pdf --> - <jar - destfile="${cldc.dir}/lib/scalaapi10.jar" - basedir="${cldc.dir}/lib/preverified" - includes="scala/**/*.class"> - <manifest> - <attribute name="Created-By" value="${version.number} (${vendor.name})"/> - <attribute name="API-Specification-Version" value="1.0"/> - <attribute name="API" value="Scala CLDC"/> - <attribute name="API-Name" value="Scala Connected Limited Device Configuration"/> - <attribute name="API-Type" value="Configuration"/> - </manifest> - </jar> - </target> - - <target name="cldc.build" depends="cldc.libraries"> - <!-- exemples ? --> - </target> - - <target name="cldc.dist" depends="cldc.build"> - <antcall target="binaries"/> - <property name="dist.current.dir" value="${dist.dir}/scala-cldc-${version.number}"/> - <mkdir dir="${dist.current.dir}"/> - <copy todir="${dist.current.dir}/bin"> - <fileset dir="${dist.dir}/latest-jvm14/bin"/> - </copy> - <chmod perm="ugo+rx" dir="${dist.current.dir}/bin"/> - <copy todir="${dist.current.dir}/lib"> - <fileset dir="${lib.dir}" includes="cldc*.jar,midp*.jar"/> - </copy> - <copy todir="${dist.current.dir}/lib"> - <fileset dir="${dist.dir}/latest-jvm14/lib" includes="scala*.jar"/> - </copy> - <!-- Recreate the 'latest' link to point to this distribution --> - <if><isset property="os.win"/> - <then> - <copy todir="${dist.dir}/latest-cldc"> - <fileset dir="${dist.current.dir}"/> - </copy> - </then> - <else> - <symlink - link="${dist.dir}/latest-cldc" - resource="${dist.current.dir}" - overwrite="yes" failonerror="no"/> - </else> - </if> - </target> - -<!-- =========================================================================== -CLEAN -============================================================================ --> - - <target name="cldc.clean" depends="ant-init"> - <remove dir="${build.dir}/cldc"/> - <delete includeemptydirs="true" quiet="yes" failonerror="no"> - <fileset dir="@{dist.dir}" includes="**/scala-cldc*"/> - </delete> - <delete file="${dist.dir}/latest-cldc" quiet="yes" failonerror="no"/> - </target> - -</project> diff --git a/src/build/build-imports.xml b/src/build/build-imports.xml deleted file mode 100644 index 9009967a33..0000000000 --- a/src/build/build-imports.xml +++ /dev/null @@ -1,589 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="build-imports" basedir="../.." default="."> - - <property environment="env"/> - - <!-- Prevents system classpath from being used --> - <property name="build.sysclasspath" value="ignore"/> - - <!-- Defines the repository layout --> - <property name="lib.dir" value="${basedir}/lib"/> - <property name="src.dir" value="${basedir}/src"/> - <property name="test.dir" value="${basedir}/test"/> - <property name="docs.dir" value="${basedir}/docs"/> - <property name="scripts.dir" value="${src.dir}/build"/> - - <!-- Loads custom properties definitions --> - <property file="${scripts.dir}/build-imports.properties"/> - - <!-- Defines the product being built --> - <property name="vendor.name" value="LAMP/EPFL"/> - <property name="copyright.string" value="(c) 2002-2008 ${vendor.name}"/> - <property name="java.flags" value="-Xmx768M -Xms16M"/> - <property name="number.file" value="${basedir}/build.number"/> - - <!-- Sets location of pre-compiled libraries --> - <property name="lib.starr.jar" value="${lib.dir}/scala-library.jar"/> - <property name="comp.starr.jar" value="${lib.dir}/scala-compiler.jar"/> - <property name="fjbg.jar" value="${lib.dir}/fjbg.jar"/> - <property name="msil.jar" value="${lib.dir}/msil.jar"/> - <property name="jline.jar" value="${lib.dir}/jline.jar"/> - <property name="ant.jar" value="${ant.home}/lib/ant.jar"/> - <property name="ant-contrib.jar" value="${lib.dir}/ant-contrib.jar"/> - - <property name="lib.jar.name" value="scala-library.jar"/> - <property name="dbc.jar.name" value="scala-dbc.jar"/> - <property name="comp.jar.name" value="scala-compiler.jar"/> - <property name="partest.jar.name" value="scala-partest.jar"/> - <property name="libsrc.jar.name" value="scala-library-src.jar"/> - <property name="dbcsrc.jar.name" value="scala-dbc-src.jar"/> - <property name="parsrc.jar.name" value="scala-partest-src.jar"/> - <property name="compsrc.jar.name" value="scala-compiler-src.jar"/> - <property name="scala.exec.name" value="scala"/> - <property name="scalac.exec.name" value="scalac"/> - <property name="scaladoc.exec.name" value="scaladoc"/> - <property name="fsc.exec.name" value="fsc"/> - <property name="comp.prop.name" value="compiler.properties"/> - <property name="lib.prop.name" value="library.properties"/> - <property name="par.prop.name" value="partest.properties"/> - - <!-- if available, faster stability checking --> - <property name="stability.tool" value="/home/linuxsoft/apps/stability/stability"/> - -<!-- =========================================================================== -ANT INITIALISATION -============================================================================ --> - - <target name="ant-init" unless="ant-init.avail"> - <!-- Making sure lib/ contains everything that is needed --> - <fail message="A required library is missing in 'lib/'. The README file describes what should be there."> - <condition><not><and> - <available file="${lib.starr.jar}"/> - <available file="${comp.starr.jar}"/> - <available file="${fjbg.jar}"/> - <available file="${msil.jar}"/> - <available file="${jline.jar}"/> - <available file="${ant-contrib.jar}"/> - </and></not></condition> - </fail> - <!-- Setting-up Ant contrib tasks --> - <taskdef resource="net/sf/antcontrib/antlib.xml" - classpath="${ant-contrib.jar}"/> - <fail message="External library ${ant-contrib.jar} requires the optional Ant tasks to be installed"> - <condition><not><and> - <available file="${ant.home}/lib/ant-nodeps.jar"/> - </and></not></condition> - </fail> - <property name="ant-init.avail" value="yes"/> - </target> - -<!-- =========================================================================== -INITIALISATION -============================================================================ --> - - <target name="init" depends="ant-init" unless="init.avail"> - <!-- Making sure enough memory is available --> - <propertyregex - property="memory.set" input="${env.ANT_OPTS}" select="\1" - regexp="-Xmx([1-9][0-9]{3,}|[6-9][0-9]{2}|5[2-9][0-9]|51[2-9])(M|m)"/> - <fail - unless="memory.set" - message="SABBUS requires additional memory. Please set the 'ANT_OPTS' environment property to '-Xmx512M' or more."/> - <propertyregex - property="memory.info" input="${env.ANT_OPTS}" defaultValue="" - select=" (raise to 600 MB for performance)" - regexp="-Xmx([1-5][0-9]{2})(M|m)"/> - <!-- This is the start time for the distribution --> - <stopwatch name="timer.dist"/> - <tstamp prefix="time"> - <format property="human" pattern="EEEE, d MMMM yyyy, HH:mm:ss (zz)"/> - <format property="short" pattern="yyyyMMddHHmmss"/> - </tstamp> - <!-- Finding out what system architecture is being used --> - <condition property="os.win"><os family="windows"/></condition> - <if><isset property="os.win"/><then> - <exec - executable="cygpath" vmlauncher="no" - errorproperty="cygpath.err" outputproperty="cygpath.out"> - <arg value="--windir"/> - </exec> - <condition property="os.cygwin"> - <equals arg1="${cygpath.err}" arg2=""/> - </condition> - </then></if> - <condition property="os.unix"><or> - <os family="unix"/> - <os family="mac"/> - <isset property="os.cygwin"/> - </or></condition> - <if><isset property="os.cygwin"/> - <then><property name="os.type" value="Cygwin"/></then> - <elseif><isset property="os.win"/> - <then><property name="os.type" value="Windows"/></then> - </elseif> - <elseif><isset property="os.unix"/> - <then><property name="os.type" value="UNIX"/></then> - </elseif> - <else><fail>System environment could not be determined</fail></else> - </if> - <!-- Finding out SVN revision --> - <exec - executable="svn" vmlauncher="no" - errorproperty="svn.err" outputproperty="svn.out"> - <arg line=" info ${basedir}"/> - </exec> - <propertyregex - property="svn.number" input="${svn.out}" select="\1" - regexp="Revision: ([0-9]+)" - defaultValue="x"/> - <property name="init.avail" value="yes"/> - <!-- Printing out some information about what environment I am running in --> - <echo level="info" - message="OS: ${os.type} (${os.name} ${os.arch} ${os.version});"/> - <echo level="info" - message="Java: ${java.vm.name} ${java.vm.version} ('${java.home}');"/> - <echo level="info" - message="Memory: ${memory.set} MB${memory.info};"/> - <echo level="info" - message="Ant: ${ant.version}."/> - </target> - -<!-- =========================================================================== -DIST -============================================================================ --> - - <target name="dist.devel" depends="init"> - <property file="${number.file}"/> - <property name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}"/> - <runtarget target="pack"/> - </target> - - <target name="dist.patch" depends="init"> - <property file="${number.file}"/> - <property name="version.number" - value="${version.major}.${version.minor}.${version.patch}.${version.suffix}"/> - <runtarget target="pack"/> - </target> - - <target name="dist.minor" depends="init"> - <property file="${number.file}"/> - <property name="version.number" - value="${version.major}.${version.minor}.${version.patch}.${version.suffix}"/> - <runtarget target="pack"/> - </target> - - <target name="pack" - depends="build.archive" - description="Packs a distribution for SBaz and ZIP/TAR"/> - - <target name="build.dist" depends="binaries" - description="Creates the latest Scala distribution"> - <!-- Copy the API, examples and man --> - <copy todir="${dist.current.dir}/doc/scala"> - <fileset dir="${docs.dir}" includes="README,LICENSE"/> - </copy> - <!-- - <copy todir="${dist.current.dir}/doc/scala/api"> - <fileset dir="${api-lib.dir}"/> - </copy> - --> - <copy todir="${dist.current.dir}/doc/scala/examples"> - <fileset dir="${docs.dir}/examples"/> - </copy> - <!-- - <copy todir="${dist.current.dir}/man/man1"> - <fileset dir="${tooldocs.dir}" includes="**/*.1"/> - </copy> - <copy todir="${dist.current.dir}/doc/scala/tools"> - <fileset dir="${tooldocs.dir}"> - <include name="**/*.html"/> - <include name="**/*.css"/> - <include name="**/*.gif"/> - <include name="**/*.png"/> - </fileset> - </copy> - --> - <stopwatch name="timer.dist" action="total"/> - </target> - - <target name="build.archive" depends="build.dist"> - <tar - destfile="${dist.dir}/scala-${version.number}.tgz" - compression="gzip"> - <tarfileset - prefix="scala-${version.number}" - dir="${dist.current.dir}" - includes="bin/**" mode="755" - /> - <tarfileset - prefix="scala-${version.number}" - dir="${dist.current.dir}" - excludes="bin/**" - /> - </tar> - <checksum - file="${dist.dir}/scala-${version.number}.tgz" - forceOverwrite="yes" - fileext=".md5"/> - <!-- Create zip archive --> - <zip - destfile="${dist.dir}/scala-${version.number}.zip"> - <zipfileset - prefix="scala-${version.number}" - dir="${dist.current.dir}" - /> - </zip> - <checksum - file="${dist.dir}/scala-${version.number}.zip" - forceOverwrite="yes" - fileext=".md5"/> - <!-- Create source archive --> - <copy todir="${dist.dir}/scala-${version.number}"> - <fileset - dir="${basedir}" - excludes="build,build/**,dists/**" - /> - </copy> - <tar basedir="${dist.dir}" - destfile="${dist.dir}/scala-${version.number}-sources.tgz" - compression="gzip" - includes="scala-${version.number}/**" - /> - </target> - -<!-- =========================================================================== -TEST -============================================================================ --> - - <target name="test" depends="test.stability" - description="Tests the build for stability"/> - - <!-- Compares quick and test level --> - <target name="test.stability" depends="build.strap"> - <if><available file="${stability.tool}"/> - <then> <!-- use stability tool for fast checking --> - <exec executable="${stability.tool}" failonerror="true"> - <arg value="${quick.dir}"/> - <arg value="${strap.dir}"/> - </exec> - </then><else> <!-- check stability the slow way --> - <checksum totalproperty="quick.md5"> - <fileset dir="${quick.dir}/lib"> - <include name="library/**"/> - <include name="compiler/**"/> - </fileset> - </checksum> - <delete quiet="yes" failonerror="no"> - <fileset dir="${quick.dir}" includes="**/*.MD5"/> - </delete> - <checksum totalproperty="strap.md5"> - <fileset dir="${strap.dir}/lib"> - <include name="library/**"/> - <include name="compiler/**"/> - </fileset> - </checksum> - <delete quiet="yes" failonerror="no"> - <fileset dir="${strap.dir}" includes="**/*.MD5"/> - </delete> - <fail message="Build ${version.number} is not stable"> - <condition><not> - <equals arg1="${quick.md5}" arg2="${strap.md5}"/> - </not></condition> - </fail> - <echo level="info" message="Build ${version.number} is stable."/> - </else></if> - </target> - -<!-- =========================================================================== -CLEAN -============================================================================ --> - - <macrodef name="remove"> - <attribute name="dir"/> - <sequential> - <if> - <available file="@{dir}/is_symlink"/> - <then> - <delete includeemptydirs="true" quiet="yes" failonerror="no"> - <fileset dir="@{dir}" includes="**/*"/> - </delete> - </then></if> - <delete dir="@{dir}" includeemptydirs="yes" quiet="yes" failonerror="no"/> - </sequential> - </macrodef> - - <target name="clean" depends="ant-init" description="Removes QUICK, STRAP and API build products"> - <remove dir="${quick.dir}"/> - <remove dir="${strap.dir}"/> - <remove dir="${api.dir}"/> - </target> - - <target name="clean.build" depends="ant-init" - description="Removes all build products"> - <remove dir="${build.dir}"/> - </target> - - <target name="clean.all" depends="ant-init" - description="Removes all build products and distributions"> - <remove dir="${build.dir}"/> - <remove dir="${dist.dir}"/> - </target> - - <target name="clean.unfreeze" depends="init"> - <delete file="${locker.dir}/complete" quiet="yes" failonerror="no"/> - <remove dir="${quick.dir}"/> - </target> - -<!-- =========================================================================== -MACROS -============================================================================ --> - - <macrodef name="build.support"> - <attribute name="outputdir"/> - <sequential> - <copy todir="@{outputdir}/lib/library"> - <fileset dir="${src.dir}/library"> - <include name="**/*.tmpl"/> - <include name="**/*.xml"/> - <include name="**/*.js"/> - <include name="**/*.css"/> - </fileset> - </copy> - <copy todir="@{outputdir}/lib/compiler"> - <fileset dir="${src.dir}/compiler"> - <include name="**/*.tmpl"/> - <include name="**/*.xml"/> - <include name="**/*.js"/> - <include name="**/*.css"/> - </fileset> - </copy> - </sequential> - </macrodef> - - <macrodef name="buildlayer"> - <attribute name="name"/> - <attribute name="libpath"/> - <attribute name="comppath"/> - <attribute name="outputdir"/> - <attribute name="buildall" default=""/> - <sequential> - <property name="built.@{name}" value="yes"/> - <stopwatch name="timer.@{name}"/> - <!-- Create layer-specific task 'scalac' --> - <path id="starr.classpath"> - <pathelement location="@{libpath}"/> - <pathelement location="@{comppath}"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - <pathelement location="${jline.jar}"/> - <pathelement location="${ant.jar}"/> - </path> - <taskdef - name="scalac" - classname="scala.tools.ant.Scalac" - classpathref="starr.classpath" - /> - <!-- Build library --> - <mkdir dir="@{outputdir}/lib/library"/> - <javac - srcdir="${src.dir}/library" - destdir="@{outputdir}/lib/library" - source="1.4" target="1.4" deprecation="yes" - classpath="@{outputdir}/lib/library" - includes="**/*.java"/> - <scalac - srcdir="${src.dir}/library" - destdir="@{outputdir}/lib/library" - usepredefs="no" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes" - classpath="@{outputdir}/lib/library" - includes="scala/Predef.scala"/> - <scalac - srcdir="${src.dir}/library" - destdir="@{outputdir}/lib/library" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes" - classpath="@{outputdir}/lib/library"> - <include name="**/*.scala"/> - <exclude name="scala/Predef.scala"/> - <exclude name="scala/dbc/**"/> - <exclude name="scala/actors/**"/> - <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> - </scalac> - <echo - file="@{outputdir}/lib/library/${lib.prop.name}" - message="version.number=${version.number}${line.separator}" - append="false" - /> - <echo - file="@{outputdir}/lib/library/${lib.prop.name}" - message="copyright.string=${copyright.string}${line.separator}" - append="true" - /> - <!-- Build compiler --> - <mkdir dir="@{outputdir}/lib/compiler"/> - <scalac - srcdir="${src.dir}/compiler" - destdir="@{outputdir}/lib/compiler" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes"> - <classpath> - <pathelement location="@{outputdir}/lib/library"/> - <pathelement location="@{outputdir}/lib/compiler"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - <pathelement location="${jline.jar}"/> - <pathelement location="${ant.jar}"/> - </classpath> - <include name="**/*.scala"/> - <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> - </scalac> - <echo - file="@{outputdir}/lib/compiler/${comp.prop.name}" - message="version.number=${version.number}${line.separator}" - append="false" - /> - <echo - file="@{outputdir}/lib/compiler/${comp.prop.name}" - message="copyright.string=${copyright.string}${line.separator}" - append="true" - /> - <if> - <length string="@{buildall}" when="greater" length="0"/> - <then> - <!-- Build DBC library --> - <mkdir dir="@{outputdir}/lib/dbc"/> - <scalac - srcdir="${src.dir}/dbc" - destdir="@{outputdir}/lib/dbc" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes" - scalacdebugging="${nsc.log-files}"> - <classpath> - <pathelement location="@{outputdir}/lib/library"/> - <pathelement location="@{outputdir}/lib/dbc"/> - </classpath> - <include name="scala/dbc/**/*.scala"/> - <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> - </scalac> - <!-- Build actors library --> - <mkdir dir="@{outputdir}/lib/actors"/> - <javac - srcdir="${src.dir}/actors" - destdir="@{outputdir}/lib/actors" - source="1.4" target="1.4" deprecation="yes" - classpath="@{build.dir}/lib/actors" - includes="scala/actors/**/*.java"/> - <scalac - srcdir="${src.dir}/actors" - destdir="@{outputdir}/lib/actors" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes" - scalacdebugging="${nsc.log-files}"> - <classpath> - <pathelement location="@{outputdir}/lib/library"/> - <pathelement location="@{outputdir}/lib/actors"/> - </classpath> - <include name="scala/actors/**/*.scala"/> - <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> - </scalac> - <!-- Build partest --> - <mkdir dir="@{outputdir}/lib/partest"/> - <javac - srcdir="${src.dir}/partest" - destdir="@{outputdir}/lib/partest" - source="1.4" target="1.4" deprecation="yes" - classpath="@{outputdir}/lib/partest" - includes="scala/tools/partest/**/*.java"/> - <scalac - srcdir="${src.dir}/partest" - destdir="@{outputdir}/lib/partest" - addparams="${nsc.params}" target="${nsc.target}" - deprecation="yes" unchecked="yes"> - <classpath> - <pathelement location="@{outputdir}/lib/library"/> - <pathelement location="@{outputdir}/lib/compiler"/> - <pathelement location="@{outputdir}/lib/actors"/> - </classpath> - </scalac> - <echo - file="@{outputdir}/lib/partest/${par.prop.name}" - message="version.number=${version.number}${line.separator}" - append="false" - /> - <echo - file="@{outputdir}/lib/partest/${par.prop.name}" - message="copyright.string=${copyright.string}${line.separator}" - append="true" - /> - </then> - </if> - <!-- Timing the build --> - <stopwatch name="timer.@{name}" action="total"/> - <!-- Copy support files to build folder and links external libraries--> - <build.support outputdir="@{outputdir}"/> - <!-- Build executable files --> - <path id="build.classpath"> - <pathelement location="@{outputdir}/lib/library"/> - <pathelement location="@{outputdir}/lib/compiler"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - <pathelement location="${jline.jar}"/> - <pathelement location="${ant.jar}"/> - </path> - <taskdef - name="scalatool" - classname="scala.tools.ant.ScalaTool" - classpathref="build.classpath"/> - <mkdir dir="@{outputdir}/bin"/> - <scalatool - file="@{outputdir}/bin/${scala.exec.name}" - version="${version.number}" - copyright="${copyright.string}" - name="Scala code runner" - class="scala.tools.nsc.MainGenericRunner" - javaFlags="${java.flags}"/> - <scalatool - file="@{outputdir}/bin/${scalac.exec.name}" - name="Scala compiler" - class="scala.tools.nsc.Main" - version="${version.number}" - copyright="${copyright.string}" - javaFlags="${java.flags}"/> - <scalatool - file="@{outputdir}/bin/${scaladoc.exec.name}" - name="Scala doc generator" - class="scala.tools.nsc.Main" - toolflags="-Ydoc" - version="${version.number}" - copyright="${copyright.string}" - javaFlags="${java.flags}"/> - <scalatool - file="@{outputdir}/bin/${fsc.exec.name}" - name="Fast Scala compiler" - class="scala.tools.nsc.CompileClient" - version="${version.number}" - copyright="${copyright.string}" - javaFlags="${java.flags}"/> - <chmod perm="ugo+rx" - file="@{outputdir}/bin/${scalac.exec.name}"/> - <chmod perm="ugo+rx" - file="@{outputdir}/bin/${scala.exec.name}"/> - <chmod perm="ugo+rx" - file="@{outputdir}/bin/${scaladoc.exec.name}"/> - <chmod perm="ugo+rx" - file="@{outputdir}/bin/${fsc.exec.name}"/> - <fixcrlf - srcdir="@{outputdir}/bin" - eol="dos" - includes="**/*.bat"/> - <!-- Mark layer as being completely built --> - <touch file="@{outputdir}/complete" verbose="no"/> - </sequential> - </macrodef> - -</project> diff --git a/src/build/build-jvm14.xml b/src/build/build-jvm14.xml deleted file mode 100644 index e3d97f2ff6..0000000000 --- a/src/build/build-jvm14.xml +++ /dev/null @@ -1,346 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="scala-jvm14" basedir="../.." default="build"> - -<!-- =========================================================================== -PROPERTIES -============================================================================ --> - - <import file="build-imports.xml"/> - - <!-- Loads custom properties definitions --> - <property file="${scripts.dir}/build-jvm14.properties"/> - - <!-- Configuring how the compiler is run --> - <property name="nsc.log-files" value="no"/> - <property name="nsc.excludes.file" value="${basedir}/build.excludes"/> - <property name="nsc.params" value=""/> - <fail message="Use Ant script 'build-jvm15.xml' for targeting the Java 1.5+ platform"> - <condition> - <not><contains string="${ant.java.version}" substring="1.4"/></not> - </condition> - </fail> - <property name="nsc.target" value="jvm-1.4"/> - - <!-- Sets location of build folders --> - <property name="build.dir" value="${basedir}/build"/> - <property name="locker.dir" value="${build.dir}/locker-jvm14"/> - <property name="quick.dir" value="${build.dir}/quick-jvm14"/> - <property name="strap.dir" value="${build.dir}/strap-jvm14"/> - <property name="dist.dir" value="${basedir}/dists"/> - -<!-- =========================================================================== -SETUP -============================================================================ --> - - <target name="setup.weave"> - <!-- Sets location of RetroWeaver installation --> - <condition property="retroweaver.home" value="${unix.retroweaver.home}"> - <and><os family="unix"/><isset property="unix.retroweaver.home"/></and> - </condition> - <condition property="retroweaver.home" value="${win.retroweaver.home}"> - <and><os family="windows"/><isset property="win.retroweaver.home"/></and> - </condition> - <property name="retroweaver.home" value="${env.RETROWEAVER_HOME}"/> - - <fail message="Set property 'retroweaver.home' to a valid RetroWeaver installation"> - <condition><not><and> - <available file="${retroweaver.home}/lib" type="dir"/> - <available file="${retroweaver.home}/release" type="dir"/> - </and></not></condition> - </fail> - <taskdef name="retroweaver" classname="net.sourceforge.retroweaver.ant.RetroWeaverTask"> - <classpath> - <fileset dir="${retroweaver.home}/lib" includes="**/*.jar"/> - <fileset dir="${retroweaver.home}/release" includes="**/*-all-*jar"/> - </classpath> - </taskdef> - <property name="lib.starr14.jar" value="${build.dir}/starr-jvm14/scala-library.jar"/> - <property name="comp.starr14.jar" value="${build.dir}/starr-jvm14/scala-compiler.jar"/> - <uptodate property="weave.notRequired" - targetfile="${lib.starr14.jar}" - srcfile= "${lib.starr.jar}" - /> - <if> - <not><isset property="weave.notRequired"/></not> - <then> - <mkdir dir="${build.dir}/starr-jvm14"/> - <retroweaver - inputjar="${lib.starr.jar}" - outputjar="${lib.starr14.jar}" - /> - <retroweaver - inputjar="${comp.starr.jar}" - outputjar="${comp.starr14.jar}" - /> - </then> - </if> - </target> - - <target name="setup" depends="init, setup.weave"> - <!-- Removing any outdated stuff --> - <if> - <and> - <available file="${locker.dir}/complete"/> - <not><uptodate targetfile="${locker.dir}/complete"> - <srcfiles dir="${lib.dir}" includes="scala-*.jar"/> - </uptodate></not> - </and> - <then> - <echo level="warning" - message="STARR updated: LOCKER is obsolete and will be rebuilt."/> - <runtarget target="clean.build"/> - </then> - </if> - <!-- Finding out what is available --> - <available property="excludes.avail" file="${nsc.excludes.file}"/> - <condition property="locker.avail"> - <available file="${locker.dir}/complete"/> - </condition> - <!-- Generating version number --> - <property file="${number.file}"/> - <property - name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> - <!-- And print-out what we are building --> - <echo level="info" message="Build number is '${version.number}'"/> - <echo level="info" message="Built ${time.human} from SVN revision ${svn.number}"/> - </target> - -<!-- =========================================================================== -BUILD -============================================================================ --> - - <target name="newlocker" - depends="clean.unfreeze, build.locker" - description="Rebuilds LOCKER from the current sources"/> - - <!-- Build the locker layer --> - <target name="build.locker" depends="setup" unless="locker.avail"> - <buildlayer - name="locker" - libpath="${lib.starr14.jar}" - comppath="${comp.starr14.jar}" - outputdir="${locker.dir}" - /> - <touch file="${locker.dir}/complete" verbose="no"/> - </target> - - <target name="build" depends="build.quick"/> - - <!-- Build the quick layer --> - <target name="build.quick" depends="build.locker" - description="Builds a quick-test (QUICK) version of the compiler"> - <buildlayer - name="quick" - libpath="${locker.dir}/lib/library" - comppath="${locker.dir}/lib/compiler" - outputdir="${quick.dir}" - buildall="true" - /> - </target> - - <!-- Build the bootstrap layer --> - <target name="build.strap" depends="build.quick"> - <buildlayer - name="strap" - libpath="${quick.dir}/lib/library" - comppath="${quick.dir}/lib/compiler" - outputdir="${strap.dir}" - buildall="true" - /> - </target> - -<!-- =========================================================================== -GENERATES A DISTRIBUTION -============================================================================ --> - - <target name="dist" - depends="clean.build, test, binaries" - description="Creates a (stability-)tested, complete Scala distribution *from scratch*"/> - - <target name="binaries" - depends="setup, build.strap" - description="Creates a binary Scala distribution"> - <property name="dist.current.dir" - value="${dist.dir}/scala-jvm14-${version.number}"/> - <if><and> - <isset property="os.unix"/> - <isset property="dist.resource"/></and> - <then> - <symlink - link="${dist.dir}" - resource="${dist.resource}" overwrite="yes" failonerror="no"/> - <touch file="${dist.dir}/is_symlink" verbose="no"/> - </then></if> - <mkdir dir="${dist.current.dir}"/> - <!-- Copy all requires libraries --> - <mkdir dir="${dist.current.dir}/lib"/> - <property name="ant.version.number" value="[1.6"/> - <!-- version ::= major('.'minor('.'micro('.'qualifier)?)?)? --> - <!-- see http://www2.osgi.org/javadoc/r4/org/osgi/framework/Version.html --> - <propertyregex - property="osgi.version.number" input="${version.number}" - regexp="([^-]*)(-.*)?" select="\1" - /> - <echo level="verbose" message="OSGi version: ${osgi.version.number}"/> - <jar destfile="${dist.current.dir}/lib/${comp.jar.name}"> - <fileset dir="${strap.dir}/lib/compiler"/> - <zipfileset src="${fjbg.jar}"/> - <zipfileset src="${msil.jar}"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.tools.nsc.Main"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/tools/nsc"> - <attribute name="Extension-Name" value="scala.tools.nsc"/> - <attribute name="Specification-Title" value="Scala Compiler"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.tools.nsc"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Compiler Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_compiler"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.tools.ant;version="${osgi.version.number}",scala.tools.nsc;version="${osgi.version.number}",scala.tools.nsc.ast;version="${osgi.version.number}",scala.tools.nsc.ast.parser;version="${osgi.version.number}",scala.tools.nsc.backend;version="${osgi.version.number}",scala.tools.nsc.doc;version="${osgi.version.number}",scala.tools.nsc.io;version="${osgi.version.number}",scala.tools.nsc.matching;version="${osgi.version.number}",scala.tools.nsc.models;version="${osgi.version.number}",scala.tools.nsc.symtab;version="${osgi.version.number}",scala.tools.nsc.symtab.classfile;version="${osgi.version.number}",scala.tools.nsc.symtab.clr;version="${osgi.version.number}",scala.tools.nsc.transform;version="${osgi.version.number}",scala.tools.nsc.typechecker;version="${osgi.version.number}",scala.tools.nsc.util;version="${osgi.version.number}",scala.tools.util;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="org.apachge.ant.tools;version="${ant.version.number}",org.apachge.ant.tools.taskdefs;version="${ant.version.number}",org.apachge.ant.types;version="${ant.version.number}",org.apachge.ant.tools.util;version="${ant.version.number}",org.xml.sax"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${lib.jar.name}"> - <fileset dir="${strap.dir}/lib/library"/> - <fileset dir="${strap.dir}/lib/actors"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.util.Properties"/> - <section name="scala"> - <attribute name="Extension-Name" value="scala"/> - <attribute name="Specification-Title" value="Scala Library"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Library Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_library"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala;version="${osgi.version.number}",scala.actors;version="${osgi.version.number}",scala.actors.remote;version="${osgi.version.number}",scala.collection;version="${osgi.version.number}",scala.collection.immutable;version="${osgi.version.number}",scala.collection.jcl;version="${osgi.version.number}",scala.collection.mutable;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}",scala.concurrent;version="${osgi.version.number}",scala.io;version="${osgi.version.number}",scala.mobile;version="${osgi.version.number}",scala.ref;version="${osgi.version.number}",scala.reflect;version="${osgi.version.number}",scala.runtime;version="${osgi.version.number}",scala.testing;version="${osgi.version.number}",scala.text;version="${osgi.version.number}",scala.util;version="${osgi.version.number}",scala.util.automata;version="${osgi.version.number}",scala.util.grammar;version="${osgi.version.number}",scala.util.logging;version="${osgi.version.number}",scala.util.parsing;version="${osgi.version.number}",scala.util.regexp;version="${osgi.version.number}",scala.xml;version="${osgi.version.number}",scala.xml.dtd;version="${osgi.version.number}",scala.xml.factory;version="${osgi.version.number}",scala.xml.parsing;version="${osgi.version.number}",scala.xml.path;version="${osgi.version.number}",scala.xml.pull;version="${osgi.version.number}",scala.xml.transform;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="javax.xml.parsers,org.xml.sax,org.xml.sax.helpers"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${dbc.jar.name}"> - <fileset dir="${strap.dir}/lib/dbc"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/dbc"> - <attribute name="Extension-Name" value="scala.dbc"/> - <attribute name="Specification-Title" value="Scala DBC Library"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.dbc"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala DBC Library Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_dbc_library"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.dbc;version="${osgi.version.number}",scala.dbc.datatype;version="${osgi.version.number}",scala.dbc.exception;version="${osgi.version.number}",scala.dbc.result;version="${osgi.version.number}",scala.dbc.statement;version="${osgi.version.number}",scala.dbc.statement.expression;version="${osgi.version.number}",scala.dbc.syntax;version="${osgi.version.number}",scala.dbc.value;version="${osgi.version.number}",scala.dbc.vendor;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="scala;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}""/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${partest.jar.name}"> - <fileset dir="${strap.dir}/lib/partest"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.tools.partest.TestRunner"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/tools/partest"> - <attribute name="Extension-Name" value="scala.tools.partest"/> - <attribute name="Specification-Title" value="Scala Test Utility"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.tools.partest"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Test Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_compiler"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.tools.partest;version="${osgi.version.number}",scala.tools.partest.utils;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="javax.swing"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - - <!-- build source jars --> - <mkdir dir="${dist.current.dir}/src"/> - <jar - destfile="${dist.current.dir}/src/${libsrc.jar.name}"> - <fileset dir="${src.dir}/library"/> - <fileset dir="${src.dir}/actors"/> - </jar> - <jar - destfile="${dist.current.dir}/src/${dbcsrc.jar.name}" - basedir="${src.dir}/dbc" - includes="**/*.scala" - /> - <jar - destfile="${dist.current.dir}/src/${parsrc.jar.name}" - basedir="${src.dir}/partest" - includes="**/*.scala" - /> - <jar - destfile="${dist.current.dir}/src/${compsrc.jar.name}" - basedir="${src.dir}/compiler" - includes="**/*.scala" - /> - - <!-- Copy executable files --> - <mkdir dir="${dist.current.dir}/bin"/> - <copy todir="${dist.current.dir}/bin"> - <fileset dir="${strap.dir}/bin"/> - </copy> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scalac.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scala.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scaladoc.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${fsc.exec.name}"/> - <!-- Recreate the 'latest' link to point to this distribution --> - <if><isset property="os.win"/> - <then> - <copy todir="${dist.dir}/latest-jvm14"> - <fileset dir="${dist.current.dir}"/> - </copy> - </then> - <else> - <symlink - link="${dist.dir}/latest-jvm14" - resource="${dist.current.dir}" - overwrite="yes" failonerror="no"/> - </else> - </if> - </target> - -</project> diff --git a/src/build/build-jvm15.xml b/src/build/build-jvm15.xml deleted file mode 100644 index 821f67395e..0000000000 --- a/src/build/build-jvm15.xml +++ /dev/null @@ -1,302 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="scala-jvm15" basedir="../.." default="build"> - -<!-- =========================================================================== -PROPERTIES -============================================================================ --> - - <import file="build-imports.xml"/> - - <!-- Loads custom properties definitions --> - <property file="${scripts.dir}/build-jvm15.properties"/> - - <!-- Configuring how the compiler is run --> - <property name="nsc.log-files" value="no"/> - <property name="nsc.excludes.file" value="${basedir}/build.excludes"/> - <property name="nsc.params" value=""/> - <fail message="Use Ant script 'build-jvm14.xml' for targeting the Java 1.4 platform"> - <condition> - <contains string="${ant.java.version}" substring="1.4"/> - </condition> - </fail> - <property name="nsc.target" value="jvm-1.5"/> - - <!-- Sets location of build folders --> - <property name="build.dir" value="${basedir}/build"/> - <property name="locker.dir" value="${build.dir}/locker"/> - <property name="quick.dir" value="${build.dir}/quick"/> - <property name="strap.dir" value="${build.dir}/strap"/> - <property name="dist.dir" value="${basedir}/dists"/> - -<!-- =========================================================================== -SETUP -============================================================================ --> - - <target name="setup" depends="init"> - <!-- Removing any outdated stuff --> - <if> - <and> - <available file="${locker.dir}/complete"/> - <not><uptodate targetfile="${locker.dir}/complete"> - <srcfiles dir="${lib.dir}" includes="scala-*.jar"/> - </uptodate></not> - </and> - <then> - <echo level="warning" - message="STARR updated: LOCKER is obsolete and will be rebuilt."/> - <runtarget target="clean.build"/> - </then> - </if> - <!-- Finding out what is available --> - <available property="excludes.avail" file="${nsc.excludes.file}"/> - <condition property="locker.avail"> - <available file="${locker.dir}/complete"/> - </condition> - <!-- Generating version number --> - <property file="${number.file}"/> - <property - name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> - <!-- And print-out what we are building --> - <echo level="info" message="Build number is '${version.number}'"/> - <echo level="info" message="Built ${time.human} from SVN revision ${svn.number}"/> - </target> - -<!-- =========================================================================== -BUILD -============================================================================ --> - - <target name="newlocker" - depends="clean.unfreeze, build.locker" - description="Rebuilds LOCKER from the current sources"/> - - <!-- Build the locker layer --> - <target name="build.locker" depends="setup" unless="locker.avail"> - <buildlayer - name="locker" - libpath="${lib.dir}/${lib.jar.name}" - comppath="${lib.dir}/${comp.jar.name}" - outputdir="${locker.dir}" - /> - <touch file="${locker.dir}/complete" verbose="no"/> - </target> - - <target name="build" depends="build.quick"/> - - <!-- Build the quick layer --> - <target name="build.quick" depends="build.locker" - description="Builds a quick-test (QUICK) version of the compiler"> - <buildlayer - name="quick" - libpath="${locker.dir}/lib/library" - comppath="${locker.dir}/lib/compiler" - outputdir="${quick.dir}" - buildall="true" - /> - </target> - - <!-- Build the bootstrap layer --> - <target name="build.strap" depends="build.quick"> - <buildlayer - name="strap" - libpath="${quick.dir}/lib/library" - comppath="${quick.dir}/lib/compiler" - outputdir="${strap.dir}" - buildall="true" - /> - </target> - -<!-- =========================================================================== -DIST -============================================================================ --> - - <target name="dist" - depends="clean.build, test, binaries" - description="Creates a (stability-)tested, complete Scala distribution *from scratch*"/> - - <target name="binaries" - depends="setup, build.strap" - description="Creates a binary Scala distribution"> - <property name="dist.current.dir" - value="${dist.dir}/scala-${version.number}"/> - <if><and> - <isset property="os.unix"/> - <isset property="dist.resource"/></and> - <then> - <symlink - link="${dist.dir}" - resource="${dist.resource}" overwrite="yes" failonerror="no"/> - <touch file="${dist.dir}/is_symlink" verbose="no"/> - </then></if> - <mkdir dir="${dist.current.dir}"/> - <!-- Copy all requires libraries --> - <mkdir dir="${dist.current.dir}/lib"/> - <property name="ant.version.number" value="[1.6"/> - <!-- version ::= major('.'minor('.'micro('.'qualifier)?)?)? --> - <!-- see http://www2.osgi.org/javadoc/r4/org/osgi/framework/Version.html --> - <propertyregex - property="osgi.version.number" input="${version.number}" - regexp="([^-]*)(-.*)?" select="\1" - /> - <echo level="verbose" message="OSGi version: ${osgi.version.number}"/> - <jar destfile="${dist.current.dir}/lib/${comp.jar.name}"> - <fileset dir="${strap.dir}/lib/compiler"/> - <zipfileset src="${fjbg.jar}"/> - <zipfileset src="${msil.jar}"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.tools.nsc.Main"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/tools/nsc"> - <attribute name="Extension-Name" value="scala.tools.nsc"/> - <attribute name="Specification-Title" value="Scala Compiler"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.tools.nsc"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Compiler Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_compiler"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.tools.ant;version="${osgi.version.number}",scala.tools.nsc;version="${osgi.version.number}",scala.tools.nsc.ast;version="${osgi.version.number}",scala.tools.nsc.ast.parser;version="${osgi.version.number}",scala.tools.nsc.backend;version="${osgi.version.number}",scala.tools.nsc.doc;version="${osgi.version.number}",scala.tools.nsc.io;version="${osgi.version.number}",scala.tools.nsc.matching;version="${osgi.version.number}",scala.tools.nsc.models;version="${osgi.version.number}",scala.tools.nsc.symtab;version="${osgi.version.number}",scala.tools.nsc.symtab.classfile;version="${osgi.version.number}",scala.tools.nsc.symtab.clr;version="${osgi.version.number}",scala.tools.nsc.transform;version="${osgi.version.number}",scala.tools.nsc.typechecker;version="${osgi.version.number}",scala.tools.nsc.util;version="${osgi.version.number}",scala.tools.util;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="org.apachge.ant.tools;version="${ant.version.number}",org.apachge.ant.tools.taskdefs;version="${ant.version.number}",org.apachge.ant.types;version="${ant.version.number}",org.apachge.ant.tools.util;version="${ant.version.number}",org.xml.sax"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${lib.jar.name}"> - <fileset dir="${strap.dir}/lib/library"/> - <fileset dir="${strap.dir}/lib/actors"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.util.Properties"/> - <section name="scala"> - <attribute name="Extension-Name" value="scala"/> - <attribute name="Specification-Title" value="Scala Library"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Library Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_library"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala;version="${osgi.version.number}",scala.actors;version="${osgi.version.number}",scala.actors.remote;version="${osgi.version.number}",scala.collection;version="${osgi.version.number}",scala.collection.immutable;version="${osgi.version.number}",scala.collection.jcl;version="${osgi.version.number}",scala.collection.mutable;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}",scala.concurrent;version="${osgi.version.number}",scala.io;version="${osgi.version.number}",scala.mobile;version="${osgi.version.number}",scala.ref;version="${osgi.version.number}",scala.reflect;version="${osgi.version.number}",scala.runtime;version="${osgi.version.number}",scala.testing;version="${osgi.version.number}",scala.text;version="${osgi.version.number}",scala.util;version="${osgi.version.number}",scala.util.automata;version="${osgi.version.number}",scala.util.grammar;version="${osgi.version.number}",scala.util.logging;version="${osgi.version.number}",scala.util.parsing;version="${osgi.version.number}",scala.util.regexp;version="${osgi.version.number}",scala.xml;version="${osgi.version.number}",scala.xml.dtd;version="${osgi.version.number}",scala.xml.factory;version="${osgi.version.number}",scala.xml.parsing;version="${osgi.version.number}",scala.xml.path;version="${osgi.version.number}",scala.xml.pull;version="${osgi.version.number}",scala.xml.transform;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="javax.xml.parsers,org.xml.sax,org.xml.sax.helpers"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${dbc.jar.name}"> - <fileset dir="${strap.dir}/lib/dbc"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/dbc"> - <attribute name="Extension-Name" value="scala.dbc"/> - <attribute name="Specification-Title" value="Scala DBC Library"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.dbc"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala DBC Library Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_dbc_library"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.dbc;version="${osgi.version.number}",scala.dbc.datatype;version="${osgi.version.number}",scala.dbc.exception;version="${osgi.version.number}",scala.dbc.result;version="${osgi.version.number}",scala.dbc.statement;version="${osgi.version.number}",scala.dbc.statement.expression;version="${osgi.version.number}",scala.dbc.syntax;version="${osgi.version.number}",scala.dbc.value;version="${osgi.version.number}",scala.dbc.vendor;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="scala;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}""/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - <jar destfile="${dist.current.dir}/lib/${partest.jar.name}"> - <fileset dir="${strap.dir}/lib/partest"/> - <manifest> - <attribute name="Signature-Version" value="${version.number}"/> - <attribute name="Built-By" value="${user.name}"/> - <attribute name="Main-Class" value="scala.tools.partest.TestRunner"/> - <attribute name="Class-Path" value="${lib.jar.name}"/> - <section name="scala/tools/partest"> - <attribute name="Extension-Name" value="scala.tools.partest"/> - <attribute name="Specification-Title" value="Scala Test Utility"/> - <attribute name="Specification-Version" value="${version.number}"/> - <attribute name="Specification-Vendor" value="${vendor.name}"/> - <attribute name="Implementation-Title" value="scala.tools.partest"/> - <attribute name="Implementation-Version" value="${version.number}"/> - <attribute name="Implementation-Vendor" value="${vendor.name}"/> - </section> - <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> - <attribute name="Bundle-ManifestVersion" value="2"/> - <attribute name="Bundle-Name" value="Scala Test Bundle"/> - <attribute name="Bundle-SymbolicName" value="scala_compiler"/> - <attribute name="Bundle-Version" value="${osgi.version.number}"/> - <attribute name="Bundle-Vendor" value="${vendor.name}"/> - <attribute name="Export-Package" value="scala.tools.partest;version="${osgi.version.number}",scala.tools.partest.utils;version="${osgi.version.number}""/> - <attribute name="Import-Package" value="javax.swing"/> - <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> - </manifest> - </jar> - - <!-- build source jars --> - <mkdir dir="${dist.current.dir}/src"/> - <jar - destfile="${dist.current.dir}/src/${libsrc.jar.name}"> - <fileset dir="${src.dir}/library"/> - <fileset dir="${src.dir}/actors"/> - </jar> - <jar - destfile="${dist.current.dir}/src/${dbcsrc.jar.name}" - basedir="${src.dir}/dbc" - includes="**/*.scala" - /> - <jar - destfile="${dist.current.dir}/src/${parsrc.jar.name}" - basedir="${src.dir}/partest" - includes="**/*.scala" - /> - <jar - destfile="${dist.current.dir}/src/${compsrc.jar.name}" - basedir="${src.dir}/compiler" - includes="**/*.scala" - /> - - <!-- Copy executable files --> - <mkdir dir="${dist.current.dir}/bin"/> - <copy todir="${dist.current.dir}/bin"> - <fileset dir="${strap.dir}/bin"/> - </copy> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scalac.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scala.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scaladoc.exec.name}"/> - <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${fsc.exec.name}"/> - <!-- Recreate the 'latest' link to point to this distribution --> - <if><isset property="os.win"/> - <then> - <copy todir="${dist.dir}/latest"> - <fileset dir="${dist.current.dir}"/> - </copy> - </then> - <else> - <symlink - link="${dist.dir}/latest" - resource="${dist.current.dir}" - overwrite="yes" failonerror="no"/> - </else> - </if> - </target> - -</project> diff --git a/src/build/build-msil.xml b/src/build/build-msil.xml deleted file mode 100644 index 8690ddb369..0000000000 --- a/src/build/build-msil.xml +++ /dev/null @@ -1,198 +0,0 @@ -<?xml version="1.0" encoding="UTF-8"?> -<!-- $Id: $ --> - -<project name="scala-msil" basedir="../.." default="build"> - -<!-- =========================================================================== -PROPERTIES -============================================================================ --> - - <import file="build-jvm15.xml"/> - - <property name="mono.dir" value="${src.dir}/mono"/> - - <!-- Loads custom properties definitions --> - <property file="${scripts.dir}/scripts/build-msil.properties"/> - - <!-- Sets location of build folders --> - <property name="build.dir" value="${basedir}/build"/> - <property name="msil.dir" value="${build.dir}/msil"/> - <property name="dist.dir" value="${basedir}/dists"/> - -<!-- =========================================================================== -SETUP -============================================================================ --> - - <target name="msil.init" depends="init"> - <!-- Sets ilasm command (either Microsoft .NET Framework or Mono) --> - <condition property="ilasm.cmd" value="${dotnet.home}/ilasm.exe"> - <and> - <os family="windows"/><isset property="dotnet.home"/> - <available file="${dotnet.home}/ilasm.exe"/> - </and> - </condition> - <condition property="ilasm.cmd" value="${unix.mono.home}/ilasm"> - <and> - <os family="unix"/><isset property="unix.mono.home"/> - <available file="${unix.mono.home}/ilasm"/> - </and> - </condition> - <condition property="ilasm.cmd" value="${win.mono.home}/ilasm"> - <and> - <os family="windows"/><isset property="win.mono.home"/> - <available file="${win.mono.home}/lib/mono/2.0/ilasm.exe"/> - </and> - </condition> - <echo level="verbose" message="Found: ${ilasm.cmd}"/> - <condition property="ilasm.cmd" value="ilasm"> - <and><available file="ilasm" filepath="${env.PATH}"/></and> - </condition> - <fail message="Command 'ilasm' not found"> - <condition><not><isset property="ilasm.cmd"/></not></condition> - </fail> - <!-- Sets ilasm arguments (either Windows or Unix) --> - <property name="ilasm.outfile" value="${msil.dir}/lib/predef.dll"/> - <if> - <isset property="os.win"/> - <then> - <property - name="ilasm.args" - value="/quiet /dll /output=${ilasm.outfile}" - /> - </then> - <else> - <property - name="ilasm.args" - value="/dll /output:${ilasm.outfile}" - /> - </else> - </if> - <property file="${number.file}"/> - <property - name="version.number" - value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> - <echo level="verbose" message="${version.number}"/> - </target> - - <target name="msil.sources" depends="msil.init"> - <mkdir dir="${msil.dir}/src"/> - <copy todir="${msil.dir}/src"> - <fileset dir="${src.dir}/library" includes="**/*.scala"> - <not> - <present targetdir="${src.dir}/dotnet-library"/> - </not> - <exclude name="scala/collection/jcl/**/*.scala"/> - </fileset> - </copy> - <copy todir="${msil.dir}/src"> - <fileset dir="${src.dir}/dotnet-library"> - <include name="**/*.scala"/> - </fileset> - </copy> - </target> - - <target name="msil.libraries" depends="msil.sources"> - <antcall target="build.quick"/> - <property name="quick.dir" value="${build.dir}/quick"/> - <path id="quick.classpath"> - <pathelement location="${quick.dir}/lib/library"/> - <pathelement location="${quick.dir}/lib/compiler"/> - <pathelement location="${fjbg.jar}"/> - <pathelement location="${msil.jar}"/> - </path> - <taskdef - name="quick" classname="scala.tools.ant.Scalac" - classpathref="quick.classpath"/> - <mkdir dir="${msil.dir}/lib"/> - <quick srcdir="${msil.dir}/src" usepredefs="no" target="msil" - assemname="predef" assemrefs="${lib.dir}" - failonerror="false"> - <include name="**/*.scala"/> - <exclude name="scala/ScalaObject.scala"/> - </quick> - <pathconvert property="ilasm.infiles" pathsep=" "> - <fileset dir="${msil.dir}" includes="*.msil"/> - </pathconvert> - <exec executable="${ilasm.cmd} {$ilasm.infiles}" vmlauncher="no"> - <arg line="${ilasm.args}"/> - </exec> - </target> - - <target name="msil.build" depends="msil.libraries"> - <copy todir="${msil.dir}/bin"> - <fileset - dir="${mono.dir}/bin" - includes="scala-net*" - /> - <filterset> - <filter token="VERSION" value="${version.number}"/> - <filter token="COPYRIGHT" value="${copyright.string}"/> - <filter token="NAME" value="Scala code runner"/> - </filterset> - </copy> - <copy todir="${msil.dir}/bin"> - <fileset - dir="${mono.dir}/bin" - includes="scalac-net*" - /> - <filterset> - <filter token="VERSION" value="${version.number}"/> - <filter token="COPYRIGHT" value="${copyright.string}"/> - <filter token="NAME" value="Scala compiler"/> - </filterset> - </copy> - <chmod perm="ugo+rx" dir="${msil.dir}/bin" includes="*-net*"/> - <jar destfile="${msil.dir}/lib/${comp.jar.name}"> - <fileset dir="${quick.dir}/lib/compiler"/> - <zipfileset src="${fjbg.jar}"/> - <zipfileset src="${msil.jar}"/> - </jar> - <jar destfile="${msil.dir}/lib/${lib.jar.name}"> - <fileset dir="${strap.dir}/lib/library"/> - <fileset dir="${strap.dir}/lib/actors"/> - </jar> - </target> - - <target name="msil.dist" depends="msil.build"> - <antcall target="binaries"/> - <property name="dist.current.dir" value="${dist.dir}/scala-msil-${version.number}"/> - <mkdir dir="${dist.current.dir}"/> - <copy todir="${dist.current.dir}"> - <fileset dir="${msil.dir}" includes="bin/**,lib/**"/> - </copy> - <chmod perm="ugo+rx" dir="${dist.current.dir}/bin" includes="*-net*"/> - <copy todir="${dist.current.dir}/lib"> - <fileset dir="${lib.dir}" includes="*.dll"/> - </copy> - <copy todir="${dist.current.dir}/lib"> - <fileset dir="${dist.dir}/latest/lib" includes="scala*.jar"/> - </copy> - <!-- Recreate the 'latest' link to point to this distribution --> - <if><isset property="os.win"/> - <then> - <copy todir="${dist.dir}/latest-msil"> - <fileset dir="${dist.current.dir}"/> - </copy> - </then> - <else> - <symlink - link="${dist.dir}/latest-mono" - resource="${dist.current.dir}" - overwrite="yes" failonerror="no"/> - </else> - </if> - </target> - -<!-- =========================================================================== -CLEAN -============================================================================ --> - - <target name="msil.clean" depends="ant-init"> - <remove dir="${build.dir}/msil"/> - <delete includeemptydirs="true" quiet="yes" failonerror="no"> - <fileset dir="@{dist.dir}" includes="**/scala-msil*"/> - </delete> - <delete file="${dist.dir}/latest-msil" quiet="yes" failonerror="no"/> - </target> - -</project> diff --git a/src/build/four.xml b/src/build/four.xml index 6dd92f34f4..a47ce57927 100644 --- a/src/build/four.xml +++ b/src/build/four.xml @@ -290,11 +290,14 @@ DOCUMENTATION </target> <!-- =========================================================================== -BOOTRAPING TEST AND TEST SUITE +TEST SUITE WHEN RUN ON JVM 1.5 +================================================================================ +This tests how a compiler, library and tests that where targeted for JVM 1.4 +work on a JVM 1.5. ============================================================================ --> <target name="four-test.suite" depends="four-pack.done"> - <partest showlog="yes" erroronfailed="no" scalacopts="-target:jvm-1.4"> + <partest showlog="yes" erroronfailed="no" scalacopts="-target:jvm-1.4" javacmd="${java.home}/bin/java"> <classpath> <pathelement location="${build-four-pack.dir}/lib/scala-library.jar"/> <pathelement location="${build-four-pack.dir}/lib/scala-compiler.jar"/> @@ -311,6 +314,42 @@ BOOTRAPING TEST AND TEST SUITE </target> <target name="four-test.done" depends="four-test.suite"/> + +<!-- =========================================================================== +TEST SUITE WHEN RUN ON JVM 1.4 (standalone) +================================================================================ +This tests how a compiler, library and tests that where targeted for JVM 1.4 +work on a JVM 1.4. +============================================================================ --> + + <target name="fourfour-test.start"> + <path id="four-pack.classpath"> + <pathelement location="${build-four-pack.dir}/lib/scala-library.jar"/> + <pathelement location="${build-four-pack.dir}/lib/scala-compiler.jar"/> + <pathelement location="${build-four-pack.dir}/lib/scala-partest.jar"/> + <pathelement location="${ant.jar}"/> + </path> + <taskdef resource="scala/tools/partest/antlib.xml" classpathref="four-pack.classpath"/> + </target> + + <target name="fourfour-test.suite" depends="fourfour-test.start"> + <partest showlog="yes" erroronfailed="no" scalacopts="-target:jvm-1.4" javacmd="${java.home}/bin/java"> + <classpath> + <pathelement location="${build-four-pack.dir}/lib/scala-library.jar"/> + <pathelement location="${build-four-pack.dir}/lib/scala-compiler.jar"/> + <fileset dir="${test.dir}/files/lib" includes="*.jar"/> + </classpath> + <postests dir="${test.dir}/files/pos" includes="*.scala"/> + <negtests dir="${test.dir}/files/neg" includes="*.scala"/> + <runtests dir="${test.dir}/files"> + <include name="run/**/*.scala"/> + <include name="jvm/**/*.scala"/> + </runtests> + <residenttests dir="${test.dir}/files/res" includes="*.res"/> + </partest> + </target> + + <target name="fourfour-test.done" depends="fourfour-test.suite"/> <!-- =========================================================================== DISTRIBUTION diff --git a/src/build/old_sabbus.xml b/src/build/old_sabbus.xml new file mode 100644 index 0000000000..f8f8dab8c6 --- /dev/null +++ b/src/build/old_sabbus.xml @@ -0,0 +1,2012 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- $Id$ --> + +<project name="scala-core" default="build"> + + <description> + I am SABBUS for Scala core, the build system for the Scala compiler and core + library. Please check the 'docs/README' file for more information about me. + </description> + + <echo level="info" message="Running SABBUS for ${ant.project.name}..."/> + +<!-- =========================================================================== +PROPERTIES +============================================================================ --> + + <property environment="env"/> + + <!-- Prevents system classpath from being used --> + <property name="build.sysclasspath" value="ignore"/> + + <!-- Defines the repository layout --> + <property name="docs.dir" value="${basedir}/docs"/> + <property name="lib.dir" value="${basedir}/lib"/> + <property name="src.dir" value="${basedir}/src"/> + <property name="test.dir" value="${basedir}/test"/> + + <!-- Loads custom properties definitions --> + <property name="properties.file" value="${basedir}/build.properties"/> + <property file="${properties.file}"/> + + <!-- Defines the product being built --> + <property name="vendor.name" value="LAMP/EPFL"/> + <property name="copyright.string" value="(c) 2002-2008 ${vendor.name}"/> + <property name="java.flags" value="-Xmx768M -Xms16M"/> + <property name="number.file" value="${basedir}/build.number"/> + + <!-- Configuring how the compiler is run --> + <property name="nsc.log-files" value="no"/> + <property name="nsc.excludes.file" value="${basedir}/build.excludes"/> + <property name="nsc.params" value=""/> + <condition property="nsc.target" value="jvm-1.4"> + <contains string="${ant.java.version}" substring="1.4"/> + </condition> + <property name="nsc.target" value="jvm-1.5"/> + + <!-- Sets location of pre-compiled libraries --> + <property name="lib.starr.jar" value="${lib.dir}/scala-library.jar"/> + <property name="comp.starr.jar" value="${lib.dir}/scala-compiler.jar"/> + <property name="fjbg.jar" value="${lib.dir}/fjbg.jar"/> + <property name="msil.jar" value="${lib.dir}/msil.jar"/> + <property name="ant.jar" value="${ant.home}/lib/ant.jar"/> + <property name="jline.jar" value="${lib.dir}/jline.jar"/> + <property name="ant-contrib.jar" value="${lib.dir}/ant-contrib.jar"/> + + <!-- Sets location of build folders --> + <property name="build.dir" value="${basedir}/build"/> + <property name="locker.dir" value="${build.dir}/locker"/> + <property name="quick.dir" value="${build.dir}/quick"/> + <property name="strap.dir" value="${build.dir}/strap"/> + <property name="optimised.dir" value="${build.dir}/optimised"/> + <property name="api-lib.dir" value="${build.dir}/api-library"/> + <property name="api-comp.dir" value="${build.dir}/api-compiler"/> + <property name="tooldocs.dir" value="${build.dir}/tooldocs"/> + <property name="examples.dir" value="${build.dir}/examples"/> +<!-- <property name="cldc.dir" value="${build.dir}/cldc"/> --> + <property name="android.dir" value="${build.dir}/android"/> + <property name="msil.dir" value="${build.dir}/msil"/> + <property name="mono.dir" value="${src.dir}/mono"/> + + <!-- Sets location and structure of the distribution --> + <property name="dist.dir" value="${basedir}/dists"/> + <property name="lib.jar.name" value="scala-library.jar"/> + <property name="dbc.jar.name" value="scala-dbc.jar"/> + <property name="comp.jar.name" value="scala-compiler.jar"/> + <property name="partest.jar.name" value="scala-partest.jar"/> + <property name="jline.jar.name" value="jline.jar"/> + <property name="libsrc.jar.name" value="scala-library-src.jar"/> + <property name="dbcsrc.jar.name" value="scala-dbc-src.jar"/> + <property name="parsrc.jar.name" value="scala-partest-src.jar"/> + <property name="compsrc.jar.name" value="scala-compiler-src.jar"/> + <property name="scala.exec.name" value="scala"/> + <property name="scalac.exec.name" value="scalac"/> + <property name="scaladoc.exec.name" value="scaladoc"/> + <property name="fsc.exec.name" value="fsc"/> + <property name="comp.prop.name" value="compiler.properties"/> + <property name="lib.prop.name" value="library.properties"/> + <property name="par.prop.name" value="partest.properties"/> + + <!-- if available, faster stability checking --> + <property name="stability.tool" value="/home/linuxsoft/apps/stability/stability"/> + +<!-- =========================================================================== +ANT INITIALISATION +============================================================================ --> + + <target name="ant-init"> + <!-- Making sure lib/ contains everything that is needed --> + <fail message="A required library is missing in 'lib/'. The README file describes what should be there."> + <condition><not><and> + <available file="${lib.starr.jar}"/> + <available file="${comp.starr.jar}"/> + <available file="${fjbg.jar}"/> + <available file="${msil.jar}"/> + <available file="${ant-contrib.jar}"/> + </and></not></condition> + </fail> + <!-- Setting-up Ant contrib tasks --> + <taskdef resource="net/sf/antcontrib/antlib.xml" + classpath="${ant-contrib.jar}"/> + <fail message="External library ${ant-contrib.jar} requires the optional Ant tasks to be installed"> + <condition><not><and> + <available file="${ant.home}/lib/ant-nodeps.jar"/> + </and></not></condition> + </fail> + </target> + +<!-- =========================================================================== +INITIALISATION +============================================================================ --> + + <target name="init" depends="ant-init" unless="init.avail"> + <!-- Making sure enough memory is available --> + <propertyregex + property="memory.set" input="${env.ANT_OPTS}" select="\1" + regexp="-Xmx([1-9][0-9]{3,}|[6-9][0-9]{2}|5[2-9][0-9]|51[2-9])(M|m)"/> + <fail + unless="memory.set" + message="SABBUS requires additional memory. Please set the 'ANT_OPTS' environment property to '-Xmx512M' or more."/> + <propertyregex + property="memory.info" input="${env.ANT_OPTS}" defaultValue="" + select=" (raise to 600 MB for performance)" + regexp="-Xmx([1-5][0-9]{2})(M|m)"/> + <!-- This is the start time for the distribution --> + <stopwatch name="timer.dist"/> + <tstamp prefix="time"> + <format property="human" pattern="EEEE, d MMMM yyyy, HH:mm:ss (zz)"/> + <format property="short" pattern="yyyyMMddHHmmss"/> + </tstamp> + <!-- Finding out what system architecture is being used --> + <condition property="os.win"><os family="windows"/></condition> + <if><isset property="os.win"/><then> + <exec + executable="cygpath" vmlauncher="no" + errorproperty="cygpath.err" outputproperty="cygpath.out"> + <arg value="--windir"/> + </exec> + <condition property="os.cygwin"> + <equals arg1="${cygpath.err}" arg2=""/> + </condition> + </then></if> + <condition property="os.unix"><or> + <os family="unix"/> + <os family="mac"/> + <isset property="os.cygwin"/> + </or></condition> + <if><isset property="os.cygwin"/> + <then><property name="os.type" value="Cygwin"/></then> + <elseif><isset property="os.win"/> + <then><property name="os.type" value="Windows"/></then> + </elseif> + <elseif><isset property="os.unix"/> + <then><property name="os.type" value="UNIX"/></then> + </elseif> + <else><fail>System environment could not be determined</fail></else> + </if> + <!-- Setting flag for Java versions 1.4.x --> + <condition property="java14"> + <contains string="${java.version}" substring="1.4"/> + </condition> + <!-- Finding out SVN revision --> + <exec + executable="svn" vmlauncher="no" + errorproperty="svn.err" outputproperty="svn.out"> + <arg line=" info ${basedir}"/> + </exec> + <propertyregex + property="svn.number" input="${svn.out}" select="\1" + regexp="Revision: ([0-9]+)" + defaultValue="x"/> + <property name="init.avail" value="yes"/> + <!-- Printing out some information about what environment I am running in --> + <echo level="info" + message="OS: ${os.type} (${os.name} ${os.arch} ${os.version});"/> + <echo level="info" + message="Java: ${java.vm.name} ${java.vm.version} ('${java.home}');"/> + <echo level="info" + message="Memory: ${memory.set} MB${memory.info};"/> + <echo level="info" + message="Ant: ${ant.version}."/> + </target> + +<!-- =========================================================================== +SETUP +============================================================================ --> + + <target name="setup.weave"> + <!-- Sets location of RetroWeaver installation --> + <condition property="retroweaver.home" value="${unix.retroweaver.home}"> + <and><os family="unix"/><isset property="unix.retroweaver.home"/></and> + </condition> + <condition property="retroweaver.home" value="${win.retroweaver.home}"> + <and><os family="windows"/><isset property="win.retroweaver.home"/></and> + </condition> + <property name="retroweaver.home" value="${env.RETROWEAVER_HOME}"/> + + <fail message="Set property 'retroweaver.home' to a valid RetroWeaver installation"> + <condition><not><and> + <available file="${retroweaver.home}/lib" type="dir"/> + <available file="${retroweaver.home}/release" type="dir"/> + </and></not></condition> + </fail> + <taskdef name="retroweaver" classname="net.sourceforge.retroweaver.ant.RetroWeaverTask"> + <classpath> + <fileset dir="${retroweaver.home}/lib" includes="**/*.jar"/> + <fileset dir="${retroweaver.home}/release" includes="**/*-all-*jar"/> + </classpath> + </taskdef> + <retroweaver + inputjar="${lib.starr.jar}" + outputjar="${lib.starr14.jar}" + /> + <retroweaver + inputjar="${comp.starr.jar}" + outputjar="${comp.starr14.jar}" + /> + </target> + + <target name="setup" depends="init"> + <!-- Creating class-pathes --> + <if> + <contains string="${java.version}" substring="1.4"/> + <then> + <mkdir dir="${build.dir}/starr"/> + <property name="lib.starr14.jar" value="${build.dir}/starr/scala-library-14.jar"/> + <property name="comp.starr14.jar" value="${build.dir}/starr/scala-compiler-14.jar"/> + <antcall target="setup.weave"> + <param name="lib.starr14.jar" value="${lib.starr14.jar}"/> + <param name="comp.starr14.jar" value="${comp.starr14.jar}"/> + </antcall> + <path id="starr.classpath"> + <pathelement location="${lib.starr14.jar}"/> + <pathelement location="${comp.starr14.jar}"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </path> + </then> + <else> + <path id="starr.classpath"> + <pathelement location="${lib.starr.jar}"/> + <pathelement location="${comp.starr.jar}"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </path> + </else> + </if> + <!-- Creating boot-level tasks --> + <taskdef + name="starr" + classname="scala.tools.ant.Scalac" + classpathref="starr.classpath"/> + <taskdef + name="starrtool" + classname="scala.tools.ant.ScalaTool" + classpathref="starr.classpath" /> + <!-- Removing any outdated stuff --> + <if> + <and> + <available file="${locker.dir}/complete"/> + <not><uptodate targetfile="${locker.dir}/complete"> + <srcfiles dir="${lib.dir}" includes="scala-*.jar"/> + </uptodate></not> + </and> + <then> + <echo level="warning" + message="STARR updated: LOCKER is obsolete and will be rebuilt."/> + <runtarget target="clean.build"/> + </then> + </if> + <!-- Finding out what is available --> + <available property="excludes.avail" file="${nsc.excludes.file}"/> + <condition property="locker.avail"> + <available file="${locker.dir}/complete"/> + </condition> + <!-- Generating version number --> + <property file="${number.file}"/> + <property + name="version.number" + value="${version.major}.${version.minor}.${version.patch}.r${svn.number}-b${time.short}"/> + <!-- And print-out what we are building --> + <echo level="info" message="Build number is '${version.number}'"/> + <echo level="info" message="Built ${time.human} from SVN revision ${svn.number}"/> + </target> + + <target name="setup.locker" depends="setup, build.locker"> + <path id="locker.classpath"> + <pathelement location="${locker.dir}/lib/library"/> + <pathelement location="${locker.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + </path> + <taskdef + name="locker" + classname="scala.tools.ant.Scalac" + classpathref="locker.classpath"/> + </target> + + <target name="setup.quick" depends="setup, build"> + <path id="quick.classpath"> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + </path> + <taskdef + name="quick" classname="scala.tools.ant.Scalac" + classpathref="quick.classpath"/> + <taskdef + name="quicksbaz" classname="scala.tools.ant.ScalaBazaar" + classpathref="quick.classpath"/> + <taskdef + name="quickdoc" classname="scala.tools.ant.Scaladoc" + classpathref="quick.classpath"/> + </target> + +<!-- =========================================================================== +BUILD SUPPORT MACROS +============================================================================ --> + + <macrodef name="build.support"> + <attribute name="build.dir"/> + <sequential> + <copy todir="@{build.dir}/lib/library"> + <fileset dir="${src.dir}/library"> + <include name="**/*.tmpl"/> + <include name="**/*.xml"/> + <include name="**/*.js"/> + <include name="**/*.css"/> + </fileset> + </copy> + <copy todir="@{build.dir}/lib/compiler"> + <fileset dir="${src.dir}/compiler"> + <include name="**/*.tmpl"/> + <include name="**/*.xml"/> + <include name="**/*.js"/> + <include name="**/*.css"/> + </fileset> + </copy> + </sequential> + </macrodef> + + <macrodef name="build.links"> + <attribute name="build.dir"/> + <sequential> + <if><not><available file="@{build.dir}/lib/fjbg.jar"/></not><then> + <if><isset property="os.win"/><then> + <copy file="${fjbg.jar}" tofile="@{build.dir}/lib/fjbg.jar"/> + </then><else> + <symlink + link="@{build.dir}/lib/fjbg.jar" + resource="${fjbg.jar}" overwrite="yes" failonerror="no"/> + </else></if> + </then></if> + <if><not><available file="@{build.dir}/lib/msil.jar"/></not><then> + <if><isset property="os.win"/><then> + <copy file="${msil.jar}" tofile="@{build.dir}/lib/msil.jar"/> + </then><else> + <symlink + link="@{build.dir}/lib/msil.jar" + resource="${msil.jar}" overwrite="yes" failonerror="no"/> + </else></if> + </then></if> + <if><not><available file="@{build.dir}/lib/jline.jar"/></not><then> + <if><isset property="os.win"/><then> + <copy file="${jline.jar}" tofile="@{build.dir}/lib/jline.jar"/> + </then><else> + <symlink + link="@{build.dir}/lib/jline.jar" + resource="${jline.jar}" overwrite="yes" failonerror="no"/> + </else></if> + </then></if> + </sequential> + </macrodef> + +<!-- =========================================================================== +BUILD LOCAL REFERENCE (LOCKER) LAYER +============================================================================ --> + + <target name="newlocker" + depends="clean.unfreeze, build.locker" + description="Rebuilds LOCKER from the current sources"/> + + <target name="build.locker" depends="setup" unless="locker.avail"> + <property name="built.locker" value="yes"/> + <stopwatch name="timer.locker"/> + <!-- Build library --> + <if><and> + <isset property="os.unix"/> + <isset property="build.resource"/></and> + <then> + <symlink + link="${build.dir}" + resource="${build.resource}" overwrite="yes" failonerror="no"/> + <touch file="${build.dir}/is_symlink" verbose="no"/> + </then></if> + <mkdir dir="${locker.dir}/lib/library"/> + <javac + srcdir="${src.dir}/library" + destdir="${locker.dir}/lib/library" + source="1.4" target="1.4" deprecation="yes" + classpath="${locker.dir}/lib/library" + includes="**/*.java"/> + <starr + srcdir="${src.dir}/library" + destdir="${locker.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + classpath="${locker.dir}/lib/library" + includes="scala/Predef.scala"/> + <starr + srcdir="${src.dir}/library" + destdir="${locker.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + classpath="${locker.dir}/lib/library"> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <exclude name="scala/dbc/**"/> + <exclude name="scala/actors/**"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </starr> + <echo + file="${locker.dir}/lib/library/${lib.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${locker.dir}/lib/library/${lib.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build compiler --> + <mkdir dir="${locker.dir}/lib/compiler"/> + <starr + srcdir="${src.dir}/compiler" + destdir="${locker.dir}/lib/compiler" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes"> + <classpath> + <pathelement location="${locker.dir}/lib/library"/> + <pathelement location="${locker.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </classpath> + <include name="**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </starr> + <echo + file="${locker.dir}/lib/compiler/${comp.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${locker.dir}/lib/compiler/${comp.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Timing the build --> + <stopwatch name="timer.locker" action="total"/> + <!-- Copy support files to build folder and links external libraries--> + <build.support build.dir="${locker.dir}"/> + <build.links build.dir="${locker.dir}"/> + <!-- Build executable files --> + <taskdef + name="lockertool" + classname="scala.tools.ant.ScalaTool" + classpathref="locker.classpath"/> + <mkdir dir="${locker.dir}/bin"/> + <lockertool + file="${locker.dir}/bin/${scala.exec.name}" + class="scala.tools.nsc.MainGenericRunner" + javaFlags="${java.flags}"/> + <lockertool + file="${locker.dir}/bin/${scalac.exec.name}" + class="scala.tools.nsc.Main" + javaFlags="${java.flags}"/> + <lockertool + file="${locker.dir}/bin/${scaladoc.exec.name}" + class="scala.tools.nsc.ScalaDoc" + javaFlags="${java.flags}"/> + <lockertool + file="${locker.dir}/bin/${fsc.exec.name}" + class="scala.tools.nsc.CompileClient" + javaFlags="${java.flags}"/> + <chmod perm="ugo+rx" + file="${locker.dir}/bin/${scalac.exec.name}"/> + <chmod perm="ugo+rx" + file="${locker.dir}/bin/${scala.exec.name}"/> + <chmod perm="ugo+rx" + file="${locker.dir}/bin/${scaladoc.exec.name}"/> + <chmod perm="ugo+rx" + file="${locker.dir}/bin/${fsc.exec.name}"/> + <fixcrlf + srcdir="${locker.dir}/bin" + eol="dos" + includes="**/*.bat"/> + <!-- Mark LOCKER as being completely built --> + <touch file="${locker.dir}/complete" verbose="no"/> + </target> + +<!-- =========================================================================== +BUILD QUICK-TEST LAYER +============================================================================ --> + + <target name="build" depends="setup.locker" + description="Builds a quick-test (QUICK) version of the compiler"> + <stopwatch name="timer.quick"/> + <!-- Build library --> + <mkdir dir="${quick.dir}/lib/library"/> + <javac + srcdir="${src.dir}/library" + destdir="${quick.dir}/lib/library" + source="1.4" target="1.4" deprecation="yes" + classpath="${quick.dir}/lib/library" + includes="**/*.java"/> + <locker + srcdir="${src.dir}/library" + destdir="${quick.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + scalacdebugging="${nsc.log-files}" + classpath="${quick.dir}/lib/library" + includes="scala/Predef.scala"/> + <locker + srcdir="${src.dir}/library" + destdir="${quick.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + scalacdebugging="${nsc.log-files}" + classpath="${quick.dir}/lib/library"> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <exclude name="scala/dbc/**"/> + <exclude name="scala/actors/**"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </locker> + <echo + file="${quick.dir}/lib/library/${lib.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${quick.dir}/lib/library/${lib.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build DBC --> + <mkdir dir="${quick.dir}/lib/dbc"/> + <locker + srcdir="${src.dir}/dbc" + destdir="${quick.dir}/lib/dbc" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + scalacdebugging="${nsc.log-files}"> + <classpath> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/dbc"/> + </classpath> + <include name="scala/dbc/**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </locker> + <!-- Build actors library --> + <mkdir dir="${quick.dir}/lib/actors"/> + <javac + srcdir="${src.dir}/actors" + destdir="${quick.dir}/lib/actors" + source="1.4" target="1.4" deprecation="yes" + classpath="${quick.dir}/lib/actors" + includes="scala/actors/**/*.java"/> + <locker + srcdir="${src.dir}/actors" + destdir="${quick.dir}/lib/actors" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + scalacdebugging="${nsc.log-files}"> + <classpath> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/actors"/> + </classpath> + <include name="scala/actors/**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </locker> + <!-- Build compiler --> + <mkdir dir="${quick.dir}/lib/compiler"/> + <locker + srcdir="${src.dir}/compiler" + destdir="${quick.dir}/lib/compiler" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + scalacdebugging="${nsc.log-files}"> + <classpath> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </classpath> + <include name="**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </locker> + <echo + file="${quick.dir}/lib/compiler/${comp.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${quick.dir}/lib/compiler/${comp.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build partest --> + <mkdir dir="${quick.dir}/lib/partest"/> + <javac + srcdir="${src.dir}/partest" + destdir="${quick.dir}/lib/partest" + source="1.4" target="1.4" deprecation="yes" + classpath="${quick.dir}/lib/partest" + includes="scala/tools/partest/**/*.java"/> + <locker + srcdir="${src.dir}/partest" + destdir="${quick.dir}/lib/partest" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes"> + <classpath> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/compiler"/> + <pathelement location="${quick.dir}/lib/actors"/> + <pathelement location="${ant.jar}"/> + </classpath> + </locker> + <echo + file="${quick.dir}/lib/partest/${par.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${quick.dir}/lib/partest/${par.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Timing the build --> + <stopwatch name="timer.quick" action="total"/> + <!-- Copy support files to build folder and links external libraries--> + <build.support build.dir="${quick.dir}"/> + <build.links build.dir="${quick.dir}"/> + <!-- Build executable files --> + <taskdef + name="quicktool" + classname="scala.tools.ant.ScalaTool" + classpathref="quick.classpath"/> + <mkdir dir="${quick.dir}/bin"/> + <quicktool + file="${quick.dir}/bin/${scala.exec.name}" + class="scala.tools.nsc.MainGenericRunner" + javaFlags="${java.flags}"/> + <quicktool + file="${quick.dir}/bin/${scalac.exec.name}" + class="scala.tools.nsc.Main" + javaFlags="${java.flags}"/> + <quicktool + file="${quick.dir}/bin/${scaladoc.exec.name}" + class="scala.tools.nsc.ScalaDoc" + javaFlags="${java.flags}"/> + <quicktool + file="${quick.dir}/bin/${fsc.exec.name}" + class="scala.tools.nsc.CompileClient" + javaFlags="${java.flags}"/> + <chmod perm="ugo+rx" + file="${quick.dir}/bin/${scalac.exec.name}"/> + <chmod perm="ugo+rx" + file="${quick.dir}/bin/${scala.exec.name}"/> + <chmod perm="ugo+rx" + file="${quick.dir}/bin/${scaladoc.exec.name}"/> + <chmod perm="ugo+rx" + file="${quick.dir}/bin/${fsc.exec.name}"/> + <fixcrlf + srcdir="${quick.dir}/bin" + eol="dos" + includes="**/*.bat"/> + </target> + + <target name="test.quick" depends="build"> + <echo level="info" + message="Ant test bench is not available yet."/> + </target> + +<!-- =========================================================================== +CLDC +============================================================================ --> +<!-- + <property name="cldcapi.jar" value="${lib.dir}/cldcapi10.jar"/> + <property name="midpapi.jar" value="${lib.dir}/midpapi10.jar"/> + + <target name="cldc.sources" + description="Create the source directory for the J2ME (CLDC) library" + > + <mkdir dir="${cldc.dir}/src"/> + + <copy todir="${cldc.dir}/src"> + <fileset dir="${src.dir}/library" includes="**/*.scala, **/*.java"> + <not> + <present targetdir="${src.dir}/cldc-library"/> + </not> + <exclude name="**/*CharSequence.scala"/> + <exclude name="**/jcl/**"/> + <exclude name="**/ref/**"/> + <exclude name="**/compat/**"/> + <exclude name="**/concurrent/**"/> + <exclude name="**/runtime/RichFloat.scala"/> + <exclude name="**/runtime/RichDouble.scala"/> + <exclude name="**/util/**"/> + <exclude name="**/xml/**"/> + </fileset> + </copy> + + <copy todir="${cldc.dir}/src"> + <fileset dir="${src.dir}/cldc-library"> + <include name="**/*.scala"/> + <include name="**/*.java"/> + </fileset> + </copy> + + </target> + + <target name="cldc.libraries" + depends="setup.quick, cldc.sources" + description="Builds the Scala library for J2ME (CLDC)" + > + <mkdir dir="${cldc.dir}/lib/library"/> + <javac + srcdir="${cldc.dir}/src" + destdir="${cldc.dir}/lib/library" + compiler="javac1.4" + source="1.1" + target="1.1" + deprecation="${jc.deprecation}" + > + <bootclasspath> + <pathelement location="${cldcapi.jar}"/> + </bootclasspath> + <include name="**/*.java"/> + <exclude name="scala/runtime/FloatRef.java"/> + <exclude name="scala/runtime/DoubleRef.java"/> + </javac> + + <quick + srcdir="${cldc.dir}/src" + destdir="${cldc.dir}/lib/library" + addparams="${nsc.params}" + target="cldc" + scalacdebugging="${nsc.log-files}" + > + <bootclasspath> + <pathelement location="${cldcapi.jar}"/> + </bootclasspath> + <classpath> + <pathelement location="${cldc.dir}"/> + </classpath> + <include name="scala/Predef.scala"/> + </quick> + <quick + srcdir="${cldc.dir}/src" + destdir="${cldc.dir}/lib/library" + target="cldc" + addparams="${nsc.params}" + scalacdebugging="${nsc.log-files}" + > + <bootclasspath> + <pathelement location="${cldcapi.jar}"/> + </bootclasspath> + <classpath> + <pathelement location="${cldc.dir}"/> + </classpath> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <exclude name="scala/BigDecimal.scala"/> + <exclude name="scala/BigInt.scala"/> + <exclude name="scala/collection/mutable/JavaMapAdaptor.scala"/> + <exclude name="scala/collection/mutable/JavaSetAdaptor.scala"/> + <exclude name="scala/collection/mutable/LinkedHashSet.scala"/> + <exclude name="scala/util/Fluid.scala"/> + <exclude name="scala/runtime/BoxedFloatArray.scala"/> + <exclude name="scala/runtime/BoxedDoubleArray.scala"/> + <exclude name="scala/io/**"/> + <exclude name="scala/mobile/**"/> + <exclude name="scala/reflect/**"/> + <exclude name="scala/text/**"/> + <exclude name="scala/testing/**"/> + <exclude name="scala/xml/**"/> + <excludesfile name="${nsc.excludes}" if="excludes.avail"/> + </quick> + <macrodef name="preverify"> + <attribute name="srcdir"/> + <attribute name="destdir"/> + <sequential> + <exec executable="preverify" failonerror="false"> + <arg line="-classpath ${cldcapi.jar}${path.separator}${midpapi.jar}"/> + <arg line="-target cldc1.0"/> + <arg line="-d @{destdir}"/> + <arg value="@{srcdir}"/> + </exec> + </sequential> + </macrodef> + <mkdir dir="${cldc.dir}/lib/preverified"/> + <preverify + srcdir="${cldc.dir}/lib/library" + destdir="${cldc.dir}/lib/preverified" + /> + <jar + destfile="${cldc.dir}/lib/scalaapi10-unverified.jar" + basedir="${cldc.dir}/lib/library" + includes="scala/**/*.class"> + <manifest> + <attribute name="Created-By" value="${version.number} (${vendor.name})"/> + </manifest> + </jar> + <jar + destfile="${cldc.dir}/lib/scalaapi10.jar" + basedir="${cldc.dir}/lib/preverified" + includes="scala/**/*.class"> + <manifest> + <attribute name="Created-By" value="${version.number} (${vendor.name})"/> + <attribute name="API-Specification-Version" value="1.0"/> + <attribute name="API" value="Scala CLDC"/> + <attribute name="API-Name" value="Scala Connected Limited Device Configuration"/> + <attribute name="API-Type" value="Configuration"/> + </manifest> + </jar> + </target> + + <target name="cldc" depends="cldc.libraries"> + </target> +--> + +<!-- =========================================================================== +ANDROID +============================================================================ --> + + <target name="android.init"> + <!-- Sets location of Android installation --> + <condition property="android.home" value="${unix.android.home}"> + <and><os family="unix"/><isset property="unix.android.home"/></and> + </condition> + <condition property="android.home" value="${win.android.home}"> + <and><os family="windows"/><isset property="win.android.home"/></and> + </condition> + <property name="android.home" value="${env.ANDROID_HOME}"/> + + <fail message="Android home is not set or could not find android.jar in ${android.home}"> + <condition><not> + <available file="${android.home}/android.jar"/> + </not></condition> + </fail> + </target> + + <target name="android.sources" depends="android.init" + description="Create the source directory for Android library" + > + <mkdir dir="${android.dir}/src"/> + <copy todir="${android.dir}/src"> + <fileset dir="${src.dir}/android-library" includes="**/*.scala, **/*.java"/> + </copy> + <copy todir="${android.dir}/src"> + <fileset dir="${src.dir}/library" includes="**/*.scala, **/*.java" /> + </copy> + </target> + + <target name="android.libraries" + depends="setup.quick, android.sources" + description="Builds the Scala library for Android"> + <mkdir dir="${android.dir}/lib/library"/> + <javac + srcdir="${android.dir}/src" + destdir="${android.dir}/lib/library" + deprecation="${jc.deprecation}" + > + <bootclasspath> + <pathelement location="${android.home}/android.jar}"/> + </bootclasspath> + <include name="**/*.java"/> + </javac> + + <quick + srcdir="${android.dir}/src" + destdir="${android.dir}/lib/library" + deprecation="yes" unchecked="yes" + addparams="${nsc.params}" + extdirs="" + scalacdebugging="${nsc.log-files}" + > + <bootclasspath> + <pathelement location="${android.home}/android.jar"/> + </bootclasspath> + <include name="scala/Predef.scala"/> + </quick> + + <quick + srcdir="${android.dir}/src" + destdir="${android.dir}/lib/library" + deprecation="yes" unchecked="yes" + extdirs="" + addparams="${nsc.params}" + scalacdebugging="${nsc.log-files}" + > + <bootclasspath> + <pathelement location="${android.home}/android.jar"/> + </bootclasspath> + <classpath> + <pathelement location="${android.dir}"/> + </classpath> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <excludesfile name="${nsc.excludes}" if="excludes.avail"/> + </quick> + </target> + + <target name="android.build" depends="android.libraries" + description="Convert this project's .class files into .dex files"> + <property name="dx.jar" value="${android.home}/tools/lib/dx.jar"/> + <java jar="${dx.jar}" fork="true" failonerror="true"> + <jvmarg value="-Djava.ext.dirs=${android.home}${file.separator}tools${file.separator}lib"/> + <jvmarg value="-Xmx384M"/> + <arg value="--dex"/> + <arg value="--output=${android.dir}/lib/scala.dex"/> + <arg value="--locals=full"/> + <arg value="--positions=lines"/> + <arg value="--no-optimize"/> <!-- workaround for M5-RC14 bug --> + <arg value="${android.dir}/lib/library"/> + </java> + <jar + destfile="${android.dir}/lib/scala-dex.jar" + basedir="${android.dir}/lib" + includes="scala.dex" + /> + <jar + destfile="${android.dir}/lib/scala-android.jar" + basedir="${android.dir}/lib/library" + includes="scala/**/*.class" + /> + </target> + + <target name="android" depends="init"> + <condition property="android.supported"> + <and> + <not><contains string="${java.version}" substring="1.4"/></not> + <contains string="${java.vendor}" substring="Sun"/> + </and> + </condition> + <if><isset property="android.supported"/><then> + <antcall target="android.build"/> + </then><else> + <echo message="The Android library build requires Sun Java 1.5 or newer"/> + </else></if> + </target> + +<!-- =========================================================================== +MSIL +============================================================================ --> + + <target name="msil.init" depends="ant-init"> + <!-- Sets ilasm command (either Microsoft .NET Framework or Mono) --> + <condition property="ilasm.cmd" value="${msdn.home}/ilasm.exe"> + <and> + <os family="windows"/><isset property="msdn.home"/> + <available file="${msdn.home}/ilasm.exe"/> + </and> + </condition> + <condition property="ilasm.cmd" value="${unix.mono.home}/ilasm"> + <and> + <os family="unix"/><isset property="unix.mono.home"/> + <available file="${unix.mono.home}/ilasm"/> + </and> + </condition> + <condition property="ilasm.cmd" value="${win.mono.home}/ilasm"> + <and> + <os family="windows"/><isset property="${win.mono.home}/lib/mono/2.0/ilasm.exe"/> + <available file="${win.mono.home}/lib/mono/2.0/ilasm.exe"/> + </and> + </condition> + <echo level="verbose" message="Found: ${ilasm.cmd}"/> + <condition property="ilasm.cmd" value="ilasm"> + <and><available file="ilasm" filepath="${env.PATH}"/></and> + </condition> + <fail message="Command 'ilasm' not found"> + <condition><not><isset property="ilasm.cmd"/></not></condition> + </fail> + <!-- Sets ilasm arguments (either Windows or Unix) --> + <property name="ilasm.outfile" value="${msil.dir}/predef.dll"/> + <if> + <isset property="os.win"/> + <then> + <property + name="ilasm.args" + value="/quiet /dll /output=${ilasm.outfile}" + /> + </then> + <else> + <property + name="ilasm.args" + value="/dll /output:${ilasm.outfile}" + /> + </else> + </if> + </target> + + <target name="msil.sources" depends="msil.init"> + <mkdir dir="${msil.dir}/src"/> + <copy todir="${msil.dir}/src"> + <fileset dir="${src.dir}/dotnet-library" includes="**/*.scala, **/*.cs"/> + </copy> + <copy todir="${msil.dir}/src"> + <fileset dir="${src.dir}/library" includes="**/*.scala"/> + </copy> + </target> + + <target name="msil.libraries" depends="setup.quick, msil.sources"> + <quick srcdir="${msil.dir}/src" destdir="${msil.dir}" target="msil" + assemname="predef" assemrefs="${lib.dir}" + failonerror="false"> + <include name="**/*.scala"/> + <exclude name="scala/ScalaObject.scala"/> + <!-- + <include name="scala/Predef.scala"/> + <include name="scala/Either.scala"/> + <include name="scala/Option.scala"/> + <include name="scala/Pair.scala"/> + <include name="scala/Console.scala"/> + <include name="scala/Application.scala"/> + <include name="scala/ByNameFunction.scala"/> + <include name="scala/Stream.scala"/> + <include name="scala/*Annotation.scala"/> + <include name="scala/Function*.scala"/> + <include name="scala/Tuple*.scala"/> + <include name="scala/Product*.scala"/> + <include name="scala/List.scala"/> + <include name="scala/cloneable.scala"/> + <include name="scala/deprecated.scala"/> + <include name="scala/native.scala"/> + <include name="scala/serializable.scala"/> + <include name="scala/transient.scala"/> + <include name="scala/volatile.scala"/> + <include name="scala/remote.scala"/> + <include name="scala/throws.scala"/> + <include name="scala/BigInt.scala"/> + <include name="scala/CountedIterator.scala"/> + <include name="scala/collection/**/*.scala"/> + <include name="scala/runtime/*.scala"/> + <include name="scala/concurrent/*.scala"/> + <include name="scala/ref/*.scala"/> + <include name="scala/reflect/*.scala"/> + <include name="scala/testing/*.scala"/> + <include name="scala/text/*.scala"/> --> + </quick> + <pathconvert property="ilasm.infile" pathsep=" "> + <fileset dir="${msil.dir}" includes="*.msil"/> + </pathconvert> + <exec + executable="${ilasm.cmd}" vmlauncher="no"> + <!-- + errorproperty="ilasm.err" outputproperty="ilasm.out"> + --> + <arg line="${ilasm.args} ${ilasm.infile}"/> + </exec> + </target> + + <target name="msil" depends="msil.libraries"> + <copy todir="${quick.dir}/bin"> + <fileset + dir="${mono.dir}/bin" + includes="scala-net*" + /> + <filterset> + <filter token="VERSION" value="${version.number}"/> + <filter token="COPYRIGHT" value="${copyright.string}"/> + <filter token="NAME" value="Scala code runner"/> + </filterset> + </copy> + <copy todir="${quick.dir}/bin"> + <fileset + dir="${mono.dir}/bin" + includes="scalac-net*" + /> + <filterset> + <filter token="VERSION" value="${version.number}"/> + <filter token="COPYRIGHT" value="${copyright.string}"/> + <filter token="NAME" value="Scala compiler"/> + </filterset> + </copy> + <chmod perm="ugo+rx" + dir="${quick.dir}/bin" includes="*-net*"/> + <if><isset property="os.win"/> + <then> + <copy todir="${quick.dir}/lib"> + <fileset dir="${msil.dir}" includes="*.dll"/> + <fileset dir="${lib.dir}" includes="*.dll"/> + </copy> + </then> + <else> + <symlink + link="${quick.dir}/lib/predef.dll" + resource="${msil.dir}/predef.dll" + overwrite="yes" failonerror="no"/> + <symlink + link="${quick.dir}/lib/scalaruntime.dll" + resource="${lib.dir}/scalaruntime.dll" + overwrite="yes" failonerror="no"/> + <symlink + link="${quick.dir}/lib/mscorlib.dll" + resource="${lib.dir}/mscorlib.dll" + overwrite="yes" failonerror="no"/> + </else> + </if> + </target> + +<!-- =========================================================================== +OPTIMIZE +============================================================================ --> + <target name="optimised" depends="build.optimised" + description="Build the compiler with optimizations on."/> + + <!-- Build the bootstrap layer --> + <target name="build.optimised" depends="setup.quick"> + <stopwatch name="timer.optimised"/> + <!-- Build library --> + <mkdir dir="${optimised.dir}/lib/library"/> + <javac + srcdir="${src.dir}/library" + destdir="${optimised.dir}/lib/library" + source="1.4" target="1.4" deprecation="yes" + classpath="${optimised.dir}/lib/library" + includes="**/*.java"/> + <quick + srcdir="${src.dir}/library" + destdir="${optimised.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + optimise="yes" + classpath="${optimised.dir}/lib/library" + includes="scala/Predef.scala"/> + <quick + srcdir="${src.dir}/library" + destdir="${optimised.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + optimise="yes" + deprecation="yes" unchecked="yes" + classpath="${optimised.dir}/lib/library"> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <exclude name="scala/dbc/**"/> + <exclude name="scala/actors/**"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <echo + file="${optimised.dir}/lib/library/${lib.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${optimised.dir}/lib/library/${lib.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build compiler --> + <mkdir dir="${optimised.dir}/lib/compiler"/> + <quick + srcdir="${src.dir}" + destdir="${optimised.dir}/lib/compiler" + optimise="yes" + addparams="${nsc.params}" target="${nsc.target}"> + <classpath> + <pathelement location="${optimised.dir}/lib/library"/> + <pathelement location="${optimised.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </classpath> + <include name="compiler/**/*.scala"/> + <include name="library/scala/List.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <echo + file="${optimised.dir}/lib/compiler/${comp.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${optimised.dir}/lib/compiler/${comp.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Timing the build --> + <stopwatch name="timer.strap" action="total"/> + <!-- Copy support files to build folder and links external libraries--> + <build.support build.dir="${optimised.dir}"/> + <build.links build.dir="${optimised.dir}"/> + <!-- Build executable files --> + <taskdef + name="straptool" + classname="scala.tools.ant.ScalaTool" + classpathref="quick.classpath"/> + <mkdir dir="${optimised.dir}/bin"/> + <straptool + file="${optimised.dir}/bin/${scala.exec.name}" + class="scala.tools.nsc.MainGenericRunner" + javaFlags="${java.flags}"/> + <straptool + file="${optimised.dir}/bin/${scalac.exec.name}" + class="scala.tools.nsc.Main" + javaFlags="${java.flags}"/> + <straptool + file="${optimised.dir}/bin/${scaladoc.exec.name}" + class="scala.tools.nsc.ScalaDoc" + javaFlags="${java.flags}"/> + <straptool + file="${optimised.dir}/bin/${fsc.exec.name}" + class="scala.tools.nsc.CompileClient" + javaFlags="${java.flags}"/> + <chmod perm="ugo+rx" + file="${optimised.dir}/bin/${scalac.exec.name}"/> + <chmod perm="ugo+rx" + file="${optimised.dir}/bin/${scala.exec.name}"/> + <chmod perm="ugo+rx" + file="${optimised.dir}/bin/${scaladoc.exec.name}"/> + <chmod perm="ugo+rx" + file="${optimised.dir}/bin/${fsc.exec.name}"/> + <fixcrlf + srcdir="${optimised.dir}/bin" + eol="dos" + includes="**/*.bat"/> + </target> + + +<!-- =========================================================================== +TEST +============================================================================ --> + + <target name="test" depends="test.stability, test.strap" + description="Tests the build for stability"/> + + <!-- Build the bootstrap layer --> + <target name="build.strap" depends="setup.quick"> + <stopwatch name="timer.strap"/> + <!-- Build library --> + <mkdir dir="${strap.dir}/lib/library"/> + <javac + srcdir="${src.dir}/library" + destdir="${strap.dir}/lib/library" + source="1.4" target="1.4" deprecation="yes" + classpath="${strap.dir}/lib/library" + includes="**/*.java"/> + <quick + srcdir="${src.dir}/library" + destdir="${strap.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + classpath="${strap.dir}/lib/library" + includes="scala/Predef.scala"/> + <quick + srcdir="${src.dir}/library" + destdir="${strap.dir}/lib/library" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + classpath="${strap.dir}/lib/library"> + <include name="**/*.scala"/> + <exclude name="scala/Predef.scala"/> + <exclude name="scala/dbc/**"/> + <exclude name="scala/actors/**"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <echo + file="${strap.dir}/lib/library/${lib.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${strap.dir}/lib/library/${lib.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build DBC --> + <mkdir dir="${strap.dir}/lib/dbc"/> + <quick + srcdir="${src.dir}/dbc" + destdir="${strap.dir}/lib/dbc" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes"> + <classpath> + <pathelement location="${strap.dir}/lib/library"/> + <pathelement location="${strap.dir}/lib/dbc"/> + </classpath> + <include name="scala/dbc/**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <!-- Build actors library --> + <mkdir dir="${strap.dir}/lib/actors"/> + <javac + srcdir="${src.dir}/actors" + destdir="${strap.dir}/lib/actors" + source="1.4" target="1.4" deprecation="yes" + classpath="${strap.dir}/lib/actors" + includes="scala/actors/**/*.java"/> + <quick + srcdir="${src.dir}/actors" + destdir="${strap.dir}/lib/actors" + addparams="${nsc.params}" target="${nsc.target}"> + <classpath> + <pathelement location="${strap.dir}/lib/library"/> + <pathelement location="${strap.dir}/lib/actors"/> + </classpath> + <include name="scala/actors/**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <!-- Build compiler --> + <mkdir dir="${strap.dir}/lib/compiler"/> + <quick + srcdir="${src.dir}/compiler" + destdir="${strap.dir}/lib/compiler" + addparams="${nsc.params}" target="${nsc.target}"> + <classpath> + <pathelement location="${strap.dir}/lib/library"/> + <pathelement location="${strap.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </classpath> + <include name="**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quick> + <echo + file="${strap.dir}/lib/compiler/${comp.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${strap.dir}/lib/compiler/${comp.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Build partest --> + <mkdir dir="${strap.dir}/lib/partest"/> + <javac + srcdir="${src.dir}/partest" + destdir="${strap.dir}/lib/partest" + source="1.4" target="1.4" deprecation="yes" + classpath="${strap.dir}/lib/partest" + includes="scala/tools/partest/**/*.java"/> + <quick + srcdir="${src.dir}/partest" + destdir="${strap.dir}/lib/partest" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes"> + <classpath> + <pathelement location="${strap.dir}/lib/library"/> + <pathelement location="${strap.dir}/lib/compiler"/> + <pathelement location="${strap.dir}/lib/actors"/> + <pathelement location="${ant.jar}"/> + </classpath> + </quick> + <echo + file="${strap.dir}/lib/partest/${par.prop.name}" + message="version.number=${version.number}${line.separator}" + append="false" + /> + <echo + file="${strap.dir}/lib/partest/${par.prop.name}" + message="copyright.string=${copyright.string}${line.separator}" + append="true" + /> + <!-- Timing the build --> + <stopwatch name="timer.strap" action="total"/> + <!-- Copy support files to build folder and links external libraries--> + <build.support build.dir="${strap.dir}"/> + <build.links build.dir="${strap.dir}"/> + <!-- Build executable files --> + <taskdef + name="straptool" + classname="scala.tools.ant.ScalaTool" + classpathref="quick.classpath"/> + <mkdir dir="${strap.dir}/bin"/> + <straptool + file="${strap.dir}/bin/${scala.exec.name}" + class="scala.tools.nsc.MainGenericRunner" + javaFlags="${java.flags}"/> + <straptool + file="${strap.dir}/bin/${scalac.exec.name}" + class="scala.tools.nsc.Main" + javaFlags="${java.flags}"/> + <straptool + file="${strap.dir}/bin/${scaladoc.exec.name}" + class="scala.tools.nsc.ScalaDoc" + javaFlags="${java.flags}"/> + <straptool + file="${strap.dir}/bin/${fsc.exec.name}" + class="scala.tools.nsc.CompileClient" + javaFlags="${java.flags}"/> + <chmod perm="ugo+rx" + file="${strap.dir}/bin/${scalac.exec.name}"/> + <chmod perm="ugo+rx" + file="${strap.dir}/bin/${scala.exec.name}"/> + <chmod perm="ugo+rx" + file="${strap.dir}/bin/${scaladoc.exec.name}"/> + <chmod perm="ugo+rx" + file="${strap.dir}/bin/${fsc.exec.name}"/> + <fixcrlf + srcdir="${strap.dir}/bin" + eol="dos" + includes="**/*.bat"/> + </target> + + <!-- Compares quick and test level --> + <target name="test.stability" depends="build.strap"> + <if><available file="${stability.tool}"/> + <then> <!-- use stability tool for fast checking --> + <exec executable="${stability.tool}" failonerror="true"> + <arg value="${quick.dir}"/> + <arg value="${strap.dir}"/> + </exec> + </then><else> <!-- check stability the slow way --> + <checksum totalproperty="quick.md5"> + <fileset dir="${quick.dir}/lib"> + <include name="library/**"/> + <include name="compiler/**"/> + </fileset> + </checksum> + <delete quiet="yes" failonerror="no"> + <fileset dir="${quick.dir}" includes="**/*.MD5"/> + </delete> + <checksum totalproperty="strap.md5"> + <fileset dir="${strap.dir}/lib"> + <include name="library/**"/> + <include name="compiler/**"/> + </fileset> + </checksum> + <delete quiet="yes" failonerror="no"> + <fileset dir="${strap.dir}" includes="**/*.MD5"/> + </delete> + <fail message="Build ${version.number} is not stable"> + <condition><not> + <equals arg1="${quick.md5}" arg2="${strap.md5}"/> + </not></condition> + </fail> + <echo level="info" message="Build ${version.number} is stable."/> + </else></if> + </target> + + <target name="test.strap" depends="build.strap"> + <echo level="info" message="Ant test bench is not available yet."/> + </target> + +<!-- =========================================================================== +DOCUMENTATION +============================================================================ --> + + <target name="docs" depends="setup.quick" + description="Generated the API for library sources"> + <mkdir dir="${api-lib.dir}"/> + <quickdoc + srcdir="${src.dir}" + destdir="${api-lib.dir}" + sourcepath="" + deprecation="yes" unchecked="yes" + windowtitle="Scala Library Documentation" + doctitle="<div>Scala ${version.number}<br/>API Specification</div>" + classpath="${quick.dir}/lib/library${path.separator}${quick.dir}/lib/actors"> + <include name="dbc/**/*.scala"/> + <include name="actors/**/*.scala"/> + <include name="library/**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quickdoc> + </target> + + <target name="docs.compiler" depends="setup.quick" + description="Generated the API for compiler sources"> + <mkdir dir="${api-comp.dir}"/> + <quickdoc + srcdir="${src.dir}/compiler" + destdir="${api-comp.dir}" + sourcepath="" + windowtitle="Scala Compiler Documentation" + doctitle="<div>Scala ${version.number}<br/>API Specification</div>"> + <classpath> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${quick.dir}/lib/compiler"/> + <pathelement location="${fjbg.jar}"/> + <pathelement location="${msil.jar}"/> + <pathelement location="${ant.jar}"/> + <pathelement location="${jline.jar}"/> + </classpath> + <include name="**/*.scala"/> + <excludesfile name="${nsc.excludes.file}" if="excludes.avail"/> + </quickdoc> + </target> + + <target name="docs.manual" depends="setup.quick" + description="Generated the manual for the Scala tools"> + <mkdir dir="${tooldocs.dir}/classes"/> + <path id="manual.classpath"> + <pathelement location="${quick.dir}/lib/library"/> + <pathelement location="${tooldocs.dir}/classes"/> + </path> + <quick + srcdir="${src.dir}/manual" + destdir="${tooldocs.dir}/classes" + addparams="${nsc.params}" target="${nsc.target}" + deprecation="yes" unchecked="yes" + classpathref="manual.classpath"> + <include name="**/*.scala"/> + </quick> + <emit command="fsc"/> + <emit command="sbaz"/> + <emit command="scala"/> + <emit command="scalac"/> + <emit command="scaladoc"/> + <emit command="scalap"/> + <fixcrlf srcdir="${tooldocs.dir}" eol="unix" includes="**/*.1"/> + <copy todir="${tooldocs.dir}"> + <fileset dir="${src.dir}/manual/scala/tools/docutil/resources"> + <include name="**/*.html"/> + <include name="**/*.css"/> + <include name="**/*.gif"/> + <include name="**/*.png"/> + </fileset> + </copy> + </target> + + <macrodef name="emit"> + <attribute name="command"/> + <sequential> + <java classname="scala.tools.docutil.EmitHtml" + output="${tooldocs.dir}/@{command}.html" + classpathref="manual.classpath" + fork="true" logError="yes" + > + <arg value="scala.man1.@{command}"/> + </java> + <java classname="scala.tools.docutil.EmitManPage" + output="${tooldocs.dir}/@{command}.1" + classpathref="manual.classpath" + fork="true" logError="yes" + > + <arg value="scala.man1.@{command}"/> + </java> + </sequential> + </macrodef> + +<!-- =========================================================================== +GENERATES A DISTRIBUTION +============================================================================ --> + + <target name="dist.devel" depends="init"> + <property file="${number.file}"/> + <property name="version.number" + value="${version.major}.${version.minor}.${version.patch}.r${svn.number}"/> + <runtarget target="pack"/> + </target> + + <target name="dist.patch" depends="init"> + <property file="${number.file}"/> + <property name="version.number" + value="${version.major}.${version.minor}.${version.patch}.${version.suffix}"/> + <runtarget target="pack"/> + </target> + + <target name="dist.minor" depends="init"> + <property file="${number.file}"/> + <property name="version.number" + value="${version.major}.${version.minor}.${version.patch}.${version.suffix}"/> + <runtarget target="pack"/> + </target> + + <target name="dist" + depends="clean.build, test, build.dist" + description="Creates a (stability-)tested, complete Scala distribution *from scratch*"/> + + <target name="pack" + depends="build.archive, build.sbaz" + description="Packs a distribution for SBaz and ZIP/TAR"/> + + <target name="binaries" + depends="setup, build.strap" + description="Creates a binary Scala distribution"> + <property name="dist.current.dir" + value="${dist.dir}/scala-${version.number}"/> + <if><and> + <isset property="os.unix"/> + <isset property="dist.resource"/></and> + <then> + <symlink + link="${dist.dir}" + resource="${dist.resource}" overwrite="yes" failonerror="no"/> + <touch file="${dist.dir}/is_symlink" verbose="no"/> + </then></if> + <mkdir dir="${dist.current.dir}"/> + <!-- Copy all requires libraries --> + <mkdir dir="${dist.current.dir}/lib"/> + <property name="ant.version.number" value="1.6.0"/> + <!-- see http://swik.net/Spring/Interface21+Team+Blog/Creating+OSGi+bundles/b2yoy --> + <propertyregex + property="osgi.version.number" input="${version.number}" + regexp="([^-]*)(-.*)?" select="\1" + /> + <echo level="verbose" message="OSGi version: ${osgi.version.number}"/> + <jar destfile="${dist.current.dir}/lib/${comp.jar.name}"> + <fileset dir="${strap.dir}/lib/compiler"/> + <zipfileset src="${fjbg.jar}"/> + <zipfileset src="${msil.jar}"/> + <manifest> + <attribute name="Signature-Version" value="${version.number}"/> + <attribute name="Built-By" value="${user.name}"/> + <attribute name="Main-Class" value="scala.tools.nsc.Main"/> + <attribute name="Class-Path" value="${lib.jar.name}"/> + <section name="scala/tools/nsc"> + <attribute name="Extension-Name" value="scala.tools.nsc"/> + <attribute name="Specification-Title" value="Scala Compiler"/> + <attribute name="Specification-Version" value="${version.number}"/> + <attribute name="Specification-Vendor" value="${vendor.name}"/> + <attribute name="Implementation-Title" value="scala.tools.nsc"/> + <attribute name="Implementation-Version" value="${version.number}"/> + <attribute name="Implementation-Vendor" value="${vendor.name}"/> + </section> + <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> + <attribute name="Bundle-ManifestVersion" value="2"/> + <attribute name="Bundle-Name" value="Scala Compiler Bundle"/> + <attribute name="Bundle-SymbolicName" value="scala_compiler"/> + <attribute name="Bundle-Version" value="${osgi.version.number}"/> + <attribute name="Bundle-Vendor" value="${vendor.name}"/> + <attribute name="Export-Package" value="scala.tools.ant;version="${osgi.version.number}",scala.tools.nsc;version="${osgi.version.number}",scala.tools.nsc.ast;version="${osgi.version.number}",scala.tools.nsc.ast.parser;version="${osgi.version.number}",scala.tools.nsc.backend;version="${osgi.version.number}",scala.tools.nsc.doc;version="${osgi.version.number}",scala.tools.nsc.io;version="${osgi.version.number}",scala.tools.nsc.matching;version="${osgi.version.number}",scala.tools.nsc.models;version="${osgi.version.number}",scala.tools.nsc.symtab;version="${osgi.version.number}",scala.tools.nsc.symtab.classfile;version="${osgi.version.number}",scala.tools.nsc.symtab.clr;version="${osgi.version.number}",scala.tools.nsc.transform;version="${osgi.version.number}",scala.tools.nsc.typechecker;version="${osgi.version.number}",scala.tools.nsc.util;version="${osgi.version.number}",scala.tools.util;version="${osgi.version.number}""/> + <attribute name="Import-Package" value="org.apache.ant.tools;version="${ant.version.number}";resolution:=optional,org.apache.ant.tools.taskdefs;version="${ant.version.number}";resolution:=optional,org.apache.ant.types;version="${ant.version.number}";resolution:=optional,org.apache.ant.tools.util;version="${ant.version.number}";resolution:=optional,org.xml.sax"/> + <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> + </manifest> + </jar> + <jar destfile="${dist.current.dir}/lib/${lib.jar.name}"> + <fileset dir="${strap.dir}/lib/library"/> + <fileset dir="${strap.dir}/lib/actors"/> + <manifest> + <attribute name="Signature-Version" value="${version.number}"/> + <attribute name="Built-By" value="${user.name}"/> + <attribute name="Main-Class" value="scala.util.Properties"/> + <section name="scala"> + <attribute name="Extension-Name" value="scala"/> + <attribute name="Specification-Title" value="Scala Library"/> + <attribute name="Specification-Version" value="${version.number}"/> + <attribute name="Specification-Vendor" value="${vendor.name}"/> + <attribute name="Implementation-Title" value="scala"/> + <attribute name="Implementation-Version" value="${version.number}"/> + <attribute name="Implementation-Vendor" value="${vendor.name}"/> + </section> + <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> + <attribute name="Bundle-ManifestVersion" value="2"/> + <attribute name="Bundle-Name" value="Scala Library Bundle"/> + <attribute name="Bundle-SymbolicName" value="scala_library"/> + <attribute name="Bundle-Version" value="${osgi.version.number}"/> + <attribute name="Bundle-Vendor" value="${vendor.name}"/> + <attribute name="Export-Package" value="scala;version="${osgi.version.number}",scala.actors;version="${osgi.version.number}",scala.actors.remote;version="${osgi.version.number}",scala.collection;version="${osgi.version.number}",scala.collection.immutable;version="${osgi.version.number}",scala.collection.jcl;version="${osgi.version.number}",scala.collection.mutable;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}",scala.concurrent;version="${osgi.version.number}",scala.io;version="${osgi.version.number}",scala.mobile;version="${osgi.version.number}",scala.ref;version="${osgi.version.number}",scala.reflect;version="${osgi.version.number}",scala.runtime;version="${osgi.version.number}",scala.testing;version="${osgi.version.number}",scala.text;version="${osgi.version.number}",scala.util;version="${osgi.version.number}",scala.util.automata;version="${osgi.version.number}",scala.util.grammar;version="${osgi.version.number}",scala.util.logging;version="${osgi.version.number}",scala.util.parsing;version="${osgi.version.number}",scala.util.parsing.ast;version="${osgi.version.number}",scala.util.parsing.combinator;version="${osgi.version.number}",scala.util.parsing.combinator.lexical;version="${osgi.version.number}",scala.util.parsing.combinator.syntactical;version="${osgi.version.number}",scala.util.parsing.combinator.testing;version="${osgi.version.number}",scala.util.parsing.combinatorold;version="${osgi.version.number}",scala.util.parsing.combinatorold.lexical;version="${osgi.version.number}",scala.util.parsing.combinatorold.syntactical;version="${osgi.version.number}",scala.util.parsing.combinatorold.testing;version="${osgi.version.number}",scala.util.parsing.input;version="${osgi.version.number}",scala.util.parsing.json;version="${osgi.version.number}",scala.util.parsing.syntax;version="${osgi.version.number}",scala.util.regexp;version="${osgi.version.number}",scala.xml;version="${osgi.version.number}",scala.xml.dtd;version="${osgi.version.number}",scala.xml.factory;version="${osgi.version.number}",scala.xml.parsing;version="${osgi.version.number}",scala.xml.path;version="${osgi.version.number}",scala.xml.pull;version="${osgi.version.number}",scala.xml.transform;version="${osgi.version.number}""/> + <attribute name="Import-Package" value="javax.xml.parsers,org.xml.sax,org.xml.sax.helpers"/> + <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> + </manifest> + </jar> + <jar destfile="${dist.current.dir}/lib/${dbc.jar.name}"> + <fileset dir="${strap.dir}/lib/dbc"/> + <manifest> + <attribute name="Signature-Version" value="${version.number}"/> + <attribute name="Built-By" value="${user.name}"/> + <attribute name="Class-Path" value="${lib.jar.name}"/> + <section name="scala/dbc"> + <attribute name="Extension-Name" value="scala.dbc"/> + <attribute name="Specification-Title" value="Scala DBC Library"/> + <attribute name="Specification-Version" value="${version.number}"/> + <attribute name="Specification-Vendor" value="${vendor.name}"/> + <attribute name="Implementation-Title" value="scala.dbc"/> + <attribute name="Implementation-Version" value="${version.number}"/> + <attribute name="Implementation-Vendor" value="${vendor.name}"/> + </section> + <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> + <attribute name="Bundle-ManifestVersion" value="2"/> + <attribute name="Bundle-Name" value="Scala DBC Library Bundle"/> + <attribute name="Bundle-SymbolicName" value="scala_dbc_library"/> + <attribute name="Bundle-Version" value="${osgi.version.number}"/> + <attribute name="Bundle-Vendor" value="${vendor.name}"/> + <attribute name="Export-Package" value="scala.dbc;version="${osgi.version.number}",scala.dbc.datatype;version="${osgi.version.number}",scala.dbc.exception;version="${osgi.version.number}",scala.dbc.result;version="${osgi.version.number}",scala.dbc.statement;version="${osgi.version.number}",scala.dbc.statement.expression;version="${osgi.version.number}",scala.dbc.syntax;version="${osgi.version.number}",scala.dbc.value;version="${osgi.version.number}",scala.dbc.vendor;version="${osgi.version.number}""/> + <attribute name="Import-Package" value="scala;version="${osgi.version.number}",scala.compat;version="${osgi.version.number}""/> + <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> + </manifest> + </jar> + <jar destfile="${dist.current.dir}/lib/${partest.jar.name}"> + <fileset dir="${strap.dir}/lib/partest"/> + <manifest> + <attribute name="Signature-Version" value="${version.number}"/> + <attribute name="Built-By" value="${user.name}"/> + <attribute name="Main-Class" value="scala.tools.partest.TestRunner"/> + <attribute name="Class-Path" value="${lib.jar.name}"/> + <section name="scala/tools/partest"> + <attribute name="Extension-Name" value="scala.tools.partest"/> + <attribute name="Specification-Title" value="Scala Test Utility"/> + <attribute name="Specification-Version" value="${version.number}"/> + <attribute name="Specification-Vendor" value="${vendor.name}"/> + <attribute name="Implementation-Title" value="scala.tools.partest"/> + <attribute name="Implementation-Version" value="${version.number}"/> + <attribute name="Implementation-Vendor" value="${vendor.name}"/> + </section> + <attribute name="Bundle-DocURL" value="http://www.scala-lang.org/"/> + <attribute name="Bundle-ManifestVersion" value="2"/> + <attribute name="Bundle-Name" value="Scala Test Bundle"/> + <attribute name="Bundle-SymbolicName" value="scala_compiler"/> + <attribute name="Bundle-Version" value="${osgi.version.number}"/> + <attribute name="Bundle-Vendor" value="${vendor.name}"/> + <attribute name="Export-Package" value="scala.tools.partest;version="${osgi.version.number}",scala.tools.partest.utils;version="${osgi.version.number}""/> + <attribute name="Import-Package" value="javax.swing"/> + <attribute name="Bundle-RequiredExecutionEnvironment" value="J2SE-1.4"/> + </manifest> + </jar> + <copy todir="${dist.current.dir}/lib" file="${jline.jar}"/> + + <!-- build source jars --> + <mkdir dir="${dist.current.dir}/src"/> + <jar + destfile="${dist.current.dir}/src/${libsrc.jar.name}"> + <fileset dir="${src.dir}/library"/> + <fileset dir="${src.dir}/actors"/> + </jar> + <jar + destfile="${dist.current.dir}/src/${dbcsrc.jar.name}" + basedir="${src.dir}/dbc" + includes="**/*.scala" + /> + <jar + destfile="${dist.current.dir}/src/${parsrc.jar.name}" + basedir="${src.dir}/partest" + includes="**/*.scala" + /> + <jar + destfile="${dist.current.dir}/src/${compsrc.jar.name}" + basedir="${src.dir}/compiler" + includes="**/*.scala" + /> + + <!-- Copy executable files --> + <mkdir dir="${dist.current.dir}/bin"/> + <copy todir="${dist.current.dir}/bin"> + <fileset dir="${strap.dir}/bin"/> + </copy> + <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scalac.exec.name}"/> + <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scala.exec.name}"/> + <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${scaladoc.exec.name}"/> + <chmod perm="ugo+rx" file="${dist.current.dir}/bin/${fsc.exec.name}"/> + <!-- Recreate the 'latest' link to point to this distribution --> + <if><isset property="os.win"/> + <then> + <copy todir="${dist.dir}/latest"> + <fileset dir="${dist.current.dir}"/> + </copy> + </then> + <else> + <symlink + link="${dist.dir}/latest" + resource="${dist.current.dir}" + overwrite="yes" failonerror="no"/> + </else> + </if> + </target> + + <target name="build.dist" + depends="binaries,docs,docs.manual" + description="Creates the latest Scala distribution"> + <!-- Copy the API, examples and man --> + <copy todir="${dist.current.dir}/doc/scala"> + <fileset dir="${docs.dir}" includes="README,LICENSE"/> + </copy> + <copy todir="${dist.current.dir}/doc/scala/api"> + <fileset dir="${api-lib.dir}"/> + </copy> + <copy todir="${dist.current.dir}/doc/scala/examples"> + <fileset dir="${docs.dir}/examples"/> + </copy> + <copy todir="${dist.current.dir}/man/man1"> + <fileset dir="${tooldocs.dir}" includes="**/*.1"/> + </copy> + <copy todir="${dist.current.dir}/doc/scala/tools"> + <fileset dir="${tooldocs.dir}"> + <include name="**/*.html"/> + <include name="**/*.css"/> + <include name="**/*.gif"/> + <include name="**/*.png"/> + </fileset> + </copy> + <stopwatch name="timer.dist" action="total"/> + </target> + + <!-- Create the SBaz packages --> + <target name="build.sbaz" depends="build.dist,msil,android"> + <property name="sbaz.universe" value="http://www.scala-lang.org/downloads/packages"/> + <mkdir dir="${dist.dir}"/> + <!-- Create the Scala library package --> + <quicksbaz + file="${dist.dir}/scala-library-${version.number}.sbp" + adfile="${dist.dir}/scala-library-${version.number}.advert" + name="scala-library" + version="${version.number}" + desc="The Scala library. This is the minimal requirement to run any Scala program." + link="${sbaz.universe}/scala-library-${version.number}.sbp"> + <libset dir="${dist.current.dir}/lib" includes="${lib.jar.name},${dbc.jar.name}"/> + <srcset dir="${dist.current.dir}/src" includes="${libsrc.jar.name},${dbcsrc.jar.name}"/> + </quicksbaz> + <!-- Create the Scala developer package --> + <quicksbaz + file="${dist.dir}/scala-devel-${version.number}.sbp" + adfile="${dist.dir}/scala-devel-${version.number}.advert" + name="scala-devel" + version="${version.number}" + desc="The Scala developer tools. This contains everything that is required to write, test and document new Scala programs." + depends="scala-library" + link="${sbaz.universe}/scala-devel-${version.number}.sbp"> + <binset dir="${dist.current.dir}/bin" includes="**"/> + <docset dir="${dist.current.dir}/doc" includes="**" excludes="**/scala/api/**,**/scala/tools/**"/> + <libset dir="${dist.current.dir}/lib" includes="${comp.jar.name},${jline.jar.name}"/> + <manset dir="${dist.current.dir}/man" includes="**"/> + <srcset dir="${dist.current.dir}/src" includes="${compsrc.jar.name}"/> + </quicksbaz> + <!-- Create the Scala developer docs package --> + <quicksbaz + file="${dist.dir}/scala-devel-docs-${version.number}.sbp" + adfile="${dist.dir}/scala-devel-docs-${version.number}.advert" + name="scala-devel-docs" + version="${version.number}" + desc="The Scala developer documentation. This contains all developer documentation." + link="${sbaz.universe}/scala-devel-docs-${version.number}.sbp"> + <docset dir="${dist.current.dir}/doc" includes="**/scala/api/**,**/scala/tools/**"/> + </quicksbaz> + <!-- Creates the empty umbrella Scala package --> + <quicksbaz + file="${dist.dir}/scala-${version.number}.sbp" + adfile="${dist.dir}/scala-${version.number}.advert" + name="scala" + version="${version.number}" + desc="The base Scala package that contains everything needed to start using Scala." + depends="scala-library,scala-devel" + link="${sbaz.universe}/scala-${version.number}.sbp"/> + <!-- Creates the Scala test package --> + <quicksbaz + file="${dist.dir}/scala-test-${version.number}.sbp" + adfile="${dist.dir}/scala-test-${version.number}.advert" + name="scala-test" + version="${version.number}" + desc="The Scala test package contains everything needed to test Scala." + link="${sbaz.universe}/scala-test-${version.number}.sbp"> + <binset dir="${basedir}/test" + includes="clitest,diff/diff.*,diff/lib*.dll,scalatest,scalatest.bat,partest"/> + <miscset + dir="${basedir}/test" + includes="files/**/*.args,files/**/*.check,files/**/*.jar,files/**/*.java,files/**/*.scala,files/cli/**/*.check.*,files/jvm/*.so,files/shootout/*.javaopts,files/shootout/*.runner,files/shootout/*.txt"/> + <srcset dir="${dist.current.dir}/src" includes="${parsrc.jar.name}"/> + <libset dir="${dist.current.dir}/lib" includes="${partest.jar.name}"/> + </quicksbaz> + <!-- Creates the MSIL package --> + <quicksbaz + file="${dist.dir}/scala-msil-${version.number}.sbp" + adfile="${dist.dir}/scala-msil-${version.number}.advert" + name="scala-msil" + version="${version.number}" + desc="The Scala MSIL package contains everything needed to use Scala on .NET." + depends="scala-library,scala-devel" + link="${sbaz.universe}/scala-msil-${version.number}.sbp"> + <binset dir="${quick.dir}/bin" includes="scala*net*"/> + <libset dir="${quick.dir}/lib" includes="*.dll"/> + </quicksbaz> + <!-- Creates the CLDC package --> +<!-- + <quicksbaz + file="${dist.dir}/scala-cldc-${version.number}.sbp" + adfile="${dist.dir}/scala-cldc-${version.number}.advert" + name="scala-cldc" + version="${version.number}" + desc="The Scala CLDC package contains everything needed to use Scala on CLDC devices." + link="${sbaz.universe}/scala-cldc-${version.number}.sbp"> + <libset dir="${cldc.dir}/lib" includes="*.jar"/> + </quicksbaz> +--> + <!-- Creates the Android package --> + <if><isset property="android.supported"/><then> + <copy todir="${dist.current.dir}/doc/scala-android/examples"> + <fileset dir="${docs.dir}/android-examples"> + <exclude name="**/R.java"/> + </fileset> + </copy> + <quicksbaz + file="${dist.dir}/scala-android-${version.number}.sbp" + adfile="${dist.dir}/scala-android-${version.number}.advert" + name="scala-android" + version="${version.number}" + desc="The Scala Android package contains everything needed to use Scala on Android." + link="${sbaz.universe}/scala-android-${version.number}.sbp"> + <libset dir="${android.dir}/lib" includes="*.jar"/> + <docset dir="${dist.current.dir}/doc/scala-android" includes="**"/> + </quicksbaz> + </then></if> + </target> + + <target name="build.archive" depends="build.dist"> + <tar + destfile="${dist.dir}/scala-${version.number}.tgz" + compression="gzip"> + <tarfileset + prefix="scala-${version.number}" + dir="${dist.current.dir}" + includes="bin/**" mode="755" + /> + <tarfileset + prefix="scala-${version.number}" + dir="${dist.current.dir}" + excludes="bin/**" + /> + </tar> + <checksum + file="${dist.dir}/scala-${version.number}.tgz" + forceOverwrite="yes" + fileext=".md5"/> + <!-- Create zip archive --> + <zip + destfile="${dist.dir}/scala-${version.number}.zip"> + <zipfileset + prefix="scala-${version.number}" + dir="${dist.current.dir}" + /> + </zip> + <checksum + file="${dist.dir}/scala-${version.number}.zip" + forceOverwrite="yes" + fileext=".md5"/> + <!-- Create source archive --> + <copy todir="${dist.dir}/scala-${version.number}"> + <fileset + dir="${basedir}" + excludes="build,build/**,dists/**" + /> + </copy> + <tar basedir="${dist.dir}" + destfile="${dist.dir}/scala-${version.number}-sources.tgz" + compression="gzip" + includes="scala-${version.number}/**" + /> + </target> + +<!-- =========================================================================== +CLEAN +============================================================================ --> + + <macrodef name="remove"> + <attribute name="dir"/> + <sequential> + <if> + <available file="@{dir}/is_symlink"/> + <then> + <delete includeemptydirs="true" quiet="yes" failonerror="no"> + <fileset dir="@{dir}" includes="**/*"/> + </delete> + </then></if> + <delete dir="@{dir}" includeemptydirs="yes" quiet="yes" failonerror="no"/> + </sequential> + </macrodef> + + <target name="clean" depends="ant-init" description="Removes QUICK, STRAP and API build products"> + <remove dir="${quick.dir}"/> + <remove dir="${strap.dir}"/> + <remove dir="${api.dir}"/> + </target> + + <target name="clean.build" depends="ant-init" + description="Removes all build products"> + <remove dir="${build.dir}"/> + </target> + + <target name="clean.msil" depends="ant-init" description="Removes all MSIL build products"> + <remove dir="${msil.dir}"/> + </target> + +<!-- + <target name="clean.cldc" depends="ant-init" description="Removes all CLDC build products"> + <remove dir="${cldc.dir}"/> + </target> +--> + + <target name="clean.all" depends="ant-init" + description="Removes all build products and distributions"> + <remove dir="${build.dir}"/> + <remove dir="${dist.dir}"/> + </target> + + <target name="clean.unfreeze" depends="init"> + <delete file="${locker.dir}/complete" quiet="yes" failonerror="no"/> + <remove dir="${quick.dir}"/> + </target> + +</project> |