GraphVizjsTeaVMEngine.java
/* ========================================================================
* PlantUML : a free UML diagram generator
* ========================================================================
*
* (C) Copyright 2009-2025, Arnaud Roques
*
* Project Info: https://plantuml.com
*
* If you like this project or if you find it useful, you can support us at:
*
* https://plantuml.com/patreon (only 1$ per month!)
* https://plantuml.com/paypal
*
* This file is part of PlantUML.
*
* PlantUML is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* PlantUML distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
* License for more details.
*
* You should have received a copy of the GNU General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
* USA.
*
*
* Original Author: Arnaud Roques
*
*/
package net.sourceforge.plantuml.teavm;
import org.teavm.interop.Async;
import org.teavm.interop.AsyncCallback;
import org.teavm.jso.JSBody;
import org.teavm.jso.JSFunctor;
import org.teavm.jso.JSObject;
/**
* TeaVM engine for rendering DOT graphs to SVG using Viz.js.
* <p>
* This class provides a bridge between Java code running in TeaVM and the
* Viz.js JavaScript library. It handles the asynchronous nature of
* Viz.instance() using TeaVM's @Async annotation.
* <p>
* Usage:
* <pre>
* String dot = "digraph G { A -> B; }";
* String svg = GraphVizjsTeaVMEngine.renderDotToSvg(dot);
* </pre>
*/
public class GraphVizjsTeaVMEngine {
// ::remove file when JAVA8
/**
* Renders a DOT graph description to SVG format.
* <p>
* This method is asynchronous from JavaScript's perspective but appears
* synchronous to the Java caller thanks to TeaVM's @Async mechanism.
*
* @param dotSource the graph description in DOT format
* @return the rendered SVG as a string
*/
@Async
public static native String renderDotToSvg(String dotSource);
/**
* Internal implementation called by TeaVM's async mechanism.
* Sets up the JavaScript Promise handling and calls the callback when complete.
*/
private static void renderDotToSvg(String dotSource, AsyncCallback<String> callback) {
renderDotToSvgAsync(dotSource, result -> callback.complete(result), error -> callback.error(new RuntimeException(error)));
}
/**
* JavaScript bridge that calls Viz.instance() and renders the DOT source.
* Uses Viz.js API: Viz.instance().then(viz => viz.renderString(dot, options))
*/
@JSBody(params = { "dotSource", "onSuccess", "onError" }, script =
"Viz.instance().then(function(viz) {" +
" try {" +
" var svg = viz.renderString(dotSource, { format: 'svg', engine: 'dot' });" +
" onSuccess(svg);" +
" } catch(e) {" +
" onError(e.toString());" +
" }" +
"}).catch(function(err) {" +
" onError(err.toString());" +
"});")
private static native void renderDotToSvgAsync(String dotSource, StringCallback onSuccess, StringCallback onError);
/**
* Renders a DOT graph using a specific GraphViz engine.
*
* @param dotSource the graph description in DOT format
* @param engine the GraphViz engine to use (dot, neato, fdp, sfdp, twopi, circo)
* @return the rendered SVG as a string
*/
@Async
public static native String renderDotToSvg(String dotSource, String engine);
/**
* Internal implementation for engine-specific rendering.
*/
private static void renderDotToSvg(String dotSource, String engine, AsyncCallback<String> callback) {
renderDotToSvgWithEngineAsync(dotSource, engine, result -> callback.complete(result), error -> callback.error(new RuntimeException(error)));
}
/**
* JavaScript bridge for engine-specific rendering.
*/
@JSBody(params = { "dotSource", "engine", "onSuccess", "onError" }, script =
"Viz.instance().then(function(viz) {" +
" try {" +
" var svg = viz.renderString(dotSource, { format: 'svg', engine: engine });" +
" onSuccess(svg);" +
" } catch(e) {" +
" onError(e.toString());" +
" }" +
"}).catch(function(err) {" +
" onError(err.toString());" +
"});")
private static native void renderDotToSvgWithEngineAsync(String dotSource, String engine, StringCallback onSuccess, StringCallback onError);
/**
* Callback interface for receiving string results from JavaScript.
*/
@JSFunctor
private interface StringCallback extends JSObject {
void call(String value);
}
}