Browse Source

Init. commit

Kajetan Johannes Hammerle 8 years ago
commit
70919e10db
81 changed files with 4024 additions and 0 deletions
  1. BIN
      .DS_Store
  2. 73 0
      build.xml
  3. 4 0
      build/built-jar.properties
  4. 0 0
      build/classes/.netbeans_automatic_build
  5. 0 0
      build/classes/.netbeans_update_resources
  6. BIN
      build/classes/me/hammerle/console/BlackBox.class
  7. BIN
      build/classes/me/hammerle/console/Console.class
  8. BIN
      build/classes/me/hammerle/console/InputBox$1.class
  9. BIN
      build/classes/me/hammerle/console/InputBox.class
  10. BIN
      build/classes/me/hammerle/console/OutputBox.class
  11. BIN
      build/classes/me/hammerle/exceptions/CodeTooLongException.class
  12. BIN
      build/classes/me/hammerle/exceptions/GoHigherAtRootTreeException.class
  13. BIN
      build/classes/me/hammerle/exceptions/GotoLabelNotFoundException.class
  14. BIN
      build/classes/me/hammerle/exceptions/IllegalColorException.class
  15. BIN
      build/classes/me/hammerle/exceptions/IllegalStringException.class
  16. BIN
      build/classes/me/hammerle/exceptions/InfiniteLoopException.class
  17. BIN
      build/classes/me/hammerle/exceptions/NoChildTreeException.class
  18. BIN
      build/classes/me/hammerle/graphics/FullOval.class
  19. BIN
      build/classes/me/hammerle/graphics/FullRectangle.class
  20. BIN
      build/classes/me/hammerle/graphics/GraphicObject.class
  21. BIN
      build/classes/me/hammerle/graphics/Image.class
  22. BIN
      build/classes/me/hammerle/graphics/Line.class
  23. BIN
      build/classes/me/hammerle/graphics/Oval.class
  24. BIN
      build/classes/me/hammerle/graphics/Rectangle.class
  25. BIN
      build/classes/me/hammerle/graphics/StartPoint.class
  26. BIN
      build/classes/me/hammerle/graphics/Text.class
  27. BIN
      build/classes/me/hammerle/math/Fraction.class
  28. BIN
      build/classes/me/hammerle/scheduler/SnuviScheduler.class
  29. BIN
      build/classes/me/hammerle/scriptsystem/CodeParser.class
  30. BIN
      build/classes/me/hammerle/scriptsystem/GraphicEngine.class
  31. BIN
      build/classes/me/hammerle/scriptsystem/ScriptControl.class
  32. BIN
      build/classes/me/hammerle/scriptsystem/ScriptData.class
  33. BIN
      build/classes/me/hammerle/scriptsystem/ScriptEngine$1.class
  34. BIN
      build/classes/me/hammerle/scriptsystem/ScriptEngine$2.class
  35. BIN
      build/classes/me/hammerle/scriptsystem/ScriptEngine$3.class
  36. BIN
      build/classes/me/hammerle/scriptsystem/ScriptEngine.class
  37. BIN
      build/classes/me/hammerle/scriptsystem/ScriptUtils.class
  38. BIN
      build/classes/me/hammerle/scriptsystem/Tree$1.class
  39. BIN
      build/classes/me/hammerle/scriptsystem/Tree$Node.class
  40. BIN
      build/classes/me/hammerle/scriptsystem/Tree.class
  41. BIN
      build/classes/me/hammerle/snuviscript/SnuviScript.class
  42. 32 0
      dist/README.TXT
  43. BIN
      dist/SnuviScript.jar
  44. 3 0
      manifest.mf
  45. 1419 0
      nbproject/build-impl.xml
  46. 8 0
      nbproject/genfiles.properties
  47. 0 0
      nbproject/private/config.properties
  48. 6 0
      nbproject/private/private.properties
  49. 7 0
      nbproject/private/private.xml
  50. 76 0
      nbproject/project.properties
  51. 15 0
      nbproject/project.xml
  52. 34 0
      src/me/hammerle/console/BlackBox.java
  53. 36 0
      src/me/hammerle/console/Console.java
  54. 33 0
      src/me/hammerle/console/InputBox.java
  55. 19 0
      src/me/hammerle/console/OutputBox.java
  56. 6 0
      src/me/hammerle/exceptions/CodeTooLongException.java
  57. 6 0
      src/me/hammerle/exceptions/GoHigherAtRootTreeException.java
  58. 9 0
      src/me/hammerle/exceptions/GotoLabelNotFoundException.java
  59. 9 0
      src/me/hammerle/exceptions/IllegalColorException.java
  60. 16 0
      src/me/hammerle/exceptions/IllegalStringException.java
  61. 6 0
      src/me/hammerle/exceptions/InfiniteLoopException.java
  62. 6 0
      src/me/hammerle/exceptions/NoChildTreeException.java
  63. 18 0
      src/me/hammerle/graphics/FullOval.java
  64. 18 0
      src/me/hammerle/graphics/FullRectangle.java
  65. 26 0
      src/me/hammerle/graphics/GraphicObject.java
  66. 60 0
      src/me/hammerle/graphics/Image.java
  67. 67 0
      src/me/hammerle/graphics/Line.java
  68. 18 0
      src/me/hammerle/graphics/Oval.java
  69. 18 0
      src/me/hammerle/graphics/Rectangle.java
  70. 9 0
      src/me/hammerle/graphics/StartPoint.java
  71. 73 0
      src/me/hammerle/graphics/Text.java
  72. 517 0
      src/me/hammerle/math/Fraction.java
  73. 20 0
      src/me/hammerle/scheduler/SnuviScheduler.java
  74. 389 0
      src/me/hammerle/scriptsystem/CodeParser.java
  75. 49 0
      src/me/hammerle/scriptsystem/GraphicEngine.java
  76. 69 0
      src/me/hammerle/scriptsystem/ScriptControl.java
  77. 504 0
      src/me/hammerle/scriptsystem/ScriptData.java
  78. 98 0
      src/me/hammerle/scriptsystem/ScriptEngine.java
  79. 73 0
      src/me/hammerle/scriptsystem/ScriptUtils.java
  80. 154 0
      src/me/hammerle/scriptsystem/Tree.java
  81. 21 0
      src/me/hammerle/snuviscript/SnuviScript.java

BIN
.DS_Store


+ 73 - 0
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="SnuviScript" default="default" basedir=".">
+    <description>Builds, tests, and runs the project SnuviScript.</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="SnuviScript-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>

+ 4 - 0
build/built-jar.properties

@@ -0,0 +1,4 @@
+#Sat, 01 Apr 2017 03:21:06 +0200
+
+
+/Users/kajetanjohannes/Dropbox/Projekte/Informatik/SnuviScript=

+ 0 - 0
build/classes/.netbeans_automatic_build


+ 0 - 0
build/classes/.netbeans_update_resources


BIN
build/classes/me/hammerle/console/BlackBox.class


BIN
build/classes/me/hammerle/console/Console.class


BIN
build/classes/me/hammerle/console/InputBox$1.class


BIN
build/classes/me/hammerle/console/InputBox.class


BIN
build/classes/me/hammerle/console/OutputBox.class


BIN
build/classes/me/hammerle/exceptions/CodeTooLongException.class


BIN
build/classes/me/hammerle/exceptions/GoHigherAtRootTreeException.class


BIN
build/classes/me/hammerle/exceptions/GotoLabelNotFoundException.class


BIN
build/classes/me/hammerle/exceptions/IllegalColorException.class


BIN
build/classes/me/hammerle/exceptions/IllegalStringException.class


BIN
build/classes/me/hammerle/exceptions/InfiniteLoopException.class


BIN
build/classes/me/hammerle/exceptions/NoChildTreeException.class


BIN
build/classes/me/hammerle/graphics/FullOval.class


BIN
build/classes/me/hammerle/graphics/FullRectangle.class


BIN
build/classes/me/hammerle/graphics/GraphicObject.class


BIN
build/classes/me/hammerle/graphics/Image.class


BIN
build/classes/me/hammerle/graphics/Line.class


BIN
build/classes/me/hammerle/graphics/Oval.class


BIN
build/classes/me/hammerle/graphics/Rectangle.class


BIN
build/classes/me/hammerle/graphics/StartPoint.class


BIN
build/classes/me/hammerle/graphics/Text.class


BIN
build/classes/me/hammerle/math/Fraction.class


BIN
build/classes/me/hammerle/scheduler/SnuviScheduler.class


BIN
build/classes/me/hammerle/scriptsystem/CodeParser.class


BIN
build/classes/me/hammerle/scriptsystem/GraphicEngine.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptControl.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptData.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptEngine$1.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptEngine$2.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptEngine$3.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptEngine.class


BIN
build/classes/me/hammerle/scriptsystem/ScriptUtils.class


BIN
build/classes/me/hammerle/scriptsystem/Tree$1.class


BIN
build/classes/me/hammerle/scriptsystem/Tree$Node.class


BIN
build/classes/me/hammerle/scriptsystem/Tree.class


BIN
build/classes/me/hammerle/snuviscript/SnuviScript.class


+ 32 - 0
dist/README.TXT

