< prev index next >
src/jdk.jextract/share/classes/com/sun/tools/jextract/JextractTool.java
Print this page
@@ -30,10 +30,11 @@
import java.io.IOException;
import java.io.UncheckedIOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Collection;
+import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
@@ -42,21 +43,17 @@
import java.util.stream.Stream;
public class JextractTool {
private final HeaderResolver headerResolver;
private final Parser parser;
- private final Function<HeaderFile, AsmCodeFactory> codeFactory;
private final Collection<String> clangArgs;
private final Collection<Path> sources;
private final Context ctx;
public JextractTool(Context ctx) {
this.headerResolver = new HeaderResolver(ctx);
this.parser = new Parser(ctx, Options.INCLUDE_MACROS);
- this.codeFactory = ctx.options.genStaticForwarder ?
- hf -> new AsmCodeFactoryExt(ctx, hf) :
- hf -> new AsmCodeFactory(ctx, hf);
this.clangArgs = ctx.options.clangArgs;
this.sources = ctx.sources;
this.ctx = ctx;
assert sources.size() > 0;
}
@@ -75,25 +72,22 @@
.flatMap(h -> h.declarations().stream())
.peek(new FlexibleArrayWarningVisitor(ctx))
.collect(Collectors.groupingBy(this::headerFromDecl));
//generate classes
- Map<String, byte[]> results = new LinkedHashMap<>();
- headerMap.forEach((hf, decls) -> generateHeader(hf, decls, results));
- return new Writer(ctx, results);
+ Map<String, String> srcMap = new HashMap<>();
+ headerMap.forEach((hf, decls) -> generateHeader(hf, decls,srcMap));
+ Map<String, byte[]> classMap = !srcMap.isEmpty()? InMemoryJavaCompiler.compile(srcMap) : Map.of();
+ return new Writer(ctx, classMap);
}
- private void generateHeader(HeaderFile hf, List<Tree> decls, Map<String, byte[]> results) {
+ private void generateHeader(HeaderFile hf, List<Tree> decls, Map<String, String> srcMap) {
TypeEnter enter = new TypeEnter(hf.dictionary());
decls.forEach(t -> t.accept(enter, null));
- if (ctx.options.srcDumpDir != null) {
JavaSourceFactory jsb = ctx.options.genStaticForwarder ?
new JavaSourceFactoryExt(ctx, hf) : new JavaSourceFactory(ctx, hf);
- jsb.generate(decls);
- }
- AsmCodeFactory cf = codeFactory.apply(hf);
- results.putAll(cf.generateNativeHeader(decls));
+ srcMap.putAll(jsb.generate(decls));
}
private HeaderFile headerFromDecl(Tree tree) {
Path path = tree.cursor().getSourceLocation().getFileLocation().path();
return headerResolver.headerFor(path);
< prev index next >