diff options
Diffstat (limited to 'Week7 Polynomials')
| -rw-r--r-- | Week7 Polynomials/.gitignore | 3 | ||||
| -rw-r--r-- | Week7 Polynomials/Assignment (in Dutch).pdf | bin | 0 -> 132898 bytes | |||
| -rw-r--r-- | Week7 Polynomials/Week7.tar.gz | bin | 0 -> 5487 bytes | |||
| -rw-r--r-- | Week7 Polynomials/build.xml | 73 | ||||
| -rw-r--r-- | Week7 Polynomials/nbproject/build-impl.xml | 1413 | ||||
| -rw-r--r-- | Week7 Polynomials/nbproject/genfiles.properties | 8 | ||||
| -rw-r--r-- | Week7 Polynomials/nbproject/project.properties | 73 | ||||
| -rw-r--r-- | Week7 Polynomials/nbproject/project.xml | 15 | ||||
| -rw-r--r-- | Week7 Polynomials/src/main/Main.java | 23 | ||||
| -rw-r--r-- | Week7 Polynomials/src/polynomial/Polynomial.java | 189 | ||||
| -rw-r--r-- | Week7 Polynomials/src/polynomial/Term.java | 145 | ||||
| -rw-r--r-- | Week7 Polynomials/test/polynomial/PolynomialTest.java | 226 | 
12 files changed, 2168 insertions, 0 deletions
| diff --git a/Week7 Polynomials/.gitignore b/Week7 Polynomials/.gitignore new file mode 100644 index 0000000..4523fc2 --- /dev/null +++ b/Week7 Polynomials/.gitignore @@ -0,0 +1,3 @@ +nbproject/private/ +build/ +dist/ diff --git a/Week7 Polynomials/Assignment (in Dutch).pdf b/Week7 Polynomials/Assignment (in Dutch).pdfBinary files differ new file mode 100644 index 0000000..5c9bd0c --- /dev/null +++ b/Week7 Polynomials/Assignment (in Dutch).pdf diff --git a/Week7 Polynomials/Week7.tar.gz b/Week7 Polynomials/Week7.tar.gzBinary files differ new file mode 100644 index 0000000..eaa77df --- /dev/null +++ b/Week7 Polynomials/Week7.tar.gz diff --git a/Week7 Polynomials/build.xml b/Week7 Polynomials/build.xml new file mode 100644 index 0000000..a54a461 --- /dev/null +++ b/Week7 Polynomials/build.xml @@ -0,0 +1,73 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- You may freely edit this file. See commented blocks below for --> +<!-- some examples of how to customize the build. --> +<!-- (If you delete it and reopen the project it will be recreated.) --> +<!-- By default, only the Clean and Build commands use this build script. --> +<!-- Commands such as Run, Debug, and Test only use this build script if --> +<!-- the Compile on Save feature is turned off for the project. --> +<!-- You can turn off the Compile on Save (or Deploy on Save) setting --> +<!-- in the project's Project Properties dialog box.--> +<project name="Week7_Polynomials" default="default" basedir="."> +    <description>Builds, tests, and runs the project Week7 Polynomials.</description> +    <import file="nbproject/build-impl.xml"/> +    <!-- + +    There exist several targets which are by default empty and which can be  +    used for execution of your tasks. These targets are usually executed  +    before and after some main targets. They are:  + +      -pre-init:                 called before initialization of project properties +      -post-init:                called after initialization of project properties +      -pre-compile:              called before javac compilation +      -post-compile:             called after javac compilation +      -pre-compile-single:       called before javac compilation of single file +      -post-compile-single:      called after javac compilation of single file +      -pre-compile-test:         called before javac compilation of JUnit tests +      -post-compile-test:        called after javac compilation of JUnit tests +      -pre-compile-test-single:  called before javac compilation of single JUnit test +      -post-compile-test-single: called after javac compilation of single JUunit test +      -pre-jar:                  called before JAR building +      -post-jar:                 called after JAR building +      -post-clean:               called after cleaning build products + +    (Targets beginning with '-' are not intended to be called on their own.) + +    Example of inserting an obfuscator after compilation could look like this: + +        <target name="-post-compile"> +            <obfuscate> +                <fileset dir="${build.classes.dir}"/> +            </obfuscate> +        </target> + +    For list of available properties check the imported  +    nbproject/build-impl.xml file.  + + +    Another way to customize the build is by overriding existing main targets. +    The targets of interest are:  + +      -init-macrodef-javac:     defines macro for javac compilation +      -init-macrodef-junit:     defines macro for junit execution +      -init-macrodef-debug:     defines macro for class debugging +      -init-macrodef-java:      defines macro for class execution +      -do-jar:                  JAR building +      run:                      execution of project  +      -javadoc-build:           Javadoc generation +      test-report:              JUnit report generation + +    An example of overriding the target for project execution could look like this: + +        <target name="run" depends="Week7_Polynomials-impl.jar"> +            <exec dir="bin" executable="launcher.exe"> +                <arg file="${dist.jar}"/> +            </exec> +        </target> + +    Notice that the overridden target depends on the jar target and not only on  +    the compile target as the regular run target does. Again, for a list of available  +    properties which you can use, check the target you are overriding in the +    nbproject/build-impl.xml file.  + +    --> +</project> diff --git a/Week7 Polynomials/nbproject/build-impl.xml b/Week7 Polynomials/nbproject/build-impl.xml new file mode 100644 index 0000000..28a95e1 --- /dev/null +++ b/Week7 Polynomials/nbproject/build-impl.xml @@ -0,0 +1,1413 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- +*** GENERATED FROM project.xml - DO NOT EDIT  *** +***         EDIT ../build.xml INSTEAD         *** + +For the purpose of easier reading the script +is divided into following sections: + +  - initialization +  - compilation +  - jar +  - execution +  - debugging +  - javadoc +  - test compilation +  - test execution +  - test debugging +  - applet +  - cleanup + +        --> +<project xmlns:j2seproject1="http://www.netbeans.org/ns/j2se-project/1" xmlns:j2seproject3="http://www.netbeans.org/ns/j2se-project/3" xmlns:jaxrpc="http://www.netbeans.org/ns/j2se-project/jax-rpc" basedir=".." default="default" name="Week7_Polynomials-impl"> +    <fail message="Please build using Ant 1.8.0 or higher."> +        <condition> +            <not> +                <antversion atleast="1.8.0"/> +            </not> +        </condition> +    </fail> +    <target depends="test,jar,javadoc" description="Build and test whole project." name="default"/> +    <!--  +                ====================== +                INITIALIZATION SECTION  +                ====================== +            --> +    <target name="-pre-init"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="-pre-init" name="-init-private"> +        <property file="nbproject/private/config.properties"/> +        <property file="nbproject/private/configs/${config}.properties"/> +        <property file="nbproject/private/private.properties"/> +    </target> +    <target depends="-pre-init,-init-private" name="-init-user"> +        <property file="${user.properties.file}"/> +        <!-- The two properties below are usually overridden --> +        <!-- by the active platform. Just a fallback. --> +        <property name="default.javac.source" value="1.4"/> +        <property name="default.javac.target" value="1.4"/> +    </target> +    <target depends="-pre-init,-init-private,-init-user" name="-init-project"> +        <property file="nbproject/configs/${config}.properties"/> +        <property file="nbproject/project.properties"/> +    </target> +    <target depends="-pre-init,-init-private,-init-user,-init-project,-init-macrodef-property" name="-do-init"> +        <property name="platform.java" value="${java.home}/bin/java"/> +        <available file="${manifest.file}" property="manifest.available"/> +        <condition property="splashscreen.available"> +            <and> +                <not> +                    <equals arg1="${application.splash}" arg2="" trim="true"/> +                </not> +                <available file="${application.splash}"/> +            </and> +        </condition> +        <condition property="main.class.available"> +            <and> +                <isset property="main.class"/> +                <not> +                    <equals arg1="${main.class}" arg2="" trim="true"/> +                </not> +            </and> +        </condition> +        <condition property="profile.available"> +            <and> +                <isset property="javac.profile"/> +                <length length="0" string="${javac.profile}" when="greater"/> +                <matches pattern="1\.[89](\..*)?" string="${javac.source}"/> +            </and> +        </condition> +        <condition property="do.archive"> +            <or> +                <not> +                    <istrue value="${jar.archive.disabled}"/> +                </not> +                <istrue value="${not.archive.disabled}"/> +            </or> +        </condition> +        <condition property="do.mkdist"> +            <and> +                <isset property="do.archive"/> +                <isset property="libs.CopyLibs.classpath"/> +                <not> +                    <istrue value="${mkdist.disabled}"/> +                </not> +            </and> +        </condition> +        <condition property="do.archive+manifest.available"> +            <and> +                <isset property="manifest.available"/> +                <istrue value="${do.archive}"/> +            </and> +        </condition> +        <condition property="do.archive+main.class.available"> +            <and> +                <isset property="main.class.available"/> +                <istrue value="${do.archive}"/> +            </and> +        </condition> +        <condition property="do.archive+splashscreen.available"> +            <and> +                <isset property="splashscreen.available"/> +                <istrue value="${do.archive}"/> +            </and> +        </condition> +        <condition property="do.archive+profile.available"> +            <and> +                <isset property="profile.available"/> +                <istrue value="${do.archive}"/> +            </and> +        </condition> +        <condition property="have.tests"> +            <or> +                <available file="${test.src.dir}"/> +            </or> +        </condition> +        <condition property="have.sources"> +            <or> +                <available file="${src.dir}"/> +            </or> +        </condition> +        <condition property="netbeans.home+have.tests"> +            <and> +                <isset property="netbeans.home"/> +                <isset property="have.tests"/> +            </and> +        </condition> +        <condition property="no.javadoc.preview"> +            <and> +                <isset property="javadoc.preview"/> +                <isfalse value="${javadoc.preview}"/> +            </and> +        </condition> +        <property name="run.jvmargs" value=""/> +        <property name="run.jvmargs.ide" value=""/> +        <property name="javac.compilerargs" value=""/> +        <property name="work.dir" value="${basedir}"/> +        <condition property="no.deps"> +            <and> +                <istrue value="${no.dependencies}"/> +            </and> +        </condition> +        <property name="javac.debug" value="true"/> +        <property name="javadoc.preview" value="true"/> +        <property name="application.args" value=""/> +        <property name="source.encoding" value="${file.encoding}"/> +        <property name="runtime.encoding" value="${source.encoding}"/> +        <condition property="javadoc.encoding.used" value="${javadoc.encoding}"> +            <and> +                <isset property="javadoc.encoding"/> +                <not> +                    <equals arg1="${javadoc.encoding}" arg2=""/> +                </not> +            </and> +        </condition> +        <property name="javadoc.encoding.used" value="${source.encoding}"/> +        <property name="includes" value="**"/> +        <property name="excludes" value=""/> +        <property name="do.depend" value="false"/> +        <condition property="do.depend.true"> +            <istrue value="${do.depend}"/> +        </condition> +        <path id="endorsed.classpath.path" path="${endorsed.classpath}"/> +        <condition else="" property="endorsed.classpath.cmd.line.arg" value="-Xbootclasspath/p:'${toString:endorsed.classpath.path}'"> +            <and> +                <isset property="endorsed.classpath"/> +                <not> +                    <equals arg1="${endorsed.classpath}" arg2="" trim="true"/> +                </not> +            </and> +        </condition> +        <condition else="" property="javac.profile.cmd.line.arg" value="-profile ${javac.profile}"> +            <isset property="profile.available"/> +        </condition> +        <condition else="false" property="jdkBug6558476"> +            <and> +                <matches pattern="1\.[56]" string="${java.specification.version}"/> +                <not> +                    <os family="unix"/> +                </not> +            </and> +        </condition> +        <property name="javac.fork" value="${jdkBug6558476}"/> +        <property name="jar.index" value="false"/> +        <property name="jar.index.metainf" value="${jar.index}"/> +        <property name="copylibs.rebase" value="true"/> +        <available file="${meta.inf.dir}/persistence.xml" property="has.persistence.xml"/> +        <condition property="junit.available"> +            <or> +                <available classname="org.junit.Test" classpath="${run.test.classpath}"/> +                <available classname="junit.framework.Test" classpath="${run.test.classpath}"/> +            </or> +        </condition> +        <condition property="testng.available"> +            <available classname="org.testng.annotations.Test" classpath="${run.test.classpath}"/> +        </condition> +        <condition property="junit+testng.available"> +            <and> +                <istrue value="${junit.available}"/> +                <istrue value="${testng.available}"/> +            </and> +        </condition> +        <condition else="testng" property="testng.mode" value="mixed"> +            <istrue value="${junit+testng.available}"/> +        </condition> +        <condition else="" property="testng.debug.mode" value="-mixed"> +            <istrue value="${junit+testng.available}"/> +        </condition> +    </target> +    <target name="-post-init"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="-pre-init,-init-private,-init-user,-init-project,-do-init" name="-init-check"> +        <fail unless="src.dir">Must set src.dir</fail> +        <fail unless="test.src.dir">Must set test.src.dir</fail> +        <fail unless="build.dir">Must set build.dir</fail> +        <fail unless="dist.dir">Must set dist.dir</fail> +        <fail unless="build.classes.dir">Must set build.classes.dir</fail> +        <fail unless="dist.javadoc.dir">Must set dist.javadoc.dir</fail> +        <fail unless="build.test.classes.dir">Must set build.test.classes.dir</fail> +        <fail unless="build.test.results.dir">Must set build.test.results.dir</fail> +        <fail unless="build.classes.excludes">Must set build.classes.excludes</fail> +        <fail unless="dist.jar">Must set dist.jar</fail> +    </target> +    <target name="-init-macrodef-property"> +        <macrodef name="property" uri="http://www.netbeans.org/ns/j2se-project/1"> +            <attribute name="name"/> +            <attribute name="value"/> +            <sequential> +                <property name="@{name}" value="${@{value}}"/> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-ap-cmdline-properties" if="ap.supported.internal" name="-init-macrodef-javac-with-processors"> +        <macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${src.dir}" name="srcdir"/> +            <attribute default="${build.classes.dir}" name="destdir"/> +            <attribute default="${javac.classpath}" name="classpath"/> +            <attribute default="${javac.processorpath}" name="processorpath"/> +            <attribute default="${build.generated.sources.dir}/ap-source-output" name="apgeneratedsrcdir"/> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="${javac.debug}" name="debug"/> +            <attribute default="${empty.dir}" name="sourcepath"/> +            <attribute default="${empty.dir}" name="gensrcdir"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property location="${build.dir}/empty" name="empty.dir"/> +                <mkdir dir="${empty.dir}"/> +                <mkdir dir="@{apgeneratedsrcdir}"/> +                <javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" fork="${javac.fork}" includeantruntime="false" includes="@{includes}" source="${javac.source}" sourcepath="@{sourcepath}" srcdir="@{srcdir}" target="${javac.target}" tempdir="${java.io.tmpdir}"> +                    <src> +                        <dirset dir="@{gensrcdir}" erroronmissingdir="false"> +                            <include name="*"/> +                        </dirset> +                    </src> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                    <compilerarg line="${endorsed.classpath.cmd.line.arg}"/> +                    <compilerarg line="${javac.profile.cmd.line.arg}"/> +                    <compilerarg line="${javac.compilerargs}"/> +                    <compilerarg value="-processorpath"/> +                    <compilerarg path="@{processorpath}:${empty.dir}"/> +                    <compilerarg line="${ap.processors.internal}"/> +                    <compilerarg line="${annotation.processing.processor.options}"/> +                    <compilerarg value="-s"/> +                    <compilerarg path="@{apgeneratedsrcdir}"/> +                    <compilerarg line="${ap.proc.none.internal}"/> +                    <customize/> +                </javac> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-ap-cmdline-properties" name="-init-macrodef-javac-without-processors" unless="ap.supported.internal"> +        <macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${src.dir}" name="srcdir"/> +            <attribute default="${build.classes.dir}" name="destdir"/> +            <attribute default="${javac.classpath}" name="classpath"/> +            <attribute default="${javac.processorpath}" name="processorpath"/> +            <attribute default="${build.generated.sources.dir}/ap-source-output" name="apgeneratedsrcdir"/> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="${javac.debug}" name="debug"/> +            <attribute default="${empty.dir}" name="sourcepath"/> +            <attribute default="${empty.dir}" name="gensrcdir"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property location="${build.dir}/empty" name="empty.dir"/> +                <mkdir dir="${empty.dir}"/> +                <javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" fork="${javac.fork}" includeantruntime="false" includes="@{includes}" source="${javac.source}" sourcepath="@{sourcepath}" srcdir="@{srcdir}" target="${javac.target}" tempdir="${java.io.tmpdir}"> +                    <src> +                        <dirset dir="@{gensrcdir}" erroronmissingdir="false"> +                            <include name="*"/> +                        </dirset> +                    </src> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                    <compilerarg line="${endorsed.classpath.cmd.line.arg}"/> +                    <compilerarg line="${javac.profile.cmd.line.arg}"/> +                    <compilerarg line="${javac.compilerargs}"/> +                    <customize/> +                </javac> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-javac-with-processors,-init-macrodef-javac-without-processors" name="-init-macrodef-javac"> +        <macrodef name="depend" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${src.dir}" name="srcdir"/> +            <attribute default="${build.classes.dir}" name="destdir"/> +            <attribute default="${javac.classpath}" name="classpath"/> +            <sequential> +                <depend cache="${build.dir}/depcache" destdir="@{destdir}" excludes="${excludes}" includes="${includes}" srcdir="@{srcdir}"> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                </depend> +            </sequential> +        </macrodef> +        <macrodef name="force-recompile" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${build.classes.dir}" name="destdir"/> +            <sequential> +                <fail unless="javac.includes">Must set javac.includes</fail> +                <pathconvert pathsep="${line.separator}" property="javac.includes.binary"> +                    <path> +                        <filelist dir="@{destdir}" files="${javac.includes}"/> +                    </path> +                    <globmapper from="*.java" to="*.class"/> +                </pathconvert> +                <tempfile deleteonexit="true" property="javac.includesfile.binary"/> +                <echo file="${javac.includesfile.binary}" message="${javac.includes.binary}"/> +                <delete> +                    <files includesfile="${javac.includesfile.binary}"/> +                </delete> +                <delete> +                    <fileset file="${javac.includesfile.binary}"/> +                </delete> +            </sequential> +        </macrodef> +    </target> +    <target if="${junit.available}" name="-init-macrodef-junit-init"> +        <condition else="false" property="nb.junit.batch" value="true"> +            <and> +                <istrue value="${junit.available}"/> +                <not> +                    <isset property="test.method"/> +                </not> +            </and> +        </condition> +        <condition else="false" property="nb.junit.single" value="true"> +            <and> +                <istrue value="${junit.available}"/> +                <isset property="test.method"/> +            </and> +        </condition> +    </target> +    <target name="-init-test-properties"> +        <property name="test.binaryincludes" value="<nothing>"/> +        <property name="test.binarytestincludes" value=""/> +        <property name="test.binaryexcludes" value=""/> +    </target> +    <target if="${nb.junit.single}" name="-init-macrodef-junit-single" unless="${nb.junit.batch}"> +        <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property name="junit.forkmode" value="perTest"/> +                <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" showoutput="true" tempdir="${build.dir}"> +                    <test methods="@{testmethods}" name="@{testincludes}" todir="${build.test.results.dir}"/> +                    <syspropertyset> +                        <propertyref prefix="test-sys-prop."/> +                        <mapper from="test-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <formatter type="brief" usefile="false"/> +                    <formatter type="xml"/> +                    <jvmarg value="-ea"/> +                    <customize/> +                </junit> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-test-properties" if="${nb.junit.batch}" name="-init-macrodef-junit-batch" unless="${nb.junit.single}"> +        <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property name="junit.forkmode" value="perTest"/> +                <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" showoutput="true" tempdir="${build.dir}"> +                    <batchtest todir="${build.test.results.dir}"> +                        <fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="@{includes}"> +                            <filename name="@{testincludes}"/> +                        </fileset> +                        <fileset dir="${build.test.classes.dir}" excludes="@{excludes},${excludes},${test.binaryexcludes}" includes="${test.binaryincludes}"> +                            <filename name="${test.binarytestincludes}"/> +                        </fileset> +                    </batchtest> +                    <syspropertyset> +                        <propertyref prefix="test-sys-prop."/> +                        <mapper from="test-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <formatter type="brief" usefile="false"/> +                    <formatter type="xml"/> +                    <jvmarg value="-ea"/> +                    <customize/> +                </junit> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-junit-init,-init-macrodef-junit-single, -init-macrodef-junit-batch" if="${junit.available}" name="-init-macrodef-junit"/> +    <target if="${testng.available}" name="-init-macrodef-testng"> +        <macrodef name="testng" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element name="customize" optional="true"/> +            <sequential> +                <condition else="" property="testng.methods.arg" value="@{testincludes}.@{testmethods}"> +                    <isset property="test.method"/> +                </condition> +                <union id="test.set"> +                    <fileset dir="${test.src.dir}" excludes="@{excludes},**/*.xml,${excludes}" includes="@{includes}"> +                        <filename name="@{testincludes}"/> +                    </fileset> +                </union> +                <taskdef classname="org.testng.TestNGAntTask" classpath="${run.test.classpath}" name="testng"/> +                <testng classfilesetref="test.set" failureProperty="tests.failed" listeners="org.testng.reporters.VerboseReporter" methods="${testng.methods.arg}" mode="${testng.mode}" outputdir="${build.test.results.dir}" suitename="Week7_Polynomials" testname="TestNG tests" workingDir="${work.dir}"> +                    <xmlfileset dir="${build.test.classes.dir}" includes="@{testincludes}"/> +                    <propertyset> +                        <propertyref prefix="test-sys-prop."/> +                        <mapper from="test-sys-prop.*" to="*" type="glob"/> +                    </propertyset> +                    <customize/> +                </testng> +            </sequential> +        </macrodef> +    </target> +    <target name="-init-macrodef-test-impl"> +        <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element implicit="true" name="customize" optional="true"/> +            <sequential> +                <echo>No tests executed.</echo> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-junit" if="${junit.available}" name="-init-macrodef-junit-impl"> +        <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element implicit="true" name="customize" optional="true"/> +            <sequential> +                <j2seproject3:junit excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}"> +                    <customize/> +                </j2seproject3:junit> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-testng" if="${testng.available}" name="-init-macrodef-testng-impl"> +        <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element implicit="true" name="customize" optional="true"/> +            <sequential> +                <j2seproject3:testng excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}"> +                    <customize/> +                </j2seproject3:testng> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-test-impl,-init-macrodef-junit-impl,-init-macrodef-testng-impl" name="-init-macrodef-test"> +        <macrodef name="test" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <sequential> +                <j2seproject3:test-impl excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}"> +                    <customize> +                        <classpath> +                            <path path="${run.test.classpath}"/> +                        </classpath> +                        <jvmarg line="${endorsed.classpath.cmd.line.arg}"/> +                        <jvmarg line="${run.jvmargs}"/> +                        <jvmarg line="${run.jvmargs.ide}"/> +                    </customize> +                </j2seproject3:test-impl> +            </sequential> +        </macrodef> +    </target> +    <target if="${junit.available}" name="-init-macrodef-junit-debug" unless="${nb.junit.batch}"> +        <macrodef name="junit-debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property name="junit.forkmode" value="perTest"/> +                <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" showoutput="true" tempdir="${build.dir}"> +                    <test methods="@{testmethods}" name="@{testincludes}" todir="${build.test.results.dir}"/> +                    <syspropertyset> +                        <propertyref prefix="test-sys-prop."/> +                        <mapper from="test-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <formatter type="brief" usefile="false"/> +                    <formatter type="xml"/> +                    <jvmarg value="-ea"/> +                    <jvmarg line="${debug-args-line}"/> +                    <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/> +                    <customize/> +                </junit> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-test-properties" if="${nb.junit.batch}" name="-init-macrodef-junit-debug-batch"> +        <macrodef name="junit-debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property name="junit.forkmode" value="perTest"/> +                <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" showoutput="true" tempdir="${build.dir}"> +                    <batchtest todir="${build.test.results.dir}"> +                        <fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="@{includes}"> +                            <filename name="@{testincludes}"/> +                        </fileset> +                        <fileset dir="${build.test.classes.dir}" excludes="@{excludes},${excludes},${test.binaryexcludes}" includes="${test.binaryincludes}"> +                            <filename name="${test.binarytestincludes}"/> +                        </fileset> +                    </batchtest> +                    <syspropertyset> +                        <propertyref prefix="test-sys-prop."/> +                        <mapper from="test-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <formatter type="brief" usefile="false"/> +                    <formatter type="xml"/> +                    <jvmarg value="-ea"/> +                    <jvmarg line="${debug-args-line}"/> +                    <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/> +                    <customize/> +                </junit> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-junit-debug,-init-macrodef-junit-debug-batch" if="${junit.available}" name="-init-macrodef-junit-debug-impl"> +        <macrodef name="test-debug-impl" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <element implicit="true" name="customize" optional="true"/> +            <sequential> +                <j2seproject3:junit-debug excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}"> +                    <customize/> +                </j2seproject3:junit-debug> +            </sequential> +        </macrodef> +    </target> +    <target if="${testng.available}" name="-init-macrodef-testng-debug"> +        <macrodef name="testng-debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${main.class}" name="testClass"/> +            <attribute default="" name="testMethod"/> +            <element name="customize2" optional="true"/> +            <sequential> +                <condition else="-testclass @{testClass}" property="test.class.or.method" value="-methods @{testClass}.@{testMethod}"> +                    <isset property="test.method"/> +                </condition> +                <condition else="-suitename Week7_Polynomials -testname @{testClass} ${test.class.or.method}" property="testng.cmd.args" value="@{testClass}"> +                    <matches pattern=".*\.xml" string="@{testClass}"/> +                </condition> +                <delete dir="${build.test.results.dir}" quiet="true"/> +                <mkdir dir="${build.test.results.dir}"/> +                <j2seproject3:debug classname="org.testng.TestNG" classpath="${debug.test.classpath}"> +                    <customize> +                        <customize2/> +                        <jvmarg value="-ea"/> +                        <arg line="${testng.debug.mode}"/> +                        <arg line="-d ${build.test.results.dir}"/> +                        <arg line="-listener org.testng.reporters.VerboseReporter"/> +                        <arg line="${testng.cmd.args}"/> +                    </customize> +                </j2seproject3:debug> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-testng-debug" if="${testng.available}" name="-init-macrodef-testng-debug-impl"> +        <macrodef name="testng-debug-impl" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${main.class}" name="testClass"/> +            <attribute default="" name="testMethod"/> +            <element implicit="true" name="customize2" optional="true"/> +            <sequential> +                <j2seproject3:testng-debug testClass="@{testClass}" testMethod="@{testMethod}"> +                    <customize2/> +                </j2seproject3:testng-debug> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-junit-debug-impl" if="${junit.available}" name="-init-macrodef-test-debug-junit"> +        <macrodef name="test-debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <attribute default="${main.class}" name="testClass"/> +            <attribute default="" name="testMethod"/> +            <sequential> +                <j2seproject3:test-debug-impl excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}"> +                    <customize> +                        <classpath> +                            <path path="${run.test.classpath}"/> +                        </classpath> +                        <jvmarg line="${endorsed.classpath.cmd.line.arg}"/> +                        <jvmarg line="${run.jvmargs}"/> +                        <jvmarg line="${run.jvmargs.ide}"/> +                    </customize> +                </j2seproject3:test-debug-impl> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-testng-debug-impl" if="${testng.available}" name="-init-macrodef-test-debug-testng"> +        <macrodef name="test-debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${includes}" name="includes"/> +            <attribute default="${excludes}" name="excludes"/> +            <attribute default="**" name="testincludes"/> +            <attribute default="" name="testmethods"/> +            <attribute default="${main.class}" name="testClass"/> +            <attribute default="" name="testMethod"/> +            <sequential> +                <j2seproject3:testng-debug-impl testClass="@{testClass}" testMethod="@{testMethod}"> +                    <customize2> +                        <syspropertyset> +                            <propertyref prefix="test-sys-prop."/> +                            <mapper from="test-sys-prop.*" to="*" type="glob"/> +                        </syspropertyset> +                    </customize2> +                </j2seproject3:testng-debug-impl> +            </sequential> +        </macrodef> +    </target> +    <target depends="-init-macrodef-test-debug-junit,-init-macrodef-test-debug-testng" name="-init-macrodef-test-debug"/> +    <!-- +                pre NB7.2 profiling section; consider it deprecated +            --> +    <target depends="-profile-pre-init, init, -profile-post-init, -profile-init-macrodef-profile, -profile-init-check" if="profiler.info.jvmargs.agent" name="profile-init"/> +    <target if="profiler.info.jvmargs.agent" name="-profile-pre-init"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target if="profiler.info.jvmargs.agent" name="-profile-post-init"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target if="profiler.info.jvmargs.agent" name="-profile-init-macrodef-profile"> +        <macrodef name="resolve"> +            <attribute name="name"/> +            <attribute name="value"/> +            <sequential> +                <property name="@{name}" value="${env.@{value}}"/> +            </sequential> +        </macrodef> +        <macrodef name="profile"> +            <attribute default="${main.class}" name="classname"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property environment="env"/> +                <resolve name="profiler.current.path" value="${profiler.info.pathvar}"/> +                <java classname="@{classname}" dir="${profiler.info.dir}" fork="true" jvm="${profiler.info.jvm}"> +                    <jvmarg line="${endorsed.classpath.cmd.line.arg}"/> +                    <jvmarg value="${profiler.info.jvmargs.agent}"/> +                    <jvmarg line="${profiler.info.jvmargs}"/> +                    <env key="${profiler.info.pathvar}" path="${profiler.info.agentpath}:${profiler.current.path}"/> +                    <arg line="${application.args}"/> +                    <classpath> +                        <path path="${run.classpath}"/> +                    </classpath> +                    <syspropertyset> +                        <propertyref prefix="run-sys-prop."/> +                        <mapper from="run-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <customize/> +                </java> +            </sequential> +        </macrodef> +    </target> +    <target depends="-profile-pre-init, init, -profile-post-init, -profile-init-macrodef-profile" if="profiler.info.jvmargs.agent" name="-profile-init-check"> +        <fail unless="profiler.info.jvm">Must set JVM to use for profiling in profiler.info.jvm</fail> +        <fail unless="profiler.info.jvmargs.agent">Must set profiler agent JVM arguments in profiler.info.jvmargs.agent</fail> +    </target> +    <!-- +                end of pre NB7.2 profiling section +            --> +    <target depends="-init-debug-args" name="-init-macrodef-nbjpda"> +        <macrodef name="nbjpdastart" uri="http://www.netbeans.org/ns/j2se-project/1"> +            <attribute default="${main.class}" name="name"/> +            <attribute default="${debug.classpath}" name="classpath"/> +            <attribute default="" name="stopclassname"/> +            <sequential> +                <nbjpdastart addressproperty="jpda.address" name="@{name}" stopclassname="@{stopclassname}" transport="${debug-transport}"> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                </nbjpdastart> +            </sequential> +        </macrodef> +        <macrodef name="nbjpdareload" uri="http://www.netbeans.org/ns/j2se-project/1"> +            <attribute default="${build.classes.dir}" name="dir"/> +            <sequential> +                <nbjpdareload> +                    <fileset dir="@{dir}" includes="${fix.classes}"> +                        <include name="${fix.includes}*.class"/> +                    </fileset> +                </nbjpdareload> +            </sequential> +        </macrodef> +    </target> +    <target name="-init-debug-args"> +        <property name="version-output" value="java version "${ant.java.version}"/> +        <condition property="have-jdk-older-than-1.4"> +            <or> +                <contains string="${version-output}" substring="java version "1.0"/> +                <contains string="${version-output}" substring="java version "1.1"/> +                <contains string="${version-output}" substring="java version "1.2"/> +                <contains string="${version-output}" substring="java version "1.3"/> +            </or> +        </condition> +        <condition else="-Xdebug" property="debug-args-line" value="-Xdebug -Xnoagent -Djava.compiler=none"> +            <istrue value="${have-jdk-older-than-1.4}"/> +        </condition> +        <condition else="dt_socket" property="debug-transport-by-os" value="dt_shmem"> +            <os family="windows"/> +        </condition> +        <condition else="${debug-transport-by-os}" property="debug-transport" value="${debug.transport}"> +            <isset property="debug.transport"/> +        </condition> +    </target> +    <target depends="-init-debug-args" name="-init-macrodef-debug"> +        <macrodef name="debug" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${main.class}" name="classname"/> +            <attribute default="${debug.classpath}" name="classpath"/> +            <element name="customize" optional="true"/> +            <sequential> +                <java classname="@{classname}" dir="${work.dir}" fork="true"> +                    <jvmarg line="${endorsed.classpath.cmd.line.arg}"/> +                    <jvmarg line="${debug-args-line}"/> +                    <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/> +                    <jvmarg value="-Dfile.encoding=${runtime.encoding}"/> +                    <redirector errorencoding="${runtime.encoding}" inputencoding="${runtime.encoding}" outputencoding="${runtime.encoding}"/> +                    <jvmarg line="${run.jvmargs}"/> +                    <jvmarg line="${run.jvmargs.ide}"/> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                    <syspropertyset> +                        <propertyref prefix="run-sys-prop."/> +                        <mapper from="run-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <customize/> +                </java> +            </sequential> +        </macrodef> +    </target> +    <target name="-init-macrodef-java"> +        <macrodef name="java" uri="http://www.netbeans.org/ns/j2se-project/1"> +            <attribute default="${main.class}" name="classname"/> +            <attribute default="${run.classpath}" name="classpath"/> +            <attribute default="jvm" name="jvm"/> +            <element name="customize" optional="true"/> +            <sequential> +                <java classname="@{classname}" dir="${work.dir}" fork="true"> +                    <jvmarg line="${endorsed.classpath.cmd.line.arg}"/> +                    <jvmarg value="-Dfile.encoding=${runtime.encoding}"/> +                    <redirector errorencoding="${runtime.encoding}" inputencoding="${runtime.encoding}" outputencoding="${runtime.encoding}"/> +                    <jvmarg line="${run.jvmargs}"/> +                    <jvmarg line="${run.jvmargs.ide}"/> +                    <classpath> +                        <path path="@{classpath}"/> +                    </classpath> +                    <syspropertyset> +                        <propertyref prefix="run-sys-prop."/> +                        <mapper from="run-sys-prop.*" to="*" type="glob"/> +                    </syspropertyset> +                    <customize/> +                </java> +            </sequential> +        </macrodef> +    </target> +    <target name="-init-macrodef-copylibs"> +        <macrodef name="copylibs" uri="http://www.netbeans.org/ns/j2se-project/3"> +            <attribute default="${manifest.file}" name="manifest"/> +            <element name="customize" optional="true"/> +            <sequential> +                <property location="${build.classes.dir}" name="build.classes.dir.resolved"/> +                <pathconvert property="run.classpath.without.build.classes.dir"> +                    <path path="${run.classpath}"/> +                    <map from="${build.classes.dir.resolved}" to=""/> +                </pathconvert> +                <pathconvert pathsep=" " property="jar.classpath"> +                    <path path="${run.classpath.without.build.classes.dir}"/> +                    <chainedmapper> +                        <flattenmapper/> +                        <filtermapper> +                            <replacestring from=" " to="%20"/> +                        </filtermapper> +                        <globmapper from="*" to="lib/*"/> +                    </chainedmapper> +                </pathconvert> +                <taskdef classname="org.netbeans.modules.java.j2seproject.copylibstask.CopyLibs" classpath="${libs.CopyLibs.classpath}" name="copylibs"/> +                <copylibs compress="${jar.compress}" excludeFromCopy="${copylibs.excludes}" index="${jar.index}" indexMetaInf="${jar.index.metainf}" jarfile="${dist.jar}" manifest="@{manifest}" rebase="${copylibs.rebase}" runtimeclasspath="${run.classpath.without.build.classes.dir}"> +                    <fileset dir="${build.classes.dir}" excludes="${dist.archive.excludes}"/> +                    <manifest> +                        <attribute name="Class-Path" value="${jar.classpath}"/> +                        <customize/> +                    </manifest> +                </copylibs> +            </sequential> +        </macrodef> +    </target> +    <target name="-init-presetdef-jar"> +        <presetdef name="jar" uri="http://www.netbeans.org/ns/j2se-project/1"> +            <jar compress="${jar.compress}" index="${jar.index}" jarfile="${dist.jar}"> +                <j2seproject1:fileset dir="${build.classes.dir}" excludes="${dist.archive.excludes}"/> +            </jar> +        </presetdef> +    </target> +    <target name="-init-ap-cmdline-properties"> +        <property name="annotation.processing.enabled" value="true"/> +        <property name="annotation.processing.processors.list" value=""/> +        <property name="annotation.processing.processor.options" value=""/> +        <property name="annotation.processing.run.all.processors" value="true"/> +        <property name="javac.processorpath" value="${javac.classpath}"/> +        <property name="javac.test.processorpath" value="${javac.test.classpath}"/> +        <condition property="ap.supported.internal" value="true"> +            <not> +                <matches pattern="1\.[0-5](\..*)?" string="${javac.source}"/> +            </not> +        </condition> +    </target> +    <target depends="-init-ap-cmdline-properties" if="ap.supported.internal" name="-init-ap-cmdline-supported"> +        <condition else="" property="ap.processors.internal" value="-processor ${annotation.processing.processors.list}"> +            <isfalse value="${annotation.processing.run.all.processors}"/> +        </condition> +        <condition else="" property="ap.proc.none.internal" value="-proc:none"> +            <isfalse value="${annotation.processing.enabled}"/> +        </condition> +    </target> +    <target depends="-init-ap-cmdline-properties,-init-ap-cmdline-supported" name="-init-ap-cmdline"> +        <property name="ap.cmd.line.internal" value=""/> +    </target> +    <target depends="-pre-init,-init-private,-init-user,-init-project,-do-init,-post-init,-init-check,-init-macrodef-property,-init-macrodef-javac,-init-macrodef-test,-init-macrodef-test-debug,-init-macrodef-nbjpda,-init-macrodef-debug,-init-macrodef-java,-init-presetdef-jar,-init-ap-cmdline" name="init"/> +    <!-- +                =================== +                COMPILATION SECTION +                =================== +            --> +    <target name="-deps-jar-init" unless="built-jar.properties"> +        <property location="${build.dir}/built-jar.properties" name="built-jar.properties"/> +        <delete file="${built-jar.properties}" quiet="true"/> +    </target> +    <target if="already.built.jar.${basedir}" name="-warn-already-built-jar"> +        <echo level="warn" message="Cycle detected: Week7 Polynomials was already built"/> +    </target> +    <target depends="init,-deps-jar-init" name="deps-jar" unless="no.deps"> +        <mkdir dir="${build.dir}"/> +        <touch file="${built-jar.properties}" verbose="false"/> +        <property file="${built-jar.properties}" prefix="already.built.jar."/> +        <antcall target="-warn-already-built-jar"/> +        <propertyfile file="${built-jar.properties}"> +            <entry key="${basedir}" value=""/> +        </propertyfile> +    </target> +    <target depends="init,-check-automatic-build,-clean-after-automatic-build" name="-verify-automatic-build"/> +    <target depends="init" name="-check-automatic-build"> +        <available file="${build.classes.dir}/.netbeans_automatic_build" property="netbeans.automatic.build"/> +    </target> +    <target depends="init" if="netbeans.automatic.build" name="-clean-after-automatic-build"> +        <antcall target="clean"/> +    </target> +    <target depends="init,deps-jar" name="-pre-pre-compile"> +        <mkdir dir="${build.classes.dir}"/> +    </target> +    <target name="-pre-compile"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target if="do.depend.true" name="-compile-depend"> +        <pathconvert property="build.generated.subdirs"> +            <dirset dir="${build.generated.sources.dir}" erroronmissingdir="false"> +                <include name="*"/> +            </dirset> +        </pathconvert> +        <j2seproject3:depend srcdir="${src.dir}:${build.generated.subdirs}"/> +    </target> +    <target depends="init,deps-jar,-pre-pre-compile,-pre-compile, -copy-persistence-xml,-compile-depend" if="have.sources" name="-do-compile"> +        <j2seproject3:javac gensrcdir="${build.generated.sources.dir}"/> +        <copy todir="${build.classes.dir}"> +            <fileset dir="${src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/> +        </copy> +    </target> +    <target if="has.persistence.xml" name="-copy-persistence-xml"> +        <mkdir dir="${build.classes.dir}/META-INF"/> +        <copy todir="${build.classes.dir}/META-INF"> +            <fileset dir="${meta.inf.dir}" includes="persistence.xml orm.xml"/> +        </copy> +    </target> +    <target name="-post-compile"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile,-do-compile,-post-compile" description="Compile project." name="compile"/> +    <target name="-pre-compile-single"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,deps-jar,-pre-pre-compile" name="-do-compile-single"> +        <fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail> +        <j2seproject3:force-recompile/> +        <j2seproject3:javac excludes="" gensrcdir="${build.generated.sources.dir}" includes="${javac.includes}" sourcepath="${src.dir}"/> +    </target> +    <target name="-post-compile-single"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile-single,-do-compile-single,-post-compile-single" name="compile-single"/> +    <!-- +                ==================== +                JAR BUILDING SECTION +                ==================== +            --> +    <target depends="init" name="-pre-pre-jar"> +        <dirname file="${dist.jar}" property="dist.jar.dir"/> +        <mkdir dir="${dist.jar.dir}"/> +    </target> +    <target name="-pre-jar"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init" if="do.archive" name="-do-jar-create-manifest" unless="manifest.available"> +        <tempfile deleteonexit="true" destdir="${build.dir}" property="tmp.manifest.file"/> +        <touch file="${tmp.manifest.file}" verbose="false"/> +    </target> +    <target depends="init" if="do.archive+manifest.available" name="-do-jar-copy-manifest"> +        <tempfile deleteonexit="true" destdir="${build.dir}" property="tmp.manifest.file"/> +        <copy file="${manifest.file}" tofile="${tmp.manifest.file}"/> +    </target> +    <target depends="init,-do-jar-create-manifest,-do-jar-copy-manifest" if="do.archive+main.class.available" name="-do-jar-set-mainclass"> +        <manifest file="${tmp.manifest.file}" mode="update"> +            <attribute name="Main-Class" value="${main.class}"/> +        </manifest> +    </target> +    <target depends="init,-do-jar-create-manifest,-do-jar-copy-manifest" if="do.archive+profile.available" name="-do-jar-set-profile"> +        <manifest file="${tmp.manifest.file}" mode="update"> +            <attribute name="Profile" value="${javac.profile}"/> +        </manifest> +    </target> +    <target depends="init,-do-jar-create-manifest,-do-jar-copy-manifest" if="do.archive+splashscreen.available" name="-do-jar-set-splashscreen"> +        <basename file="${application.splash}" property="splashscreen.basename"/> +        <mkdir dir="${build.classes.dir}/META-INF"/> +        <copy failonerror="false" file="${application.splash}" todir="${build.classes.dir}/META-INF"/> +        <manifest file="${tmp.manifest.file}" mode="update"> +            <attribute name="SplashScreen-Image" value="META-INF/${splashscreen.basename}"/> +        </manifest> +    </target> +    <target depends="init,-init-macrodef-copylibs,compile,-pre-pre-jar,-pre-jar,-do-jar-create-manifest,-do-jar-copy-manifest,-do-jar-set-mainclass,-do-jar-set-profile,-do-jar-set-splashscreen" if="do.mkdist" name="-do-jar-copylibs"> +        <j2seproject3:copylibs manifest="${tmp.manifest.file}"/> +        <echo level="info">To run this application from the command line without Ant, try:</echo> +        <property location="${dist.jar}" name="dist.jar.resolved"/> +        <echo level="info">java -jar "${dist.jar.resolved}"</echo> +    </target> +    <target depends="init,compile,-pre-pre-jar,-pre-jar,-do-jar-create-manifest,-do-jar-copy-manifest,-do-jar-set-mainclass,-do-jar-set-profile,-do-jar-set-splashscreen" if="do.archive" name="-do-jar-jar" unless="do.mkdist"> +        <j2seproject1:jar manifest="${tmp.manifest.file}"/> +        <property location="${build.classes.dir}" name="build.classes.dir.resolved"/> +        <property location="${dist.jar}" name="dist.jar.resolved"/> +        <pathconvert property="run.classpath.with.dist.jar"> +            <path path="${run.classpath}"/> +            <map from="${build.classes.dir.resolved}" to="${dist.jar.resolved}"/> +        </pathconvert> +        <condition else="" property="jar.usage.message" value="To run this application from the command line without Ant, try:${line.separator}${platform.java} -cp ${run.classpath.with.dist.jar} ${main.class}"> +            <isset property="main.class.available"/> +        </condition> +        <condition else="debug" property="jar.usage.level" value="info"> +            <isset property="main.class.available"/> +        </condition> +        <echo level="${jar.usage.level}" message="${jar.usage.message}"/> +    </target> +    <target depends="-do-jar-copylibs" if="do.archive" name="-do-jar-delete-manifest"> +        <delete> +            <fileset file="${tmp.manifest.file}"/> +        </delete> +    </target> +    <target depends="init,compile,-pre-pre-jar,-pre-jar,-do-jar-create-manifest,-do-jar-copy-manifest,-do-jar-set-mainclass,-do-jar-set-profile,-do-jar-set-splashscreen,-do-jar-jar,-do-jar-delete-manifest" name="-do-jar-without-libraries"/> +    <target depends="init,compile,-pre-pre-jar,-pre-jar,-do-jar-create-manifest,-do-jar-copy-manifest,-do-jar-set-mainclass,-do-jar-set-profile,-do-jar-set-splashscreen,-do-jar-copylibs,-do-jar-delete-manifest" name="-do-jar-with-libraries"/> +    <target name="-post-jar"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,compile,-pre-jar,-do-jar-without-libraries,-do-jar-with-libraries,-post-jar" name="-do-jar"/> +    <target depends="init,compile,-pre-jar,-do-jar,-post-jar" description="Build JAR." name="jar"/> +    <!-- +                ================= +                EXECUTION SECTION +                ================= +            --> +    <target depends="init,compile" description="Run a main class." name="run"> +        <j2seproject1:java> +            <customize> +                <arg line="${application.args}"/> +            </customize> +        </j2seproject1:java> +    </target> +    <target name="-do-not-recompile"> +        <property name="javac.includes.binary" value=""/> +    </target> +    <target depends="init,compile-single" name="run-single"> +        <fail unless="run.class">Must select one file in the IDE or set run.class</fail> +        <j2seproject1:java classname="${run.class}"/> +    </target> +    <target depends="init,compile-test-single" name="run-test-with-main"> +        <fail unless="run.class">Must select one file in the IDE or set run.class</fail> +        <j2seproject1:java classname="${run.class}" classpath="${run.test.classpath}"/> +    </target> +    <!-- +                ================= +                DEBUGGING SECTION +                ================= +            --> +    <target depends="init" if="netbeans.home" name="-debug-start-debugger"> +        <j2seproject1:nbjpdastart name="${debug.class}"/> +    </target> +    <target depends="init" if="netbeans.home" name="-debug-start-debugger-main-test"> +        <j2seproject1:nbjpdastart classpath="${debug.test.classpath}" name="${debug.class}"/> +    </target> +    <target depends="init,compile" name="-debug-start-debuggee"> +        <j2seproject3:debug> +            <customize> +                <arg line="${application.args}"/> +            </customize> +        </j2seproject3:debug> +    </target> +    <target depends="init,compile,-debug-start-debugger,-debug-start-debuggee" description="Debug project in IDE." if="netbeans.home" name="debug"/> +    <target depends="init" if="netbeans.home" name="-debug-start-debugger-stepinto"> +        <j2seproject1:nbjpdastart stopclassname="${main.class}"/> +    </target> +    <target depends="init,compile,-debug-start-debugger-stepinto,-debug-start-debuggee" if="netbeans.home" name="debug-stepinto"/> +    <target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-single"> +        <fail unless="debug.class">Must select one file in the IDE or set debug.class</fail> +        <j2seproject3:debug classname="${debug.class}"/> +    </target> +    <target depends="init,compile-single,-debug-start-debugger,-debug-start-debuggee-single" if="netbeans.home" name="debug-single"/> +    <target depends="init,compile-test-single" if="netbeans.home" name="-debug-start-debuggee-main-test"> +        <fail unless="debug.class">Must select one file in the IDE or set debug.class</fail> +        <j2seproject3:debug classname="${debug.class}" classpath="${debug.test.classpath}"/> +    </target> +    <target depends="init,compile-test-single,-debug-start-debugger-main-test,-debug-start-debuggee-main-test" if="netbeans.home" name="debug-test-with-main"/> +    <target depends="init" name="-pre-debug-fix"> +        <fail unless="fix.includes">Must set fix.includes</fail> +        <property name="javac.includes" value="${fix.includes}.java"/> +    </target> +    <target depends="init,-pre-debug-fix,compile-single" if="netbeans.home" name="-do-debug-fix"> +        <j2seproject1:nbjpdareload/> +    </target> +    <target depends="init,-pre-debug-fix,-do-debug-fix" if="netbeans.home" name="debug-fix"/> +    <!-- +                ================= +                PROFILING SECTION +                ================= +            --> +    <!-- +                pre NB7.2 profiler integration +            --> +    <target depends="profile-init,compile" description="Profile a project in the IDE." if="profiler.info.jvmargs.agent" name="-profile-pre72"> +        <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail> +        <nbprofiledirect> +            <classpath> +                <path path="${run.classpath}"/> +            </classpath> +        </nbprofiledirect> +        <profile/> +    </target> +    <target depends="profile-init,compile-single" description="Profile a selected class in the IDE." if="profiler.info.jvmargs.agent" name="-profile-single-pre72"> +        <fail unless="profile.class">Must select one file in the IDE or set profile.class</fail> +        <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail> +        <nbprofiledirect> +            <classpath> +                <path path="${run.classpath}"/> +            </classpath> +        </nbprofiledirect> +        <profile classname="${profile.class}"/> +    </target> +    <target depends="profile-init,compile-single" if="profiler.info.jvmargs.agent" name="-profile-applet-pre72"> +        <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail> +        <nbprofiledirect> +            <classpath> +                <path path="${run.classpath}"/> +            </classpath> +        </nbprofiledirect> +        <profile classname="sun.applet.AppletViewer"> +            <customize> +                <arg value="${applet.url}"/> +            </customize> +        </profile> +    </target> +    <target depends="profile-init,compile-test-single" if="profiler.info.jvmargs.agent" name="-profile-test-single-pre72"> +        <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail> +        <nbprofiledirect> +            <classpath> +                <path path="${run.test.classpath}"/> +            </classpath> +        </nbprofiledirect> +        <junit dir="${profiler.info.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" jvm="${profiler.info.jvm}" showoutput="true"> +            <env key="${profiler.info.pathvar}" path="${profiler.info.agentpath}:${profiler.current.path}"/> +            <jvmarg value="${profiler.info.jvmargs.agent}"/> +            <jvmarg line="${profiler.info.jvmargs}"/> +            <test name="${profile.class}"/> +            <classpath> +                <path path="${run.test.classpath}"/> +            </classpath> +            <syspropertyset> +                <propertyref prefix="test-sys-prop."/> +                <mapper from="test-sys-prop.*" to="*" type="glob"/> +            </syspropertyset> +            <formatter type="brief" usefile="false"/> +            <formatter type="xml"/> +        </junit> +    </target> +    <!-- +                end of pre NB72 profiling section +            --> +    <target if="netbeans.home" name="-profile-check"> +        <condition property="profiler.configured"> +            <or> +                <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-agentpath:"/> +                <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-javaagent:"/> +            </or> +        </condition> +    </target> +    <target depends="-profile-check,-profile-pre72" description="Profile a project in the IDE." if="profiler.configured" name="profile" unless="profiler.info.jvmargs.agent"> +        <startprofiler/> +        <antcall target="run"/> +    </target> +    <target depends="-profile-check,-profile-single-pre72" description="Profile a selected class in the IDE." if="profiler.configured" name="profile-single" unless="profiler.info.jvmargs.agent"> +        <fail unless="run.class">Must select one file in the IDE or set run.class</fail> +        <startprofiler/> +        <antcall target="run-single"/> +    </target> +    <target depends="-profile-test-single-pre72" description="Profile a selected test in the IDE." name="profile-test-single"/> +    <target depends="-profile-check" description="Profile a selected test in the IDE." if="profiler.configured" name="profile-test" unless="profiler.info.jvmargs"> +        <fail unless="test.includes">Must select some files in the IDE or set test.includes</fail> +        <startprofiler/> +        <antcall target="test-single"/> +    </target> +    <target depends="-profile-check" description="Profile a selected class in the IDE." if="profiler.configured" name="profile-test-with-main"> +        <fail unless="run.class">Must select one file in the IDE or set run.class</fail> +        <startprofiler/> +        <antcal target="run-test-with-main"/> +    </target> +    <target depends="-profile-check,-profile-applet-pre72" if="profiler.configured" name="profile-applet" unless="profiler.info.jvmargs.agent"> +        <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail> +        <startprofiler/> +        <antcall target="run-applet"/> +    </target> +    <!-- +                =============== +                JAVADOC SECTION +                =============== +            --> +    <target depends="init" if="have.sources" name="-javadoc-build"> +        <mkdir dir="${dist.javadoc.dir}"/> +        <condition else="" property="javadoc.endorsed.classpath.cmd.line.arg" value="-J${endorsed.classpath.cmd.line.arg}"> +            <and> +                <isset property="endorsed.classpath.cmd.line.arg"/> +                <not> +                    <equals arg1="${endorsed.classpath.cmd.line.arg}" arg2=""/> +                </not> +            </and> +        </condition> +        <condition else="" property="bug5101868workaround" value="*.java"> +            <matches pattern="1\.[56](\..*)?" string="${java.version}"/> +        </condition> +        <javadoc additionalparam="-J-Dfile.encoding=${file.encoding} ${javadoc.additionalparam}" author="${javadoc.author}" charset="UTF-8" destdir="${dist.javadoc.dir}" docencoding="UTF-8" encoding="${javadoc.encoding.used}" failonerror="true" noindex="${javadoc.noindex}" nonavbar="${javadoc.nonavbar}" notree="${javadoc.notree}" private="${javadoc.private}" source="${javac.source}" splitindex="${javadoc.splitindex}" use="${javadoc.use}" useexternalfile="true" version="${javadoc.version}" windowtitle="${javadoc.windowtitle}"> +            <classpath> +                <path path="${javac.classpath}"/> +            </classpath> +            <fileset dir="${src.dir}" excludes="${bug5101868workaround},${excludes}" includes="${includes}"> +                <filename name="**/*.java"/> +            </fileset> +            <fileset dir="${build.generated.sources.dir}" erroronmissingdir="false"> +                <include name="**/*.java"/> +                <exclude name="*.java"/> +            </fileset> +            <arg line="${javadoc.endorsed.classpath.cmd.line.arg}"/> +        </javadoc> +        <copy todir="${dist.javadoc.dir}"> +            <fileset dir="${src.dir}" excludes="${excludes}" includes="${includes}"> +                <filename name="**/doc-files/**"/> +            </fileset> +            <fileset dir="${build.generated.sources.dir}" erroronmissingdir="false"> +                <include name="**/doc-files/**"/> +            </fileset> +        </copy> +    </target> +    <target depends="init,-javadoc-build" if="netbeans.home" name="-javadoc-browse" unless="no.javadoc.preview"> +        <nbbrowse file="${dist.javadoc.dir}/index.html"/> +    </target> +    <target depends="init,-javadoc-build,-javadoc-browse" description="Build Javadoc." name="javadoc"/> +    <!-- +                ========================= +                TEST COMPILATION SECTION +                ========================= +            --> +    <target depends="init,compile" if="have.tests" name="-pre-pre-compile-test"> +        <mkdir dir="${build.test.classes.dir}"/> +    </target> +    <target name="-pre-compile-test"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target if="do.depend.true" name="-compile-test-depend"> +        <j2seproject3:depend classpath="${javac.test.classpath}" destdir="${build.test.classes.dir}" srcdir="${test.src.dir}"/> +    </target> +    <target depends="init,deps-jar,compile,-pre-pre-compile-test,-pre-compile-test,-compile-test-depend" if="have.tests" name="-do-compile-test"> +        <j2seproject3:javac apgeneratedsrcdir="${build.test.classes.dir}" classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" processorpath="${javac.test.processorpath}" srcdir="${test.src.dir}"/> +        <copy todir="${build.test.classes.dir}"> +            <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/> +        </copy> +    </target> +    <target name="-post-compile-test"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,compile,-pre-pre-compile-test,-pre-compile-test,-do-compile-test,-post-compile-test" name="compile-test"/> +    <target name="-pre-compile-test-single"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,deps-jar,compile,-pre-pre-compile-test,-pre-compile-test-single" if="have.tests" name="-do-compile-test-single"> +        <fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail> +        <j2seproject3:force-recompile destdir="${build.test.classes.dir}"/> +        <j2seproject3:javac apgeneratedsrcdir="${build.test.classes.dir}" classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" excludes="" includes="${javac.includes}" processorpath="${javac.test.processorpath}" sourcepath="${test.src.dir}" srcdir="${test.src.dir}"/> +        <copy todir="${build.test.classes.dir}"> +            <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/> +        </copy> +    </target> +    <target name="-post-compile-test-single"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,compile,-pre-pre-compile-test,-pre-compile-test-single,-do-compile-test-single,-post-compile-test-single" name="compile-test-single"/> +    <!-- +                ======================= +                TEST EXECUTION SECTION +                ======================= +            --> +    <target depends="init" if="have.tests" name="-pre-test-run"> +        <mkdir dir="${build.test.results.dir}"/> +    </target> +    <target depends="init,compile-test,-pre-test-run" if="have.tests" name="-do-test-run"> +        <j2seproject3:test includes="${includes}" testincludes="**/*Test.java"/> +    </target> +    <target depends="init,compile-test,-pre-test-run,-do-test-run" if="have.tests" name="-post-test-run"> +        <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail> +    </target> +    <target depends="init" if="have.tests" name="test-report"/> +    <target depends="init" if="netbeans.home+have.tests" name="-test-browse"/> +    <target depends="init,compile-test,-pre-test-run,-do-test-run,test-report,-post-test-run,-test-browse" description="Run unit tests." name="test"/> +    <target depends="init" if="have.tests" name="-pre-test-run-single"> +        <mkdir dir="${build.test.results.dir}"/> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-do-test-run-single"> +        <fail unless="test.includes">Must select some files in the IDE or set test.includes</fail> +        <j2seproject3:test excludes="" includes="${test.includes}" testincludes="${test.includes}"/> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single" if="have.tests" name="-post-test-run-single"> +        <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single,-post-test-run-single" description="Run single unit test." name="test-single"/> +    <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-do-test-run-single-method"> +        <fail unless="test.class">Must select some files in the IDE or set test.class</fail> +        <fail unless="test.method">Must select some method in the IDE or set test.method</fail> +        <j2seproject3:test excludes="" includes="${javac.includes}" testincludes="${test.class}" testmethods="${test.method}"/> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single-method" if="have.tests" name="-post-test-run-single-method"> +        <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single-method,-post-test-run-single-method" description="Run single unit test." name="test-single-method"/> +    <!-- +                ======================= +                TEST DEBUGGING SECTION +                ======================= +            --> +    <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-debug-start-debuggee-test"> +        <fail unless="test.class">Must select one file in the IDE or set test.class</fail> +        <j2seproject3:test-debug excludes="" includes="${javac.includes}" testClass="${test.class}" testincludes="${javac.includes}"/> +    </target> +    <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-debug-start-debuggee-test-method"> +        <fail unless="test.class">Must select one file in the IDE or set test.class</fail> +        <fail unless="test.method">Must select some method in the IDE or set test.method</fail> +        <j2seproject3:test-debug excludes="" includes="${javac.includes}" testClass="${test.class}" testMethod="${test.method}" testincludes="${test.class}" testmethods="${test.method}"/> +    </target> +    <target depends="init,compile-test" if="netbeans.home+have.tests" name="-debug-start-debugger-test"> +        <j2seproject1:nbjpdastart classpath="${debug.test.classpath}" name="${test.class}"/> +    </target> +    <target depends="init,compile-test-single,-debug-start-debugger-test,-debug-start-debuggee-test" name="debug-test"/> +    <target depends="init,compile-test-single,-debug-start-debugger-test,-debug-start-debuggee-test-method" name="debug-test-method"/> +    <target depends="init,-pre-debug-fix,compile-test-single" if="netbeans.home" name="-do-debug-fix-test"> +        <j2seproject1:nbjpdareload dir="${build.test.classes.dir}"/> +    </target> +    <target depends="init,-pre-debug-fix,-do-debug-fix-test" if="netbeans.home" name="debug-fix-test"/> +    <!-- +                ========================= +                APPLET EXECUTION SECTION +                ========================= +            --> +    <target depends="init,compile-single" name="run-applet"> +        <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail> +        <j2seproject1:java classname="sun.applet.AppletViewer"> +            <customize> +                <arg value="${applet.url}"/> +            </customize> +        </j2seproject1:java> +    </target> +    <!-- +                ========================= +                APPLET DEBUGGING  SECTION +                ========================= +            --> +    <target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-applet"> +        <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail> +        <j2seproject3:debug classname="sun.applet.AppletViewer"> +            <customize> +                <arg value="${applet.url}"/> +            </customize> +        </j2seproject3:debug> +    </target> +    <target depends="init,compile-single,-debug-start-debugger,-debug-start-debuggee-applet" if="netbeans.home" name="debug-applet"/> +    <!-- +                =============== +                CLEANUP SECTION +                =============== +            --> +    <target name="-deps-clean-init" unless="built-clean.properties"> +        <property location="${build.dir}/built-clean.properties" name="built-clean.properties"/> +        <delete file="${built-clean.properties}" quiet="true"/> +    </target> +    <target if="already.built.clean.${basedir}" name="-warn-already-built-clean"> +        <echo level="warn" message="Cycle detected: Week7 Polynomials was already built"/> +    </target> +    <target depends="init,-deps-clean-init" name="deps-clean" unless="no.deps"> +        <mkdir dir="${build.dir}"/> +        <touch file="${built-clean.properties}" verbose="false"/> +        <property file="${built-clean.properties}" prefix="already.built.clean."/> +        <antcall target="-warn-already-built-clean"/> +        <propertyfile file="${built-clean.properties}"> +            <entry key="${basedir}" value=""/> +        </propertyfile> +    </target> +    <target depends="init" name="-do-clean"> +        <delete dir="${build.dir}"/> +        <delete dir="${dist.dir}" followsymlinks="false" includeemptydirs="true"/> +    </target> +    <target name="-post-clean"> +        <!-- Empty placeholder for easier customization. --> +        <!-- You can override this target in the ../build.xml file. --> +    </target> +    <target depends="init,deps-clean,-do-clean,-post-clean" description="Clean build products." name="clean"/> +    <target name="-check-call-dep"> +        <property file="${call.built.properties}" prefix="already.built."/> +        <condition property="should.call.dep"> +            <and> +                <not> +                    <isset property="already.built.${call.subproject}"/> +                </not> +                <available file="${call.script}"/> +            </and> +        </condition> +    </target> +    <target depends="-check-call-dep" if="should.call.dep" name="-maybe-call-dep"> +        <ant antfile="${call.script}" inheritall="false" target="${call.target}"> +            <propertyset> +                <propertyref prefix="transfer."/> +                <mapper from="transfer.*" to="*" type="glob"/> +            </propertyset> +        </ant> +    </target> +</project> diff --git a/Week7 Polynomials/nbproject/genfiles.properties b/Week7 Polynomials/nbproject/genfiles.properties new file mode 100644 index 0000000..54a54b5 --- /dev/null +++ b/Week7 Polynomials/nbproject/genfiles.properties @@ -0,0 +1,8 @@ +build.xml.data.CRC32=e009bca9 +build.xml.script.CRC32=6ab8560a +build.xml.stylesheet.CRC32=8064a381@1.75.2.48 +# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml. +# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you. +nbproject/build-impl.xml.data.CRC32=e009bca9 +nbproject/build-impl.xml.script.CRC32=918db01b +nbproject/build-impl.xml.stylesheet.CRC32=876e7a8f@1.75.2.48 diff --git a/Week7 Polynomials/nbproject/project.properties b/Week7 Polynomials/nbproject/project.properties new file mode 100644 index 0000000..bbf02d2 --- /dev/null +++ b/Week7 Polynomials/nbproject/project.properties @@ -0,0 +1,73 @@ +annotation.processing.enabled=true +annotation.processing.enabled.in.editor=false +annotation.processing.processor.options= +annotation.processing.processors.list= +annotation.processing.run.all.processors=true +annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output +build.classes.dir=${build.dir}/classes +build.classes.excludes=**/*.java,**/*.form +# This directory is removed when the project is cleaned: +build.dir=build +build.generated.dir=${build.dir}/generated +build.generated.sources.dir=${build.dir}/generated-sources +# Only compile against the classpath explicitly listed here: +build.sysclasspath=ignore +build.test.classes.dir=${build.dir}/test/classes +build.test.results.dir=${build.dir}/test/results +# Uncomment to specify the preferred debugger connection transport: +#debug.transport=dt_socket +debug.classpath=\ +    ${run.classpath} +debug.test.classpath=\ +    ${run.test.classpath} +# Files in build.classes.dir which should be excluded from distribution jar +dist.archive.excludes= +# This directory is removed when the project is cleaned: +dist.dir=dist +dist.jar=${dist.dir}/Week7_Polynomials.jar +dist.javadoc.dir=${dist.dir}/javadoc +excludes= +includes=** +jar.compress=false +javac.classpath= +# Space-separated list of extra javac options +javac.compilerargs= +javac.deprecation=false +javac.processorpath=\ +    ${javac.classpath} +javac.source=1.7 +javac.target=1.7 +javac.test.classpath=\ +    ${javac.classpath}:\ +    ${build.classes.dir}:\ +    ${libs.junit_4.classpath} +javac.test.processorpath=\ +    ${javac.test.classpath} +javadoc.additionalparam= +javadoc.author=false +javadoc.encoding=${source.encoding} +javadoc.noindex=false +javadoc.nonavbar=false +javadoc.notree=false +javadoc.private=false +javadoc.splitindex=true +javadoc.use=true +javadoc.version=false +javadoc.windowtitle= +main.class=main.Main +meta.inf.dir=${src.dir}/META-INF +mkdist.disabled=true +platform.active=default_platform +run.classpath=\ +    ${javac.classpath}:\ +    ${build.classes.dir} +# Space-separated list of JVM arguments used when running the project. +# You may also define separate properties like run-sys-prop.name=value instead of -Dname=value. +# To set system properties for unit tests define test-sys-prop.name=value: +run.jvmargs= +run.test.classpath=\ +    ${javac.test.classpath}:\ +    ${build.test.classes.dir} +source.encoding=UTF-8 +src.dir=src +test.src.dir=test diff --git a/Week7 Polynomials/nbproject/project.xml b/Week7 Polynomials/nbproject/project.xml new file mode 100644 index 0000000..18f6583 --- /dev/null +++ b/Week7 Polynomials/nbproject/project.xml @@ -0,0 +1,15 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://www.netbeans.org/ns/project/1"> +    <type>org.netbeans.modules.java.j2seproject</type> +    <configuration> +        <data xmlns="http://www.netbeans.org/ns/j2se-project/3"> +            <name>Week7 Polynomials</name> +            <source-roots> +                <root id="src.dir"/> +            </source-roots> +            <test-roots> +                <root id="test.src.dir"/> +            </test-roots> +        </data> +    </configuration> +</project> diff --git a/Week7 Polynomials/src/main/Main.java b/Week7 Polynomials/src/main/Main.java new file mode 100644 index 0000000..725b8f3 --- /dev/null +++ b/Week7 Polynomials/src/main/Main.java @@ -0,0 +1,23 @@ +package main; + +import polynomial.Polynomial; + +/** + * + * @author Sjaak Smetsers + */ +public class Main { + +    public static void main(String[] args) { +        Polynomial p1 = new Polynomial( "3.0 1 2 3" ); +        Polynomial p2 = new Polynomial( "4 0 5 3" ); +        Polynomial p3 = new Polynomial( "4 0 -5 3" ); +        Polynomial p4 = new Polynomial( "6 1" ); + +        System.out.println( p1 ); +        System.out.println( p2 ); +        System.out.println( p3 ); +        System.out.println( p4 ); +   } + +} diff --git a/Week7 Polynomials/src/polynomial/Polynomial.java b/Week7 Polynomials/src/polynomial/Polynomial.java new file mode 100644 index 0000000..c87b96a --- /dev/null +++ b/Week7 Polynomials/src/polynomial/Polynomial.java @@ -0,0 +1,189 @@ +package polynomial; + +import java.util.ArrayList; +import java.util.Iterator; +import java.util.List; +import java.util.Scanner; + +/** + * A class for representing Polynomials + * + * @author Sjaak Smetsers + * @date 10-03-2015 + *  + * @author Camil Staps, s4498062 + * @date 17-03-2015 + */ +public class Polynomial { + +    /** +     * A polynomial is a sequence of terms here kept in an List. +     * The assignment tells us 'it's handy' when terms are ordered by exponent. +     * We don't seem to need that though, so there's no need to implement it. +     */ +    List<Term> terms; + +    /** +     * A constructor for creating the zero Polynomial zero is presented as an +     * empty list of terms and not as a single term with 0 as a coefficient +     */ +    public Polynomial() { +        terms = new ArrayList<>(); +    } + +    /** +     * A Constructor creating a polynomial from the argument string. +     *  +     * This implementation, in contrast to the given implementation, allows for  +     * entering polynomials with two or more terms with the same exponent. Even  +     * though this is strictly not necessary and these inputs aren't legit, this +     * behaviour is always better than the behaviour of the given implementation  +     * which would happily add two terms with the same exponent to our list. +     *  +     * This implementation also directly checks that the coefficient unequals 0, +     * which is also not need-to-have, but still nice-to-have. +     *  +     * Both changes to the given implementation do not change the behaviour on +     * legit input but do allow a user to mess up in some cases. +     * +     * @param s a String representing a list of terms which is converted to a +     * scanner and passed to scanTerm for reading each individual term +     */ +    public Polynomial( String s ) { +        terms = new ArrayList<>(); +        Scanner scan = new Scanner(s); + +        for (Term t = Term.scanTerm(scan); t != null; t = Term.scanTerm(scan)) +            if (t.getCoef() != 0) +                plus(t); +    } + +    /** +     * The copy constructor for making a deep copy +     * +     * @param p the copied polynomial +     */ +    public Polynomial( Polynomial p ) { +        terms = new ArrayList<>(p.terms.size()); +        for (Term t : p.terms) { +            terms.add(new Term(t)); +        } +    } +     +    /** +     * A straightforward conversion of a Polynomial into a string based on the +     * toString for terms +     * +     * @return a readable string representation of this +     */ +    @Override +    public String toString() { +        StringBuilder sb = new StringBuilder(); +        boolean not_first = false; +        for (Term t : terms) { +            if (not_first && t.getCoef() >= 0)  +                sb.append("+"); +            sb.append(t); +            not_first = true; +        } +        return sb.toString(); +    } + +    /** +     * Add a polynomial to this polynomial +     * @param b the polynomial to add +     */ +    public void plus(Polynomial b) { +        for (Term t : b.terms) +            plus(t); +    } +     +    /** +     * Add a term +     * @param t the term to add +     */ +    private void plus(Term t) { +        if (t.getCoef() == 0) +            return; +         +        Iterator<Term> iter = terms.iterator(); +        while (iter.hasNext()) { +            Term this_t = iter.next(); +            if (this_t.getExp() == t.getExp()) { +                this_t.plus(t); +                if (this_t.getCoef() == 0) +                    iter.remove(); +                return; +            } +        } +        terms.add(new Term(t)); +    } + +    /** +     * Subtract a polynomial from this polynomial +     * @param p the polynomial to subtract +     */ +    public void minus(Polynomial p) { +        Polynomial temp = new Polynomial(p); +        temp.times(new Polynomial("-1 0")); +        plus(temp); +    } + +    /** +     * Multiply a polynomial with this polynomial +     * @param p the polynomial to multiply with +     */ +    public void times(Polynomial p) { +        Polynomial result = new Polynomial(); +        for (Term that_t : p.terms)  +            for (Term this_t : terms) +                result.plus(new Term(that_t.getCoef() * this_t.getCoef(), that_t.getExp() + this_t.getExp())); +        terms = result.terms; +    } + +    public void divide(Polynomial b) { +    } + +    /** +     * Check equality +     * @param other_poly the object to check with +     * @return true iff other_poly represents the same polynomial as this instance +     */ +    @Override +    public boolean equals(Object other_poly) { +        if (other_poly == null || other_poly.getClass() != getClass()) +            return false; +         +        Polynomial that = new Polynomial((Polynomial) other_poly);      // We need to copy because later we'll remove elements +        if (terms.size() != that.terms.size())  +            return false; +        for (Term this_t : terms) { +            Iterator<Term> that_iter = that.terms.iterator(); +            boolean found = false; +            while (that_iter.hasNext()) { +                if (this_t.equals(that_iter.next())) { +                    found = true; +                    that_iter.remove(); +                    break; +                } +            } +            if (!found) { +                return false; +            } +        } +        return true; +    } +     +    /** +     * Apply the polynomial to a concrete variable +     * @param x the variable +     * @return the result of the polynomial applied on x +     */ +    public double apply(double x) { +        double result = 0; +        for (Term t : terms) +            result += t.apply(x); +        return result; +    } + +} diff --git a/Week7 Polynomials/src/polynomial/Term.java b/Week7 Polynomials/src/polynomial/Term.java new file mode 100644 index 0000000..60c6381 --- /dev/null +++ b/Week7 Polynomials/src/polynomial/Term.java @@ -0,0 +1,145 @@ +package polynomial; + +import java.util.Scanner; + +/** + * For representing terms in a polynomial. + * + * @author Sjaak Smetsers + * @version 1.0 + * @date 15-02-2012 + *  + * @author Camil Staps, s4498062 + * @date 17-03-2015 + */ +public class Term { + +    /** +     * Each term consists of a coefficient and an exponent +     */ +    private double coefficient; +    private int exponent; + +    /** +     * a get-method for the exponent +     * +     * @return exponent +     */ +    public int getExp() { +        return exponent; +    } + +    /** +     * a get-method for the coefficient +     * +     * @return coefficient +     */ +    public double getCoef() { +        return coefficient; +    } + +    /** +     * A two-argument constructor +     * +     * @param c the value for the coefficient +     * @param e the value for the exponent +     */ +    public Term(double c, int e) { +        coefficient = c; +        exponent = e; +    } + +    /** +     * A copy-constructor +     * +     * @param t the term to be copied +     */ +    public Term(Term t) { +        this(t.coefficient, t.exponent); +    } + +    /** +     * For adding two terms with equal exponents +     * +     * @param t the term added to this +     * @require exponent == t.exponent +     */ +    public void plus(Term t) { +        coefficient += t.coefficient; +    } + +    /** +     * For multiplying two terms +     * +     * @param t the multiplier +     */ +    public void times(Term t) { +        exponent += t.exponent; +        coefficient *= t.coefficient; +    } + +    /** +     * Converts a term into a readable representation the standard format is +     * %fx^%d +     * I changed the implementation to remove trailing zeroes from the coefficient. +     * +     * @return the string representing the term +     */ +    @Override +    public String toString() { +        String nice_coefficient = Double.toString(coefficient); +        if (Math.round(coefficient) == coefficient) +            nice_coefficient =  Integer.toString((int) coefficient); +        if (exponent == 0) { +            return String.format("%s", nice_coefficient, exponent); +        } else if (exponent == 1) { +            return String.format("%sx", nice_coefficient, exponent); +        } else { +            return String.format("%sx^%d", nice_coefficient, exponent); +        } +    } + +    /** +     * Standard implementation of equality +     * @param may_be_term the object to check equality with +     * @return true iff may_be_term represents the same term as this term +     */ +    @Override +    public boolean equals(Object may_be_term) { +        if (may_be_term == null || getClass() != may_be_term.getClass()) { +            return false; +        } else { +            Term term = (Term) may_be_term; +            return exponent == term.exponent +                    && coefficient == term.coefficient; +        } +    } +     +    /** +     * Apply a term to a concrete variable +     * @param x the variable to apply the term to +     * @return the result of the application of the term to x +     */ +    public double apply(double x) { +        return coefficient * Math.pow(x, exponent); +    } + +    /** +     * A static method for converting scanner input into a term. The expected +     * format is two numbers (coef, exp) separated by whitespaces. The coef +     * should be either an integer or a decimal number. The exp is an integer. +     * +     * @param s the scanner providing the input +     * @return null if no term could be found, the found term otherwise +     */ +    public static Term scanTerm(Scanner s) { +        String coef_patt = "\\-?\\d+(\\.\\d+)?"; +        if (s.hasNext(coef_patt)) { +            String coef = s.next(coef_patt); +            int exp = s.nextInt(); +            return new Term(Double.parseDouble(coef), exp); +        } else { +            return null; +        } +    } +} diff --git a/Week7 Polynomials/test/polynomial/PolynomialTest.java b/Week7 Polynomials/test/polynomial/PolynomialTest.java new file mode 100644 index 0000000..c00f165 --- /dev/null +++ b/Week7 Polynomials/test/polynomial/PolynomialTest.java @@ -0,0 +1,226 @@ +package polynomial; + +import org.junit.After; +import org.junit.AfterClass; +import org.junit.Before; +import org.junit.BeforeClass; +import org.junit.Test; +import static org.junit.Assert.*; + +/** + * A test class for the polynomial.Polynomial class + * @author Camil Staps, s4498062 + */ +public class PolynomialTest { +     +    public PolynomialTest() { +    } +     +    @BeforeClass +    public static void setUpClass() { +    } +     +    @AfterClass +    public static void tearDownClass() { +    } +     +    @Before +    public void setUp() { +    } +     +    @After +    public void tearDown() { +    } + +    /** +     * Test of toString method, of class Polynomial. +     */ +    @Test +    public void testToString() { +        System.out.println("toString"); +        // Test exp=0, exp=1, exp>1, positive & negative integer & floating point coefficients all at once +        assertEquals("3x^5-4x+2.5-3.4x^-7", new Polynomial("3 5 -4 1 2.5 0 -3.4 -7").toString()); +        // Test zero polynomial +        assertEquals("", new Polynomial().toString()); +    } + +    /** +     * Test of minus method, of class Polynomial. +     */ +    @Test +    public void testMinus() { +        System.out.println("minus"); +        // Test cancelling out and exponents that don't exist in either of the two polynomials all at once +        Polynomial instance = new Polynomial("7 4 -4 2 3 1 5 0");       // 7x^4 - 4x^2 + 3x + 5 +        instance.minus(new Polynomial("5 3 4 2 3 1 10 0"));             // 5x^3 + 4x^2 + 3x + 10 +        assertEquals(new Polynomial("7 4 -5 3 -8 2 -5 0"), instance);   // 7x^4 - 5x^3 - 8x^2 - 5 +         +        // Test minus = plus (times -1) on many small 2-term polynomials +        for (float c1 = -10; c1 < 10; c1 += 2.3) +            for (int exp1 = 5; exp1 < 10; exp1++) +                for (float c2 = -10; c2 < 10; c2 += 2.3) +                    for (int exp2 = 5; exp2 < 10; exp2++) { +                        Polynomial fst = new Polynomial(c1 + " " + exp1 + " " + c2 + " " + exp2); +                        Polynomial snd = new Polynomial(c1 + " " + exp2 + " " + c2 + " " + exp1); +                        Polynomial fst_2 = new Polynomial(fst); +                        Polynomial snd_2 = new Polynomial(snd); +                        fst.minus(snd); +                        snd_2.times(new Polynomial("-1 0")); +                        fst_2.plus(snd_2); +                        assertEquals(true, fst.equals(fst_2)); +                    } +         +        // Test associativity for some random polynomials +        Polynomial a = new Polynomial("5 4 2 5 20 8 4 0"); +        Polynomial b = new Polynomial("9 2 48 2 10 8 28 2"); +        Polynomial c = new Polynomial("3 8 4 20 8 2 4 5 0 0"); +        Polynomial a_bc = new Polynomial(a); +        a_bc.minus(b); +        a_bc.minus(c); +        Polynomial a_cb = new Polynomial(a); +        a_cb.minus(c); +        a_cb.minus(b); +        assertEquals(true, a_bc.equals(a_cb)); +    } + +    /** +     * Test of times method, of class Polynomial. +     */ +    @Test +    public void testTimes() { +        System.out.println("times"); +         +        // Simple case +        Polynomial instance = new Polynomial("7 1 6 3"); +        instance.times(new Polynomial("5 3 4 2")); +        assertEquals(new Polynomial("30 6 24 5 35 4 28 3"), instance); +         +        // Simple case with zero polynomial +        instance = new Polynomial("5 3"); +        instance.times(new Polynomial()); +        assertEquals(new Polynomial(), instance); +         +        // Advanced case with coefficient 0 in the result +        instance = new Polynomial("4 4 2 3");                           // 4x^4 + 2x^3 +        instance.times(new Polynomial("2 2 -4 3"));                     // 2x^2 - 4x^3 +        assertEquals(new Polynomial("4 5 -16 7"), instance);            // 4x^5 - 16x^7 (exponent 6 cancels out) +         +        // Test associativity for some random polynomials +        Polynomial a = new Polynomial("5 4 2 5 20 8 4 0"); +        Polynomial b = new Polynomial("9 2 48 2 10 8 28 2"); +        Polynomial c = new Polynomial("3 8 4 20 8 2 4 5 0 0"); +        Polynomial a_bc = new Polynomial(a); +        a_bc.times(b); +        a_bc.times(c); +        Polynomial a_cb = new Polynomial(a); +        a_cb.times(c); +        a_cb.times(b); +        assertEquals(true, a_bc.equals(a_cb)); +         +        // Test commutativity +        Polynomial a_b = new Polynomial(a); +        a_b.times(b); +        Polynomial b_a = new Polynomial(b); +        b_a.times(a); +        assertEquals(true, a_b.equals(b_a)); +         +        // Test left distributivity +        Polynomial b_plus_c = new Polynomial(b); +        b_plus_c.plus(c); +        Polynomial a_times_b_plus_c = new Polynomial(a); +        a_times_b_plus_c.times(b_plus_c); +        Polynomial a_times_c = new Polynomial(a); +        a_times_c.times(c); +        Polynomial a_times_b_plus_a_times_c = new Polynomial(a); +        a_times_b_plus_a_times_c.times(b); +        a_times_b_plus_a_times_c.plus(a_times_c); +        assertEquals(true, a_times_b_plus_c.equals(a_times_b_plus_a_times_c)); +         +        // Test right distributivity +        Polynomial b_plus_c_times_a = new Polynomial(b); +        b_plus_c_times_a.plus(c); +        b_plus_c_times_a.times(a); +        Polynomial c_times_a = new Polynomial(c); +        c_times_a.times(a); +        Polynomial b_times_a_plus_c_times_a = new Polynomial(b); +        b_times_a_plus_c_times_a.times(a); +        b_times_a_plus_c_times_a.plus(c_times_a); +        assertEquals(true, b_plus_c_times_a.equals(b_times_a_plus_c_times_a)); +    } + +    /** +     * Test of divide method, of class Polynomial. +     */ +    @Test +    public void testDivide() { +        System.out.println("divide"); +        Polynomial b = null; +        Polynomial instance = new Polynomial(); +        instance.divide(b); +        // TODO review the generated test code and remove the default call to fail. +        fail("The test case is a prototype."); +    } + +    /** +     * Test of equals method, of class Polynomial. +     */ +    @Test +    public void testEquals() { +        System.out.println("equals"); +        // Order of terms irrelevant +        assertEquals(true, new Polynomial("4 2 3 5").equals(new Polynomial("3 5 4 2"))); +        // Terms with same exponent are added +        assertEquals(true, new Polynomial("5 5 10 5").equals(new Polynomial("15 5"))); +        // Simple coefficient 0 removed +        assertEquals(true, new Polynomial("0 7").equals(new Polynomial())); +        // Advanced coefficient 0 removed +        assertEquals(true, new Polynomial("5 10 -5 10").equals(new Polynomial())); +        // Difference in exponent matters +        assertEquals(false, new Polynomial("10 0").equals(new Polynomial("10 1"))); +        // Difference in coefficient matters +        assertEquals(false, new Polynomial("10 0").equals(new Polynomial("5 0"))); +    } + +    /** +     * Test of plus method, of class Polynomial. +     */ +    @Test +    public void testPlus_Polynomial() { +        System.out.println("plus"); +        // Test cancelling out and exponents that don't exist in either of the two polynomials all at once +        Polynomial instance = new Polynomial("7 4 -4 2 7 1 5 0");       // 7x^4 - 4x^2 + 7x + 5 +        instance.plus(new Polynomial("5 3 4 2 3 1 10 0"));              // 5x^3 + 4x^2 + 3x + 10 +        assertEquals(new Polynomial("7 4 5 3 10 1 15 0"), instance);    // 7x^4 + 5x^3 + 10x + 15 +         +        // Test associativity for some random polynomials +        Polynomial a = new Polynomial("5 4 2 5 20 8 4 0"); +        Polynomial b = new Polynomial("9 2 7 5 10 8 28 2"); +        Polynomial c = new Polynomial("3 8 4 20 8 2 4 5 0 0"); +        Polynomial a_bc = new Polynomial(a); +        a_bc.plus(b); +        a_bc.plus(c); +        Polynomial a_cb = new Polynomial(a); +        a_cb.plus(c); +        a_cb.plus(b); +        assertEquals(true, a_bc.equals(a_cb)); +         +        // Test commutativity +        Polynomial a_b = new Polynomial(a); +        a_b.plus(b); +        Polynomial b_a = new Polynomial(b); +        b_a.plus(a); +        assertEquals(true, a_b.equals(b_a)); +    } + +    /** +     * Test of apply method, of class Polynomial. +     */ +    @Test +    public void testApply() { +        System.out.println("apply"); +        // Test zero coefficient, floating point coefficient and negative coefficient all at once +        Polynomial instance = new Polynomial("0 7 5 4 0.5 3 9 2 -8 0"); +        assertEquals(422654.5, instance.apply(17.0), 0.0); +    } +     +} | 