@@ -0,0 +1,32 @@
+========================
+BUILD OUTPUT DESCRIPTION
+========================
+
+When you build an Java application project that has a main class, the IDE
+automatically copies all of the JAR
+files on the projects classpath to your projects dist/lib folder. The IDE
+also adds each of the JAR files to the Class-Path element in the application
+JAR files manifest file (MANIFEST.MF).
+
+To run the project from the command line, go to the dist folder and
+type the following:
+
+java -jar "SnuviScript.jar" 
+
+To distribute this project, zip up the dist folder (including the lib folder)
+and distribute the ZIP file.
+
+Notes:
+
+* If two JAR files on the project classpath have the same name, only the first
+JAR file is copied to the lib folder.
+* Only JAR files are copied to the lib folder.
+If the classpath contains other types of files or folders, these files (folders)
+are not copied.
+* If a library on the projects classpath also has a Class-Path element
+specified in the manifest,the content of the Class-Path element has to be on
+the projects runtime path.
+* To set a main class in a standard Java project, right-click the project node
+in the Projects window and choose Properties. Then click Run and enter the
+class name in the Main Class field. Alternatively, you can manually type the
+class name in the manifest Main-Class element.

BIN
dist/SnuviScript.jar


+ 3 - 0
manifest.mf

@@ -0,0 +1,3 @@
+Manifest-Version: 1.0
+X-COMMENT: Main-Class will be added automatically by build
+

+ 1419 - 0
nbproject/build-impl.xml

@@ -0,0 +1,1419 @@
+<?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="SnuviScript-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>
+        <condition else="false" property="javac.fork">
+            <or>
+                <istrue value="${jdkBug6558476}"/>
+                <istrue value="${javac.external.vm}"/>
+            </or>
+        </condition>
+        <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>
+        <property name="java.failonerror" value="true"/>
+    </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="&lt;nothing&gt;"/>
+        <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="SnuviScript" 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 SnuviScript -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}" failonerror="${java.failonerror}" 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 &quot;${ant.java.version}"/>
+        <condition property="have-jdk-older-than-1.4">
+            <or>
+                <contains string="${version-output}" substring="java version &quot;1.0"/>
+                <contains string="${version-output}" substring="java version &quot;1.1"/>
+                <contains string="${version-output}" substring="java version &quot;1.2"/>
+                <contains string="${version-output}" substring="java version &quot;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}" failonerror="${java.failonerror}" 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}" failonerror="${java.failonerror}" 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: SnuviScript 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: SnuviScript 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>

+ 8 - 0
nbproject/genfiles.properties

@@ -0,0 +1,8 @@
+build.xml.data.CRC32=8254428b
+build.xml.script.CRC32=55ca9e7c
+build.xml.stylesheet.CRC32=8064a381@1.79.1.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=8254428b
+nbproject/build-impl.xml.script.CRC32=eeccd9c7
+nbproject/build-impl.xml.stylesheet.CRC32=05530350@1.79.1.48

+ 0 - 0
nbproject/private/config.properties


+ 6 - 0
nbproject/private/private.properties

@@ -0,0 +1,6 @@
+compile.on.save=true
+do.depend=false
+do.jar=true
+javac.debug=true
+javadoc.preview=true
+user.properties.file=/Users/kajetanjohannes/Library/Application Support/NetBeans/8.1/build.properties

+ 7 - 0
nbproject/private/private.xml

@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project-private xmlns="http://www.netbeans.org/ns/project-private/1">
+    <editor-bookmarks xmlns="http://www.netbeans.org/ns/editor-bookmarks/2" lastBookmarkId="0"/>
+    <open-files xmlns="http://www.netbeans.org/ns/projectui-open-files/2">
+        <group/>
+    </open-files>
+</project-private>

+ 76 - 0
nbproject/project.properties

@@ -0,0 +1,76 @@
+annotation.processing.enabled=true
+annotation.processing.enabled.in.editor=false
+annotation.processing.processors.list=
+annotation.processing.run.all.processors=true
+annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output
+application.title=SnuviScript
+application.vendor=kajetanjohannes
+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}/SnuviScript.jar
+dist.javadoc.dir=${dist.dir}/javadoc
+endorsed.classpath=
+excludes=
+includes=**
+jar.compress=false
+javac.classpath=
+# Space-separated list of extra javac options
+javac.compilerargs=-Xlint:deprecation -Xlint:unchecked
+javac.deprecation=false
+javac.external.vm=true
+javac.processorpath=\
+    ${javac.classpath}
+javac.source=1.8
+javac.target=1.8
+javac.test.classpath=\
+    ${javac.classpath}:\
+    ${build.classes.dir}
+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=me.hammerle.snuviscript.SnuviScript
+manifest.file=manifest.mf
+meta.inf.dir=${src.dir}/META-INF
+mkdist.disabled=false
+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

+ 15 - 0
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>SnuviScript</name>
+            <source-roots>
+                <root id="src.dir"/>
+            </source-roots>
+            <test-roots>
+                <root id="test.src.dir"/>
+            </test-roots>
+        </data>
+    </configuration>
+</project>

+ 34 - 0
src/me/hammerle/console/BlackBox.java

@@ -0,0 +1,34 @@
+package me.hammerle.console;
+
+import java.awt.Color;
+import java.awt.Font;
+import javax.swing.JScrollPane;
+import javax.swing.JTextArea;
+
+public class BlackBox extends JScrollPane
+{
+    protected final JTextArea area;
+    protected final Console c;
+    
+    public BlackBox(Console c)
+    {
+        this.c = c;
+        
+        area = new JTextArea();
+        area.setLineWrap(true);
+        area.setBackground(Color.black);
+        area.setFont(new Font("Monaco", Font.PLAIN, 16));
+        area.setForeground(Color.white);
+        area.setCaretColor(Color.white);
+        area.setAutoscrolls(true);
+        
+        super.setViewportView(area);
+        super.setBackground(Color.black);
+        super.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_ALWAYS);
+    }
+    
+    public JTextArea getTextArea()
+    {
+        return area;
+    }
+}

+ 36 - 0
src/me/hammerle/console/Console.java

@@ -0,0 +1,36 @@
+package me.hammerle.console;
+
+import java.awt.BorderLayout;
+import java.awt.Dimension;
+import javax.swing.JFrame;
+
+public class Console extends JFrame
+{
+    protected final OutputBox output;
+    protected final InputBox input;
+    
+    public Console()
+    {
+        super.setDefaultCloseOperation(EXIT_ON_CLOSE);
+        super.setTitle("SnuviScript - 0.0.1 - Konsole");
+        super.setPreferredSize(new Dimension(660, 460));
+        super.setLayout(new BorderLayout(0, 1));
+        
+        // -------------------------------------------------------------------------------
+        // Input
+        // -------------------------------------------------------------------------------
+        
+        input = new InputBox(this);
+        super.add(input, BorderLayout.CENTER);
+        
+        // -------------------------------------------------------------------------------
+        // Output
+        // -------------------------------------------------------------------------------
+        
+        output = new OutputBox(this);
+        super.add(output, BorderLayout.PAGE_START);
+
+        super.pack();
+        super.setVisible(true);
+    }
+}

+ 33 - 0
src/me/hammerle/console/InputBox.java

@@ -0,0 +1,33 @@
+package me.hammerle.console;
+
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+
+public class InputBox extends BlackBox
+{
+    public InputBox(Console c)
+    {
+        super(c);
+        area.addKeyListener(new KeyAdapter() 
+        {
+            @Override
+            public void keyPressed(KeyEvent e) 
+            {
+                if(e.getKeyCode() == KeyEvent.VK_ENTER)
+                {
+                    if(e.isAltDown())
+                    {
+                        area.append("\n");
+                        e.consume();
+                    }
+                    else
+                    {
+                        c.output.pushText(area.getText());
+                        area.setText(null);
+                        e.consume();
+                    }
+                }
+            }
+        });
+    }
+}

+ 19 - 0
src/me/hammerle/console/OutputBox.java

@@ -0,0 +1,19 @@
+package me.hammerle.console;
+
+import java.awt.Dimension;
+
+public class OutputBox extends BlackBox
+{
+    public OutputBox(Console c)
+    {
+        super(c);
+        super.setPreferredSize(new Dimension(660, 345));
+        area.setEditable(false);
+        area.setText("--- Hello " + System.getProperty("user.name") + " ---");
+    }
+    
+    public void pushText(String s)
+    {
+        area.append("\n> " + s);
+    }
+}

+ 6 - 0
src/me/hammerle/exceptions/CodeTooLongException.java

@@ -0,0 +1,6 @@
+package me.hammerle.exceptions;
+
+public class CodeTooLongException extends Exception
+{
+    
+}

+ 6 - 0
src/me/hammerle/exceptions/GoHigherAtRootTreeException.java

@@ -0,0 +1,6 @@
+package me.hammerle.exceptions;
+
+public class GoHigherAtRootTreeException extends Exception
+{
+    
+}

+ 9 - 0
src/me/hammerle/exceptions/GotoLabelNotFoundException.java

@@ -0,0 +1,9 @@
+package me.hammerle.exceptions;
+
+public class GotoLabelNotFoundException extends IllegalStringException
+{
+    public GotoLabelNotFoundException(String s) 
+    {
+        super(s);
+    }  
+}

+ 9 - 0
src/me/hammerle/exceptions/IllegalColorException.java

@@ -0,0 +1,9 @@
+package me.hammerle.exceptions;
+
+public class IllegalColorException extends IllegalStringException
+{
+    public IllegalColorException(String s) 
+    {
+        super(s);
+    }   
+}

+ 16 - 0
src/me/hammerle/exceptions/IllegalStringException.java

@@ -0,0 +1,16 @@
+package me.hammerle.exceptions;
+
+public class IllegalStringException extends RuntimeException
+{
+    private final String s;
+    
+    public IllegalStringException(String s)
+    {
+        this.s = s;
+    }
+    
+    public String getBadString()
+    {
+        return s;
+    }
+}

+ 6 - 0
src/me/hammerle/exceptions/InfiniteLoopException.java

@@ -0,0 +1,6 @@
+package me.hammerle.exceptions;
+
+public class InfiniteLoopException extends RuntimeException
+{
+    
+}

+ 6 - 0
src/me/hammerle/exceptions/NoChildTreeException.java

