SDF demo work in progress.
Netbeans re-formatting.
Netbeans project files.
config.make
mandelbrot.pam
movie.avi
+/build/
+/dist/
+/.lib/
+/nbproject/private/
notzed.apistatic notzed.apiobject \
notzed.ffmpeg \
notzed.clstatic \
- notzed.xlib notzed.xcb \
+ notzed.xlib notzed.xcb notzed.display \
notzed.vkregistry notzed.vkregistry.test \
notzed.vkheader notzed.vkheader.test \
notzed.vulkan notzed.vulkan.test
notzed.vulkan.test_JDEPMOD = notzed.vulkan
notzed.xcb_JDEPMOD = notzed.nativez
notzed.xlib_JDEPMOD = notzed.nativez
+notzed.display_JDEPMOD = notzed.xlib notzed.xcb
notzed.apistatic_JMAIN = api.test.TestAPI
notzed.apiobject_JMAIN = api.test.TestAPI
notzed.vulkan.test_JMAINFLAGS = --enable-native-access=notzed.nativez,notzed.xlib,notzed.xcb,notzed.vulkan
include java.make
+
+maven_central_JARS =org.openjdk.jmh:jmh-core:1.33 org.openjdk.jmh:jmh-generator-annprocess:1.33
+
+include maven.make
--- /dev/null
+<?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:if="ant:if" xmlns:unless="ant:unless" basedir=".." default="default" name="panamaz-impl">
+ <fail message="Please build using Ant 1.9.7 or higher.">
+ <condition>
+ <not>
+ <antversion atleast="1.9.7"/>
+ </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="9"/>
+ <property name="default.javac.target" value="9"/>
+ </target>
+ <target depends="-pre-init,-init-private,-init-user" name="-init-pre-project">
+ <property file="nbproject/configs/${config}.properties"/>
+ <property file="nbproject/project.properties"/>
+ <property name="netbeans.modular.tasks.version" value="1"/>
+ <property location="${build.dir}/tasks/${netbeans.modular.tasks.version}" name="netbeans.modular.tasks.dir"/>
+ </target>
+ <target depends="-init-pre-project" name="-check-netbeans-tasks">
+ <condition property="netbeans.tasks.compiled">
+ <available file="${netbeans.modular.tasks.dir}/out/netbeans/ModuleInfoSelector.class"/>
+ </condition>
+ </target>
+ <target depends="-init-pre-project,-check-netbeans-tasks" name="-init-compile-netbeans-tasks" unless="netbeans.tasks.compiled">
+ <echo file="${netbeans.modular.tasks.dir}/src/netbeans/CoalesceKeyvalue.java">
+
+package netbeans;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.regex.Pattern;
+import java.util.stream.Collectors;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.Task;
+
+public class CoalesceKeyvalue extends Task {
+ private String property;
+
+ public void setProperty(String property) {
+ this.property = property;
+ }
+
+ private String value;
+
+ public void setValue(String value) {
+ this.value = value;
+ }
+
+ private String valueSep;
+
+ public void setValueSep(String valueSep) {
+ this.valueSep = valueSep;
+ }
+
+ private String entrySep;
+
+ public void setEntrySep(String entrySep) {
+ this.entrySep = entrySep;
+ }
+
+ private String multiSep;
+
+ public void setMultiSep(String multiSep) {
+ this.multiSep = multiSep;
+ }
+
+ private String outSep;
+
+ public void setOutSep(String outSep) {
+ this.outSep = outSep;
+ }
+
+ @Override
+ public void execute() throws BuildException {
+ List<String> result = new ArrayList<>();
+ Map<String, List<String>> module2Paths = new HashMap<>();
+
+ for (String entry : value.split(Pattern.quote(entrySep))) {
+ String[] keyValue = entry.split(Pattern.quote(valueSep), 2);
+ if (keyValue.length == 1) {
+ result.add(keyValue[0]);
+ } else {
+ module2Paths.computeIfAbsent(keyValue[0], s -> new ArrayList<>())
+ .add(keyValue[1].trim());
+ }
+ }
+ module2Paths.entrySet()
+ .stream()
+ .forEach(e -> result.add(e.getKey() + valueSep + e.getValue().stream().collect(Collectors.joining(multiSep))));
+ getProject().setProperty(property, result.stream().collect(Collectors.joining(" " + entrySep)));
+ }
+
+}
+
+ </echo>
+ <echo file="${netbeans.modular.tasks.dir}/src/netbeans/ModsourceRegexp.java">
+
+package netbeans;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.Task;
+
+public class ModsourceRegexp extends Task {
+ private String property;
+
+ public void setProperty(String property) {
+ this.property = property;
+ }
+
+ private String filePattern;
+
+ public void setFilePattern(String filePattern) {
+ this.filePattern = filePattern;
+ }
+
+ private String modsource;
+
+ public void setModsource(String modsource) {
+ this.modsource = modsource;
+ }
+
+ private List<String> expandGroup(String grp) {
+ List<String> exp = new ArrayList<>();
+ String item = "";
+ int depth = 0;
+
+ for (int i = 0; i < grp.length(); i++) {
+ char c = grp.charAt(i);
+ switch (c) {
+ case '{':
+ if (depth++ == 0) {
+ continue;
+ }
+ break;
+ case '}':
+ if (--depth == 0) {
+ exp.add(item);
+ continue;
+ }
+ break;
+ case ',':
+ if (depth == 1) {
+ exp.add(item);
+ item = "";
+ continue;
+ }
+ default:
+ break;
+ }
+ item = item + c;
+ }
+ return exp;
+ }
+
+ private List<String> pathVariants(String spec) {
+ return pathVariants(spec, new ArrayList<>());
+ }
+
+ private List<String> pathVariants(String spec, List<String> res) {
+ int start = spec.indexOf('{');
+ if (start == -1) {
+ res.add(spec);
+ return res;
+ }
+ int depth = 1;
+ int end;
+ for (end = start + 1; end < spec.length() && depth > 0; end++) {
+ char c = spec.charAt(end);
+ switch (c) {
+ case '{': depth++; break;
+ case '}': depth--; break;
+ }
+ }
+ String prefix = spec.substring(0, start);
+ String suffix = spec.substring(end);
+ expandGroup(spec.substring(start, end)).stream().forEach(item -> {
+ pathVariants(prefix + item + suffix, res);
+ });
+ return res;
+ }
+
+ private String toRegexp2(String spec, String filepattern, String separator) {
+ List<String> prefixes = new ArrayList<>();
+ List<String> suffixes = new ArrayList<>();
+ pathVariants(spec).forEach(item -> {
+ suffixes.add(item);
+ });
+ String tail = "";
+ String separatorString = separator;
+ if ("\\".equals(separatorString)) {
+ separatorString = "\\\\";
+ }
+ if (filepattern != null && !Objects.equals(filepattern, tail)) {
+ tail = separatorString + filepattern;
+ }
+ return "([^" + separatorString +"]+)\\Q" + separator + "\\E(" + suffixes.stream().collect(Collectors.joining("|")) + ")" + tail;
+ }
+
+ @Override
+ public void execute() throws BuildException {
+ getProject().setProperty(property, toRegexp2(modsource, filePattern, getProject().getProperty("file.separator")));
+ }
+
+}
+
+ </echo>
+ <echo file="${netbeans.modular.tasks.dir}/src/netbeans/ModuleInfoSelector.java">
+
+package netbeans;
+
+import java.io.File;
+import java.util.Arrays;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.types.selectors.BaseExtendSelector;
+
+public class ModuleInfoSelector extends BaseExtendSelector {
+
+ @Override
+ public boolean isSelected(File basedir, String filename, File file) throws BuildException {
+ String extension = Arrays.stream(getParameters())
+ .filter(p -> "extension".equals(p.getName()))
+ .map(p -> p.getValue())
+ .findAny()
+ .get();
+ return !new File(file, "module-info." + extension).exists();
+ }
+
+}
+
+ </echo>
+ <mkdir dir="${netbeans.modular.tasks.dir}/out"/>
+ <javac classpath="${ant.core.lib}" destdir="${netbeans.modular.tasks.dir}/out" srcdir="${netbeans.modular.tasks.dir}/src"/>
+ </target>
+ <target depends="-init-pre-project,-init-compile-netbeans-tasks" name="-init-project">
+ <taskdef classname="netbeans.CoalesceKeyvalue" classpath="${netbeans.modular.tasks.dir}/out" name="coalesce_keyvalue" uri="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ <taskdef classname="netbeans.ModsourceRegexp" classpath="${netbeans.modular.tasks.dir}/out" name="modsource_regexp" uri="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ </target>
+ <target name="-init-source-module-properties">
+ <property name="javac.modulepath" value=""/>
+ <property name="run.modulepath" value="${javac.modulepath}:${build.modules.dir}"/>
+ <property name="debug.modulepath" value="${run.modulepath}"/>
+ <property name="javac.upgrademodulepath" value=""/>
+ <property name="run.upgrademodulepath" value="${javac.upgrademodulepath}"/>
+ <condition else="" property="javac.systemmodulepath.cmd.line.arg" value="-system '${javac.systemmodulepath}'">
+ <and>
+ <isset property="javac.systemmodulepath"/>
+ <length length="0" string="${javac.systemmodulepath}" when="greater"/>
+ </and>
+ </condition>
+ <property name="dist.jlink.dir" value="${dist.dir}/jlink"/>
+ <property name="dist.jlink.output" value="${dist.jlink.dir}/${application.title}"/>
+ </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"/>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" modsource="${test.src.dir.path}" property="have.tests.test.src.dir.regexp"/>
+ <dirset dir="${basedir}/${test.src.dir}" id="have.tests.test.src.dir.set" includes="*/*">
+ <filename regex="${have.tests.test.src.dir.regexp}"/>
+ </dirset>
+ <union id="have.tests.set">
+ <dirset refid="have.tests.test.src.dir.set"/>
+ </union>
+ <condition property="have.tests">
+ <or>
+ <resourcecount count="0" when="greater">
+ <union refid="have.tests.set"/>
+ </resourcecount>
+ </or>
+ </condition>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" modsource="${test.src.dir.path}" property="have.tests.test.src.dir.regexp"/>
+ <dirset dir="${basedir}/${test.src.dir}" id="have.tests.test.src.dir.patchset" includes="*/*">
+ <filename regex="${have.tests.test.src.dir.regexp}"/>
+ </dirset>
+ <union id="have.tests.patchset">
+ <dirset refid="have.tests.test.src.dir.patchset"/>
+ </union>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" modsource="${src.dir.path}" property="have.sources.src.dir.regexp"/>
+ <dirset dir="${basedir}/${src.dir}" id="have.sources.src.dir.set" includes="*/*">
+ <filename regex="${have.sources.src.dir.regexp}"/>
+ </dirset>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" modsource="${src.gen.dir.path}" property="have.sources.src.gen.dir.regexp"/>
+ <dirset dir="${basedir}/${src.gen.dir}" id="have.sources.src.gen.dir.set" includes="*/*">
+ <filename regex="${have.sources.src.gen.dir.regexp}"/>
+ </dirset>
+ <union id="have.sources.set">
+ <dirset refid="have.sources.src.dir.set"/>
+ <dirset refid="have.sources.src.gen.dir.set"/>
+ </union>
+ <condition property="have.sources">
+ <or>
+ <resourcecount count="0" when="greater">
+ <union refid="have.sources.set"/>
+ </resourcecount>
+ <resourcecount count="0" when="greater">
+ <union refid="have.sources.set"/>
+ </resourcecount>
+ </or>
+ </condition>
+ <condition property="main.class.available">
+ <and>
+ <isset property="main.class"/>
+ <not>
+ <equals arg1="${main.class}" arg2="" trim="true"/>
+ </not>
+ </and>
+ </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>
+ <condition property="do.archive">
+ <or>
+ <not>
+ <istrue value="${jar.archive.disabled}"/>
+ </not>
+ <istrue value="${not.archive.disabled}"/>
+ </or>
+ </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>
+ <condition property="main.class.check.available">
+ <and>
+ <isset property="libs.CopyLibs.classpath"/>
+ <available classname="org.netbeans.modules.java.j2seproject.moduletask.ModuleMainClass" classpath="${libs.CopyLibs.classpath}"/>
+ </and>
+ </condition>
+ <property name="jar.index" value="false"/>
+ <property name="jar.index.metainf" value="${jar.index}"/>
+ <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"/>
+ <macrodef name="for-paths" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute name="paths"/>
+ <attribute default="${path.separator}" name="separator"/>
+ <element implicit="yes" name="call"/>
+ <sequential>
+ <local name="entry"/>
+ <local name="tail"/>
+ <local name="moreElements"/>
+ <loadresource property="entry" quiet="true" unless:blank="@{paths}">
+ <concat>@{paths}</concat>
+ <filterchain>
+ <replaceregex pattern="([^@{separator}]*)\Q@{separator}\E.*" replace="\1"/>
+ </filterchain>
+ </loadresource>
+ <sequential if:set="entry">
+ <call/>
+ </sequential>
+ <condition else="false" property="moreElements" value="true">
+ <contains string="@{paths}" substring="@{separator}"/>
+ </condition>
+ <loadresource if:true="${moreElements}" property="tail" quiet="true">
+ <concat>@{paths}</concat>
+ <filterchain>
+ <replaceregex pattern="[^@{separator}]*\Q@{separator}\E(.*)" replace="\1"/>
+ </filterchain>
+ </loadresource>
+ <j2semodularproject1:for-paths xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" if:true="${moreElements}" paths="${tail}">
+ <call/>
+ </j2semodularproject1:for-paths>
+ </sequential>
+ </macrodef>
+ <property name="modules.supported.internal" value="true"/>
+ <condition else="${file.separator}" property="file.separator.string" value="\${file.separator}">
+ <equals arg1="${file.separator}" arg2="\"/>
+ </condition>
+ </target>
+ <target name="-post-init">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="-pre-init,-init-private,-init-user,-init-project,-do-init" name="-init-check">
+ <fail unless="src.dir">Must set src.dir</fail>
+ <fail unless="src.gen.dir">Must set src.gen.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.modules.dir">Must set build.modules.dir</fail>
+ <fail unless="dist.javadoc.dir">Must set dist.javadoc.dir</fail>
+ <fail unless="build.test.modules.dir">Must set build.test.modules.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 message="Java 9 support requires Ant 1.10.0 or higher.">
+ <condition>
+ <not>
+ <antversion atleast="1.10.0"/>
+ </not>
+ </condition>
+ </fail>
+ </target>
+ <target name="-init-macrodef-property">
+ <macrodef name="property" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute name="name"/>
+ <attribute name="value"/>
+ <sequential>
+ <property name="@{name}" value="${@{value}}"/>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-ap-cmdline-properties,-init-source-module-properties" name="-init-macrodef-javac">
+ <macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${build.modules.dir}" name="destdir"/>
+ <attribute default="${javac.classpath}" name="classpath"/>
+ <attribute default="${javac.modulepath}" name="modulepath"/>
+ <attribute default="${src.dir}/*/${src.dir.path}:${src.gen.dir}/*/${src.gen.dir.path}" name="modulesourcepath"/>
+ <attribute default="${javac.upgrademodulepath}" name="upgrademodulepath"/>
+ <attribute default="${javac.processorpath}" name="processorpath"/>
+ <attribute default="${javac.processormodulepath}" name="processormodulepath"/>
+ <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="gensrcdir"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property location="${build.dir}/empty" name="empty.dir"/>
+ <mkdir dir="${empty.dir}"/>
+ <mkdir dir="@{apgeneratedsrcdir}"/>
+ <condition property="processormodulepath.set">
+ <resourcecount count="0" when="greater">
+ <path>
+ <pathelement path="@{processormodulepath}"/>
+ </path>
+ </resourcecount>
+ </condition>
+ <javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" fork="${javac.fork}" includeantruntime="false" includes="@{includes}" source="${javac.source}" target="${javac.target}" tempdir="${java.io.tmpdir}">
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <modulepath>
+ <path path="@{modulepath}"/>
+ </modulepath>
+ <modulesourcepath>
+ <path path="@{modulesourcepath}"/>
+ </modulesourcepath>
+ <upgrademodulepath>
+ <path path="@{upgrademodulepath}"/>
+ </upgrademodulepath>
+ <compilerarg line="${javac.systemmodulepath.cmd.line.arg}"/>
+ <compilerarg line="${javac.profile.cmd.line.arg}"/>
+ <compilerarg line="${javac.compilerargs}"/>
+ <compilerarg if:set="processormodulepath.set" value="--processor-module-path"/>
+ <compilerarg if:set="processormodulepath.set" path="@{processormodulepath}"/>
+ <compilerarg unless:set="processormodulepath.set" value="-processorpath"/>
+ <compilerarg path="@{processorpath}:${empty.dir}" unless:set="processormodulepath.set"/>
+ <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-macrodef-javac" name="-init-macrodef-javac-depend">
+ <macrodef name="depend" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${src.dir}:${src.gen.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-modular-project/1">
+ <attribute default="${build.modules.dir}" name="destdir"/>
+ <sequential>
+ <fail unless="javac.includes">Must set javac.includes</fail>
+ <pathconvert pathsep="${line.separator}" property="javac.includes.binary">
+ <path>
+ <filelist dir="@{destdir}" files="${javac.includes}"/>
+ </path>
+ <globmapper from="*.java" to="*.class"/>
+ </pathconvert>
+ <tempfile deleteonexit="true" property="javac.includesfile.binary"/>
+ <echo file="${javac.includesfile.binary}" message="${javac.includes.binary}"/>
+ <delete>
+ <files includesfile="${javac.includesfile.binary}"/>
+ </delete>
+ <delete>
+ <fileset file="${javac.includesfile.binary}"/>
+ </delete>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="${junit.available}" name="-init-macrodef-junit-init">
+ <condition else="false" property="nb.junit.batch" value="true">
+ <and>
+ <istrue value="${junit.available}"/>
+ <not>
+ <isset property="test.method"/>
+ </not>
+ </and>
+ </condition>
+ <condition else="false" property="nb.junit.single" value="true">
+ <and>
+ <istrue value="${junit.available}"/>
+ <isset property="test.method"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-init-test-properties">
+ <property name="test.binaryincludes" value="<nothing>"/>
+ <property name="test.binarytestincludes" value=""/>
+ <property name="test.binaryexcludes" value=""/>
+ </target>
+ <target name="-init-macrodef-junit-prototype">
+ <macrodef name="junit-prototype" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <element name="customizePrototype" optional="true"/>
+ <sequential>
+ <property location="${build.dir}/empty" name="empty.dir"/>
+ <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}">
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg value="-ea"/>
+ <jvmarg value="--module-path"/>
+ <jvmarg path="${run.modulepath}${path.separator}${run.test.modulepath}${path.separator}${empty.dir}"/>
+ <jvmarg line="${run.test.jvmargs}"/>
+ <customizePrototype/>
+ </junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-test-properties,-init-macrodef-junit-prototype" if="${nb.junit.single}" name="-init-macrodef-junit-single" unless="${nb.junit.batch}">
+ <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <j2semodularproject1:junit-prototype xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <customizePrototype>
+ <test methods="@{testmethods}" name="@{testincludes}" todir="${build.test.results.dir}"/>
+ <customize/>
+ </customizePrototype>
+ </j2semodularproject1:junit-prototype>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-test-properties,-init-macrodef-junit-prototype" if="${nb.junit.batch}" name="-init-macrodef-junit-batch" unless="${nb.junit.single}">
+ <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <j2semodularproject1:junit-prototype xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <customizePrototype>
+ <batchtest todir="${build.test.results.dir}">
+ <mappedresources>
+ <union>
+ <fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="**/@{includes}">
+ <filename name="**/@{testincludes}"/>
+ <filename regex="${have.tests.test.src.dir.regexp}"/>
+ </fileset>
+ </union>
+ <regexpmapper from="${have.tests.test.src.dir.regexp}\Q${file.separator}\E(.*)$" to="\3"/>
+ </mappedresources>
+ <fileset dir="${build.test.modules.dir}" excludes="@{excludes},${excludes},${test.binaryexcludes}" includes="${test.binaryincludes}">
+ <filename name="${test.binarytestincludes}"/>
+ </fileset>
+ </batchtest>
+ <customize/>
+ </customizePrototype>
+ </j2semodularproject1:junit-prototype>
+ </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-modular-project/1">
+ <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="panamaz" 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>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <customize/>
+ </testng>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-macrodef-test-impl">
+ <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <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-modular-project/1">
+ <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>
+ <j2semodularproject1:junit xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize/>
+ </j2semodularproject1: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-modular-project/1">
+ <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>
+ <j2semodularproject1:testng xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize/>
+ </j2semodularproject1: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-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <sequential>
+ <j2semodularproject1:test-impl xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ </customize>
+ </j2semodularproject1:test-impl>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-junit" if="${junit.available}" name="-init-macrodef-junit-debug-impl">
+ <macrodef name="test-debug-impl" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customizeDebuggee" optional="true"/>
+ <sequential>
+ <j2semodularproject1:junit xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize>
+ <jvmarg value="-agentlib:jdwp=transport=${debug-transport},address=${jpda.address}"/>
+ <customizeDebuggee/>
+ </customize>
+ </j2semodularproject1:junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="${testng.available}" name="-init-macrodef-testng-debug">
+ <macrodef name="testng-debug" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <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 panamaz -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}"/>
+ <j2semodularproject1:debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classname="org.testng.TestNG" classpath="${debug.test.classpath}">
+ <customizeDebuggee>
+ <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}"/>
+ </customizeDebuggee>
+ </j2semodularproject1: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-modular-project/1">
+ <attribute default="${main.class}" name="testClass"/>
+ <attribute default="" name="testMethod"/>
+ <element implicit="true" name="customize2" optional="true"/>
+ <sequential>
+ <j2semodularproject1:testng-debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" testClass="@{testClass}" testMethod="@{testMethod}">
+ <customize2/>
+ </j2semodularproject1: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-modular-project/1">
+ <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>
+ <j2semodularproject1:test-debug-impl xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customizeDebuggee>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ </customizeDebuggee>
+ </j2semodularproject1: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-modular-project/1">
+ <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>
+ <j2semodularproject1:testng-debug-impl xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" testClass="@{testClass}" testMethod="@{testMethod}">
+ <customize2>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ </customize2>
+ </j2semodularproject1: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-modular-project/1">
+ <attribute default="${main.class}" name="name"/>
+ <attribute default="${debug.modulepath}" name="modulepath"/>
+ <attribute default="${debug.classpath}" name="classpath"/>
+ <attribute default="" name="stopclassname"/>
+ <sequential>
+ <nbjpdastart addressproperty="jpda.address" name="@{name}" stopclassname="@{stopclassname}" transport="${debug-transport}">
+ <modulepath>
+ <path path="@{modulepath}"/>
+ </modulepath>
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ </nbjpdastart>
+ </sequential>
+ </macrodef>
+ <macrodef name="nbjpdareload" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${debug.modules.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">
+ <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-modular-project/1">
+ <attribute default="${module.name}" name="modulename"/>
+ <attribute default="${main.class}" name="classname"/>
+ <attribute default="${debug.modulepath}" name="modulepath"/>
+ <attribute default="${debug.classpath}" name="classpath"/>
+ <element name="customizeDebuggee" optional="true"/>
+ <sequential>
+ <j2semodularproject1:java xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classname="@{classname}" classpath="@{classpath}" modulename="@{modulename}" modulepath="@{modulepath}">
+ <customize>
+ <jvmarg value="-agentlib:jdwp=transport=${debug-transport},address=${jpda.address}"/>
+ <customizeDebuggee/>
+ </customize>
+ </j2semodularproject1:java>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-source-module-properties" name="-init-macrodef-java">
+ <macrodef name="java" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${module.name}" name="modulename"/>
+ <attribute default="${main.class}" name="classname"/>
+ <attribute default="${run.modulepath}" name="modulepath"/>
+ <attribute default="${run.upgrademodulepath}" name="upgrademodulepath"/>
+ <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" module="@{modulename}">
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <modulepath>
+ <path path="@{modulepath}"/>
+ </modulepath>
+ <upgrademodulepath>
+ <path path="@{upgrademodulepath}"/>
+ </upgrademodulepath>
+ <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}"/>
+ <syspropertyset>
+ <propertyref prefix="run-sys-prop."/>
+ <mapper from="run-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <customize/>
+ </java>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-presetdef-jar">
+ <presetdef name="jar" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <jar compress="${jar.compress}" index="${jar.index}" jarfile="${dist.jar}" manifestencoding="UTF-8">
+ <j2semodularproject1:fileset xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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}"/>
+ </target>
+ <target depends="-init-ap-cmdline-properties" 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-depend,-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: panamaz 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.modules.dir}/.netbeans_automatic_build" property="netbeans.automatic.build"/>
+ </target>
+ <target depends="init" if="netbeans.automatic.build" name="-clean-after-automatic-build">
+ <antcall target="clean">
+ <param name="no.dependencies" value="true"/>
+ </antcall>
+ </target>
+ <target name="-pre-pre-compile">
+ <mkdir dir="${build.modules.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>
+ <j2semodularproject1:depend xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" srcdir="${src.dir}:${src.gen.dir}:${build.generated.subdirs}"/>
+ </target>
+ <target depends="init,deps-jar,-pre-pre-compile,-pre-compile,-compile-depend" if="have.sources" name="-do-compile">
+ <j2semodularproject1:javac xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" gensrcdir="${build.generated.sources.dir}"/>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" filePattern="(.*$)" modsource="${src.dir.path}" property="src.dir.path.regexp"/>
+ <echo message="Copying resources from ${src.dir}"/>
+ <copy todir="${build.modules.dir}">
+ <fileset dir="${src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ <regexpmapper from="${src.dir.path.regexp}" to="\1/\3"/>
+ </copy>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" filePattern="(.*$)" modsource="${src.gen.dir.path}" property="src.gen.dir.path.regexp"/>
+ <echo message="Copying resources from ${src.gen.dir}"/>
+ <copy todir="${build.modules.dir}">
+ <fileset dir="${src.gen.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ <regexpmapper from="${src.gen.dir.path.regexp}" to="\1/\3"/>
+ </copy>
+ </target>
+ <target if="has.persistence.xml" name="-copy-persistence-xml">
+ <fail message="XXX: Not supported on MM projects"/>
+ <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" name="-do-compile-single">
+ <fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail>
+ <j2semodularproject1:force-recompile xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ <j2semodularproject1:javac xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="" gensrcdir="${build.generated.sources.dir}" includes="${javac.includes}, module-info.java"/>
+ </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,compile" name="-check-module-main-class">
+ <condition property="do.module.main.class">
+ <and>
+ <available file="${module.dir}/module-info.class"/>
+ <isset property="main.class.check.available"/>
+ </and>
+ </condition>
+ </target>
+ <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 name="-pre-single-jar"/>
+ <target depends="-pre-single-jar" if="module.jar.filename" name="-make-single-jar">
+ <jar basedir="${module.dir}" compress="${jar.compress}" destfile="${dist.dir}/${module.jar.filename}" excludes="${dist.archive.excludes}" manifestencoding="UTF-8"/>
+ </target>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar,-main-module-check-condition" if="do.archive" name="-do-jar-jar" unless="do.mkdist">
+ <property location="${build.modules.dir}" name="build.modules.dir.resolved"/>
+ <dirset dir="${build.modules.dir.resolved}" id="do.jar.dirs" includes="*"/>
+ <pathconvert property="do.jar.dir.list" refid="do.jar.dirs">
+ <identitymapper/>
+ </pathconvert>
+ <j2semodularproject1:for-paths xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" paths="${do.jar.dir.list}">
+ <local name="module.jar.filename"/>
+ <local name="module.jar.name.tmp"/>
+ <basename file="${entry}" property="module.jar.name.tmp"/>
+ <property name="module.jar.filename" value="${module.jar.name.tmp}.jar"/>
+ <antcall inheritRefs="true" target="-make-single-jar">
+ <param name="module.jar.filename" value="${module.jar.filename}"/>
+ <param location="${entry}" name="module.dir"/>
+ </antcall>
+ </j2semodularproject1:for-paths>
+ <condition property="named.module.internal">
+ <and>
+ <isset property="module.name"/>
+ <length length="0" string="${module.name}" when="greater"/>
+ </and>
+ </condition>
+ <condition property="unnamed.module.internal">
+ <not>
+ <isset property="named.module.internal"/>
+ </not>
+ </condition>
+ <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>
+ <pathconvert property="run.modulepath.with.dist.jar">
+ <path path="${run.modulepath}"/>
+ <map from="${build.classes.dir.resolved}" to="${dist.jar.resolved}"/>
+ </pathconvert>
+ <condition else="" property="jar.usage.message.module.path" value=" --module-path ${run.modulepath.with.dist.jar}">
+ <and>
+ <isset property="modules.supported.internal"/>
+ <length length="0" string="${run.modulepath.with.dist.jar}" when="greater"/>
+ </and>
+ </condition>
+ <condition else="" property="jar.usage.message.class.path" value=" -cp ${run.classpath.with.dist.jar}">
+ <length length="0" string="${run.classpath.with.dist.jar}" when="greater"/>
+ </condition>
+ <condition else=" ${main.class}" property="jar.usage.message.main.class" value=" -m ${module.name}/${main.class}">
+ <isset property="named.module.internal"/>
+ </condition>
+ <condition else="" property="jar.usage.message" value="To run this application from the command line without Ant, try:${line.separator}${platform.java}${jar.usage.message.module.path}${jar.usage.message.class.path}${jar.usage.message.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="init,compile,-pre-pre-jar,-pre-jar,-do-jar-jar" name="-do-jar-without-libraries"/>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar" 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,deploy" description="Build JAR." name="jar"/>
+ <!--
+ =================
+ DEPLOY SECTION
+ =================
+ -->
+ <target name="-pre-deploy">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init" name="-check-jlink">
+ <condition property="do.jlink.internal">
+ <and>
+ <istrue value="${do.jlink}"/>
+ <isset property="do.archive"/>
+ </and>
+ </condition>
+ </target>
+ <target depends="init,-do-jar,-post-jar,-pre-deploy,-check-jlink,-main-module-set" if="do.jlink.internal" name="-do-deploy">
+ <delete dir="${dist.jlink.dir}" failonerror="false" quiet="true"/>
+ <property name="jlink.launcher.name" value="${application.title}"/>
+ <pathconvert pathsep="," property="jlink.modulelist.internal">
+ <fileset dir="${dist.dir}" includes="*.jar"/>
+ <mapper>
+ <chainedmapper>
+ <flattenmapper/>
+ <globmapper from="*.jar" to="*"/>
+ </chainedmapper>
+ </mapper>
+ </pathconvert>
+ <condition else="${jlink.modulelist.internal}" property="jlink.add.modules" value="${jlink.modulelist.internal},${jlink.additionalmodules}">
+ <and>
+ <isset property="jlink.additionalmodules"/>
+ <length length="0" string="${jlink.additionalmodules}" when="greater"/>
+ </and>
+ </condition>
+ <condition property="jlink.do.strip.internal">
+ <and>
+ <isset property="jlink.strip"/>
+ <istrue value="${jlink.strip}"/>
+ </and>
+ </condition>
+ <condition property="jlink.do.additionalparam.internal">
+ <and>
+ <isset property="jlink.additionalparam"/>
+ <length length="0" string="${jlink.additionalparam}" when="greater"/>
+ </and>
+ </condition>
+ <condition property="jlink.do.launcher.internal">
+ <and>
+ <istrue value="${jlink.launcher}"/>
+ <isset property="module.name"/>
+ <length length="0" string="${module.name}" when="greater"/>
+ <isset property="main.class.available"/>
+ </and>
+ </condition>
+ <property name="platform.jlink" value="${jdk.home}/bin/jlink"/>
+ <property name="jlink.systemmodules.internal" value="${jdk.home}/jmods"/>
+ <exec executable="${platform.jlink}">
+ <arg value="--module-path"/>
+ <arg path="${jlink.systemmodules.internal}:${run.modulepath}:${dist.dir}"/>
+ <arg value="--add-modules"/>
+ <arg value="${jlink.add.modules}"/>
+ <arg if:set="jlink.do.strip.internal" value="--strip-debug"/>
+ <arg if:set="jlink.do.launcher.internal" value="--launcher"/>
+ <arg if:set="jlink.do.launcher.internal" value="${jlink.launcher.name}=${module.name}/${main.class}"/>
+ <arg if:set="jlink.do.additionalparam.internal" line="${jlink.additionalparam}"/>
+ <arg value="--output"/>
+ <arg value="${dist.jlink.output}"/>
+ </exec>
+ </target>
+ <target name="-post-deploy">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="-do-jar,-post-jar,-pre-deploy,-do-deploy,-post-deploy" name="deploy"/>
+ <!--
+ =================
+ EXECUTION SECTION
+ =================
+ -->
+ <target name="-check-main-class">
+ <fail unless="main.class">No main class specified</fail>
+ </target>
+ <target depends="init,compile,-check-main-class,-main-module-check" description="Run a main class." name="run">
+ <property name="main.class.relativepath" refid="main.class.relativepath"/>
+ <pathconvert pathsep="," property="src.dir.list" refid="have.sources.set"/>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" filePattern="(.*$)" modsource="${src.dir.path}" property="run.src.dir.path.regexp"/>
+ <j2semodularproject1:java xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <customize>
+ <arg line="${application.args}"/>
+ </customize>
+ </j2semodularproject1:java>
+ </target>
+ <target name="-main-module-set" unless="module.name">
+ <condition else="${main.class}" property="check.class.name" value="${run.class}">
+ <isset property="run.class"/>
+ </condition>
+ <condition property="run.modules.dir" value="${build.modules.dir}">
+ <not>
+ <isset property="run.modules.dir"/>
+ </not>
+ </condition>
+ <resources id="main.class.relativepath">
+ <mappedresources>
+ <string value="${check.class.name}"/>
+ <unpackagemapper from="*" to="*.class"/>
+ </mappedresources>
+ </resources>
+ <property location="${run.modules.dir}" name="run.modules.dir.location"/>
+ <pathconvert property="module.name">
+ <fileset dir="${run.modules.dir}" includes="**/${toString:main.class.relativepath}"/>
+ <regexpmapper from="\Q${run.modules.dir.location}${file.separator}\E([^${file.separator.string}]+)\Q${file.separator}\E.*\.class" to="\1"/>
+ </pathconvert>
+ </target>
+ <target depends="-main-module-set" name="-main-module-check">
+ <fail message="Could not determine module of the main class and module.name is not set">
+ <condition>
+ <or>
+ <not>
+ <isset property="module.name"/>
+ </not>
+ <length length="0" string="${module.name}" when="equal"/>
+ </or>
+ </condition>
+ </fail>
+ </target>
+ <target depends="-main-module-set" if="main.class.available" name="-main-module-check-condition">
+ <fail message="Could not determine module of the main class and module.name is not set">
+ <condition>
+ <or>
+ <not>
+ <isset property="module.name"/>
+ </not>
+ <length length="0" string="${module.name}" when="equal"/>
+ </or>
+ </condition>
+ </fail>
+ </target>
+ <target name="-do-not-recompile">
+ <property name="javac.includes.binary" value=""/>
+ </target>
+ <target depends="init,compile-single,-main-module-check" name="run-single">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <j2semodularproject1:java xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classname="${run.class}"/>
+ </target>
+ <target depends="init,compile-test-single,-init-test-run-module-properties,-main-module-check" name="run-test-with-main">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <j2semodularproject1:java xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classname="${run.class}" classpath="${run.test.classpath}" modulepath="${run.test.modulepath}">
+ <customize>
+ <jvmarg line="${run.test.jvmargs}"/>
+ </customize>
+ </j2semodularproject1:java>
+ </target>
+ <!--
+ =================
+ DEBUGGING SECTION
+ =================
+ -->
+ <target name="-debug-init">
+ <condition else="${main.class}" property="run.class" value="${debug.class}">
+ <isset property="debug.class"/>
+ </condition>
+ <fail message="debug.class or main.class property is not set" unless="run.class"/>
+ </target>
+ <target depends="init,-debug-init,-main-module-check" if="netbeans.home" name="-debug-start-debugger">
+ <j2semodularproject1:nbjpdastart xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" name="${debug.class}"/>
+ </target>
+ <target depends="init,-debug-init,-main-module-check" if="netbeans.home" name="-debug-start-debugger-main-test">
+ <j2semodularproject1:nbjpdastart xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classpath="${debug.test.classpath}" name="${debug.class}"/>
+ </target>
+ <target depends="init,compile,-debug-init,-main-module-check" name="-debug-start-debuggee">
+ <j2semodularproject1:debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classname="${run.class}">
+ <customizeDebuggee>
+ <arg line="${application.args}"/>
+ </customizeDebuggee>
+ </j2semodularproject1:debug>
+ </target>
+ <target depends="init,compile,-debug-init,-main-module-check,-debug-start-debugger,-debug-start-debuggee" description="Debug project in IDE." if="netbeans.home" name="debug"/>
+ <target depends="init,-debug-init,-main-module-check" if="netbeans.home" name="-debug-start-debugger-stepinto">
+ <j2semodularproject1:nbjpdastart xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" stopclassname="${debug.class}"/>
+ </target>
+ <target depends="init,compile,-debug-start-debugger-stepinto,-debug-start-debuggee" if="netbeans.home" name="debug-stepinto"/>
+ <target depends="init,compile-single,-debug-init,-main-module-check" if="netbeans.home" name="-debug-start-debuggee-single">
+ <fail unless="debug.class">Must select one file in the IDE or set debug.class</fail>
+ <j2semodularproject1:debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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,-debug-init,-main-module-check" 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>
+ <j2semodularproject1:debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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">
+ <property location="${build.modules.dir}" name="debug.modules.dir"/>
+ <j2semodularproject1:nbjpdareload xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ </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="-init-macrodef-junit,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>
+ <j2semodularproject1:junit xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="${excludes}" includes="${includes}" testincludes="${profile.class}" testmethods="">
+ <customize>
+ <jvmarg value="-agentlib:jdwp=transport=${debug-transport},address=${jpda.address}"/>
+ <env key="${profiler.info.pathvar}" path="${profiler.info.agentpath}:${profiler.current.path}"/>
+ <jvmarg value="${profiler.info.jvmargs.agent}"/>
+ <jvmarg line="${profiler.info.jvmargs}"/>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ </customize>
+ </j2semodularproject1: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/>
+ <antcall 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>
+ <condition else="" property="javadoc.html5.cmd.line.arg" value="-html5">
+ <and>
+ <isset property="javadoc.html5"/>
+ <available file="${jdk.home}${file.separator}lib${file.separator}jrt-fs.jar"/>
+ </and>
+ </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="${src.gen.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}"/>
+ <arg line="${javadoc.html5.cmd.line.arg}"/>
+ </javadoc>
+ <copy todir="${dist.javadoc.dir}">
+ <fileset dir="${src.dir}" excludes="${excludes}" includes="${includes}">
+ <filename name="**/doc-files/**"/>
+ </fileset>
+ <fileset dir="${src.gen.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.modules.dir}"/>
+ </target>
+ <target name="-pre-compile-test">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="-init-source-module-properties" name="-init-test-run-module-properties">
+ <fileset dir="${build.test.modules.dir}" id="run.test.packages.internal" includes="**/*.class"/>
+ <property location="${build.test.modules.dir}" name="build.test.modules.dir.abs.internal"/>
+ <pathconvert pathsep=" " property="run.test.addexports.internal" refid="run.test.packages.internal">
+ <chainedmapper>
+ <filtermapper>
+ <replacestring from="${build.test.modules.dir.abs.internal}${file.separator}" to=""/>
+ </filtermapper>
+ <regexpmapper from="^([^${file.separator.string}]*)\Q${file.separator}\E(.*)\Q${file.separator}\E.*\.class$$" to="\1${path.separator}\2"/>
+ <filtermapper>
+ <uniqfilter/>
+ <replacestring from="${file.separator}" to="."/>
+ </filtermapper>
+ <regexpmapper from="([^${file.separator.string}]+)${path.separator}(.*)" to="--add-exports \1/\2=ALL-UNNAMED"/>
+ </chainedmapper>
+ </pathconvert>
+ <property location="${build.test.modules.dir}" name="build.test.modules.location"/>
+ <pathconvert pathsep="," property="run.test.addmodules.list">
+ <map from="${build.test.modules.location}${file.separator}" to=""/>
+ <dirset dir="${build.test.modules.dir}" includes="*"/>
+ <chainedmapper>
+ <filtermapper>
+ <uniqfilter/>
+ </filtermapper>
+ </chainedmapper>
+ </pathconvert>
+ <pathconvert pathsep=" " property="run.test.patchmodules.list">
+ <dirset dir="${build.test.modules.dir}" includes="*">
+ <custom classname="netbeans.ModuleInfoSelector" classpath="${netbeans.modular.tasks.dir}/out">
+ <param name="extension" value="class"/>
+ </custom>
+ </dirset>
+ <chainedmapper>
+ <filtermapper>
+ <uniqfilter/>
+ </filtermapper>
+ <regexpmapper from=".*\Q${file.separator}\E([^${file.separator.string}]+)$" to="--patch-module \1=\0"/>
+ </chainedmapper>
+ </pathconvert>
+ <j2semodularproject1:coalesce_keyvalue xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" entrySep="--patch-module " multiSep="${path.separator}" property="run.test.patchmodules" value="${run.test.patchmodules.list}" valueSep="="/>
+ <condition else="" property="run.test.addmodules.internal" value="--add-modules ${run.test.addmodules.list}">
+ <isset property="run.test.addmodules.list"/>
+ </condition>
+ <pathconvert pathsep=" " property="run.test.addreads.internal">
+ <map from="${build.test.modules.location}" to=""/>
+ <dirset dir="${build.test.modules.dir}" includes="*"/>
+ <chainedmapper>
+ <regexpmapper from="^\Q${build.test.modules.location}${file.separator}\E(.*)" to="\1"/>
+ <regexpmapper from="(.*)" to="--add-reads \1=ALL-UNNAMED"/>
+ <filtermapper>
+ <uniqfilter/>
+ </filtermapper>
+ </chainedmapper>
+ </pathconvert>
+ <property name="run.test.jvmargs" value="${run.test.addmodules.internal} ${run.test.addreads.internal} ${run.test.addexports.internal} ${run.test.patchmodules}"/>
+ </target>
+ <target depends="-init-source-module-properties" name="-init-test-javac-module-properties">
+ <pathconvert pathsep=" " property="compile.test.patchmodule.internal" refid="have.tests.patchset">
+ <regexpmapper from="(.*\Q${file.separator}\E)([^${file.separator.string}]+)\Q${file.separator}\E(.*)$$" to="--patch-module \2=\1\2${file.separator.string}\3"/>
+ </pathconvert>
+ <pathconvert pathsep=" " property="compile.test.addreads">
+ <union refid="have.tests.set"/>
+ <chainedmapper>
+ <firstmatchmapper>
+ <regexpmapper from="${have.tests.test.src.dir.regexp}" to="\1"/>
+ </firstmatchmapper>
+ <regexpmapper from="(.*)" to="--add-reads \1=ALL-UNNAMED"/>
+ <filtermapper>
+ <uniqfilter/>
+ </filtermapper>
+ </chainedmapper>
+ </pathconvert>
+ <j2semodularproject1:coalesce_keyvalue xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" entrySep="--patch-module " multiSep="${path.separator}" property="compile.test.patchmodules" value="${compile.test.patchmodule.internal}" valueSep="="/>
+ <property name="javac.test.moduleargs" value="${compile.test.patchmodules} ${compile.test.addreads}"/>
+ </target>
+ <target depends="-init-test-javac-module-properties" name="-init-test-module-properties">
+ <property location="${build.modules.dir}" name="test.module.build.location"/>
+ <property name="test.source.modulepath" value="${test.src.dir}/*/${test.src.dir.path}"/>
+ <property name="test.compile.modulepath" value="${javac.test.modulepath}:${build.modules.dir}"/>
+ <macrodef name="test-javac" uri="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <element implicit="true" name="additionalargs" optional="true"/>
+ <sequential>
+ <j2semodularproject1:javac xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" apgeneratedsrcdir="${build.test.modules.dir}" classpath="${javac.test.classpath}" debug="true" destdir="${build.test.modules.dir}" excludes="@{excludes}" includes="@{includes}" modulepath="${test.compile.modulepath}" modulesourcepath="${test.source.modulepath}" processorpath="${javac.test.processorpath}">
+ <customize>
+ <compilerarg line="${javac.test.moduleargs}"/>
+ <additionalargs/>
+ </customize>
+ </j2semodularproject1:javac>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="do.depend.true" name="-compile-test-depend">
+ <j2semodularproject1:depend xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classpath="${javac.test.classpath}" destdir="${build.test.classes.dir}" srcdir="${test.src.dir}"/>
+ </target>
+ <target depends="init,deps-jar,compile,-init-test-module-properties,-pre-pre-compile-test,-pre-compile-test,-compile-test-depend" if="have.tests" name="-do-compile-test">
+ <j2semodularproject1:test-javac xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" filePattern="(.*$)" modsource="${test.src.dir.path}" property="test.src.dir.path.regexp"/>
+ <echo message="Copying resources from ${test.src.dir}"/>
+ <copy todir="${build.test.modules.dir}">
+ <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ <regexpmapper from="${test.src.dir.path.regexp}" to="\1/\3"/>
+ </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,-init-test-module-properties,-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>
+ <j2semodularproject1:force-recompile xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" destdir="${build.test.modules.dir}"/>
+ <j2semodularproject1:test-javac xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" includes="${javac.includes}"/>
+ <j2semodularproject1:modsource_regexp xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" filePattern="(.*$)" modsource="${test.src.dir.path}" property="test.src.dir.path.regexp"/>
+ <echo message="Copying resources from ${test.src.dir}"/>
+ <copy todir="${build.test.modules.dir}">
+ <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ <regexpmapper from="${test.src.dir.path.regexp}" to="\1/\3"/>
+ </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 name="-init-test-run">
+ <property name="run.modules.dir" value="${build.test.modules.dir}"/>
+ </target>
+ <target depends="init,compile-test,-init-test-run-module-properties,-pre-test-run" if="have.tests" name="-do-test-run">
+ <j2semodularproject1:test xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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,-init-test-run-module-properties,-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>
+ <j2semodularproject1:test xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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,-init-test-run-module-properties,-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>
+ <j2semodularproject1:test xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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,-init-test-run-module-properties,-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,-init-test-run-module-properties,-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>
+ <j2semodularproject1:test-debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" excludes="" includes="${javac.includes}" testClass="${test.class}" testincludes="${javac.includes}"/>
+ </target>
+ <target depends="init,compile-test-single,-init-test-run-module-properties,-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>
+ <j2semodularproject1:test-debug xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" 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">
+ <j2semodularproject1:nbjpdastart xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1" classpath="${debug.test.classpath}" name="${test.class}"/>
+ </target>
+ <target depends="init,compile-test-single,-init-test-run-module-properties,-debug-start-debugger-test,-debug-start-debuggee-test" name="debug-test"/>
+ <target depends="init,compile-test-single,-init-test-run-module-properties,-debug-start-debugger-test,-debug-start-debuggee-test-method" name="debug-test-method"/>
+ <target depends="debug-test-method" name="debug-single-method"/>
+ <target depends="init,-pre-debug-fix,compile-test-single" if="netbeans.home" name="-do-debug-fix-test">
+ <property name="debug.modules.dir" value="${build.test.modules.dir}"/>
+ <j2semodularproject1:nbjpdareload xmlns:j2semodularproject1="http://www.netbeans.org/ns/j2se-modular-project/1"/>
+ </target>
+ <target depends="init,-pre-debug-fix,-do-debug-fix-test" if="netbeans.home" name="debug-fix-test"/>
+ <!--
+ =========================
+ APPLET EXECUTION SECTION
+ =========================
+ -->
+ <target name="run-applet">
+ <fail message="Applets are no longer supported by JDK 9"/>
+ </target>
+ <!--
+ =========================
+ APPLET DEBUGGING SECTION
+ =========================
+ -->
+ <target name="-debug-start-debuggee-applet">
+ <fail message="Applets are no longer supported by JDK 9"/>
+ </target>
+ <target name="debug-applet">
+ <fail message="Applets are no longer supported by JDK 9"/>
+ </target>
+ <!--
+ ===============
+ 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: panamaz 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.jlink.output}"/>
+ <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 name="-recompile-netbeans-tasks-after-clean">
+ <antcall inheritall="false" target="-init-compile-netbeans-tasks"/>
+ </target>
+ <target depends="init,deps-clean,-do-clean,-recompile-netbeans-tasks-after-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>
--- /dev/null
+build.xml.data.CRC32=40912c6b
+build.xml.script.CRC32=1a338ef5
+build.xml.stylesheet.CRC32=32069288@1.17
+# 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=40912c6b
+nbproject/build-impl.xml.script.CRC32=d2abfa69
+nbproject/build-impl.xml.stylesheet.CRC32=d1ebcf0f@1.17
--- /dev/null
+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=panamaz
+application.vendor=notzed
+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
+build.modules.dir=${build.dir}/modules
+# Only compile against the classpath explicitly listed here:
+build.sysclasspath=ignore
+build.test.classes.dir=${build.dir}/test/classes
+build.test.modules.dir=${build.dir}/test/modules
+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.modulepath=\
+ ${run.modulepath}
+debug.test.classpath=\
+ ${run.test.classpath}
+debug.test.modulepath=\
+ ${run.test.modulepath}
+# 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.javadoc.dir=${dist.dir}/javadoc
+dist.jlink.dir=${dist.dir}/jlink
+dist.jlink.output=${dist.jlink.dir}/panamaz
+endorsed.classpath=
+excludes=
+includes=**
+jar.compress=false
+javac.classpath=
+# Space-separated list of extra javac options
+javac.compilerargs=
+javac.deprecation=false
+javac.external.vm=false
+javac.modulepath=
+javac.processormodulepath=
+javac.processorpath=\
+ ${javac.classpath}
+javac.source=18
+javac.target=18
+javac.test.classpath=\
+ ${javac.classpath}
+javac.test.modulepath=\
+ ${javac.modulepath}:\
+ ${build.modules.dir}
+javac.test.processorpath=\
+ ${javac.test.classpath}
+javadoc.additionalparam=
+javadoc.author=false
+javadoc.encoding=${source.encoding}
+javadoc.html5=false
+javadoc.noindex=false
+javadoc.nonavbar=false
+javadoc.notree=false
+javadoc.private=false
+javadoc.splitindex=true
+javadoc.use=true
+javadoc.version=false
+javadoc.windowtitle=
+# The jlink additional root modules to resolve
+jlink.additionalmodules=
+# The jlink additional command line parameters
+jlink.additionalparam=
+jlink.launcher=true
+jlink.launcher.name=panamaz
+platform.active=default_platform
+run.classpath=
+run.jvmargs=--enable-native-access=notzed.vulkan,notzed.nativez,notzed.xlib
+run.modulepath=\
+ ${javac.modulepath}:\
+ ${build.modules.dir}
+run.test.classpath=\
+ ${javac.test.classpath}
+run.test.modulepath=\
+ ${javac.test.modulepath}:\
+ ${build.test.modules.dir}
+source.encoding=UTF-8
+src.dir=src
+src.dir.path=classes
+src.gen.dir=bin/gen
+src.gen.dir.path=classes
+test.src.dir=src
+test.src.dir.path=tests
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://www.netbeans.org/ns/project/1">
+ <type>org.netbeans.modules.java.j2semodule</type>
+ <configuration>
+ <data xmlns="http://www.netbeans.org/ns/j2se-modular-project/1">
+ <name>panamaz</name>
+ <source-roots>
+ <root id="src.dir" pathref="src.dir.path"/>
+ <root id="src.gen.dir" pathref="src.gen.dir.path"/>
+ </source-roots>
+ <test-roots>
+ <root id="test.src.dir" pathref="test.src.dir.path"/>
+ </test-roots>
+ </data>
+ </configuration>
+</project>
--- /dev/null
+
+package au.notzed.display;
+
+import jdk.incubator.foreign.*;
+import au.notzed.nativez.*;
+
+import vulkan.*;
+import static vulkan.Vulkan.*;
+
+import xlib.*;
+import static xlib.XLib.*;
+
+public abstract class Display {
+
+ public abstract Window createWindow(int width, int height);
+ public abstract void close();
+
+ public static Display createX11Display() {
+ return new X11Display(XOpenDisplay(null));
+ }
+
+ static class X11Display extends Display {
+ XDisplay display;
+
+ static {
+ XInitThreads();
+ }
+
+ X11Display(XDisplay display) {
+ this.display = display;
+ }
+
+ public Window createWindow(int width, int height) {
+ return Window.createX11Window(display, width, height);
+ }
+
+ public void close() {
+ XCloseDisplay(display);
+ }
+ }
+
+ // xcb, sdl etc
+}
--- /dev/null
+package au.notzed.display;
+
+// basic event handling
+public class Event {
+
+ public final int type;
+ public final int x, y, width, height;
+ // shift etc
+ public final int key;
+ public final int button;
+
+ public static final int CLOSE = 0;
+ public static final int KEY = 1;
+ public static final int POINTER = 2;
+ public static final int BUTTON = 3;
+ public static final int EXPOSE = 4;
+ public static final int RESIZE = 5;
+
+ public Event(int type, int x, int y, int width, int height, int key, int button) {
+ this.type = type;
+ this.x = x;
+ this.y = y;
+ this.width = width;
+ this.height = height;
+ this.key = key;
+ this.button = button;
+ }
+
+ public static Event key(int key) {
+ return new Event(KEY, 0, 0, 0, 0, key, 0);
+ }
+
+ public static Event expose(int x, int y, int width, int height) {
+ return new Event(EXPOSE, x, y, width, height, 0, 0);
+ }
+
+ public static Event resize(int x, int y, int width, int height) {
+ return new Event(RESIZE, x, y, width, height, 0, 0);
+ }
+
+ public static Event close() {
+ return new Event(CLOSE, 0, 0, 0, 0, 0, 0);
+ }
+
+}
--- /dev/null
+package au.notzed.display;
+
+import jdk.incubator.foreign.*;
+import au.notzed.nativez.*;
+
+import vulkan.*;
+import static vulkan.Vulkan.*;
+
+import xlib.*;
+import static xlib.XLib.*;
+
+public abstract class Window {
+
+ public abstract VkSurfaceKHR createVulkanSurface(VkInstance instance, ResourceScope scope);
+
+ public abstract Event nextEvent(boolean blocking);
+
+ public abstract void close();
+
+ static Window createX11Window(XDisplay display, int width, int height) {
+ try ( Frame frame = Frame.frame()) {
+ long visualMask = VisualScreenMask;
+ IntArray numberOfVisuals = IntArray.createArray(1, frame);
+ XVisualInfo vInfoTemplate = XVisualInfo.create(frame);
+
+ vInfoTemplate.setScreen(DefaultScreen(display));
+
+ XVisualInfo visualInfo = XGetVisualInfo(display, visualMask, vInfoTemplate, numberOfVisuals);
+ long colormap = XCreateColormap(display, RootWindow(display, vInfoTemplate.getScreen()), visualInfo.getVisual(), AllocNone);
+
+ XSetWindowAttributes windowAttributes = XSetWindowAttributes.create(frame);
+
+ windowAttributes.setColormap(colormap);
+ windowAttributes.setBackgroundPixel(0xffffffff);
+ windowAttributes.setBorderPixel(0);
+ windowAttributes.setEventMask(KeyPressMask | KeyReleaseMask | StructureNotifyMask | ExposureMask);
+ //windowAttributes.setEventMask(0xffffff);
+
+ long window = XCreateWindow(display, RootWindow(display, vInfoTemplate.getScreen()),
+ 0, 0, width, height,
+ 0, visualInfo.getDepth(), InputOutput, visualInfo.getVisual(),
+ CWBackPixel | CWBorderPixel | CWEventMask | CWColormap, windowAttributes);
+
+ XSelectInput(display, window, ExposureMask | KeyPressMask | StructureNotifyMask | PointerMotionMask);
+ //XSelectInput(display, window, 0xffffff);
+ XMapWindow(display, window);
+ XFlush(display);
+
+ return new X11Window(display, window);
+ }
+ }
+
+ static class X11Window extends Window {
+
+ XDisplay display;
+ long window;
+ // TODO: move to display
+ long wm_delete_window;
+ long wm_protocols;
+
+ X11Window(XDisplay display, long window) {
+ this.display = display;
+ this.window = window;
+ wm_delete_window = XInternAtom(display, "WM_DELETE_WINDOW", 0);
+ wm_protocols = XInternAtom(display, "WM_PROTOCOLS", 0);
+ try ( Frame frame = Frame.frame()) {
+ LongArray atoms = LongArray.create(frame, wm_delete_window);
+ XSetWMProtocols(display, window, atoms, 1);
+ }
+ }
+
+ @Override
+ public void close() {
+ XDestroyWindow(display, window);
+ }
+
+ @Override
+ public Event nextEvent(boolean blocking) {
+
+ try ( Frame frame = Frame.frame()) {
+ XEvent event = XEvent.create(frame);
+
+ while (true) {
+ if (!blocking && XPending(display) == 0)
+ return null;
+ // err this just dies on error
+ //XWindowEvent(display, window, ~0, event);
+ int res = XNextEvent(display, event);
+
+ //System.out.printf("next event: %d type %d\n", res, event.getType());
+ switch (event.getType()) {
+ case KeyPress:
+ return Event.key(event.getXkey().getKeycode());
+ case Expose: {
+ XExposeEvent x = event.getXexpose();
+ return Event.expose(x.getX(), x.getY(), x.getWidth(), x.getHeight());
+ }
+ case ConfigureNotify: {
+ XConfigureEvent x = event.getXconfigure();
+ return Event.resize(x.getX(), x.getY(), x.getWidth(), x.getHeight());
+ }
+ case ClientMessage: {
+ XClientMessageEvent x = event.getXclient();
+
+ if (x.getMessageType() == wm_protocols
+ && x.getData().getLElement(0) == wm_delete_window) {
+ return Event.close();
+ } else {
+ System.out.printf("unknown client message\n");
+ }
+ break;
+ }
+ }
+ }
+ }
+ }
+
+ @Override
+ public VkSurfaceKHR createVulkanSurface(VkInstance instance, ResourceScope scope) {
+ try ( Frame frame = Frame.frame()) {
+ VkXlibSurfaceCreateInfoKHR surfaceinfo = VkXlibSurfaceCreateInfoKHR.create(frame,
+ 0,
+ display,
+ window);
+
+ return instance.vkCreateXlibSurfaceKHR(surfaceinfo, scope);
+ }
+ }
+ }
+}
--- /dev/null
+
+module notzed.display {
+ requires notzed.xlib;
+ requires notzed.xcb;
+ requires notzed.vulkan;
+
+ exports au.notzed.display;
+}
module notzed.vulkan.test {
requires notzed.vulkan;
- requires notzed.xlib;
-
+ requires notzed.display;
+
requires java.desktop;
}
- /*
+/*
The MIT License (MIT)
Copyright (C) 2017 Eric Arnebäck
*/
-/*
+ /*
* This is a Java conversion of a C conversion of this:
* https://github.com/Erkaman/vulkan_minimal_compute
*
* It's been simplified a bit and converted to the 'zvk' api.
*/
-
package vulkan.test;
-import java.io.InputStream;
-import java.io.FileOutputStream;
-import java.io.IOException;
-import java.nio.channels.Channels;
-import java.nio.ByteBuffer;
-import java.nio.ByteOrder;
-
-import java.awt.Graphics;
-import java.awt.Image;
-import java.awt.Toolkit;
-import java.awt.event.ActionEvent;
-import java.awt.event.KeyEvent;
-import java.awt.image.MemoryImageSource;
-import javax.swing.AbstractAction;
-import javax.swing.JComponent;
-import javax.swing.JFrame;
-import javax.swing.JPanel;
-import javax.swing.KeyStroke;
-
-import java.lang.ref.WeakReference;
-import java.util.List;
-import java.util.Collections;
-
-import java.lang.invoke.*;
+import au.notzed.display.Display;
import jdk.incubator.foreign.*;
-import jdk.incubator.foreign.MemoryLayout.PathElement;
import au.notzed.nativez.*;
import vulkan.*;
-import static vulkan.VkConstants.*;
+import static vulkan.Vulkan.*;
-import xlib.*;
-import static xlib.XLib.*;
+import au.notzed.display.*;
import static vulkan.test.GLMaths.*;
public class TestCube {
+
static final boolean debug = true;
final static int NUM_SAMPLES = VK_SAMPLE_COUNT_1_BIT;
float projection[] = new float[16];
float view[] = new float[16];
float model[] = new float[16];
- float clip[] = new float[] {
+ float clip[] = new float[]{
1.0f, 0.0f, 0.0f, 0.0f,
0.0f, -1.0f, 0.0f, 0.0f,
0.0f, 0.0f, 0.5f, 0.0f,
VkDescriptorPool desc_pool;
HandleArray<VkDescriptorSet> desc_set;
-
VkRenderPass render_pass;
HandleArray<VkFramebuffer> framebuffers;
VkSemaphore chainSemaphore;
VkFence drawFence;
- record BufferMemory (VkBuffer buffer, VkDeviceMemory memory, long size) {
+ record BufferMemory(VkBuffer buffer, VkDeviceMemory memory, long size) {
+
public void free(VkDevice device) {
device.vkFreeMemory(memory);
device.vkDestroyBuffer(buffer);
void init_debug() throws Exception {
if (!debug)
return;
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
var cb = PFN_vkDebugUtilsMessengerCallbackEXT.upcall((severity, flags, data) -> {
- System.out.printf("Debug: %d: %s\n", severity, data.getMessage());
- return 0;
- }, scope);
+ System.out.printf("Debug: %d: %s\n", severity, data.getMessage());
+ return 0;
+ }, scope);
VkDebugUtilsMessengerCreateInfoEXT info = VkDebugUtilsMessengerCreateInfoEXT.create(frame,
0,
VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT
}
//typedef VkBool32 (*PFN_vkDebugUtilsMessengerCallbackEXT)(VkDebugUtilsMessageSeverityFlagBitsEXT, VkDebugUtilsMessageTypeFlagsEXT, const VkDebugUtilsMessengerCallbackDataEXT *, void *);
-
}
void init_instance() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkInstanceCreateInfo info = VkInstanceCreateInfo.create(frame,
0,
- VkApplicationInfo.create(frame, "cube", 1, "cube-engine", 2, VK_MAKE_API_VERSION(0, 1, 0, 0)),
- new String[] { "VK_LAYER_KHRONOS_validation" },
- new String[] { "VK_KHR_surface", "VK_KHR_xlib_surface", "VK_EXT_debug_utils" }
- );
+ VkApplicationInfo.create(frame, "cube", 1, "cube-engine", 2, VK_API_VERSION_1_0),
+ new String[]{"VK_LAYER_KHRONOS_validation"},
+ new String[]{"VK_KHR_surface", "VK_KHR_xlib_surface", "VK_EXT_debug_utils"}
+ );
instance = VkInstance.vkCreateInstance(info, scope);
System.out.printf("instance = %s\n", instance);
}
}
- XDisplay display;
- long window;
- long wm_delete_window;
+ Display display;
+ Window window;
VkSurfaceKHR surface;
void init_surface() throws Exception {
- try (Frame frame = Frame.frame()) {
- XInitThreads();
- display = XOpenDisplay(null);
- long visualMask = VisualScreenMask;
- IntArray numberOfVisuals = IntArray.createArray(1, frame);
- XVisualInfo vInfoTemplate = XVisualInfo.create(frame);
-
- vInfoTemplate.setScreen(DefaultScreen(display));
-
- XVisualInfo visualInfo = XGetVisualInfo(display, visualMask, vInfoTemplate, numberOfVisuals);
- long colormap = XCreateColormap(display, RootWindow(display, vInfoTemplate.getScreen()), visualInfo.getVisual(), AllocNone);
-
- XSetWindowAttributes windowAttributes = XSetWindowAttributes.create(frame);
-
- windowAttributes.setColormap(colormap);
- windowAttributes.setBackgroundPixel(0xffffffff);
- windowAttributes.setBorderPixel(0);
- windowAttributes.setEventMask(KeyPressMask | KeyReleaseMask | StructureNotifyMask | ExposureMask);
-
- window = XCreateWindow(display, RootWindow(display, vInfoTemplate.getScreen()),
- 0, 0, width, height,
- 0, visualInfo.getDepth(), InputOutput, visualInfo.getVisual(),
- CWBackPixel | CWBorderPixel | CWEventMask | CWColormap, windowAttributes);
-
- XSelectInput(display, window, ExposureMask | KeyPressMask);
- XMapWindow(display, window);
- XFlush(display);
- wm_delete_window = XInternAtom(display, "WM_DELETE_WINDOW", 0);
-
- VkXlibSurfaceCreateInfoKHR surfaceinfo = VkXlibSurfaceCreateInfoKHR.create(frame,
- 0,
- display,
- window);
-
- surface = instance.vkCreateXlibSurfaceKHR(surfaceinfo, scope);
- System.out.printf("surface: %s\n", surface);
- }
+ display = Display.createX11Display();
+ window = display.createWindow(width, height);
+ surface = window.createVulkanSurface(instance, scope);
+ System.out.printf("surface: %s\n", surface);
}
void init_device() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
IntArray count$h = IntArray.create(frame, 1);
IntArray present$h = IntArray.create(frame, 1);
HandleArray<VkPhysicalDevice> devs;
0,
graphics_queue,
qpri);
- String [] extensions = {
+ String[] extensions = {
"VK_KHR_swapchain"
};
VkPhysicalDeviceFeatures features = VkPhysicalDeviceFeatures.create(frame);
VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR,
VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR,
VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR,
- VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR,
- };
+ VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR,};
for (int flag: compositeAlphaFlags) {
if ((surfCapabilities.getSupportedCompositeAlpha() & flag) != 0) {
compositeAlpha = flag;
}
void init_command() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkCommandPoolCreateInfo poolinfo = VkCommandPoolCreateInfo.create(frame,
0,
graphics_queue_index);
// parameterise as init_image?
void init_depth() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
int format = VK_FORMAT_D16_UNORM;
VkMemoryRequirements req = VkMemoryRequirements.create(frame);
VkImageCreateInfo imageinfo = VkImageCreateInfo.create(frame, 0,
}
void init_descriptor() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
HandleArray<VkDescriptorSetLayout> layout_table = VkDescriptorSetLayout.createArray(1, frame);
VkDescriptorSetLayoutBinding layout_binding = VkDescriptorSetLayoutBinding.create(frame,
0,
}
void init_render() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkAttachmentDescription attachments = VkAttachmentDescription.createArray(2, frame);
attachments.setFormat(chainImageFormat);
}
void init_framebuffer() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
HandleArray<VkImageView> attachments = VkImageView.createArray(2, frame);
attachments.setAtIndex(1, depthView);
}
void init_vertexbuffer() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
vertex = init_buffer(Cube.data.length * 4, VK_BUFFER_USAGE_VERTEX_BUFFER_BIT, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, MemorySegment.ofArray(Cube.data));
vertexBuffer.setAtIndex(0, vertex.buffer);
void init_pipeline() throws Exception {
int res;
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
IntArray dynamicStateEnables = IntArray.create(frame,
VK_DYNAMIC_STATE_VIEWPORT,
VK_DYNAMIC_STATE_SCISSOR);
null,
0, //.alphaToCoverageEnable = VK_FALSE,
0 //.alphaToOneEnable = VK_FALSE,
- );
+ );
VkShaderModuleCreateInfo vsInfo = VkShaderModuleCreateInfo.create(frame,
0,
VkPipelineShaderStageCreateInfo shaderStages = VkPipelineShaderStageCreateInfo.createArray(2, (SegmentAllocator)scope);
// FIXME: createArray should initialise this
- shaderStages.setSType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO);
shaderStages.setStage(VK_SHADER_STAGE_VERTEX_BIT);
shaderStages.setName("main", (SegmentAllocator)scope);
shaderStages.setModule(shader.get(0));
- shaderStages.setSTypeAtIndex(1, VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO);
shaderStages.setStageAtIndex(1, VK_SHADER_STAGE_FRAGMENT_BIT);
shaderStages.setNameAtIndex(1, "main", (SegmentAllocator)scope);
shaderStages.setModuleAtIndex(1, shader.get(1));
}
}
-
void execute_begin_command_buffer() throws Exception {
/* DEPENDS on init_command() */
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkCommandBufferBeginInfo cmd_buf_info = VkCommandBufferBeginInfo.create(frame,
0,
null);
int res;
/* Queue the command buffer for execution */
- /* FIXME: frame shoudl provide or take explicit scope */
- try (ResourceScope scope = ResourceScope.newConfinedScope();
- Frame frame = Frame.frame()) {
+ /* FIXME: frame shoudl provide or take explicit scope */
+ try ( ResourceScope scope = ResourceScope.newConfinedScope(); Frame frame = Frame.frame()) {
IntArray pipe_stage_flags = IntArray.create(frame, VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT);
VkFenceCreateInfo fenceInfo = VkFenceCreateInfo.create(frame, 0);
HandleArray<VkFence> fences = VkFence.createArray(1, frame);
}
void cmd_viewport() {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkCommandBuffer cmd = this.cmd.getAtIndex(0);
VkViewport viewport = VkViewport.create(frame,
0, 0, width, height, 0.0f, 1.0f);
}
void cmd_scissors() {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkCommandBuffer cmd = this.cmd.getAtIndex(0);
VkRect2D scissor = VkRect2D.create(frame);
VkExtent2D extent = scissor.getExtent();
void cmd_paint() throws Exception {
int res;
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
int chainIndex;
IntArray chainIndices = IntArray.createArray(1, frame);
VkCommandBuffer cmd = this.cmd.getAtIndex(0);
* 1) create buffer, specifying usage and size
* 2) allocate memory based on memory requirements
* 3) bind memory
- *
+ * <p>
*/
BufferMemory init_buffer(long dataSize, int usage, int properties, MemorySegment init) throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkMemoryRequirements req = VkMemoryRequirements.create(frame);
VkBufferCreateInfo buf_info = VkBufferCreateInfo.create(frame,
0,
device.vkDestroySemaphore(chainSemaphore);
device.vkDestroyPipeline(pipeline.getAtIndex(0));
- for (int i=0;i<shader.size();i++)
+ for (int i = 0; i < shader.size(); i++)
device.vkDestroyShaderModule(shader.getAtIndex(i));
vertex.free(device);
uniform.free(device);
- for (int i=0;i<framebuffers.size();i++)
+ for (int i = 0; i < framebuffers.size(); i++)
device.vkDestroyFramebuffer(framebuffers.getAtIndex(i));
device.vkDestroyRenderPass(render_pass);
device.vkDestroyDevice();
instance.vkDestroySurfaceKHR(surface);
+ window.close();
+ display.close();
if (logger != null)
instance.vkDestroyDebugUtilsMessengerEXT(logger);
instance.vkDestroyInstance();
}
- IntArray loadSPIRV0(String name) throws IOException {
- // hmm any way to just load this directly?
- try (InputStream is = TestCube.class.getResourceAsStream(name)) {
- ByteBuffer bb = ByteBuffer.allocateDirect(8192).order(ByteOrder.nativeOrder());
- int length = Channels.newChannel(is).read(bb);
-
- bb.position(0);
- bb.limit(length);
-
- return IntArray.create(MemorySegment.ofByteBuffer(bb));
- }
- }
-
- IntArray loadSPIRV(String name) throws IOException {
- try (InputStream is = TestCube.class.getResourceAsStream(name)) {
- MemorySegment seg = ((SegmentAllocator)scope).allocateArray(Memory.INT, 2048);
- int length = Channels.newChannel(is).read(seg.asByteBuffer());
-
- return IntArray.create(seg.asSlice(0, length));
- }
- }
- IntArray loadSPIRV(String name, SegmentAllocator alloc) throws IOException {
- try (InputStream is = TestCube.class.getResourceAsStream(name)) {
- MemorySegment seg = alloc.allocateArray(Memory.INT, 2048);
- int length = Channels.newChannel(is).read(seg.asByteBuffer());
-
- return IntArray.create(seg.asSlice(0, length));
- }
- }
-
/**
* This finds the memory type index for the memory on a specific device.
*/
return -1;
}
- public static int VK_MAKE_API_VERSION(int variant, int major, int minor, int patch) {
- return (variant << 29) | (major << 22) | (minor << 12) | patch;
- }
-
static int clampi(int v, int min, int max) {
return v < min ? min : v < max ? v : max;
}
void init_matrices() {
- float eye[] = new float[] {-5, 3, -10};
- float centre[] = new float[] {0, 0, 0};
- float up[] = new float[] {0, -1, 0};
+ float eye[] = new float[]{-5, 3, -10};
+ float centre[] = new float[]{0, 0, 0};
+ float up[] = new float[]{0, -1, 0};
float t0[] = new float[16], t1[] = new float[16];
perspective(projection, (float)(Math.PI * 0.25), 1.0f, 0.1f, 100.0f);
}
void demo() throws Exception {
- cube_vs = loadSPIRV("cube_vs.bin");
- cube_fs = loadSPIRV("cube_fs.bin");
+ cube_vs = ShaderIO.loadCube_vs((SegmentAllocator)scope);
+ cube_fs = ShaderIO.loadCube_fs((SegmentAllocator)scope);
init_matrices();
cmd_paint();
- System.out.println("behold the prize!");
- Thread.sleep(2000);
+ System.out.println("Any key to quit");
+ Event e;
+outer: while ((e = window.nextEvent(true)) != null) {
+ switch (e.type) {
+ case Event.KEY:
+ case Event.CLOSE:
+ break outer;
+ }
+ }
shutdown();
}
- /*
+/*
The MIT License (MIT)
Copyright (C) 2017 Eric Arnebäck
*/
-/*
+ /*
* This is a Java conversion of a C conversion of this:
* https://github.com/Erkaman/vulkan_minimal_compute
*
* It's been simplified a bit and converted to the 'zvk' api.
*/
-
package vulkan.test;
import java.io.InputStream;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Toolkit;
-import java.awt.event.ActionEvent;
-import java.awt.event.KeyEvent;
import java.awt.image.MemoryImageSource;
-import javax.swing.AbstractAction;
-import javax.swing.JComponent;
import javax.swing.JFrame;
import javax.swing.JPanel;
-import javax.swing.KeyStroke;
-
-import java.lang.ref.WeakReference;
-
-import java.lang.invoke.*;
import jdk.incubator.foreign.*;
-import jdk.incubator.foreign.MemoryLayout.PathElement;
import au.notzed.nativez.*;
+import java.util.ArrayList;
+import java.util.List;
import vulkan.*;
-
-import static vulkan.VkConstants.*;
+import static vulkan.Vulkan.*;
public class TestMandelbrot {
+
static final boolean debug = true;
ResourceScope scope = ResourceScope.newSharedScope();
- int WIDTH = 1920*1;
- int HEIGHT = 1080*1;
+ int WIDTH = 1920 * 1;
+ int HEIGHT = 1080 * 1;
VkInstance instance;
VkPhysicalDevice physicalDevice;
VkCommandPool commandPool;
HandleArray<VkCommandBuffer> commandBuffers;
- record BufferMemory ( VkBuffer buffer, VkDeviceMemory memory ) {};
+ record BufferMemory(VkBuffer buffer, VkDeviceMemory memory) {
+
+ }
VkDebugUtilsMessengerEXT logger;
void init_debug() throws Exception {
if (!debug)
return;
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
var cb = PFN_vkDebugUtilsMessengerCallbackEXT.upcall((severity, flags, data) -> {
- System.out.printf("Debug: %d: %s\n", severity, data.getMessage());
- return 0;
- }, scope);
+ System.out.printf("Debug: %d: %s\n", severity, data.getMessage());
+ return 0;
+ }, scope);
VkDebugUtilsMessengerCreateInfoEXT info = VkDebugUtilsMessengerCreateInfoEXT.create(frame,
0,
//VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT |
}
void init_instance() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkInstanceCreateInfo info = VkInstanceCreateInfo.create(frame,
0,
- VkApplicationInfo.create(frame, "test", 1, "test-engine", 2, VK_MAKE_API_VERSION(0, 1, 0, 0)),
- new String[] { "VK_LAYER_KHRONOS_validation" },
- debug ? new String[] { "VK_EXT_debug_utils" } : null
- );
+ VkApplicationInfo.create(frame, "test", 1, "test-engine", 2, VK_API_VERSION_1_0),
+ new String[]{"VK_LAYER_KHRONOS_validation"},
+ debug ? new String[]{"VK_EXT_debug_utils"} : null
+ );
instance = VkInstance.vkCreateInstance(info, scope);
}
}
void init_device() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
HandleArray<VkPhysicalDevice> devs;
int count;
int res;
int devid = -1;
int queueid = -1;
- for (int i=0;i<devs.length();i++) {
+ for (int i = 0; i < devs.length(); i++) {
VkPhysicalDevice dev = devs.getAtIndex(i);
VkQueueFamilyProperties famprops = dev.vkGetPhysicalDeviceQueueFamilyProperties(frame);
int family_count = (int)famprops.length();
- for (int j=0;j<family_count;j++) {
+ for (int j = 0; j < family_count; j++) {
var flags = famprops.getAtIndex(j).getQueueFlags();
int score = 0;
* 1) create buffer, specifying usage and size
* 2) allocate memory based on memory requirements
* 3) bind memory
- *
+ * <p>
*/
BufferMemory init_buffer(long dataSize, int usage, int properties) throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkMemoryRequirements req = VkMemoryRequirements.create(frame);
VkBufferCreateInfo buf_info = VkBufferCreateInfo.create(frame,
0,
/**
* Descriptors are used to bind and describe memory blocks
* to shaders.
- *
+ * <p>
* *Pool is used to allocate descriptors, it is per-device.
* *Layout is used to group descriptors for a given pipeline,
* The descriptors describe individually-addressable blocks.
*/
void init_descriptor() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
/* Create descriptorset layout */
VkDescriptorSetLayoutBinding layout_binding = VkDescriptorSetLayoutBinding.create(frame,
0,
}
/**
- * Create the compute pipeline. This is the shader and data layouts for it.
+ * Create the compute pipeline. This is the shader and data layouts for it.
*/
void init_pipeline() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
/* Set shader code */
VkShaderModuleCreateInfo vsInfo = VkShaderModuleCreateInfo.create(frame,
0,
* Create a command buffer, this is somewhat like a display list.
*/
void init_command_buffer() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkCommandPoolCreateInfo poolinfo = VkCommandPoolCreateInfo.create(frame,
0,
computeQueueIndex);
/**
* Execute the pre-created command buffer.
- *
+ * <p>
* A fence is used to wait for completion.
*/
void execute() throws Exception {
- try (Frame frame = Frame.frame()) {
+ try ( Frame frame = Frame.frame()) {
VkSubmitInfo submitInfo = VkSubmitInfo.create(frame);
submitInfo.setCommandBufferCount(1);
* Accesses the gpu buffer, converts it to RGB byte, and saves it as a pam file.
*/
void save_result() throws Exception {
- try (ResourceScope scope = ResourceScope.newConfinedScope()) {
+ try ( ResourceScope scope = ResourceScope.newConfinedScope()) {
MemorySegment mem = device.vkMapMemory(dst.memory(), 0, dstBufferSize, 0, scope);
byte[] pixels = new byte[WIDTH * HEIGHT * 3];
}
void show_result() throws Exception {
- try (ResourceScope scope = ResourceScope.newConfinedScope()) {
+ try ( ResourceScope scope = ResourceScope.newConfinedScope()) {
MemorySegment mem = device.vkMapMemory(dst.memory(), 0, dstBufferSize, 0, scope);
int[] pixels = new int[WIDTH * HEIGHT];
* Trivial pnm format image output.
*/
void pam_save(String name, int width, int height, int depth, byte[] pixels) throws IOException {
- try (FileOutputStream fos = new FileOutputStream(name)) {
+ try ( FileOutputStream fos = new FileOutputStream(name)) {
fos.write(String.format("P6\n%d\n%d\n255\n", width, height).getBytes());
fos.write(pixels);
System.out.printf("wrote: %s\n", name);
window.setVisible(true);
}
- IntArray loadSPIRV0(String name) throws IOException {
- // hmm any way to just load this directly?
- try (InputStream is = TestMandelbrot.class.getResourceAsStream(name)) {
- ByteBuffer bb = ByteBuffer.allocateDirect(8192).order(ByteOrder.nativeOrder());
- int length = Channels.newChannel(is).read(bb);
-
- bb.position(0);
- bb.limit(length);
-
- return IntArray.create(MemorySegment.ofByteBuffer(bb));
- }
- }
-
- IntArray loadSPIRV(String name) throws IOException {
- try (InputStream is = TestMandelbrot.class.getResourceAsStream(name)) {
- MemorySegment seg = ((SegmentAllocator)scope).allocateArray(Memory.INT, 2048);
- int length = Channels.newChannel(is).read(seg.asByteBuffer());
-
- return IntArray.create(seg.asSlice(0, length));
- }
- }
-
/**
* This finds the memory type index for the memory on a specific device.
*/
return -1;
}
- public static int VK_MAKE_API_VERSION(int variant, int major, int minor, int patch) {
- return (variant << 29) | (major << 22) | (minor << 12) | patch;
- }
-
void demo() throws Exception {
- mandelbrot_cs = loadSPIRV("mandelbrot.bin");
+ mandelbrot_cs = ShaderIO.loadMandelbrot((SegmentAllocator)scope);
init_instance();
init_debug();
shutdown();
}
-
public static void main(String[] args) throws Throwable {
System.loadLibrary("vulkan");
--- /dev/null
+/*
+The MIT License (MIT)
+
+Copyright (C) 2017 Eric Arnebäck
+Copyright (C) 2019 Michael Zucchi
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+
+ */
+
+ /*
+ * This is a Java conversion of a C conversion of this:
+ * https://github.com/Erkaman/vulkan_minimal_compute
+ *
+ * It's been simplified a bit and converted to the 'zvk' api.
+ */
+package vulkan.test;
+
+import au.notzed.display.Display;
+import au.notzed.display.Event;
+import au.notzed.display.Window;
+import jdk.incubator.foreign.*;
+import au.notzed.nativez.*;
+
+import vulkan.*;
+import static vulkan.Vulkan.*;
+
+import static vulkan.test.GLMaths.*;
+
+public class TestSDF {
+
+ static final boolean debug = true;
+
+ final static int NUM_SAMPLES = VK_SAMPLE_COUNT_1_BIT;
+ final static int NUM_DESCRIPTOR_SETS = 1;
+
+ ResourceScope scope = ResourceScope.newSharedScope();
+
+ int width = 800;
+ int height = 800;
+ float projection[] = new float[16];
+ float view[] = new float[16];
+ float model[] = new float[16];
+ float clip[] = new float[]{
+ 1.0f, 0.0f, 0.0f, 0.0f,
+ 0.0f, -1.0f, 0.0f, 0.0f,
+ 0.0f, 0.0f, 0.5f, 0.0f,
+ 0.0f, 0.0f, 0.5f, 1.0f
+ };
+ float mvp[] = new float[16];
+
+ VkInstance instance;
+ VkPhysicalDevice physicalDevice;
+ VkPhysicalDeviceMemoryProperties memory_properties;
+ VkPhysicalDeviceFeatures device_features;
+
+ int present_queue_index;
+ int graphics_queue_index;
+
+ VkDevice device;
+ VkSwapchainKHR chain;
+
+ VkQueue graphics_queue;
+ VkQueue present_queue;
+
+ int chainImageFormat;
+ HandleArray<VkImage> chainImage;
+ HandleArray<VkImageView> chainImageView;
+
+ int depthFormat;
+ VkImage depthImage;
+ VkImageView depthView;
+ VkDeviceMemory depthMemory;
+
+ VkCommandPool cmd_pool;
+ HandleArray<VkCommandBuffer> cmd;
+
+ BufferMemory uniform;
+ VkPipelineLayout pipeline_layout;
+
+ VkDescriptorSetLayout desc_layout;
+ VkDescriptorPool desc_pool;
+ HandleArray<VkDescriptorSet> desc_set;
+
+ VkRenderPass render_pass;
+ HandleArray<VkFramebuffer> framebuffers;
+
+ BufferMemory vertex;
+ HandleArray<VkBuffer> vertexBuffer = VkBuffer.createArray(1, (SegmentAllocator)scope);
+ VkVertexInputBindingDescription vi_binding = VkVertexInputBindingDescription.createArray(1, (SegmentAllocator)scope);
+ VkVertexInputAttributeDescription vi_attribs = VkVertexInputAttributeDescription.createArray(1, (SegmentAllocator)scope);
+
+ IntArray sdf_vs;
+ IntArray sdf_fs;
+ HandleArray<VkShaderModule> shader = VkShaderModule.createArray(2, (SegmentAllocator)scope);
+
+ HandleArray<VkPipeline> pipeline = VkPipeline.createArray(1, (SegmentAllocator)scope);
+
+ VkSemaphore chainSemaphore;
+ VkFence drawFence;
+
+ record BufferMemory(VkBuffer buffer, VkDeviceMemory memory, long size) {
+
+ public void free(VkDevice device) {
+ device.vkFreeMemory(memory);
+ device.vkDestroyBuffer(buffer);
+ }
+ }
+
+ VkDebugUtilsMessengerEXT logger;
+
+ void init_debug() throws Exception {
+ if (!debug)
+ return;
+ try ( Frame frame = Frame.frame()) {
+ var cb = PFN_vkDebugUtilsMessengerCallbackEXT.upcall((severity, flags, data) -> {
+ System.out.printf("Debug: %d: %s\n", severity, data.getMessage());
+ return 0;
+ }, scope);
+ VkDebugUtilsMessengerCreateInfoEXT info = VkDebugUtilsMessengerCreateInfoEXT.create(frame,
+ 0,
+ VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT
+ | VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT
+ | VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT,
+ VK_DEBUG_UTILS_MESSAGE_TYPE_GENERAL_BIT_EXT | VK_DEBUG_UTILS_MESSAGE_TYPE_VALIDATION_BIT_EXT,
+ cb,
+ null);
+
+ logger = instance.vkCreateDebugUtilsMessengerEXT(info, scope);
+ }
+
+ //typedef VkBool32 (*PFN_vkDebugUtilsMessengerCallbackEXT)(VkDebugUtilsMessageSeverityFlagBitsEXT, VkDebugUtilsMessageTypeFlagsEXT, const VkDebugUtilsMessengerCallbackDataEXT *, void *);
+ }
+
+ void init_instance() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ VkInstanceCreateInfo info = VkInstanceCreateInfo.create(frame,
+ 0,
+ VkApplicationInfo.create(frame, "cube", 1, "cube-engine", 2, VK_API_VERSION_1_0),
+ new String[]{"VK_LAYER_KHRONOS_validation"},
+ new String[]{"VK_KHR_surface", "VK_KHR_xlib_surface", "VK_EXT_debug_utils"}
+ );
+
+ instance = VkInstance.vkCreateInstance(info, scope);
+ System.out.printf("instance = %s\n", instance);
+ }
+ }
+
+ Display display;
+ Window window;
+ VkSurfaceKHR surface;
+
+ void init_surface() throws Exception {
+ display = Display.createX11Display();
+ window = display.createWindow(width, height);
+ surface = window.createVulkanSurface(instance, scope);
+ System.out.printf("surface: %s\n", surface);
+ }
+
+ void init_device() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ IntArray count$h = IntArray.create(frame, 1);
+ IntArray present$h = IntArray.create(frame, 1);
+ HandleArray<VkPhysicalDevice> devs;
+ int count;
+ int res;
+
+ devs = instance.vkEnumeratePhysicalDevices(frame, scope);
+
+ // Search for device and queue indices
+ int devid = -1;
+ int present_queue = -1;
+ int graphics_queue = -1;
+ for (int i = 0; i < devs.length(); i++) {
+ VkPhysicalDevice dev = devs.getAtIndex(i);
+ VkQueueFamilyProperties famprops;
+
+ famprops = dev.vkGetPhysicalDeviceQueueFamilyProperties(frame);
+
+ for (int j = 0; j < famprops.length(); j++) {
+ boolean present;
+
+ dev.vkGetPhysicalDeviceSurfaceSupportKHR(j, surface, present$h);
+ present = present$h.get(0) != 0;
+
+ if (present && present_queue == -1)
+ present_queue = j;
+ if ((famprops.getQueueFlagsAtIndex(j) & VK_QUEUE_GRAPHICS_BIT) != 0) {
+ graphics_queue = j;
+ if (present) {
+ present_queue = j;
+ break;
+ }
+ }
+ }
+ if (present_queue != -1 && graphics_queue != -1) {
+ devid = i;
+ break;
+ }
+ }
+
+ if (devid == -1)
+ throw new Exception("Cannot find a suitable device");
+
+ physicalDevice = devs.getAtIndex(devid);
+ present_queue_index = present_queue;
+ graphics_queue_index = graphics_queue;
+
+ // NOTE: app scope
+ memory_properties = VkPhysicalDeviceMemoryProperties.create((SegmentAllocator)scope);
+ physicalDevice.vkGetPhysicalDeviceMemoryProperties(memory_properties);
+ device_features = VkPhysicalDeviceFeatures.create((SegmentAllocator)scope);
+ physicalDevice.vkGetPhysicalDeviceFeatures(device_features);
+
+ FloatArray qpri = FloatArray.create(frame, 0.0f);
+ VkDeviceQueueCreateInfo qinfo = VkDeviceQueueCreateInfo.create(
+ frame,
+ 0,
+ graphics_queue,
+ qpri);
+ String[] extensions = {
+ "VK_KHR_swapchain"
+ };
+ VkPhysicalDeviceFeatures features = VkPhysicalDeviceFeatures.create(frame);
+ features.setDepthClamp(1);
+ VkDeviceCreateInfo devinfo = VkDeviceCreateInfo.create(
+ frame,
+ 0,
+ qinfo,
+ null,
+ extensions,
+ features);
+
+ device = physicalDevice.vkCreateDevice(devinfo, scope);
+
+ System.out.printf("device = %s\n", device);
+
+ /* ************************************************************** */
+ int format;
+ VkSurfaceFormatKHR surfFormats = physicalDevice.vkGetPhysicalDeviceSurfaceFormatsKHR(surface, frame);
+ // If the format list includes just one entry of VK_FORMAT_UNDEFINED,
+ // the surface has no preferred format. Otherwise, at least one
+ // supported format will be returned.
+ if (surfFormats.length() == 1 && surfFormats.getFormatAtIndex(0) == VK_FORMAT_UNDEFINED) {
+ format = VK_FORMAT_B8G8R8A8_UNORM;
+ } else {
+ format = surfFormats.getFormatAtIndex(0);
+ }
+
+ VkSurfaceCapabilitiesKHR surfCapabilities = VkSurfaceCapabilitiesKHR.create(frame);
+
+ physicalDevice.vkGetPhysicalDeviceSurfaceCapabilitiesKHR(surface, surfCapabilities);
+ IntArray presentModes = physicalDevice.vkGetPhysicalDeviceSurfacePresentModesKHR(surface, frame);
+
+ VkExtent2D swapchainExtent;
+ // width and height are either both 0xFFFFFFFF, or both not 0xFFFFFFFF.
+ if (surfCapabilities.getCurrentExtent().getWidth() == 0xFFFFFFFF) {
+ // If the surface size is undefined, the size is set to
+ // the size of the images requested.
+ swapchainExtent = VkExtent2D.create(frame,
+ clampi(width, surfCapabilities.getMinImageExtent().getWidth(), surfCapabilities.getMaxImageExtent().getWidth()),
+ clampi(height, surfCapabilities.getMinImageExtent().getHeight(), surfCapabilities.getMaxImageExtent().getHeight()));
+ } else {
+ // If the surface size is defined, the swap chain size must match
+ swapchainExtent = surfCapabilities.getCurrentExtent();
+ }
+ int compositeAlpha = VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR;
+ int compositeAlphaFlags[] = {
+ VK_COMPOSITE_ALPHA_OPAQUE_BIT_KHR,
+ VK_COMPOSITE_ALPHA_PRE_MULTIPLIED_BIT_KHR,
+ VK_COMPOSITE_ALPHA_POST_MULTIPLIED_BIT_KHR,
+ VK_COMPOSITE_ALPHA_INHERIT_BIT_KHR,};
+ for (int flag: compositeAlphaFlags) {
+ if ((surfCapabilities.getSupportedCompositeAlpha() & flag) != 0) {
+ compositeAlpha = flag;
+ break;
+ }
+ }
+
+ VkSwapchainCreateInfoKHR chaininfo = VkSwapchainCreateInfoKHR.create(frame,
+ 0,
+ surface,
+ surfCapabilities.getMinImageCount(),
+ format,
+ VK_COLOR_SPACE_SRGB_NONLINEAR_KHR,
+ 1, //.imageArrayLayers = 1,
+ VK_IMAGE_USAGE_COLOR_ATTACHMENT_BIT,
+ VK_SHARING_MODE_EXCLUSIVE,
+ // assumes queues are same.
+ null,
+ (surfCapabilities.getSupportedTransforms() & VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR) != 0
+ ? VK_SURFACE_TRANSFORM_IDENTITY_BIT_KHR : surfCapabilities.getCurrentTransform(),
+ compositeAlpha,
+ VK_PRESENT_MODE_FIFO_KHR,
+ VK_TRUE,
+ null);
+ chaininfo.getImageExtent().setWidth(swapchainExtent.getWidth());
+ chaininfo.getImageExtent().setHeight(swapchainExtent.getHeight());
+
+ chain = device.vkCreateSwapchainKHR(chaininfo, scope);
+
+ int chainImageCount;
+
+ chainImage = device.vkGetSwapchainImagesKHR(chain, (SegmentAllocator)scope);
+ chainImageCount = (int)chainImage.length();
+ chainImageView = VkImageView.createArray(chainImageCount, (SegmentAllocator)scope);
+
+ VkImageViewCreateInfo viewinfo = VkImageViewCreateInfo.create(frame,
+ 0,
+ null,
+ VK_IMAGE_VIEW_TYPE_2D,
+ format);
+ VkComponentMapping components = viewinfo.getComponents();
+ components.setR(VK_COMPONENT_SWIZZLE_R);
+ components.setG(VK_COMPONENT_SWIZZLE_G);
+ components.setB(VK_COMPONENT_SWIZZLE_B);
+ components.setA(VK_COMPONENT_SWIZZLE_A);
+ VkImageSubresourceRange subresourceRange = viewinfo.getSubresourceRange();
+ subresourceRange.setAspectMask(VK_IMAGE_ASPECT_COLOR_BIT);
+ subresourceRange.setLevelCount(1);
+ subresourceRange.setLayerCount(1);
+
+ for (int i = 0; i < chainImageCount; i++) {
+ viewinfo.setImage(chainImage.get(i));
+
+ chainImageView.setAtIndex(i, device.vkCreateImageView(viewinfo, scope));
+ }
+
+ chainImageFormat = format;
+ }
+ }
+
+ void init_device_queue() {
+ graphics_queue = device.vkGetDeviceQueue(graphics_queue_index, 0, scope);
+ if (graphics_queue_index == present_queue_index) {
+ present_queue = graphics_queue;
+ } else {
+ present_queue = device.vkGetDeviceQueue(present_queue_index, 0, scope);
+ }
+ }
+
+ void init_command() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ VkCommandPoolCreateInfo poolinfo = VkCommandPoolCreateInfo.create(frame,
+ 0,
+ graphics_queue_index);
+
+ cmd_pool = device.vkCreateCommandPool(poolinfo, scope);
+
+ VkCommandBufferAllocateInfo cmdinfo = VkCommandBufferAllocateInfo.create(frame,
+ cmd_pool,
+ VK_COMMAND_BUFFER_LEVEL_PRIMARY,
+ 1);
+
+ cmd = device.vkAllocateCommandBuffers(cmdinfo, (SegmentAllocator)scope, scope);
+ }
+ }
+
+ // parameterise as init_image?
+ void init_depth() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ int format = VK_FORMAT_D16_UNORM;
+ VkMemoryRequirements req = VkMemoryRequirements.create(frame);
+ VkImageCreateInfo imageinfo = VkImageCreateInfo.create(frame, 0,
+ VK_IMAGE_TYPE_2D,
+ format,
+ 1,
+ 1,
+ NUM_SAMPLES,
+ 0,
+ VK_IMAGE_USAGE_DEPTH_STENCIL_ATTACHMENT_BIT,
+ VK_SHARING_MODE_EXCLUSIVE,
+ null,
+ VK_IMAGE_LAYOUT_UNDEFINED);
+ imageinfo.getExtent().setWidth(width);
+ imageinfo.getExtent().setHeight(height);
+ imageinfo.getExtent().setDepth(1);
+
+ depthImage = device.vkCreateImage(imageinfo, scope);
+
+ device.vkGetImageMemoryRequirements(depthImage, req);
+ VkMemoryAllocateInfo alloc = VkMemoryAllocateInfo.create(frame,
+ req.getSize(),
+ find_memory_type(memory_properties, req.getMemoryTypeBits(), VK_MEMORY_PROPERTY_DEVICE_LOCAL_BIT));
+
+ depthMemory = device.vkAllocateMemory(alloc, scope);
+
+ device.vkBindImageMemory(depthImage, depthMemory, 0);
+
+ VkImageViewCreateInfo viewinfo = VkImageViewCreateInfo.create(frame, 0,
+ depthImage,
+ VK_IMAGE_VIEW_TYPE_2D,
+ VK_FORMAT_D16_UNORM);
+
+ VkComponentMapping components = viewinfo.getComponents();
+ components.setR(VK_COMPONENT_SWIZZLE_R);
+ components.setG(VK_COMPONENT_SWIZZLE_G);
+ components.setB(VK_COMPONENT_SWIZZLE_B);
+ components.setA(VK_COMPONENT_SWIZZLE_A);
+ VkImageSubresourceRange subresourceRange = viewinfo.getSubresourceRange();
+ subresourceRange.setAspectMask(VK_IMAGE_ASPECT_DEPTH_BIT);
+ subresourceRange.setLevelCount(1);
+ subresourceRange.setLayerCount(1);
+
+ depthView = device.vkCreateImageView(viewinfo, scope);
+
+ depthFormat = format;
+ }
+ }
+
+ void init_uniform() throws Exception {
+ uniform = init_buffer(mvp.length * 4, VK_BUFFER_USAGE_UNIFORM_BUFFER_BIT, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, MemorySegment.ofArray(mvp));
+ }
+
+ void init_descriptor() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ HandleArray<VkDescriptorSetLayout> layout_table = VkDescriptorSetLayout.createArray(1, frame);
+ VkDescriptorSetLayoutBinding layout_binding = VkDescriptorSetLayoutBinding.create(frame,
+ 0,
+ VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
+ 1,
+ VK_SHADER_STAGE_VERTEX_BIT,
+ null);
+ VkDescriptorSetLayoutCreateInfo descriptor_layout = VkDescriptorSetLayoutCreateInfo.create(frame,
+ 0,
+ layout_binding);
+
+ desc_layout = device.vkCreateDescriptorSetLayout(descriptor_layout, scope);
+ layout_table.setAtIndex(0, desc_layout);
+
+ VkPipelineLayoutCreateInfo pipeline_info = VkPipelineLayoutCreateInfo.create(frame,
+ 0,
+ //1,
+ layout_table,
+ null);
+
+ pipeline_layout = device.vkCreatePipelineLayout(pipeline_info, scope);
+
+ VkDescriptorPoolSize type_count = VkDescriptorPoolSize.create(frame,
+ VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
+ 1);
+
+ VkDescriptorPoolCreateInfo descriptor_pool = VkDescriptorPoolCreateInfo.create(frame,
+ 0,
+ 1,
+ type_count);
+
+ desc_pool = device.vkCreateDescriptorPool(descriptor_pool, scope);
+
+ VkDescriptorSetAllocateInfo alloc_info = VkDescriptorSetAllocateInfo.create(frame,
+ desc_pool,
+ //1,
+ layout_table);
+
+ System.out.println(alloc_info);
+
+ desc_set = device.vkAllocateDescriptorSets(alloc_info, (SegmentAllocator)scope);
+
+ VkDescriptorBufferInfo uniformInfo = VkDescriptorBufferInfo.create(frame, uniform.buffer, 0, uniform.size);
+ VkWriteDescriptorSet writes = VkWriteDescriptorSet.create(frame,
+ desc_set.getAtIndex(0),
+ 0,
+ 0,
+ 1,
+ VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER,
+ null,
+ uniformInfo,
+ null);
+
+ device.vkUpdateDescriptorSets(1, writes, 0, null);
+ }
+ }
+
+ void init_render() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ VkAttachmentDescription attachments = VkAttachmentDescription.createArray(2, frame);
+
+ attachments.setFormat(chainImageFormat);
+ attachments.setSamples(NUM_SAMPLES);
+ attachments.setLoadOp(VK_ATTACHMENT_LOAD_OP_CLEAR);
+ attachments.setStoreOp(VK_ATTACHMENT_STORE_OP_STORE);
+ attachments.setStencilLoadOp(VK_ATTACHMENT_LOAD_OP_DONT_CARE);
+ attachments.setStencilStoreOp(VK_ATTACHMENT_STORE_OP_DONT_CARE);
+ attachments.setInitialLayout(VK_IMAGE_LAYOUT_UNDEFINED);
+ attachments.setFinalLayout(VK_IMAGE_LAYOUT_PRESENT_SRC_KHR);
+ attachments.setFlags(0);
+
+ attachments.setFormatAtIndex(1, depthFormat);
+ attachments.setSamplesAtIndex(1, NUM_SAMPLES);
+ attachments.setLoadOpAtIndex(1, VK_ATTACHMENT_LOAD_OP_CLEAR);
+ attachments.setStoreOpAtIndex(1, VK_ATTACHMENT_STORE_OP_STORE);
+ attachments.setStencilLoadOpAtIndex(1, VK_ATTACHMENT_LOAD_OP_DONT_CARE);
+ attachments.setStencilStoreOpAtIndex(1, VK_ATTACHMENT_STORE_OP_DONT_CARE);
+ attachments.setInitialLayoutAtIndex(1, VK_IMAGE_LAYOUT_UNDEFINED);
+ attachments.setFinalLayoutAtIndex(1, VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL);
+ attachments.setFlagsAtIndex(1, 0);
+
+ VkAttachmentReference color_reference = VkAttachmentReference.create(frame,
+ 0,
+ VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL);
+
+ VkAttachmentReference depth_reference = VkAttachmentReference.create(frame,
+ 1,
+ VK_IMAGE_LAYOUT_DEPTH_STENCIL_ATTACHMENT_OPTIMAL);
+
+ VkSubpassDescription subpass = VkSubpassDescription.create(frame,
+ 0,
+ VK_PIPELINE_BIND_POINT_GRAPHICS,
+ null,
+ 1,
+ color_reference,
+ null,
+ depth_reference,
+ null);
+
+ VkRenderPassCreateInfo rp_info = VkRenderPassCreateInfo.create(frame,
+ 0,
+ //(int)attachments.length(),
+ attachments,
+ subpass,
+ null);
+
+ render_pass = device.vkCreateRenderPass(rp_info, scope);
+ }
+ }
+
+ void init_framebuffer() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ HandleArray<VkImageView> attachments = VkImageView.createArray(2, frame);
+
+ attachments.setAtIndex(1, depthView);
+
+ // FIXME: I don't think i want lenghts implied for types tbh
+ VkFramebufferCreateInfo fb_info = VkFramebufferCreateInfo.create(frame,
+ 0,
+ render_pass,
+ //2,
+ attachments,
+ width,
+ height,
+ 1);
+
+ framebuffers = VkFramebuffer.createArray(chainImage.length(), (SegmentAllocator)scope);
+ for (int i = 0; i < chainImage.size(); i++) {
+ attachments.setAtIndex(0, chainImageView.get(i));
+ framebuffers.setAtIndex(i, device.vkCreateFramebuffer(fb_info, scope));
+ System.out.printf("framebuffer[%d] = %s\n", i, framebuffers.getAtIndex(i));
+ }
+ }
+ }
+
+ void init_vertexbuffer() throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ float[] image = {
+ -1, -1, 0, 1,
+ 1, -1, 0, 1,
+ -1, 1, 0, 1,
+ -1, 1, 0, 1,
+ 1, -1, 0, 1,
+ 1, 1, 0, 1
+ // 1, -1, 0, 1,
+ // -1, 1, 0, 1,
+ // 1, 1, 0, 1
+ };
+ vertex = init_buffer(image.length * 4, VK_BUFFER_USAGE_VERTEX_BUFFER_BIT, VK_MEMORY_PROPERTY_HOST_VISIBLE_BIT | VK_MEMORY_PROPERTY_HOST_COHERENT_BIT, MemorySegment.ofArray(image));
+
+ vertexBuffer.setAtIndex(0, vertex.buffer);
+
+ /* ***************************************** */
+ vi_binding.setBinding(0);
+ vi_binding.setInputRate(VK_VERTEX_INPUT_RATE_VERTEX);
+ vi_binding.setStride(4 * 4);
+
+ vi_attribs.setBinding(0);
+ vi_attribs.setLocation(0);
+ vi_attribs.setFormat(VK_FORMAT_R32G32B32A32_SFLOAT);
+ vi_attribs.setOffset(0);
+ //vi_attribs.setBindingAtIndex(1, 0);
+ //vi_attribs.setLocationAtIndex(1, 1);
+ //vi_attribs.setFormatAtIndex(1, VK_FORMAT_R32G32B32A32_SFLOAT);
+ //vi_attribs.setOffsetAtIndex(1, 16);
+ }
+ }
+
+ void init_pipeline() throws Exception {
+ int res;
+ try ( Frame frame = Frame.frame()) {
+ IntArray dynamicStateEnables = IntArray.create(frame,
+ VK_DYNAMIC_STATE_VIEWPORT,
+ VK_DYNAMIC_STATE_SCISSOR);
+
+ VkPipelineDynamicStateCreateInfo dynamicState = VkPipelineDynamicStateCreateInfo.create(frame,
+ 0, dynamicStateEnables);
+
+ VkPipelineVertexInputStateCreateInfo vi = VkPipelineVertexInputStateCreateInfo.create(frame,
+ 0,
+ vi_binding,
+ vi_attribs);
+
+ VkPipelineInputAssemblyStateCreateInfo ia = VkPipelineInputAssemblyStateCreateInfo.create(frame,
+ 0,
+ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST,
+ 0);
+
+ VkPipelineRasterizationStateCreateInfo rs = VkPipelineRasterizationStateCreateInfo.create(frame,
+ 0,
+ VK_TRUE,
+ VK_FALSE,
+ VK_POLYGON_MODE_FILL,
+ VK_CULL_MODE_BACK_BIT,
+ VK_FRONT_FACE_CLOCKWISE,
+ VK_FALSE,
+ 0.0f,
+ 0.0f,
+ 0.0f,
+ 1.0f);
+
+ VkPipelineColorBlendAttachmentState att_state = VkPipelineColorBlendAttachmentState.create(frame,
+ VK_FALSE,
+ VK_BLEND_FACTOR_ZERO,
+ VK_BLEND_FACTOR_ZERO,
+ VK_BLEND_OP_ADD,
+ VK_BLEND_FACTOR_ZERO,
+ VK_BLEND_FACTOR_ZERO,
+ VK_BLEND_OP_ADD,
+ 0xf);
+
+ VkPipelineColorBlendStateCreateInfo cb = VkPipelineColorBlendStateCreateInfo.create(frame,
+ 0,
+ VK_FALSE,
+ VK_LOGIC_OP_NO_OP,
+ att_state,
+ 1.0f, 1.0f, 1.0f, 1.0f);
+
+ VkPipelineViewportStateCreateInfo vp = VkPipelineViewportStateCreateInfo.create(frame,
+ 0,
+ 1, null,
+ 1, null);
+
+ VkPipelineDepthStencilStateCreateInfo ds = VkPipelineDepthStencilStateCreateInfo.create(frame,
+ 0,
+ VK_TRUE,
+ VK_TRUE,
+ VK_COMPARE_OP_LESS_OR_EQUAL,
+ VK_FALSE,
+ VK_FALSE,
+ 0.0f,
+ 0.0f);
+ VkStencilOpState back = ds.getBack();
+
+ back.setFailOp(VK_STENCIL_OP_KEEP);
+ back.setPassOp(VK_STENCIL_OP_KEEP);
+ back.setCompareOp(VK_COMPARE_OP_ALWAYS);
+ back.setCompareMask(0);
+ back.setReference(0);
+ back.setDepthFailOp(VK_STENCIL_OP_KEEP);
+ back.setWriteMask(0);
+
+ VkStencilOpState front = ds.getFront();
+
+ front.setFailOp(VK_STENCIL_OP_KEEP);
+ front.setPassOp(VK_STENCIL_OP_KEEP);
+ front.setCompareOp(VK_COMPARE_OP_ALWAYS);
+ front.setCompareMask(0);
+ front.setReference(0);
+ front.setDepthFailOp(VK_STENCIL_OP_KEEP);
+ front.setWriteMask(0);
+
+ VkPipelineMultisampleStateCreateInfo ms = VkPipelineMultisampleStateCreateInfo.create(frame,
+ 0,
+ NUM_SAMPLES,
+ 0, //.sampleShadingEnable = VK_FALSE,
+ 0.0f,
+ null,
+ 0, //.alphaToCoverageEnable = VK_FALSE,
+ 0 //.alphaToOneEnable = VK_FALSE,
+ );
+
+ VkShaderModuleCreateInfo vsInfo = VkShaderModuleCreateInfo.create(frame,
+ 0,
+ sdf_vs.length() * 4,
+ sdf_vs);
+ VkShaderModuleCreateInfo fsInfo = VkShaderModuleCreateInfo.create(frame,
+ 0,
+ sdf_fs.length() * 4,
+ sdf_fs);
+
+ shader.setAtIndex(0, device.vkCreateShaderModule(vsInfo, scope));
+ shader.setAtIndex(1, device.vkCreateShaderModule(fsInfo, scope));
+
+ VkPipelineShaderStageCreateInfo shaderStages = VkPipelineShaderStageCreateInfo.createArray(2, (SegmentAllocator)scope);
+
+ // FIXME: createArray should initialise this
+ shaderStages.setSType(VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO);
+ shaderStages.setStage(VK_SHADER_STAGE_VERTEX_BIT);
+ shaderStages.setName("main", (SegmentAllocator)scope);
+ shaderStages.setModule(shader.get(0));
+
+ shaderStages.setSTypeAtIndex(1, VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO);
+ shaderStages.setStageAtIndex(1, VK_SHADER_STAGE_FRAGMENT_BIT);
+ shaderStages.setNameAtIndex(1, "main", (SegmentAllocator)scope);
+ shaderStages.setModuleAtIndex(1, shader.get(1));
+
+ VkGraphicsPipelineCreateInfo pipeline = VkGraphicsPipelineCreateInfo.create(frame,
+ 0,
+ //2, shaderStages,
+ shaderStages,
+ vi,
+ ia,
+ null,
+ vp,
+ rs,
+ ms,
+ ds,
+ cb,
+ dynamicState,
+ pipeline_layout,
+ render_pass,
+ 0,
+ null,
+ 0);
+
+ res = device.vkCreateGraphicsPipelines(null, 1, pipeline, this.pipeline);
+
+ VkSemaphoreCreateInfo seminfo = VkSemaphoreCreateInfo.create(frame, 0);
+ chainSemaphore = device.vkCreateSemaphore(seminfo, scope);
+
+ VkFenceCreateInfo fenceInfo = VkFenceCreateInfo.create(frame, 0);
+ drawFence = device.vkCreateFence(fenceInfo, scope);
+ }
+ }
+
+ void execute_begin_command_buffer() throws Exception {
+ /* DEPENDS on init_command() */
+ try ( Frame frame = Frame.frame()) {
+ VkCommandBufferBeginInfo cmd_buf_info = VkCommandBufferBeginInfo.create(frame,
+ 0,
+ null);
+
+ cmd.getAtIndex(0).vkBeginCommandBuffer(cmd_buf_info);
+ }
+ }
+
+ void execute_end_command_buffer() throws Exception {
+ cmd.getAtIndex(0).vkEndCommandBuffer();
+ }
+
+ final static long FENCE_TIMEOUT = 100000000;
+
+ void execute_queue_command_buffer() throws Exception {
+ int res;
+
+ /* Queue the command buffer for execution */
+ /* FIXME: frame shoudl provide or take explicit scope */
+ try ( ResourceScope scope = ResourceScope.newConfinedScope(); Frame frame = Frame.frame()) {
+ IntArray pipe_stage_flags = IntArray.create(frame, VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT);
+ VkFenceCreateInfo fenceInfo = VkFenceCreateInfo.create(frame, 0);
+ HandleArray<VkFence> fences = VkFence.createArray(1, frame);
+
+ fences.setAtIndex(0, device.vkCreateFence(fenceInfo, scope));
+
+ VkSubmitInfo submit_info = VkSubmitInfo.create(frame,
+ 1, null, pipe_stage_flags,
+ cmd,
+ null);
+
+ graphics_queue.vkQueueSubmit(1, submit_info, drawFence);
+
+ do {
+ res = device.vkWaitForFences(1, fences, 1, FENCE_TIMEOUT);
+ } while (res == VK_TIMEOUT);
+
+ device.vkDestroyFence(fences.getAtIndex(0));
+ }
+ }
+
+ void cmd_viewport() {
+ try ( Frame frame = Frame.frame()) {
+ VkCommandBuffer cmd = this.cmd.getAtIndex(0);
+ VkViewport viewport = VkViewport.create(frame,
+ 0, 0, width, height, 0.0f, 1.0f);
+ cmd.vkCmdSetViewport(0, 1, viewport);
+ }
+ }
+
+ void cmd_scissors() {
+ try ( Frame frame = Frame.frame()) {
+ VkCommandBuffer cmd = this.cmd.getAtIndex(0);
+ VkRect2D scissor = VkRect2D.create(frame);
+ VkExtent2D extent = scissor.getExtent();
+
+ extent.setWidth(width);
+ extent.setHeight(height);
+
+ cmd.vkCmdSetScissor(0, 1, scissor);
+ }
+ }
+
+ void cmd_paint() throws Exception {
+ int res;
+ try ( Frame frame = Frame.frame()) {
+ int chainIndex;
+ IntArray chainIndices = IntArray.createArray(1, frame);
+ VkCommandBuffer cmd = this.cmd.getAtIndex(0);
+
+ device.vkAcquireNextImageKHR(chain, ~0L, chainSemaphore, null, chainIndices);
+ chainIndex = chainIndices.getAtIndex(0);
+ LongArray offsets = LongArray.createArray(1, frame);
+
+ VkClearValue clear_values = VkClearValue.createArray(2, frame);
+ FloatArray col = clear_values.getColor().getFloat32();
+ col.setAtIndex(0, 0.2f);
+ col.setAtIndex(1, 0.2f);
+ col.setAtIndex(2, 0.2f);
+ col.setAtIndex(3, 0.2f);
+ VkClearDepthStencilValue depthStencil = clear_values.getAtIndex(1).getDepthStencil();
+ depthStencil.setDepth(1.0f);
+ depthStencil.setStencil(0);
+
+ System.out.printf("render framebuffer[%d] = %s\n", chainIndex, framebuffers.getAtIndex(chainIndex));
+
+ VkRenderPassBeginInfo rp_begin = VkRenderPassBeginInfo.create(frame,
+ render_pass,
+ framebuffers.getAtIndex(chainIndex),
+ clear_values);
+ VkExtent2D extent = rp_begin.getRenderArea().getExtent();
+ extent.setWidth(width);
+ extent.setHeight(height);
+
+ cmd.vkCmdBeginRenderPass(rp_begin, VK_SUBPASS_CONTENTS_INLINE);
+
+ cmd.vkCmdBindPipeline(VK_PIPELINE_BIND_POINT_GRAPHICS, pipeline.getAtIndex(0));
+ cmd.vkCmdBindDescriptorSets(VK_PIPELINE_BIND_POINT_GRAPHICS, pipeline_layout, 0, NUM_DESCRIPTOR_SETS, desc_set, 0, null);
+ cmd.vkCmdBindVertexBuffers(0, 1, vertexBuffer, offsets);
+
+ cmd_viewport();
+ cmd_scissors();
+
+ cmd.vkCmdDraw(12 * 3, 1, 0, 0);
+ cmd.vkCmdEndRenderPass();
+
+ cmd.vkEndCommandBuffer();
+
+ IntArray pipe_stage_flags = IntArray.create(frame, VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT);
+ HandleArray<VkSemaphore> semaphores = VkSemaphore.createArray(1, frame);//, chainSemaphore, scope);
+
+ semaphores.setAtIndex(0, chainSemaphore);
+
+ VkSubmitInfo submit_info = VkSubmitInfo.create(frame,
+ 1, semaphores, pipe_stage_flags,
+ this.cmd,
+ null);
+
+ HandleArray<VkFence> fences = VkFence.createArray(1, frame);
+
+ fences.setAtIndex(0, drawFence);
+
+ // Queue the command buffer for execution
+ device.vkResetFences(1, fences);
+
+ graphics_queue.vkQueueSubmit(1, submit_info, drawFence);
+
+ // Make sure command buffer is finished before presenting
+ do {
+ res = device.vkWaitForFences(1, fences, VK_TRUE, FENCE_TIMEOUT);
+ } while (res == VK_TIMEOUT);
+
+ // Now present the image in the window
+ HandleArray<VkSwapchainKHR> chains = VkSwapchainKHR.createArray(1, frame);
+ chains.setAtIndex(0, chain);
+ VkPresentInfoKHR present = VkPresentInfoKHR.create(frame,
+ null,
+ 1,
+ chains,
+ chainIndices,
+ null);
+
+ present_queue.vkQueuePresentKHR(present);
+ }
+ }
+
+ /**
+ * Buffers are created in three steps:
+ * 1) create buffer, specifying usage and size
+ * 2) allocate memory based on memory requirements
+ * 3) bind memory
+ * <p>
+ */
+ BufferMemory init_buffer(long dataSize, int usage, int properties, MemorySegment init) throws Exception {
+ try ( Frame frame = Frame.frame()) {
+ VkMemoryRequirements req = VkMemoryRequirements.create(frame);
+ VkBufferCreateInfo buf_info = VkBufferCreateInfo.create(frame,
+ 0,
+ dataSize,
+ usage,
+ VK_SHARING_MODE_EXCLUSIVE,
+ //0,
+ null);
+
+ VkBuffer buffer = device.vkCreateBuffer(buf_info, scope);
+
+ device.vkGetBufferMemoryRequirements(buffer, req);
+
+ VkMemoryAllocateInfo alloc = VkMemoryAllocateInfo.create(frame,
+ req.getSize(),
+ find_memory_type(memory_properties, req.getMemoryTypeBits(), properties));
+
+ VkDeviceMemory memory = device.vkAllocateMemory(alloc, scope);
+
+ if (init != null) {
+ MemorySegment mem = device.vkMapMemory(memory, 0, dataSize, 0, scope);
+ mem.copyFrom(init);
+ device.vkUnmapMemory(memory);
+ }
+
+ device.vkBindBufferMemory(buffer, memory, 0);
+
+ return new BufferMemory(buffer, memory, dataSize);
+ }
+ }
+
+ void shutdown() {
+ device.vkDestroyFence(drawFence);
+ device.vkDestroySemaphore(chainSemaphore);
+
+ device.vkDestroyPipeline(pipeline.getAtIndex(0));
+ for (int i = 0; i < shader.size(); i++)
+ device.vkDestroyShaderModule(shader.getAtIndex(i));
+
+ vertex.free(device);
+ uniform.free(device);
+
+ for (int i = 0; i < framebuffers.size(); i++)
+ device.vkDestroyFramebuffer(framebuffers.getAtIndex(i));
+
+ device.vkDestroyRenderPass(render_pass);
+
+ device.vkDestroyDescriptorPool(desc_pool);
+ device.vkDestroyPipelineLayout(pipeline_layout);
+ device.vkDestroyDescriptorSetLayout(desc_layout);
+
+ device.vkDestroyImageView(depthView);
+ device.vkFreeMemory(depthMemory);
+ device.vkDestroyImage(depthImage);
+
+ for (int i = 0; i < chainImageView.size(); i++)
+ device.vkDestroyImageView(chainImageView.getAtIndex(i));
+
+ device.vkDestroySwapchainKHR(chain);
+
+ device.vkDestroyCommandPool(cmd_pool);
+ device.vkDestroyDevice();
+
+ instance.vkDestroySurfaceKHR(surface);
+ window.close();
+ display.close();
+
+ if (logger != null)
+ instance.vkDestroyDebugUtilsMessengerEXT(logger);
+ instance.vkDestroyInstance();
+ }
+
+ /**
+ * This finds the memory type index for the memory on a specific device.
+ */
+ static int find_memory_type(VkPhysicalDeviceMemoryProperties memory, int typeMask, int query) {
+ VkMemoryType mtypes = memory.getMemoryTypes();
+
+ for (int i = 0; i < memory.getMemoryTypeCount(); i++) {
+ if (((1 << i) & typeMask) != 0 && ((mtypes.getAtIndex(i).getPropertyFlags() & query) == query))
+ return i;
+ }
+ return -1;
+ }
+
+ static int clampi(int v, int min, int max) {
+ return v < min ? min : v < max ? v : max;
+ }
+
+ void init_matrices() {
+ //float eye[] = new float[] {-5, 3, -10};
+ float eye[] = new float[]{0, 0, -10};
+ float centre[] = new float[]{0, 0, 0};
+ float up[] = new float[]{0, -1, 0};
+ float t0[] = new float[16], t1[] = new float[16];
+
+ perspective(projection, (float)(Math.PI * 0.25), 1.0f, 0.1f, 100.0f);
+ lookAt(view, eye, centre, up);
+ identity4f(model);
+ mult4x4f(t0, clip, projection);
+ mult4x4f(t1, t0, view);
+ mult4x4f(mvp, t1, model);
+ }
+
+ void demo() throws Exception {
+ sdf_vs = ShaderIO.loadSdf_vs((SegmentAllocator)scope);
+ sdf_fs = ShaderIO.loadSdf_fs((SegmentAllocator)scope);
+
+ init_matrices();
+
+ init_instance();
+ init_debug();
+
+ init_surface();
+ init_device();
+ init_device_queue();
+ init_command();
+ init_depth();
+ init_uniform();
+
+ init_descriptor();
+ init_render();
+ init_framebuffer();
+ init_vertexbuffer();
+ init_pipeline();
+
+ execute_begin_command_buffer();
+
+ cmd_paint();
+
+ System.out.println("Any key to quit");
+ Event e;
+outer: while ((e = window.nextEvent(true)) != null) {
+ switch (e.type) {
+ case Event.KEY:
+ case Event.CLOSE:
+ break outer;
+ }
+ }
+
+ shutdown();
+ }
+
+ public static void main(String[] args) throws Throwable {
+ System.loadLibrary("vulkan");
+ System.loadLibrary("X11");
+
+ new TestSDF().demo();
+ }
+}
bin/modules/notzed.vulkan.test/vulkan/test/cube_fs.bin: src/notzed.vulkan.test/gen/cube.frag
mkdir -p $(@D)
glslangValidator --target-env vulkan1.0 -V -o $@ $<
+
+bin/modules/notzed.vulkan.test/vulkan/test/sdf_vs.bin: src/notzed.vulkan.test/gen/sdf.vert
+ mkdir -p $(@D)
+ glslangValidator --target-env vulkan1.0 -V -o $@ $<
+
+bin/modules/notzed.vulkan.test/vulkan/test/sdf_fs.bin: src/notzed.vulkan.test/gen/sdf.frag
+ mkdir -p $(@D)
+ glslangValidator --target-env vulkan1.0 -V -o $@ $<
+
+bin/status/notzed.vulkan.test.classes: \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/ShaderIO.java
+
+# Note: different to above, in classes dir for netbeans to find
+notzed.vulkan.test_SHADERS = \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/mandelbrot.bin \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/cube_vs.bin \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/cube_fs.bin \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/sdf_vs.bin \
+ bin/gen/notzed.vulkan.test/classes/vulkan/test/sdf_fs.bin
+
+bin/gen/notzed.vulkan.test/classes/vulkan/test/ShaderIO.java: $(notzed.vulkan.test_SHADERS) src/notzed.vulkan.test/gen/generate-shaderio
+ src/notzed.vulkan.test/gen/generate-shaderio $@ $(notzed.vulkan.test_SHADERS)
+
+bin/gen/notzed.vulkan.test/classes/vulkan/test/%: bin/modules/notzed.vulkan.test/vulkan/test/%
+ install -D $< $@
--- /dev/null
+#!/usr/bin/perl
+
+# probably should take scope
+
+use strict;
+
+use File::Path qw(make_path);
+use File::Basename;
+
+my $path = shift;
+
+open my $f, ">", $path || die;
+
+print $f <<END;
+package vulkan.test;
+
+import au.notzed.nativez.IntArray;
+import au.notzed.nativez.Memory;
+import java.io.IOException;
+import java.io.InputStream;
+import java.nio.channels.Channels;
+import jdk.incubator.foreign.MemorySegment;
+import jdk.incubator.foreign.SegmentAllocator;
+
+public class ShaderIO {
+ static IntArray loadSPIRV(String name, long size, SegmentAllocator alloc) throws IOException {
+ try ( InputStream is = TestMandelbrot.class.getResourceAsStream(name)) {
+ MemorySegment seg = alloc.allocateArray(Memory.INT, size);
+ int length = Channels.newChannel(is).read(seg.asByteBuffer());
+ return IntArray.create(seg.asSlice(0, length));
+ }
+ }
+END
+
+while ($#ARGV >= 0) {
+ my $file = shift;
+ my $func = ucfirst(basename($file, '.bin'));
+ my $name = basename($file);
+ my $size = (stat($file))[7];
+
+ print $f "\tstatic IntArray load$func(SegmentAllocator alloc) throws IOException { return loadSPIRV(\"$name\", $size, alloc); }\n";
+}
+
+print $f "}\n";
+
+close $f;
--- /dev/null
+#version 400
+#extension GL_ARB_separate_shader_objects : enable
+#extension GL_ARB_shading_language_420pack : enable
+layout (location = 0) out vec4 outColor;
+
+void main() {
+ vec2 res = vec2(800, 800);
+ vec2 uv = (gl_FragCoord.xy - 0.5 * res) * (1.0 / 400.0);
+
+ float d = max(-(length(uv) - 0.5), length(uv + vec2(0.1, 0.1)) - 0.6);
+
+ if (d < 0) {
+ outColor = vec4(0, 0, 1, 1);
+ } else {
+ outColor = vec4(1, 0, 0, 1);
+ }
+
+
+ //outColor = vec4(1, 0, 1, 1);
+ //outColor = vec4(gl_FragCoord.xy * 1.0 / 500.0, 0, 1);
+}
--- /dev/null
+#version 400
+#extension GL_ARB_separate_shader_objects : enable
+#extension GL_ARB_shading_language_420pack : enable
+
+layout (location = 0) in vec4 pos;
+
+void main() {
+ gl_Position = pos;
+}
}
}
+if (0) {
+ analyseAccessors($api);
+ exit 1;
+}
+
if (0) {
open(my $f, '>', 'types.pm');
print $f Dumper($commandTypes, $structTypes);
die;
}
-exportEnums($vk, $api, 'VkConstants');
+if (0) {
+ open(my $f, '>', 'vk.pm');
+ print $f Dumper($vk);
+ close $f;
+ die;
+}
+
+exportVulkan($vk, $api, $structTypes);
# dump out the extension function-pointer tables
{
# ###################################################################### #
+sub formatStructLayout {
+ my $types = shift;
+ my $s = shift;
+ my $offset = 0;
+ my @fields = ();
+
+ # This doens't need to worry about overrides
+
+ if ($s->{category} eq 'struct') {
+ foreach my $m (@{$s->{items}}) {
+ my $type = $types->{$m->{deref}};
+ my $diff = $m->{bitOffset} - $offset;
+
+ push @fields, "MemoryLayout.paddingLayout($diff)" if $diff;
+
+ if ($type) {
+ my $v = buildVars($s, $m, $type);
+
+ push @fields, code::formatTemplate($v->{layout}, $v).".withName(\"$m->{name}\") /* $m->{deref} $m->{fullType} */";
+ $offset = $m->{bitOffset} + $m->{bitSize};
+ } else {
+ push @fields, "/* Missing: $m->{deref} $m->{name} */";
+ }
+ }
+ } else {
+ foreach my $m (@{$s->{items}}) {
+ my $type = $types->{$m->{deref}};
+
+ if ($type) {
+ my $v = buildVars($s, $m, $type);
+
+ push @fields, code::formatTemplate($v->{layout}, $v).".withName(\"$m->{name}\") /* $m->{deref} $m->{fullType} */";
+ $offset = ($m->{bitOffset} + $m->{bitSize}) if ($m->{bitOffset} + $m->{bitSize}) > $offset;
+ } else {
+ push @fields, "/* Missing: $m->{deref} $m->{name} */";
+ }
+ }
+ }
+
+ my $diff = $s->{bitSize} - $offset;
+
+ push @fields, "MemoryLayout.paddingLayout($diff)" if $diff;
+
+ return "MemoryLayout.".$s->{category}."Layout(\n\t\t".join(",\n\t\t", @fields).").withName(\"$s->{name}\")";
+}
+
+# Experiment: see if sharing varhandles would be of any benefit
+# - analyse all pointer/int fields for cross-overs
+# for vulkan 1.3:
+# Total fields: 3370
+# Unique fields: 368
+# so very significant savings possible
+sub analyseAccessors {
+ my $api = shift;
+ my %handles;
+ my $total;
+ my %lookat;
+
+ map { $lookat{$_} = 1 } qw(Memory.POINTER Memory.BYTE Memory.SHORT Memory.INT Memory.LONG Memory.FLOAT Memory.DOUBLE);
+
+ foreach my $s (values %{$api->{types}}) {
+ my $override = $structTypes->{overrides}->{$s->{name}};
+
+ next if $s->{alias};
+ next if $override->{ignore};
+
+ foreach my $m (@{$s->{items}}) {
+ my $deref = $m->{deref};
+ my $type = $structTypes->{types}->{$deref};
+ my $v = buildVars($s, $m, $type);
+ my $layout = code::formatTemplate($v->{layout}, $v);
+ my $index = $m->{bitOffset} / 8;
+
+ die if ($m->{bitoffset} & ($m->{bitSize}-1));
+
+ if ($lookat{$layout}) {
+ $index = $m->{bitOffset} / $m->{bitSize};
+ }
+
+ my $k = sprintf "$layout \@ %03d", $index;
+
+ $handles{$k}++;
+ $total++;
+ }
+ }
+
+ print "Other unique handles =\n";
+ foreach my $h (sort keys %handles) {
+ $h =~ m/^(.*) \@/;
+ my $x = $lookat{$1};
+ if (!$lookat{$1}) {
+ printf " %5d $h\n", $handles{$h};
+ }
+ }
+ print "Unique handles of interest =\n";
+ foreach my $h (sort keys %handles) {
+ $h =~ m/^(.*) \@/;
+ if ($lookat{$1}) {
+ printf " %5d $h\n", $handles{$h};
+ }
+ }
+ my @keys = keys %handles;
+ print "Total fields: $total\n";
+ print "Unique fields: $#keys\n";
+}
+
+# ###################################################################### #
+
sub loadTypes {
my $api = shift;
my $file = shift;
return grep { !$seen{$_}++ } @_;
}
-sub exportEnums {
+# generate Vulkan.java
+sub exportVulkan {
my $vk = shift;
my $api = shift;
- my $name = shift;
+ my $structTypes = shift;
my $seen = {};
+ my $template = $structTypes->{templates}->{Vulkan};
- my $f = openOutput($sys, $name);
+ my @constants = ();
+ my @defines = ();
- print $f "package vulkan;\npublic interface VkConstants {\n";
-
- # special case for api constants
# special case for api constants
{
my $s = $api->{data}->{'API Constants'};
- print $f "\n\t// API Constants\n";
+ push @constants, "// API Constants\n";
foreach my $m (@{$s->{items}}) {
next if defined($m->{alias});
# convert to java
$v =~ s/[()ULF]+//gon if (!($v =~ m/^"/));
- print $f "\tpublic final static $i->{type} $m->{name} = $v$i->{suffix};\n";
+ push @constants,"public final static $i->{type} $m->{name} = $v$i->{suffix};";
+ }
+ }
+
+ # include any defines we have a template for
+ foreach my $k (sort keys %{$api->{defines}}) {
+ if ($template->{$k}) {
+ push @defines, $template->{$k};
+ } else {
+ print "Ignored: $k\n";
}
}
next if $s->{alias};
- print $f "\n\t// $s->{name} $type\n";
+ push @constants, "";
+ push @constants, "// $s->{name} $type";
foreach my $m (@{$s->{items}}) {
next if defined($m->{alias});
$v = 1<<$m->{bitpos} if !defined($v) && defined($m->{bitpos});
die Dumper("Ca't work out value", $m, $s) if !defined($v);
- print $f "\tpublic final static $i->{type} $m->{name} = $v$i->{suffix};\n";
+ push @constants, "public final static $i->{type} $m->{name} = $v$i->{suffix};";
}
}
- print $f "}\n";
- closeOutput($sys, $name, $f);
+ my $v = {
+ package => $sys->{package},
+ defines => join("\n\t", @defines),
+ constants => join("\n\t", @constants),
+ };
+
+ my $f = openOutput($sys, 'Vulkan');
+
+ print $f code::formatTemplateStream($template->{class}, $v);
+
+ closeOutput($sys, 'Vulkan', $f);
}
# ###################################################################### #
if ($s->{category} =~ m/struct|union/on) {
if ($m->{altlen}) {
if ($m->{altlen} =~ m/^(.*)(VK_UUID_SIZE)(.*)$/) {
- $m->{length} = $1.'VkConstants.'.$2.$3;
+ $m->{length} = $1.'Vulkan.'.$2.$3;
} elsif ($m->{altlen} =~ m/^([^a-zA-Z_]*)([a-zA-Z_]+)(.*)$/) {
my $len = $index->{$2};
if (defined $len) {
$info->{'native-result-define'} = 'int result$;';
$info->{'native-result-assign'} = 'result$ = (int)';
- $info->{'result-test'} = 'if ('.join("||", map { '(result$ == VkConstants.'.$_.')' } @codes).')';
+ $info->{'result-test'} = 'if ('.join("||", map { '(result$ == Vulkan.'.$_.')' } @codes).')';
$info->{'result-throw'} = 'throw new RuntimeException("error " + result$);';
if ($#codes > 0 && $info->{'java-result'} eq 'void') {
# Initialise the sType field if it has one, also include sub-
init eval {{
if ($tempname =~ m/write/) {
- my $init = "{name}\$VH.set(self\$.segment, VkConstants.{values});\n";
+ my $init = "{name}\$VH.set(self\$.segment, Vulkan.{values});\n";
foreach my $x (@{$s->{items}}) {
if ($x->{deref} eq 'struct') {
my $y = $api->{types}->{$x->{baseType}};
if ($#{$y->{items}} >= 0 && $y->{items}->[0]->{values}) {
my $z = $y->{items}->[0];
- $init .= "self\$.get$x->{Name}().set$z->{Name}(VkConstants.$z->{values});\n";
+ $init .= "self\$.get$x->{Name}().set$z->{Name}(Vulkan.$z->{values});\n";
}
}
}
init-array eval {{
if ($tempname =~ m/write.*array/n) {
- my $init = "{name}\$AH.set(self\$.segment, i, VkConstants.{values});\n";
+ my $init = "{name}\$AH.set(self\$.segment, i, Vulkan.{values});\n";
foreach my $x (@{$s->{items}}) {
if ($x->{deref} eq 'struct') {
my $y = $api->{types}->{$x->{baseType}};
if ($#{$y->{items}} >= 0 && $y->{items}->[0]->{values}) {
my $z = $y->{items}->[0];
- $init .= "self\$.get$x->{Name}AtIndex(i).set$z->{Name}(VkConstants.$z->{values});\n";
+ $init .= "self\$.get$x->{Name}AtIndex(i).set$z->{Name}(Vulkan.$z->{values});\n";
}
}
}
}}
# for complex constructors
+ #setall-arg {{ {type} {name} }}
setall-arg {{ {type} {name} }}
setall {{ self$.set{Name}({name}); }}
}
# ###################################################################### #
+code Vulkan {
+ class {{
+ package {package};
+ public class Vulkan {
+
+ public static int VK_MAKE_API_VERSION(int variant, int major, int minor, int patch) {
+ return (variant << 29) | (major << 22) | (minor << 12) | patch;
+ }
+
+ {defines}
+
+ {constants}
+ }
+ }}
+ VK_API_VERSION_1_0 {{ public final static int VK_API_VERSION_1_0 = VK_MAKE_API_VERSION(0, 1, 0, 0); }}
+ VK_API_VERSION_1_1 {{ public final static int VK_API_VERSION_1_1 = VK_MAKE_API_VERSION(0, 1, 1, 0); }}
+ VK_API_VERSION_1_2 {{ public final static int VK_API_VERSION_1_2 = VK_MAKE_API_VERSION(0, 1, 2, 0); }}
+ VK_API_VERSION_1_3 {{ public final static int VK_API_VERSION_1_3 = VK_MAKE_API_VERSION(0, 1, 3, 0); }}
+}
+
code dispatch {
class {{
// template: dispatch:class
VkAllocationCallbacks ignore;
+ # We want 'set(all fields) for these types
+ #VkOffset2D template=struct-readwrite-all;
+ #VkOffset3D template=struct-readwrite-all-array;
+ #VkExtent2D template=struct-readwrite-all;
+ #VkExtent3D template=struct-readwrite-all;
+ #VkRect2D template=struct-readwrite-all;
+
# Override default read/write
VkDebugUtilsMessengerCallbackDataEXT template=struct-readonly;
VkDebugUtilsLabelEXT template=struct-readonly-array;
# add a couple of constants that the api's dont reference
push @{$outconst->{items}}, grep { $_->{name} =~ m/VK_UUID_SIZE/ } @{$allconst->{items}};
- #print " $req->{comment}\n";
- #print Dumper($req->{types});
+ # Find included types in this requirement
foreach my $c (@{$req->{commands}}, @{$req->{types}}) {
my $d = $vk->{data}->{$c};
- #print Dumper({ d=> $d, c => $c });
-
- # what about aliases?
if (defined $d) {
if ($d->{category} eq 'enum' && !defined($d->{alias})) {
$d = { %$d };
$d->{items} = [ @{$d->{items}} ] if defined($d->{items});
}
$data->{$c} = $d;
-
- #print "Alias: $d->{alias}\n" if defined($d->{alias});
} else {
- print "Ignored: ".Dumper($c);
+ $data->{$c} = {
+ name => $c,
+ category => 'define',
+ };
}
}
foreach my $c (@{$req->{enums}}) {
my $enums = {};
my $bitmasks = {};
my $funcpointers = {};
+ my $defines = {};
foreach my $t (keys %{$data}) {
my $v = $data->{$t};
$enums->{$v->{name}} = $v if $v->{category} eq 'enum';
$bitmasks->{$v->{name}} = $v if $v->{category} eq 'bitmask';
$funcpointers->{$v->{name}} = $v if $v->{category} eq 'funcpointer';
+ $defines->{$v->{name}} = $v if $v->{category} eq 'define';
}
# link enums to their type(s)
funcpointers => $funcpointers,
enums => $enums,
bitmasks => $bitmasks,
+ defines => $defines,
};
# create sizes for every struct of interest
}
} elsif ($ya->{category} eq 'enum') {
$data->{$ya->{name}} = $ya;
- } elsif ($ya->{requires} || $ya->{name} eq 'int') {
- # ?? wtf to do with this
+ } elsif ($ya->{requires} eq 'vk_platform' || $ya->{name} eq 'int') {
+ # These are just primitive types, not sure what to do with them, could auto-map them to java i suppose
$ya->{category} = 'platform';
$data->{$ya->{name}} = $ya;
+ } else {
+ #noisy print "Unhandled: $ya->{name}\n";
}
}
} elsif ($xt eq 'enums') {
xid rename=XID;
}
+union <default> default=all access=rw rename=s/^_// field:rename=studly-caps {
+}
+
struct _XPrivDisplay {
screens array array-size=nscreens access=r;
}
define:xlib;
func:XCreateColormap;
func:XCreateWindow;
+ func:XDestroyWindow;
func:XFlush;
func:XGetVisualInfo;
func:XInitThreads;
func:XInternAtom;
func:XMapWindow;
func:XOpenDisplay;
+ func:XCloseDisplay;
func:XSelectInput;
+ func:XSetWMProtocols;
+
+ func:XPending;
+ func:XNextEvent;
+ func:XWindowEvent;
+ func:XCheckWindowEvent;
+
# #define DefaultScreen(dpy) (((_XPrivDisplay)(dpy))->default_screen)
# #define RootWindow(dpy, scr) (ScreenOfDisplay(dpy,scr)->root)
# #define ScreenOfDisplay(dpy, scr)(&((_XPrivDisplay)(dpy))->screens[scr])
define xlib xlib.h {
/Pixel$|^Input|^CW|Mask$|^Alloc/ include;
+ /KeyPress|KeyRelease|ButtonPress|ButtonRelease|MotionNotify|EnterNotify|LeaveNotify|FocusIn|FocusOut|KeymapNotify|Expose|GraphicsExpose|NoExpose|VisibilityNotify|CreateNotify|DestroyNotify|UnmapNotify|MapNotify|MapRequest|ReparentNotify|ConfigureNotify|ConfigureRequest|GravityNotify|ResizeRequest|CirculateNotify|CirculateRequest|PropertyNotify|SelectionClear|SelectionRequest|SelectionNotify|ColormapNotify|ClientMessage|MappingNotify|GenericEvent/ include;
+
}