aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/com/jogamp/gluegen/JavaConfiguration.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/java/com/jogamp/gluegen/JavaConfiguration.java')
-rw-r--r--src/java/com/jogamp/gluegen/JavaConfiguration.java101
1 files changed, 66 insertions, 35 deletions
diff --git a/src/java/com/jogamp/gluegen/JavaConfiguration.java b/src/java/com/jogamp/gluegen/JavaConfiguration.java
index 23db7b4..ca7eccf 100644
--- a/src/java/com/jogamp/gluegen/JavaConfiguration.java
+++ b/src/java/com/jogamp/gluegen/JavaConfiguration.java
@@ -73,6 +73,8 @@ public class JavaConfiguration {
protected static final Logger LOG = Logger.getLogger(JavaConfiguration.class.getPackage().getName());
+ public static String NEWLINE = System.getProperty("line.separator");
+
/**
* Root directory for the hierarchy of generated java classes. Default is
* working directory.
@@ -114,7 +116,7 @@ public class JavaConfiguration {
/**
* List of imports to emit at the head of the output files.
*/
- private List<String> imports = new ArrayList<String>();
+ private final List<String> imports = new ArrayList<String>();
/**
* The package in which the generated glue code expects to find its
@@ -130,47 +132,48 @@ public class JavaConfiguration {
private String runtimeExceptionType = "RuntimeException";
private String unsupportedExceptionType = "UnsupportedOperationException";
- private Map<String, MethodAccess> accessControl = new HashMap<String, MethodAccess>();
- private Map<String, TypeInfo> typeInfoMap = new HashMap<String, TypeInfo>();
- private Set<String> returnsString = new HashSet<String>();
- private Map<String, String> returnedArrayLengths = new HashMap<String, String>();
+ private final Map<String, MethodAccess> accessControl = new HashMap<String, MethodAccess>();
+ private final Map<String, TypeInfo> typeInfoMap = new HashMap<String, TypeInfo>();
+ private final Set<String> returnsString = new HashSet<String>();
+ private final Map<String, String> returnedArrayLengths = new HashMap<String, String>();
/**
* Key is function that has some byte[] or short[] arguments that should be
* converted to String args; value is List of Integer argument indices
*/
- private Map<String, List<Integer>> argumentsAreString = new HashMap<String, List<Integer>>();
- private Set<String> extendedIntfSymbolsIgnore = new HashSet<String>();
- private Set<String> extendedIntfSymbolsOnly = new HashSet<String>();
- private Set<String> extendedImplSymbolsIgnore = new HashSet<String>();
- private Set<String> extendedImplSymbolsOnly = new HashSet<String>();
- private Set<Pattern> ignores = new HashSet<Pattern>();
- private Map<String, Pattern> ignoreMap = new HashMap<String, Pattern>();
- private Set<Pattern> ignoreNots = new HashSet<Pattern>();
- private Set<Pattern> unignores = new HashSet<Pattern>();
- private Set<Pattern> unimplemented = new HashSet<Pattern>();
+ private final Map<String, List<Integer>> argumentsAreString = new HashMap<String, List<Integer>>();
+ private final Set<String> extendedIntfSymbolsIgnore = new HashSet<String>();
+ private final Set<String> extendedIntfSymbolsOnly = new HashSet<String>();
+ private final Set<String> extendedImplSymbolsIgnore = new HashSet<String>();
+ private final Set<String> extendedImplSymbolsOnly = new HashSet<String>();
+ private final Set<Pattern> ignores = new HashSet<Pattern>();
+ private final Map<String, Pattern> ignoreMap = new HashMap<String, Pattern>();
+ private final Set<Pattern> ignoreNots = new HashSet<Pattern>();
+ private final Set<Pattern> unignores = new HashSet<Pattern>();
+ private final Set<Pattern> unimplemented = new HashSet<Pattern>();
private boolean forceUseNIOOnly4All = false;
- private Set<String> useNIOOnly = new HashSet<String>();
+ private final Set<String> useNIOOnly = new HashSet<String>();
private boolean forceUseNIODirectOnly4All = false;
- private Set<String> useNIODirectOnly = new HashSet<String>();
- private Set<String> manuallyImplement = new HashSet<String>();
- private Map<String, List<String>> customJavaCode = new HashMap<String, List<String>>();
- private Map<String, List<String>> classJavadoc = new HashMap<String, List<String>>();
- private Map<String, String> structPackages = new HashMap<String, String>();
- private List<String> customCCode = new ArrayList<String>();
- private List<String> forcedStructs = new ArrayList<String>();
- private Map<String, String> returnValueCapacities = new HashMap<String, String>();
- private Map<String, String> returnValueLengths = new HashMap<String, String>();
- private Map<String, List<String>> temporaryCVariableDeclarations = new HashMap<String, List<String>>();
- private Map<String, List<String>> temporaryCVariableAssignments = new HashMap<String, List<String>>();
- private Map<String, List<String>> extendedInterfaces = new HashMap<String, List<String>>();
- private Map<String, List<String>> implementedInterfaces = new HashMap<String, List<String>>();
- private Map<String, String> parentClass = new HashMap<String, String>();
- private Map<String, String> javaTypeRenames = new HashMap<String, String>();
- private Map<String, String> javaSymbolRenames = new HashMap<String, String>();
- private Map<String, Set<String>> javaRenamedSymbols = new HashMap<String, Set<String>>();
- private Map<String, List<String>> javaPrologues = new HashMap<String, List<String>>();
- private Map<String, List<String>> javaEpilogues = new HashMap<String, List<String>>();
+ private final Set<String> useNIODirectOnly = new HashSet<String>();
+ private final Set<String> manuallyImplement = new HashSet<String>();
+ private final Map<String, List<String>> customJavaCode = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> classJavadoc = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> methodJavadoc = new HashMap<String, List<String>>();
+ private final Map<String, String> structPackages = new HashMap<String, String>();
+ private final List<String> customCCode = new ArrayList<String>();
+ private final List<String> forcedStructs = new ArrayList<String>();
+ private final Map<String, String> returnValueCapacities = new HashMap<String, String>();
+ private final Map<String, String> returnValueLengths = new HashMap<String, String>();
+ private final Map<String, List<String>> temporaryCVariableDeclarations = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> temporaryCVariableAssignments = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> extendedInterfaces = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> implementedInterfaces = new HashMap<String, List<String>>();
+ private final Map<String, String> parentClass = new HashMap<String, String>();
+ private final Map<String, String> javaTypeRenames = new HashMap<String, String>();
+ private final Map<String, String> javaSymbolRenames = new HashMap<String, String>();
+ private final Map<String, Set<String>> javaRenamedSymbols = new HashMap<String, Set<String>>();
+ private final Map<String, List<String>> javaPrologues = new HashMap<String, List<String>>();
+ private final Map<String, List<String>> javaEpilogues = new HashMap<String, List<String>>();
/** Reads the configuration file.
@param filename path to file that should be read
@@ -547,6 +550,15 @@ public class JavaConfiguration {
return res;
}
+ public List<String> javadocForMethod(String methodName) {
+ List<String> res = methodJavadoc.get(methodName);
+ if (res == null) {
+ res = new ArrayList<String>();
+ methodJavadoc.put(methodName, res);
+ }
+ return res;
+ }
+
/** Returns a list of Strings containing Javadoc documentation for
the given Java type name (not fully-qualified, only the class
name); returns either null or an empty list if there is no
@@ -979,6 +991,10 @@ public class JavaConfiguration {
readCustomCCode(tok, filename, lineNo);
// Warning: make sure delimiters are reset at the top of this loop
// because readCustomCCode changes them.
+ } else if (cmd.equalsIgnoreCase("MethodJavadoc")) {
+ readMethodJavadoc(tok, filename, lineNo);
+ // Warning: make sure delimiters are reset at the top of this loop
+ // because readMethodJavadoc changes them.
} else if (cmd.equalsIgnoreCase("ClassJavadoc")) {
readClassJavadoc(tok, filename, lineNo);
// Warning: make sure delimiters are reset at the top of this loop
@@ -1297,6 +1313,21 @@ public class JavaConfiguration {
}
}
+ protected void readMethodJavadoc(StringTokenizer tok, String filename, int lineNo) {
+ try {
+ String tokenClassName = tok.nextToken();
+ String restOfLine = tok.nextToken("\n\r\f");
+ addMethodJavadoc(tokenClassName, restOfLine);
+ } catch (NoSuchElementException e) {
+ throw new RuntimeException("Error parsing \"MethodJavadoc\" command at line " + lineNo +
+ " in file \"" + filename + "\"", e);
+ }
+ }
+ protected void addMethodJavadoc(String methodName, String code) {
+ List<String> codeList = javadocForMethod(methodName);
+ codeList.add(code);
+ }
+
protected void readClassJavadoc(StringTokenizer tok, String filename, int lineNo) {
try {
String tokenClassName = tok.nextToken();