@@ -0,0 +1,6 @@
+package me.hammerle.exceptions;
+
+public class NoChildTreeException extends Exception
+{
+    
+}

+ 18 - 0
src/me/hammerle/graphics/FullOval.java

@@ -0,0 +1,18 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public class FullOval extends Oval
+{
+    public FullOval(Color c, int x1, int y1, int x2, int y2) 
+    {
+        super(c, x1, y1, x2, y2);
+    }   
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.fillOval(x1, y1, x2 - x1 - 1, y2 - y1 - 1);
+    }
+}

+ 18 - 0
src/me/hammerle/graphics/FullRectangle.java

@@ -0,0 +1,18 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public class FullRectangle extends Rectangle
+{
+    public FullRectangle(Color c, int x1, int y1, int x2, int y2) 
+    {
+        super(c, x1, y1, x2, y2);
+    }   
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.fillRect(x1, y1, x2 - x1 - 1, y2 - y1 - 1);
+    }
+}

+ 26 - 0
src/me/hammerle/graphics/GraphicObject.java

@@ -0,0 +1,26 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public abstract class GraphicObject 
+{
+    private Color c;
+    
+    public GraphicObject(Color c)
+    {
+        this.c = c;        
+    }
+    
+    public Color getColor()
+    {
+        return c;
+    }
+    
+    public void setColor(Color c)
+    {
+        this.c = c;
+    }
+    
+    public abstract void paint(Graphics g);
+}

+ 60 - 0
src/me/hammerle/graphics/Image.java

@@ -0,0 +1,60 @@
+package me.hammerle.graphics;
+
+import java.awt.Graphics;
+import java.awt.image.BufferedImage;
+import me.hammerle.snuviscript.SnuviScript;
+
+public class Image extends Line implements StartPoint
+{
+    private int x;
+    private int y;
+    private BufferedImage image;
+    
+    public Image(BufferedImage image, int x, int y, int x1, int y1, int x2, int y2)
+    {
+        super(null, x1, y1, x2, y2);
+        this.image = image;
+        this.x = x;
+        this.y = y;
+    }
+    
+    public Image(BufferedImage image, int x, int y)
+    {
+        this(image, x, y, 0, 0, image.getWidth(), image.getHeight());
+    }
+    
+    @Override
+    public void setX(int x)
+    {
+        this.x = x;
+    }
+    
+    @Override
+    public void setY(int y)
+    {
+        this.y = y;
+    }
+    
+    @Override
+    public int getX()
+    {
+        return x;
+    }
+    
+    @Override
+    public int getY()
+    {
+        return y;
+    }
+    
+    public void setImage(BufferedImage image)
+    {
+        this.image = image;
+    }
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.drawImage(image.getSubimage(x1, y1, x2 - x1, y2 - y1), x, y, SnuviScript.screen);
+    }
+}

+ 67 - 0
src/me/hammerle/graphics/Line.java

@@ -0,0 +1,67 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public class Line extends GraphicObject
+{
+    protected int x1;
+    protected int y1;
+    protected int x2;
+    protected int y2;
+    
+    public Line(Color c, int x1, int y1, int x2, int y2) 
+    {
+        super(c);
+        this.x1 = x1;
+        this.y1 = y1;
+        this.x2 = x2;
+        this.y2 = y2;
+    }   
+    
+    public void setFirstX(int x)    
+    {
+        x1 = x;
+    }
+    
+    public void setFirstY(int y)    
+    {
+        y1 = y;
+    }
+    
+    public void setSecondX(int x)    
+    {
+        x2 = x;
+    }
+    
+    public void setSecondY(int y)    
+    {
+        y2 = y;
+    }
+    
+    public int getFirstX()    
+    {
+        return x1;
+    }
+    
+    public int getFirstY()    
+    {
+        return y1;
+    }
+    
+    public int getSecondX()    
+    {
+        return x2;
+    }
+    
+    public int getSecondY()    
+    {
+        return y2;
+    }
+
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.drawLine(x1, y1, x2, y2);
+    }
+}

+ 18 - 0
src/me/hammerle/graphics/Oval.java

@@ -0,0 +1,18 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public class Oval extends Line
+{
+    public Oval(Color c, int x1, int y1, int x2, int y2) 
+    {
+        super(c, x1, y1, x2, y2);
+    }  
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.drawOval(x1, y1, x2 - x1 - 1, y2 - y1 - 1);
+    }
+}

+ 18 - 0
src/me/hammerle/graphics/Rectangle.java

@@ -0,0 +1,18 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Graphics;
+
+public class Rectangle extends Line
+{
+    public Rectangle(Color c, int x1, int y1, int x2, int y2) 
+    {
+        super(c, x1, y1, x2, y2);
+    }  
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.drawRect(x1, y1, x2 - x1 - 1, y2 - y1 - 1);
+    }
+}

+ 9 - 0
src/me/hammerle/graphics/StartPoint.java

@@ -0,0 +1,9 @@
+package me.hammerle.graphics;
+
+public interface StartPoint 
+{
+    public void setX(int x);
+    public void setY(int y);
+    public int getX();
+    public int getY();
+}

+ 73 - 0
src/me/hammerle/graphics/Text.java

@@ -0,0 +1,73 @@
+package me.hammerle.graphics;
+
+import java.awt.Color;
+import java.awt.Font;
+import java.awt.Graphics;
+
+public class Text extends GraphicObject implements StartPoint
+{
+    private String text;
+    private Font font;
+    private int x;
+    private int y;
+    
+    public Text(Color c, int x, int y, String text, Font font) 
+    {
+        super(c);
+        this.x = x;
+        this.y = y;
+        this.text = text;
+        this.font = font;
+    }
+    
+    @Override
+    public void setX(int x)
+    {
+        this.x = x;
+    }
+    
+    @Override
+    public void setY(int y)
+    {
+        this.y = y;
+    }
+    
+    @Override
+    public int getX()
+    {
+        return x;
+    }
+    
+    @Override
+    public int getY()
+    {
+        return y;
+    }
+    
+    public void setText(String text)
+    {
+        this.text = text;
+    }
+    
+    public void setfont(Font font)
+    {
+        this.font = font;
+    }
+    
+    public String getText()
+    {
+        return text;
+    }
+    
+    public Font getfont()
+    {
+        return font;
+    }
+
+    @Override
+    public void paint(Graphics g) 
+    {
+        g.setFont(font);
+        g.drawString(text, x, y);
+    }  
+}

+ 517 - 0
src/me/hammerle/math/Fraction.java

