aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/com/jogamp/gluegen/CodeUnit.java
diff options
context:
space:
mode:
authorSven Gothel <[email protected]>2023-06-16 00:59:29 +0200
committerSven Gothel <[email protected]>2023-06-16 00:59:29 +0200
commitf1678c4ac8b85c85d11b737d08dcfe31b388e021 (patch)
treec13c672ad97b9a17892690e56353961215033ceb /src/java/com/jogamp/gluegen/CodeUnit.java
parent03c548d96e5c81d0fc39503fe3042cf03e0a75e2 (diff)
GlueGen Struct [2]: Add CodeUnit: Representing a generated C or Java file, covering multiple FunctionEmitter allowing to unify output, decoration and dynamic helper code injection per unit
- Handles file open and have public ctor emitAutogeneratedWarning(..), being self-contained - Includes `JVMUtil_NewDirectByteBufferCopy(..)` implementation in CCodeUnit, may be injected if required in customCode via emitHeader(..)
Diffstat (limited to 'src/java/com/jogamp/gluegen/CodeUnit.java')
-rw-r--r--src/java/com/jogamp/gluegen/CodeUnit.java99
1 files changed, 99 insertions, 0 deletions
diff --git a/src/java/com/jogamp/gluegen/CodeUnit.java b/src/java/com/jogamp/gluegen/CodeUnit.java
new file mode 100644
index 0000000..e6c31d5
--- /dev/null
+++ b/src/java/com/jogamp/gluegen/CodeUnit.java
@@ -0,0 +1,99 @@
+/**
+ * Copyright 2023 JogAmp Community. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without modification, are
+ * permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this list of
+ * conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright notice, this list
+ * of conditions and the following disclaimer in the documentation and/or other materials
+ * provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY JogAmp Community ``AS IS'' AND ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JogAmp Community OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * The views and conclusions contained in the software and documentation are those of the
+ * authors and should not be interpreted as representing official policies, either expressed
+ * or implied, of JogAmp Community.
+ */
+package com.jogamp.gluegen;
+
+import java.io.BufferedWriter;
+import java.io.File;
+import java.io.FileWriter;
+import java.io.IOException;
+import java.io.PrintWriter;
+import java.util.HashSet;
+import java.util.Set;
+
+/**
+ * General code unit (a generated C or Java source file),
+ * covering multiple {@link FunctionEmitter} allowing to unify output, decoration and dynamic helper code injection per unit.
+ **/
+public class CodeUnit {
+ public final String filename;
+ public final PrintWriter output;
+ private final Set<String> tailCode = new HashSet<String>();
+
+ /**
+ * @param filename the class's full filename to open w/ write access
+ * @param generator informal optional object that is creating this unit, used to be mentioned in a warning message if not null.
+ * @throws IOException
+ */
+ protected CodeUnit(final String filename, final Object generator) throws IOException {
+ this.filename = filename;
+ this.output = openFile(filename);
+ }
+
+ private static PrintWriter openFile(final String filename) throws IOException {
+ final File file = new File(filename);
+ final String parentDir = file.getParent();
+ if (parentDir != null) {
+ new File(parentDir).mkdirs();
+ }
+ return new PrintWriter(new BufferedWriter(new FileWriter(file)));
+ }
+
+ /**
+ * Add a tail code to this unit
+ * @param c the code to be added to the tail of this code unit
+ * @return true if the `tailCode` set did not already contain the specified code `c`
+ */
+ public boolean addTailCode(final String c) {
+ return tailCode.add(c);
+ }
+
+ public void emitln() {
+ output.println();
+ }
+ public void emitln(final String s) {
+ output.println(s);
+ }
+ public void emit(final String s) {
+ output.print(s);
+ }
+ public void emitf(final String s, final Object... args) {
+ output.printf(s, args);
+ }
+ public void emitTailCode() {
+ tailCode.forEach( (final String t) -> { output.write(t); output.println(); } );
+ tailCode.clear();
+ }
+ public void close() {
+ emitTailCode();
+ output.flush();
+ output.close();
+ }
+
+ @Override
+ public String toString() { return "CodeUnit[file "+filename+"]"; }
+}