@@ -0,0 +1,517 @@
+package me.hammerle.math;
+
+public class Fraction implements Cloneable, Comparable<Fraction>
+{
+    private long numerator;
+    private long denominator;
+    
+    public Fraction(long n, long d)
+    {
+        if(d == 0)
+        {
+            throw new ArithmeticException();
+        }
+        else if(d < 0)
+        {
+            this.denominator = -d;
+            this.numerator = -n;
+        }
+        else
+        {
+            this.denominator = d;
+            this.numerator = n;
+        }
+        shortFraction();
+    }
+    
+    public Fraction(long n)
+    {
+        this(n, 1);
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Konstanten
+    // ----------------------------------------------------------------------------------- 
+    
+    private static final Fraction PI = new Fraction(355, 113);
+    private static final Fraction E = new Fraction(2721, 1001);
+    
+    public static Fraction getPi()
+    {
+        return PI.clone();
+    }
+    
+    public static Fraction getE()
+    {
+        return E.clone();
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Ausgabe
+    // ----------------------------------------------------------------------------------- 
+
+    public double getDoubleValue()
+    {
+        return numerator / (double) denominator;
+    }
+    
+    public long getLongValue()
+    {
+        return numerator / denominator;
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Grundrechnungsarten
+    // ----------------------------------------------------------------------------------- 
+    
+    public Fraction add(Fraction f)
+    {
+        if(denominator == f.denominator)
+        {
+            boolean b = true;
+            while(b)
+            {
+                try
+                {
+                    numerator = Math.addExact(numerator, f.numerator);
+                    b = false;
+                }
+                catch(ArithmeticException ex)
+                {
+                    simplify();
+                    f.simplify();
+                }
+            }
+        }
+        else
+        {
+            boolean b = true;
+            while(b)
+            {
+                try
+                {
+                    long l = Math.addExact(Math.multiplyExact(numerator, f.denominator), Math.multiplyExact(f.numerator, denominator));
+                    long l2 = Math.multiplyExact(denominator, f.denominator);;
+                    numerator = l;
+                    denominator = l2;
+                    b = false;
+                }
+                catch(ArithmeticException ex)
+                {
+                    simplify();
+                    f.simplify();
+                }
+            }
+        }
+        shortFraction();
+        return this;
+    }
+    
+    public Fraction mul(Fraction f)
+    {
+        boolean b = true;
+        while(b)
+        {
+            try
+            {
+                long l = Math.multiplyExact(denominator, f.denominator);
+                long l2 = Math.multiplyExact(numerator, f.numerator);
+                denominator = l;
+                numerator = l2;
+                b = false;
+            }
+            catch(ArithmeticException ex)
+            {
+                simplify();
+                f.simplify();
+            }
+        }
+        shortFraction();
+        return this;
+    }
+    
+    public Fraction mul(long f)
+    {
+        boolean b = true;
+        while(b)
+        {
+            try
+            {
+                numerator = Math.multiplyExact(numerator, f);
+                b = false;
+            }
+            catch(ArithmeticException ex)
+            {
+                simplify();
+            }
+        }
+        shortFraction();
+        return this;
+    }
+    
+    public Fraction sub(Fraction f)
+    {
+        this.add(f.clone().invertSign());
+        return this;
+    }
+    
+    public Fraction div(Fraction f)
+    {
+        this.mul(f.clone().invert());
+        return this;
+    }
+    
+    public Fraction div(long f)
+    {
+        boolean b = true;
+        while(b)
+        {
+            try
+            {
+                denominator = Math.multiplyExact(denominator, f);
+                b = false;
+            }
+            catch(ArithmeticException ex)
+            {
+                simplify();
+            }
+        }
+        shortFraction();
+        return this;
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Radizieren, Potenzieren
+    // ----------------------------------------------------------------------------------- 
+    
+    public Fraction squareRoot()
+    {
+        Fraction f = new Fraction((long) Math.sqrt(this.getDoubleValue()));
+        long a = 0;
+        long b = 0;
+        Fraction f2;
+        int k = 0;
+        while(true)
+        {
+            k++;
+            f2 = f.clone();
+            f.mul(f2).add(this).div(f2.mul(2));
+            
+            if((k >= 2 && f.denominator == 1) || f.denominator > 281474976710656l || f.numerator == b)
+            {
+                break;
+            }
+            
+            b = a;
+            a = f.numerator;
+        }
+        tryExactRoot(f);
+        numerator = f.numerator;
+        denominator = f.denominator;
+        if(numerator < 0)
+        {
+            numerator = -numerator;
+        }
+        return this;
+    }
+    
+    public Fraction power(Fraction f)
+    {
+        if(f.denominator == 1)
+        {
+            power(f.numerator);
+            return this;
+        }
+        throw new ArithmeticException();
+    }
+    
+    private Fraction power(long p)
+    {
+        if(p < 0)
+        {
+            p = -p;
+            invert();
+        }
+        else if(p == 1)
+        {
+            return this;
+        }
+        long prodn = 1;
+        long prodd = 1;
+        long n = numerator;
+        long d = denominator;
+        while(p > 0)
+        {
+            if((p & 1) == 1)
+            {
+                prodn *= n;
+                prodd *= d;
+            }
+            p = p >> 1;
+            n *= n;
+            d *= d;
+        }
+        numerator = prodn;
+        denominator = prodd;
+        return this;
+    }
+    
+    private void tryExactRoot(Fraction f)
+    {
+        Fraction f2 = f.clone();
+        if(f2.denominator == 1)
+        {
+            return;
+        }
+        int k = 0;
+        while(f2.denominator > 1)
+        {
+            k++;
+            f2.simplify();
+            if(f2.clone().power(2).equals(this))
+            {
+                f.numerator = f2.numerator;
+                f.denominator = f2.denominator;
+                return;
+            }
+        }
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Invertieren
+    // ----------------------------------------------------------------------------------- 
+    
+    public Fraction invertSign()
+    {
+        numerator = -numerator;
+        return this;
+    }
+    
+    public Fraction invert()
+    {
+        if(numerator == 0)
+        {
+            throw new ArithmeticException();
+        }
+        long helper = numerator;
+        if(helper < 0)
+        {
+            numerator = -denominator;
+            denominator = -helper;
+        }
+        else
+        {
+            numerator = denominator;
+            denominator = helper;
+        }
+        return this;
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Winkelfunktionen
+    // ----------------------------------------------------------------------------------- 
+    
+    public Fraction sin()
+    {
+        int factor = 1;
+        if(numerator < 0)
+        {
+            factor = -1;
+            numerator = -numerator;
+        }
+        
+        Fraction pi = getPi().mul(2);
+        while(this.compareTo(pi) >= 0)
+        {
+            this.sub(pi);
+        }
+        
+        if(isBetween(new Fraction(0), getPi().div(2)))
+        {
+            // Nichts
+        }
+        else if(isBetween(getPi().div(2), getPi()))
+        {
+            this.invertSign().add(getPi());
+        }
+        else if(this.compareTo(getPi()) >= 0)
+        {
+            this.sub(getPi());
+            factor = -factor;
+        }
+        
+        
+        Fraction quad = this.clone().power(2);
+        Fraction value = this.clone();
+        Fraction result = this.clone();
+        
+        int k = 1;
+        for(int i = 0; i < 20; i++)
+        {
+            value.div(i + 2);
+            if((i & 1) == 1)
+            {
+                value.mul(quad);
+                k = -k;
+                if(k == -1)
+                {
+                    result.sub(value);
+                }
+                else
+                {
+                    result.add(value);
+                }
+            }
+        }
+        numerator = factor * result.numerator;
+        denominator = result.denominator;
+        return this;
+    }
+    
+    public Fraction cos()
+    {
+        this.add(getPi().div(2));
+        return sin();
+    }
+    
+    public Fraction tan()
+    {
+        sin();
+        div(this.clone().cos());
+        return this;
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Vereinfachung
+    // ----------------------------------------------------------------------------------- 
+    
+    private void shortFraction()
+    {
+        if(denominator == 1)
+        {
+            return;
+        }
+        long divisor = getGreatestCommonDivisor(numerator, denominator);
+        if(divisor != 1)
+        {
+            denominator /= divisor;
+            numerator /= divisor;
+        }
+    }
+    
+    private void simplify()
+    {
+        if(denominator == 1)
+        {
+            //denominator += 2;
+            System.out.println(this);
+            throw new ArithmeticException();
+        }
+        denominator = (denominator & 1) == 1 ? denominator - 1 : denominator;
+        numerator = (numerator & 1) == 1 ? numerator - 1 : numerator;
+        //System.out.println(denominator + "  WUSI  " + numerator);
+        shortFraction();
+        //System.out.println(denominator + "  WUSI  " + numerator);
+    }
+    
+    private long getGreatestCommonDivisor(long i, long n)
+    {
+        if(i == 0)
+        {
+            return n;
+        }
+        if(i < 0)
+        {
+            i = -i;
+        }
+        if(n < 0)
+        {
+            n = -n;
+        }
+        long helper;
+        while(true)
+        {
+            if(i < n)
+            {
+                helper = i;
+                i = n;
+                n = helper;
+            }
+            i = i % n;
+            if(i == 0)
+            {
+                return n;
+            }
+        }
+    }
+    
+    // -----------------------------------------------------------------------------------
+    // Grundobjektcode
+    // ----------------------------------------------------------------------------------- 
+    
+    @Override
+    public String toString() 
+    {
+        return numerator + " / " + denominator;
+    }
+
+    @Override
+    public Fraction clone()
+    {
+        return new Fraction(numerator, denominator);
+    }
+
+    @Override
+    public boolean equals(Object o) 
+    {
+        if(!(o instanceof Fraction))
+        {
+            return false;
+        }
+        Fraction f = (Fraction) o;
+        return numerator == f.numerator && denominator == f.denominator;
+    }
+
+    @Override
+    public int hashCode() 
+    {
+        int hash = 3;
+        hash = 97 * hash + (int) (this.numerator ^ (this.numerator >>> 32));
+        hash = 97 * hash + (int) (this.denominator ^ (this.denominator >>> 32));
+        return hash;
+    }
+
+    @Override
+    public int compareTo(Fraction f) 
+    {
+        if(f.numerator < 0 && numerator >= 0)
+        {
+            return 1;
+        }
+        else if(f.numerator >= 0 && numerator < 0)
+        {
+            return -1;
+        }
+        else
+        {
+            long i = f.clone().sub(this).numerator;
+            if(i == 0)
+            {
+                return 0;
+            }
+            else if(i < 0)
+            {
+                return 1;
+            }
+            else
+            {
+                return -1;
+            }
+        }
+    }
+    
+    public boolean isBetween(Fraction f1, Fraction f2)
+    {
+        return this.compareTo(f1) >= 0 && this.compareTo(f2) <= 0;
+    }
+}

+ 20 - 0
src/me/hammerle/scheduler/SnuviScheduler.java

@@ -0,0 +1,20 @@
+package me.hammerle.scheduler;
+
+import java.util.concurrent.Executors;
+import java.util.concurrent.ScheduledExecutorService;
+import java.util.concurrent.TimeUnit;
+
+public class SnuviScheduler 
+{
+    public static void doScheduledTask(Runnable r)
+    {
+        r.run();
+    }
+    
+    public static void doScheduledTask(Runnable r, int delay)
+    {
+        ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor();   
+        executor.schedule(r, delay, TimeUnit.MILLISECONDS);
+        executor.shutdown();
+    }
+}

+ 389 - 0
src/me/hammerle/scriptsystem/CodeParser.java

@@ -0,0 +1,389 @@
+package me.hammerle.scriptsystem;
+
+import java.awt.image.BufferedImage;
+import java.io.File;
+import java.io.IOException;
+import me.hammerle.exceptions.IllegalStringException;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.time.ZonedDateTime;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Calendar;
+import java.util.Collections;
+import java.util.GregorianCalendar;
+import java.util.List;
+import java.util.stream.Collectors;
+import java.awt.Font;
+import java.util.HashMap;
+import javax.imageio.ImageIO;
+import me.hammerle.exceptions.IllegalColorException;
+import me.hammerle.exceptions.NoChildTreeException;
+import me.hammerle.graphics.*;
+import me.hammerle.snuviscript.SnuviScript;
+
+public class CodeParser 
+{    
+    @SuppressWarnings("unchecked")
+    public static Object parseFunction(ScriptData sd, String function, List<Object> args)
+    {
+        try
+        {
+            switch(function.toLowerCase())
+            {       
+                // Rechenoperationen
+                case "add":
+                    return args.stream().mapToDouble(s -> ScriptUtils.getDouble(s)).sum();
+                case "sub":
+                    return ScriptUtils.getDouble(args.get(0)) - ScriptUtils.getDouble(args.get(1));
+                case "mul":
+                    return ScriptUtils.getDouble(args.get(0)) * ScriptUtils.getDouble(args.get(1));
+                case "div":
+                    return ScriptUtils.getDouble(args.get(0)) / ScriptUtils.getDouble(args.get(1));
+                case "math.mod":
+                    return ScriptUtils.getDouble(args.get(0)) % ScriptUtils.getDouble(args.get(1));
+                case "math.abs":
+                    return Math.abs(ScriptUtils.getDouble(args.get(0)));
+                case "math.pow":
+                    return Math.pow(ScriptUtils.getDouble(args.get(0)), ScriptUtils.getDouble(args.get(1)));
+                case "math.root":
+                    return Math.pow(ScriptUtils.getDouble(args.get(0)), 1d / ScriptUtils.getDouble(args.get(1)));
+                case "math.sin":
+                    return Math.sin(ScriptUtils.getDouble(args.get(0)));
+                case "math.cos":
+                    return Math.cos(ScriptUtils.getDouble(args.get(0)));
+                case "math.e":
+                    return Math.E;
+                case "math.pi":
+                    return Math.PI;
+                case "math.ln":
+                    return Math.log(ScriptUtils.getDouble(args.get(0)));
+                case "math.log":
+                    return Math.log10(ScriptUtils.getDouble(args.get(0)));
+                case "math.random":
+                    return ScriptUtils.randomInt(ScriptUtils.getInteger(args.get(0)), ScriptUtils.getInteger(args.get(1)));
+                case "math.round":
+                    return ((Long) Math.round(ScriptUtils.getDouble(args.get(0)))).intValue();
+                case "math.rounddown":
+                    return Math.floor(ScriptUtils.getDouble(args.get(0)));
+                case "math.roundup":
+                    return Math.ceil(ScriptUtils.getDouble(args.get(0)));
+                case "math.roundcomma":
+                    return new BigDecimal(ScriptUtils.getDouble(args.get(0))).setScale(ScriptUtils.getInteger(args.get(1)), RoundingMode.HALF_UP);
+
+                // Variablen
+                case "getvar":
+                    return sd.getVar(args.get(0));
+                case "setvar":
+                    sd.setVar(args.get(0), args.get(1)); break;
+                case "removevar":
+                    sd.removeVar(args.get(0)); break;          
+
+                // Listen - Befehle                         
+                case "list.new":                                               
+                    sd.setVar(args.get(0), new ArrayList<>()); break; 
+                case "list.exists":                                               
+                    return sd.getVar(args.get(0)) instanceof List;
+                case "list.add":  
+                    ((List) sd.getVar(args.get(0))).add(args.get(1)); break;
+                case "list.remove":          
+                    ((List) sd.getVar(args.get(0))).remove(args.get(1)); break;
+                case "list.removeindex":           
+                    ((List) sd.getVar(args.get(0))).remove((int) args.get(1)); break;                
+                case "list.contains":                           
+                    return ((List) sd.getVar(args.get(0))).contains(args.get(1));
+                case "list.size":                           
+                    return ((List) sd.getVar(args.get(0))).size();
+                case "list.get":                           
+                    return ((List) sd.getVar(args.get(0))).get((int) args.get(1));
+                case "list.set":                           
+                    ((List) sd.getVar(args.get(0))).set((int) args.get(1), args.get(2)); break;
+                case "list.indexof":                           
+                    return ((List) sd.getVar(args.get(0))).indexOf(args.get(1));
+                case "list.sort": 
+                    sortList(args, sd); break;
+                case "list.reverse":          
+                    Collections.reverse((List<Object>) sd.getVar(args.get(0))); break;
+                case "list.shuffle":                           
+                    Collections.shuffle((List<Object>) sd.getVar(args.get(0))); break;
+
+                // Maps - Befehle                         
+                case "map.new":                                               
+                    sd.setVar(args.get(0), new HashMap<>()); break;
+                case "map.exists":                                               
+                    return sd.getVar(args.get(0)) instanceof HashMap; 
+                case "map.add":                           
+                    ((HashMap) sd.getVar(args.get(0))).put(args.get(1), args.get(2)); break;
+                case "map.remove":                           
+                    ((HashMap) sd.getVar(args.get(0))).remove(args.get(1)); break;
+                case "map.contains":                         
+                    return ((HashMap) sd.getVar(args.get(0))).containsKey(args.get(1));
+                case "map.get":                           
+                    return ((HashMap) sd.getVar(args.get(0))).get(args.get(1));
+
+                // Grafik
+                case "repaint":
+                    SnuviScript.screen.graphics.repaint(); break;
+                case "drawline":
+                    SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                            new Line(ScriptUtils.getColor(args.get(1)),
+                            ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),
+                            ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)))); break;
+                case "drawoval":
+                    SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                            new Oval(ScriptUtils.getColor(args.get(1)),
+                            ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),
+                            ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)))); break;
+                case "drawrec":
+                    SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                            new Rectangle(ScriptUtils.getColor(args.get(1)),
+                            ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),
+                            ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)))); break;
+                case "drawfulloval":
+                    SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                            new FullOval(ScriptUtils.getColor(args.get(1)),
+                            ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),
+                            ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)))); break;
+                case "drawfullrec":
+                    SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                            new FullRectangle(ScriptUtils.getColor(args.get(1)),
+                            ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),
+                            ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)))); break;
+                case "drawimage":
+                    drawImage(args); break;  
+                case "drawstring":
+                    drawString(args); break;
+                case "removegraphic":
+                    SnuviScript.screen.graphics.removeGraphicObject(ScriptUtils.getInteger(args.get(0))); break;
+                case "buffergraphic":
+                    SnuviScript.screen.graphics.loadGraphicObjectIntoBuffer(ScriptUtils.getInteger(args.get(0))); break;
+                case "setcolor":
+                    SnuviScript.screen.graphics.getBuffer().setColor(ScriptUtils.getColor(args.get(0))); break;
+                case "setx":
+                    ((StartPoint) SnuviScript.screen.graphics.getBuffer()).setX(ScriptUtils.getInteger(args.get(0))); break;
+                case "sety":
+                    ((StartPoint) SnuviScript.screen.graphics.getBuffer()).setY(ScriptUtils.getInteger(args.get(0))); break;
+                case "setx1":
+                    ((Line) SnuviScript.screen.graphics.getBuffer()).setFirstX(ScriptUtils.getInteger(args.get(0))); break;
+                case "sety1":
+                    ((Line) SnuviScript.screen.graphics.getBuffer()).setFirstY(ScriptUtils.getInteger(args.get(0))); break;
+                case "setx2":
+                    ((Line) SnuviScript.screen.graphics.getBuffer()).setSecondX(ScriptUtils.getInteger(args.get(0))); break;
+                case "sety2":
+                    ((Line) SnuviScript.screen.graphics.getBuffer()).setSecondY(ScriptUtils.getInteger(args.get(0))); break; 
+                case "setscreensize":
+                    SnuviScript.screen.setSize(ScriptUtils.getInteger(args.get(0)), ScriptUtils.getInteger(args.get(1)));
+                    SnuviScript.screen.graphics.setSize(SnuviScript.screen.getWidth(), SnuviScript.screen.getHeight() - 22); break;
+                case "getscreenx":
+                    return SnuviScript.screen.graphics.getWidth();
+                case "getscreeny":
+                    return SnuviScript.screen.graphics.getHeight();
+
+                // Allgemeines
+                case "debug":
+                    System.out.println(args.get(0));
+                    break;
+                /*case "loadlib":
+                    sd.loadLibrary(args.get(0)); break;
+                case "lib":
+                    SnuviScript.scriptController.startLibrary(qd, args); return false;*/
+                case "reset":
+                    sd.resetOverflowProtection(); break;                   
+                case "wait":
+                    sd.resetOverflowProtection(); return false; 
+                case "term":
+                    SnuviScript.scriptController.term(sd); return false;
+                case "exit":
+                    System.exit(0); return false;
+                case "loadevent":
+                    sd.loadEvent(args.get(0)); break; 
+                case "unloadevent":
+                    sd.unloadEvent(args.get(0)); break; 
+                case "goto":
+                    sd.gotoLabel(args.get(0).toString()); break;
+                case "sgoto":
+                    scheduleGoto(args, sd); break;                    
+
+                // Conditions
+                case "if":
+                    ifFunction(args, sd); break;   
+                case "equal":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) == 0;
+                case "less":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) == -1;
+                case "greater":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) == 1;
+                case "notequal":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) != 0;
+                case "lessequal":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) <= 0;
+                case "greaterequal":
+                    return ((Comparable) args.get(0)).compareTo(args.get(1)) >= 0;
+                case "invert":
+                    return args.stream().allMatch(s -> s.equals(true));
+                case "and":
+                    return args.stream().allMatch(s -> s.equals(true));
+                case "or":
+                    return args.stream().anyMatch(s -> s.equals(true));
+                    
+                // Sonstiges
+                case "concatlist":                           
+                    return String.join("", ((List) sd.getVar(args.get(0))).subList(ScriptUtils.getInteger(args.get(1)), ScriptUtils.getInteger(args.get(2))));
+                case "concatlistspace":                           
+                    return String.join(" ", ((List) sd.getVar(args.get(0))).subList(ScriptUtils.getInteger(args.get(1)), ScriptUtils.getInteger(args.get(2))));
+                case "split":  
+                    sd.setVar(args.get(0), new ArrayList<>(Arrays.asList(args.get(2).toString().split(args.get(1).toString())))); break;
+                case "concat":                           
+                    return args.stream().map(o -> o.toString()).collect(Collectors.joining());
+                case "concatspace":                           
+                    return args.stream().map(o -> o.toString()).collect(Collectors.joining(" "));
+                case "tolowercase":                           
+                    return args.get(0).toString().toLowerCase();
+                case "touppercase":                           
+                    return args.get(0).toString().toUpperCase();
+
+                case "gettime":                           
+                    return System.currentTimeMillis(); 
+                case "nextday":        
+                    return getNextDay(args, sd);   
+                case "waitfor":    
+                    return waitFor(args, sd);
+
+                // Is Valid Checker    
+                case "isvalidnumber":
+                    return generalValidChecker(() -> ScriptUtils.getDouble(args.get(0)));
+
+                default:
+                    throw new NoSuchMethodException();                      
+            }
+            return 0;
+        }
+        catch(Exception ex)
+        {
+            //ex.printStackTrace();
+            printQuestException(sd, ex, function);
+            return null;
+        }
+    }
+    
+    public static void printQuestException(ScriptData sd, Exception ex, String line)
+    {
+        sd.resetOverflowProtection();
+        ScriptUtils.printDebug("Error in");
+        ScriptUtils.printDebugList("Script: " + sd.getName());
+        ScriptUtils.printDebugList("Zeile: " + line);
+        ScriptUtils.printDebugList("Exception: " + ex.getClass().getSimpleName());
+        if(ex instanceof IllegalStringException)
+        {
+            ScriptUtils.printDebugList("Ungültiger Wert: " + ((IllegalStringException) ex).getBadString());
+        }
+    }
+    
+    // -----------------------
+    // Script Befehle
+    // -----------------------
+    
+    private static void drawImage(List<Object> args) throws IOException 
+    {
+        BufferedImage image = ImageIO.read(new File(args.get(1).toString()));
+        if(args.size() >= 5)
+        {
+            SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                    new Image(image, ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),        
+                    ScriptUtils.getInteger(args.get(4)), ScriptUtils.getInteger(args.get(5)),
+                    ScriptUtils.getInteger(args.get(6)), ScriptUtils.getInteger(args.get(7))));
+            return;
+        } 
+        SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                    new Image(image, ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3))));
+    }
+    
+    private static void drawString(List<Object> args) throws IllegalColorException
+    {
+        SnuviScript.screen.graphics.addGraphicObject(ScriptUtils.getInteger(args.get(0)), 
+                new Text(ScriptUtils.getColor(args.get(1)), 
+                ScriptUtils.getInteger(args.get(2)), ScriptUtils.getInteger(args.get(3)),        
+                args.get(4).toString(), new Font(args.get(5).toString(), ScriptUtils.getInteger(args.get(6)), ScriptUtils.getInteger(args.get(7)))));
+    }
+
+    private static void ifFunction(List<Object> args, ScriptData sd) throws NoChildTreeException
+    {
+        if(args.stream().allMatch(s -> s.equals(true)))
+        {
+            sd.goDeeper();
+        }
+    }
+                  
+    private static void sortList(List<Object> args, ScriptData sd) 
+    {     
+        List<Object> list = (List<Object>) sd.getVar(args.get(0));
+        sd.setVar(args.get(0), list.stream().sorted().collect(Collectors.toList()));
+    }
+                   
+    private static void scheduleGoto(List<Object> args, ScriptData qd)
+    {
+        /*SnuviScheduler.doScheduledTask(() -> 
+        {
+            if(!sd.isValid())
+            {
+                return;
+            }
+            try
+            {
+                sd.setCodeLine(sd.getGoto(args.get(0)));
+                continueCode(qd, null);
+            }
+            catch(GotoLabelNotFoundException ex)
+            {
+                ScriptUtilities.printDebugMessage("Das Scheduled-Goto '" + args.get(0) + "' wurde nicht gefunden.");
+            }
+        }, Integer.parseInt(args.get(1)));*/
+    }
+
+    private static String getNextDay(List<Object> args, ScriptData qd)       
+    {
+        GregorianCalendar cal = GregorianCalendar.from(ZonedDateTime.now());
+        cal.setTimeInMillis(Long.parseLong(args.get(0).toString()));
+        cal.set(Calendar.HOUR, 0);
+        cal.set(Calendar.SECOND, 0);
+        cal.set(Calendar.MINUTE, 0);
+        cal.set(Calendar.MILLISECOND, 0);
+        cal.add(Calendar.DAY_OF_YEAR, 1);
+        return String.valueOf(cal.getTimeInMillis());   
+    } 
+    
+    private static boolean waitFor(List<Object> args, ScriptData qd) throws UnsupportedOperationException
+    {           
+        /*SnuviScript.scriptController.resetOverflowProtection();
+        int i = Integer.parseInt(args.get(0));
+        if(i < 1)
+        {
+            throw new UnsupportedOperationException();
+        }
+        SnuviScheduler.doScheduledTask(() -> 
+        {                   
+            if(qd == null || !sd.isValid())
+            {
+                return;
+            }
+            sd.setWaiting(false);
+            sd.nextCodeLine();
+            continueCode(qd, null);
+        }, i); 
+        sd.setWaiting(true);*/
+        return false;
+    }
+
+    private static boolean generalValidChecker(Runnable r)
+    {
+        try
+        {
+            r.run();
+            return true;
+        }
+        catch(Exception ex)
+        {
+            return false;
+        }
+    }   
+}

+ 49 - 0
src/me/hammerle/scriptsystem/GraphicEngine.java

@@ -0,0 +1,49 @@
+package me.hammerle.scriptsystem;
+
+import java.awt.Graphics;
+import java.util.TreeMap;
+import javax.swing.JPanel;
+import me.hammerle.graphics.GraphicObject;
+
+public class GraphicEngine extends JPanel
+{
+    private final TreeMap<Integer, GraphicObject> objects;
+    private GraphicObject buffer;
+    
+    public GraphicEngine()
+    {
+        this.objects = new TreeMap<>();
+    }
+    
+    public GraphicObject getBuffer()
+    {
+        return buffer;
+    }
+    
+    public GraphicObject loadGraphicObjectIntoBuffer(int id)
+    {
+        buffer = objects.get(id);
+        return buffer;
+    }
+    
+    public void removeGraphicObject(int id)
+    {
+        objects.remove(id);
+    }
+    
+    public void addGraphicObject(int id, GraphicObject go)
+    {
+        objects.put(id, go);
+    }
+    
+    @Override
+    public void paint(Graphics g) 
+    {
+        super.paint(g);
+        objects.forEach((i, go) -> 
+        {
+            g.setColor(go.getColor());
+            go.paint(g);
+        });
+    }   
+}

+ 69 - 0
src/me/hammerle/scriptsystem/ScriptControl.java

@@ -0,0 +1,69 @@
+package me.hammerle.scriptsystem;
+
+import java.util.Collection;
+import java.util.HashMap;
+
+public class ScriptControl
+{
+    private int idCounter;
+    private final HashMap<Integer, ScriptData> scripts;
+    
+    public ScriptControl() 
+    {
+        scripts = new HashMap<>();
+        idCounter = 0;
+    }    
+    
+    // -------------------------------------------------------------------------
+    // Script - Verwaltung
+    // -------------------------------------------------------------------------
+
+    public ScriptData getScript(int id)
+    {
+        return scripts.get(id);
+    }
+    
+    public void removeScripts()
+    {
+        //scripts.values().forEach(sd -> sd.setValid(false));
+        scripts.clear();
+    }
+    
+    public Collection<ScriptData> getScripts()
+    {
+        return scripts.values();
+    }
+    
+    private void add(ScriptData sd)
+    {
+        scripts.put(sd.getId(), sd);
+    }
+    
+    public void term(ScriptData sd)
+    {
+        /*if(sd == null)
+        {
+            return;
+        }
+        activeScript = sd.getIdBefore();
+        ScriptData sda = getActiveScript();
+        sda.setVar("return", sd.getVar("return"));
+        sd.setValid(false);
+        int id = sd.getId();
+        SnuviScheduler.doScheduledTask(() -> scripts.remove(id));
+        sda.nextCodeLine();
+        CodeParser.continueCode(sda, null);*/
+    }
+
+    // -----------------------
+    // Scripts laden und starten
+    // -----------------------
+  
+    public void startScript(String scriptName)
+    { 
+        ScriptData sd = new ScriptData(idCounter, scriptName);
+        idCounter++;
+        add(sd);
+        sd.runCode();
+    }
+}

+ 504 - 0
src/me/hammerle/scriptsystem/ScriptData.java

@@ -0,0 +1,504 @@
+package me.hammerle.scriptsystem;
+
+import java.io.File;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.HashMap;
+import java.util.HashSet;
+import me.hammerle.exceptions.CodeTooLongException;
+import me.hammerle.exceptions.GoHigherAtRootTreeException;
+import me.hammerle.exceptions.GotoLabelNotFoundException;
+import me.hammerle.exceptions.NoChildTreeException;
+
+public class ScriptData 
+{
+    private final int id;
+
+    private final Tree<String> code;
+    private String currentCode;
+    private int position;
+
+    private final HashMap<String, Object> variables;    
+    private final HashMap<String, Integer[]> gotos;
+    private final HashSet<String> events;
+    
+    private final String scriptName;  
+    
+    private boolean isWaiting;
+    //private boolean isValid;
+    private int overflowProtection;
+    
+    public ScriptData(int id, String filename)
+    {       
+        this.id = id;
+        
+        code = new Tree<>();
+        position = 0;
+        
+        variables = new HashMap<>();
+        gotos = new HashMap<>();
+        events = new HashSet<>();
+        
+        scriptName = filename;
+        
+        readCode(filename);
+
+        isWaiting = false;
+        //isValid = true;
+        overflowProtection = 0;
+    }
+    
+    public void goDeeper() throws NoChildTreeException
+    {
+        code.goDeeper();
+    }
+    
+    private void readCode(String filename)
+    {
+        File script = new File(filename + ".txt");  
+        List<String> lines;
+        if(script.exists())
+        {
+            try 
+            {
+                lines = Files.readAllLines(script.toPath());
+            } 
+            catch (IOException ex) 
+            {
+                ScriptUtils.printError("Datei '" + filename + "' kann nicht gelesen werden.");
+                return;
+            }
+        }
+        else
+        {
+            ScriptUtils.printError("Datei '" + filename + "' wurde nicht gefunden.");
+            return;
+        }
+        
+        int line = 0;
+        int i = 0;
+        int old = 0;
+        int bracket = 0;
+        boolean bracketEnd = false;
+        int bracketEndPos = 0;
+        boolean oneLineChild = false;
+        boolean comment = false;       
+        int commentPos = 0;
+        StringBuilder codeLine = new StringBuilder();
+        while(line < lines.size())
+        {
+            if(old == codeLine.length() && !comment)
+            {
+                codeLine = new StringBuilder(lines.get(line).trim());
+                i = 0;
+                old = 0;
+            }
+            else
+            {
+                codeLine.append(lines.get(line).trim());
+            }
+            
+            //System.out.println(codeLine);
+            
+            while(i < codeLine.length())
+            {
+                switch(codeLine.charAt(i))
+                {
+                    case '@':
+                        if(comment)
+                        {
+                            break;
+                        }
+                        old = i;
+                        while(i < codeLine.length() && codeLine.charAt(i) != ' ')
+                        {
+                            i++;
+                        }
+                        try
+                        {
+                            code.selectLastChild(); // Nur für richtige Position
+                        }
+                        catch(NoChildTreeException ex)
+                        {
+                        }
+                        gotos.put(codeLine.substring(old + 1, i), code.getCurrentPosition());
+                        codeLine.delete(old, i + 1);
+                        i = old - 1;
+                        break;
+                    case '/':
+                        if(!comment && i + 1 < codeLine.length() && codeLine.charAt(i + 1) == '*')
+                        {
+                            comment = true;
+                            commentPos = i;
+                        }
+                        if(!comment && i + 1 < codeLine.length() && codeLine.charAt(i + 1) == '/')
+                        {
+                            codeLine.delete(commentPos, codeLine.length());
+                        }
+                        break;
+                    case '*':
+                        if(comment && i + 1 < codeLine.length() && codeLine.charAt(i + 1) == '/')
+                        {
+                            comment = false;
+                            codeLine.delete(commentPos, i + 2);
+                            i = commentPos;
+                        }
+                        break;
+                    case ';':
+                        if(comment)
+                        {
+                            break;
+                        }
+                        bracketEnd = false;
+                        code.addChild(codeLine.substring(old, i));
+                        old = i + 1;
+                        if(oneLineChild)
+                        {
+                            oneLineChild = false;
+                            try
+                            {
+                                code.goHigher();
+                            }
+                            catch(GoHigherAtRootTreeException ex)
+                            {
+                                System.out.println("Das sollte nicht passieren");
+                                return;
+                            }
+                        }
+                        break;
+                    case '(':
+                        if(!comment && !oneLineChild)
+                        {
+                            bracket++;
+                            if(bracketEnd)
+                            {
+                                bracketEnd = false;
+                                oneLineChild = true;
+                                code.addChild(codeLine.substring(old, bracketEndPos));
+                                old = bracketEndPos;
+                                try
+                                {
+                                    code.selectLastChild();
+                                    code.goDeeper();
+                                }
+                                catch(NoChildTreeException ex)
+                                {
+                                    System.out.println("Das sollte nicht passieren");
+                                }
+                            }
+                        }
+                        break;
+                    case ')':
+                        if(comment || oneLineChild)
+                        {
+                            break;
+                        }
+                        bracket--;
+                        if(bracket < 0)
+                        {
+                            ScriptUtils.printError(") ohne ( in Zeile " + (line + 1));
+                            return;
+                        }
+                        if(bracket == 0)
+                        {
+                            bracketEnd = true;   
+                            bracketEndPos = i + 1;
+                        }
+                        break;
+                    case '{':
+                        if(comment)
+                        {
+                            break;
+                        }
+                        bracketEnd = false;
+                        code.addChild(codeLine.substring(old, i));
+                        old = i + 1;
+                        try
+                        {
+                            code.selectLastChild();
+                            code.goDeeper();
+                        }
+                        catch(NoChildTreeException ex)
+                        {
+                            System.out.println("Das sollte nicht passieren");
+                        }
+                        break;
+                    case '}':
+                        if(comment)
+                        {
+                            break;
+                        }
+                        old = i + 1;
+                        try
+                        {
+                            code.goHigher();
+                        }
+                        catch(GoHigherAtRootTreeException ex)
+                        {
+                            ScriptUtils.printError("} ohne { in Zeile " + (line + 1));
+                            return;
+                        }
+                        break;
+                }
+                i++;
+            } 
+            line++;
+        }
+        code.goToRoot();
+    }
+    
+    public void runCode()
+    {
+        try
+        {
+            while(!isWaiting)
+            {
+                try
+                {
+                    code.selectNextChild();
+                }
+                catch(NoChildTreeException ex)
+                {
+                    //System.out.println("NACH OBEN!");
+                    code.goHigher();
+                    continue;
+                }
+                currentCode = code.getCurrentChildData();
+                findFunction(0, currentCode.length() - 1);
+            }
+        }
+        catch(NoChildTreeException | GoHigherAtRootTreeException ex)
+        {
+            System.out.println("END PROGRAM");
+        }
+    }
+    
+    private Object findFunction(int from, int to)
+    {
+        if(to <= from) // Springt in { } ohne Kopf
+        {
+            try
+            {
+                code.goDeeper();
+            }
+            catch(NoChildTreeException ex)
+            {
+                System.out.println("SOLLTE NICHT SEIN");
+            }
+            return null;
+        }
+        int old = from;
+        int bracket;
+        ArrayList<Object> list = new ArrayList<>();
+        while(currentCode.charAt(from) != '(')
+        {
+            from++;
+        }
+        bracket = from;
+        from++;
+        
+        int last = from;
+        int counter = 0;
+        boolean string = false;
+        while(from <= to)
+        {
+            if(string)
+            {              
+                if(currentCode.charAt(from) == '"')
+                {
+                    string = !string;
+                }
+                from++;
+                continue;
+            }
+            switch(currentCode.charAt(from))
+            {
+                case '"':
+                    string = !string;
+                    break;
+                case ',':
+                    if(last != from)
+                    {
+                        list.add(currentCode.substring(last, from).trim());
+                    }
+                    last = from + 1;
+                    break;
+                case ')':
+                    if(counter > 0)
+                    {
+                        last = from + 1;
+                        counter--;
+                        break;
+                    }
+                    position = from;
+                    if(last != from)
+                    {
+                        list.add(currentCode.substring(last, from).trim());
+                    }
+                    return doFunction(currentCode.substring(old, bracket).trim(), list);
+                case '(':
+                    list.add(findFunction(last, to));  
+                    from = position - 1;
+                    last = from;
+                    counter++;
+                    break;
+            }  
+            from++;
+        }         
+        return null;
+    }
+    
+    private Object doFunction(String function, List<Object> args)
+    {
+        for(int i = 0; i < args.size(); i++)
+        {
+            args.set(i, readParameter(args.get(i)));
+        }
+        Object o = CodeParser.parseFunction(this, function, args);
+        if(o == null)
+        {
+            isWaiting = true;
+        }
+        return o;
+    }
+    
+    private Object readParameter(Object o)
+    {
+        if(!(o instanceof String))
+        {
+            return o;
+        }
+        String s = o.toString();
+        if(s.startsWith("\"") && s.endsWith("\""))
+        {
+            return s.substring(1, s.length() - 1);
+        }
+        else if(s.startsWith("$"))
+        {
+            return getVar(s);
+        }
+        try
+        {
+            return ScriptUtils.getNumber(s);
+        }
+        catch(NumberFormatException ex)
+        {
+            return s;
+        }
+    }
+    
+    public int getId() 
+    {
+        return id;
+    }
+
+    public String getName() 
+    {
+        return scriptName;
+    }
+    
+    /*public boolean isWaiting()
+    {
+        return isWaiting;
+    }
+    
+    public void setWaiting(Boolean bool) 
+    {
+        isWaiting = bool;
+    }
+    
+    public boolean isValid() 
+    {
+        return isValid;
+    }
+    
+    public void setValid(Boolean bool) 
+    {
+        isValid = bool;
+    }*/
+    
+    public Object getVar(String var)
+    {
+        if(var.startsWith("$"))
+        {
+            return variables.get(var);
+        }
+        return variables.get("$" + var);
+    }
+    
+    public Object getVar(Object var)
+    {
+        return getVar(var.toString());
+    }
+    
+    public HashMap<String, Object> getVars()
+    {
+        return variables;
+    }
+    
+    public void removeVar(String var)
+    {
+        if(var.startsWith("$"))
+        {
+            variables.remove(var);
+        }
+        variables.remove("$" + var);
+    }
+    
+    public void removeVar(Object var)
+    {
+        removeVar(var.toString());
+    }
+    
+    public void setVar(String var, Object value)
+    {
+        if(!var.startsWith("$"))
+        {
+            var = "$" + var;
+        }
+        variables.put(var, value);   
+    }
+    
+    public void setVar(Object var, Object value)
+    {
+        setVar(var.toString(), value);
+    }
+    
+    public void gotoLabel(String label) throws NoChildTreeException, CodeTooLongException
+    {
+        Integer[] i = gotos.get(label);
+        if(i == null)
+        {
+            throw new GotoLabelNotFoundException(label);
+        }
+        overflowProtection++;
+        if(overflowProtection > 50)
+        {
+            overflowProtection = 0;
+            throw new CodeTooLongException();
+        }
+        code.goToPosition(i);
+    }  
+    
+    public void resetOverflowProtection()
+    {
+        overflowProtection = 0;
+    }
+    
+    public void loadEvent(Object event)
+    {
+        events.add(event.toString());
+    }
+    
+    public void unloadEvent(Object event)
+    {
+        events.remove(event.toString());
+    }
+    
+    public boolean isEventLoaded(Object event)
+    {
+        return events.contains(event.toString());
+    }
+}

+ 98 - 0
src/me/hammerle/scriptsystem/ScriptEngine.java

@@ -0,0 +1,98 @@
+package me.hammerle.scriptsystem;
+
+import java.awt.Color;
+import java.awt.event.KeyAdapter;
+import java.awt.event.KeyEvent;
+import java.awt.event.MouseEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import javax.swing.JFrame;
+import javax.swing.event.MouseInputAdapter;
+
+public class ScriptEngine extends JFrame
+{
+    public final GraphicEngine graphics;
+    
+    public ScriptEngine()
+    {
+        graphics = new GraphicEngine();
+        graphics.setBackground(Color.black);
+        super.add(graphics);
+        super.setDefaultCloseOperation(DO_NOTHING_ON_CLOSE);
+        super.addWindowListener(new WindowAdapter() 
+        {
+            @Override
+            public void windowClosing(WindowEvent evt) 
+            {
+                windowClosingEvent(evt);
+            }
+        });
+        
+        super.addKeyListener(new KeyAdapter()
+        {
+            @Override
+            public void keyPressed(KeyEvent e) 
+            {
+                keyEvent(e, "pressed");
+            } 
+            @Override
+            public void keyTyped(KeyEvent e) 
+            {
+                keyEvent(e, "typed");
+            }
+            @Override
+            public void keyReleased(KeyEvent e) 
+            {
+                keyEvent(e, "released");
+            }
+        });
+        
+        graphics.addMouseListener(new MouseInputAdapter() 
+        {
+            @Override
+            public void mousePressed(MouseEvent e) 
+            {
+                mouseEvent(e, "pressed");
+            }          
+        });
+    }
+    
+    private void windowClosingEvent(WindowEvent e)
+    {
+        /*ScriptData sd = SnuviScript.scriptController.getActiveScript();
+        if(sd.isEventLoaded("window-closing"))
+        {
+            sd.setVar("event", "window-closing");
+            sd.nextCodeLine();
+            CodeParser.continueCode(sd, null); 
+        }*/
+    }
+    
+    private void keyEvent(KeyEvent e, String name)
+    {
+        /*ScriptData sd = SnuviScript.scriptController.getActiveScript();
+        if(sd.isEventLoaded("key-" + name))
+        {
+            sd.setVar("event", "key-" + name);
+            sd.setVar("keycode", e.getKeyCode());
+            sd.setVar("keychar", e.getKeyChar());
+            sd.nextCodeLine();
+            CodeParser.continueCode(sd, null); 
+        }*/
+    }
+    
+    private void mouseEvent(MouseEvent e, String name)
+    {
+        /*ScriptData sd = SnuviScript.scriptController.getActiveScript();
+        if(sd.isEventLoaded("mouse-" + name))
+        {
+            sd.setVar("event", "mouse-" + name);
+            sd.setVar("button", e.getButton());
+            sd.setVar("count", e.getClickCount());
+            sd.setVar("x", e.getX());
+            sd.setVar("y", e.getY());
+            sd.nextCodeLine();
+            CodeParser.continueCode(sd, null); 
+        }*/
+    }
+}

+ 73 - 0
src/me/hammerle/scriptsystem/ScriptUtils.java

@@ -0,0 +1,73 @@
+package me.hammerle.scriptsystem;
+
+import java.awt.Color;
+import java.util.Random;
+import me.hammerle.exceptions.IllegalColorException;
+
+public class ScriptUtils
+{
+    public static Color getColor(Object o) throws IllegalColorException
+    {
+        try
+        {
+            String[] parts = o.toString().split(":");
+            return new Color(Integer.parseInt(parts[0]), Integer.parseInt(parts[1]), Integer.parseInt(parts[2]));
+        }
+        catch(NumberFormatException | ArrayIndexOutOfBoundsException ex)
+        {
+            throw new IllegalColorException(o.toString());
+        }
+    }
+    
+    public static void printError(Object message)
+    {
+        System.out.println("Fehler: " + message);
+        System.exit(0);
+    }
+    
+    public static void printDebug(Object message)
+    {
+        System.out.println(message);
+    }
+    
+    public static void printDebugList(Object message)
+    {
+        System.out.println(" - " + message);
+    }
+    
+    public static int randomInt(int min, int max)
+    {
+        Random rand = new Random();
+        int randomNum = rand.nextInt((max - min) + 1) + min;
+        return randomNum;
+    }
+    
+    
+    public static Object getNumber(String s)
+    {
+        double d = Double.parseDouble(s);
+        if((int) d == d)
+        {
+            return (int) d;
+        }
+        return d;
+    }
+    
+    public static int getInteger(Object o)
+    {
+        if(o instanceof Double)
+        {
+            return (int) (double) o;
+        }
+        return (int) o;
+    }
+    
+    public static double getDouble(Object o)
+    {
+        if(o instanceof Integer)
+        {
+            return (double) (int) o;
+        }
+        return (double) o;
+    }
+}

+ 154 - 0
src/me/hammerle/scriptsystem/Tree.java

@@ -0,0 +1,154 @@
+package me.hammerle.scriptsystem;
+
+import java.util.ArrayList;
+import java.util.Stack;
+import me.hammerle.exceptions.GoHigherAtRootTreeException;
+import me.hammerle.exceptions.NoChildTreeException;
+
+public class Tree<T> 
+{
+    private final Node<T> root;
+    private Node<T> currentNode;
+    private final Stack<Integer> position;
+
+    public Tree() 
+    {
+        root = new Node<>();
+        root.parent = null;
+        root.data = null;
+        root.children = new ArrayList<>();
+        root.selectedChild = -1;
+        
+        currentNode = root;
+        
+        position = new Stack<>();
+    }
+
+    private static class Node<T> 
+    {
+        private T data;
+        private Node<T> parent;
+        private ArrayList<Node<T>> children;
+        private int selectedChild;
+    }
+    
+    public void addChild(T child)
+    {
+        Node<T> node = new Node<>();
+        node.data = child;
+        node.parent = currentNode;
+        node.children = new ArrayList<>();    
+        node.selectedChild = -1;
+        currentNode.children.add(node);
+    }
+    
+    public void goHigher() throws GoHigherAtRootTreeException
+    {
+        currentNode.selectedChild = 0;
+        currentNode = currentNode.parent;
+        if(currentNode == null)
+        {
+            currentNode = root;
+            throw new GoHigherAtRootTreeException();
+        }
+        position.pop();
+    }
+    
+    public void goDeeper() throws NoChildTreeException
+    {
+        try
+        {   
+            int i = currentNode.selectedChild;
+            currentNode = currentNode.children.get(i);
+            position.add(i);
+            currentNode.selectedChild = -1;
+        }
+        catch(IndexOutOfBoundsException ex)
+        {
+            throw new NoChildTreeException();
+        }
+    }
+    
+    public void selectChild(int index) throws NoChildTreeException
+    {
+        if(index >= currentNode.children.size())
+        {
+            throw new NoChildTreeException();
+        }
+        currentNode.selectedChild = index;
+    }
+    
+    public void selectNextChild() throws NoChildTreeException
+    {
+        currentNode.selectedChild++;
+        if(currentNode.selectedChild >= currentNode.children.size())
+        {
+            currentNode.selectedChild--;
+            throw new NoChildTreeException();
+        }
+    }
+    
+    public void selectLastChild() throws NoChildTreeException
+    {
+        currentNode.selectedChild = currentNode.children.size() - 1;
+        if(currentNode.selectedChild == -1)
+        {
+            throw new NoChildTreeException();
+        }
+    }
+    
+    public T getCurrentData()
+    {
+        return currentNode.data;
+    }
+    
+    public T getCurrentChildData() throws NoChildTreeException
+    {
+        try
+        {   
+            return currentNode.children.get(currentNode.selectedChild).data;
+        }
+        catch(IndexOutOfBoundsException ex)
+        {
+            throw new NoChildTreeException();
+        }
+    }
+    
+    public void goToRoot()
+    {
+        try
+        {
+            while(true)
+            {
+                goHigher();
+            }
+        }
+        catch(GoHigherAtRootTreeException ex)
+        {
+            currentNode.selectedChild = -1;
+        }     
+    }
+    
+    public void goToPosition(Integer... i) throws NoChildTreeException
+    {
+        goToRoot();
+        for(int a = 0; a < i.length - 1; a++)
+        {
+            selectChild(i[a]);
+            goDeeper();
+        }
+        selectChild(i[i.length - 1]);
+    }
+    
+    public boolean isRootNodeSelected()
+    {
+        return currentNode.data == null;
+    }
+    
+    public Integer[] getCurrentPosition()
+    {
+        Integer[] i = position.toArray(new Integer[position.size() + 1]);
+        i[position.size()] = currentNode.selectedChild;
+        return i;
+    }
+}

+ 21 - 0
src/me/hammerle/snuviscript/SnuviScript.java

@@ -0,0 +1,21 @@
+package me.hammerle.snuviscript;
+
+import me.hammerle.console.Console;
+import me.hammerle.scriptsystem.ScriptEngine;
+import me.hammerle.scriptsystem.ScriptControl;
+
+public class SnuviScript 
+{
+    public static ScriptEngine screen;
+    public static ScriptControl scriptController;
+    
+    public static void main(String[] args) 
+    {
+        Console console = new Console();
+        
+        /*for(String s : GraphicsEnvironment.getLocalGraphicsEnvironment().getAvailableFontFamilyNames())
+        {
+            System.out.println(s);
+        }*/
+    }   
+}