mirror of
https://github.com/octoleo/plantuml.git
synced 2024-11-22 13:05:09 +00:00
wip
This commit is contained in:
parent
a1a599b633
commit
57b1cde03a
@ -76,11 +76,11 @@ public class GraphvizUtils {
|
||||
return new GraphvizJs(dotString);
|
||||
}
|
||||
final AbstractGraphviz result;
|
||||
if (isWindows()) {
|
||||
if (isWindows())
|
||||
result = new GraphvizWindowsOld(skinParam, dotString, type);
|
||||
} else {
|
||||
else
|
||||
result = new GraphvizLinux(skinParam, dotString, type);
|
||||
}
|
||||
|
||||
if (result.getExeState() != ExeState.OK && VizJsEngine.isOk()) {
|
||||
Log.info("Error with file " + result.getDotExe() + ": " + result.getExeState().getTextMessage());
|
||||
Log.info("Using " + VIZJS);
|
||||
@ -95,11 +95,11 @@ public class GraphvizUtils {
|
||||
return new GraphvizJs(dotString);
|
||||
}
|
||||
final AbstractGraphviz result;
|
||||
if (isWindows()) {
|
||||
if (isWindows())
|
||||
result = new GraphvizWindowsLite(skinParam, dotString, type);
|
||||
} else {
|
||||
else
|
||||
result = new GraphvizLinux(skinParam, dotString, type);
|
||||
}
|
||||
|
||||
if (result.getExeState() != ExeState.OK && VizJsEngine.isOk()) {
|
||||
Log.info("Error with file " + result.getDotExe() + ": " + result.getExeState().getTextMessage());
|
||||
Log.info("Using " + VIZJS);
|
||||
@ -109,12 +109,12 @@ public class GraphvizUtils {
|
||||
}
|
||||
|
||||
private static boolean useVizJs(ISkinParam skinParam) {
|
||||
if (skinParam != null && skinParam.isUseVizJs() && VizJsEngine.isOk()) {
|
||||
if (skinParam != null && skinParam.isUseVizJs() && VizJsEngine.isOk())
|
||||
return true;
|
||||
}
|
||||
if (VIZJS.equalsIgnoreCase(getenvGraphvizDot()) && VizJsEngine.isOk()) {
|
||||
|
||||
if (VIZJS.equalsIgnoreCase(getenvGraphvizDot()) && VizJsEngine.isOk())
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -123,17 +123,17 @@ public class GraphvizUtils {
|
||||
}
|
||||
|
||||
public static String getenvGraphvizDot() {
|
||||
if (StringUtils.isNotEmpty(dotExecutable)) {
|
||||
if (StringUtils.isNotEmpty(dotExecutable))
|
||||
return StringUtils.eventuallyRemoveStartingAndEndingDoubleQuote(dotExecutable);
|
||||
}
|
||||
|
||||
final String env = System.getProperty("GRAPHVIZ_DOT");
|
||||
if (StringUtils.isNotEmpty(env)) {
|
||||
if (StringUtils.isNotEmpty(env))
|
||||
return StringUtils.eventuallyRemoveStartingAndEndingDoubleQuote(env);
|
||||
}
|
||||
|
||||
final String getenv = System.getenv("GRAPHVIZ_DOT");
|
||||
if (StringUtils.isNotEmpty(getenv)) {
|
||||
if (StringUtils.isNotEmpty(getenv))
|
||||
return StringUtils.eventuallyRemoveStartingAndEndingDoubleQuote(getenv);
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -149,13 +149,13 @@ public class GraphvizUtils {
|
||||
|
||||
public static int getenvImageLimit() {
|
||||
final Integer local = limitSize.get();
|
||||
if (local != null) {
|
||||
if (local != null)
|
||||
return local;
|
||||
}
|
||||
|
||||
final String env = SecurityUtils.getenv("PLANTUML_LIMIT_SIZE");
|
||||
if (StringUtils.isNotEmpty(env) && env.matches("\\d+")) {
|
||||
if (StringUtils.isNotEmpty(env) && env.matches("\\d+"))
|
||||
return Integer.parseInt(env);
|
||||
}
|
||||
|
||||
return 4096;
|
||||
}
|
||||
|
||||
@ -173,11 +173,11 @@ public class GraphvizUtils {
|
||||
if (dotVersion == null) {
|
||||
final File dotExe = GraphvizUtils.getDotExe();
|
||||
final ExeState exeState = ExeState.checkFile(dotExe);
|
||||
if (exeState == ExeState.OK) {
|
||||
if (exeState == ExeState.OK)
|
||||
dotVersion = create(null, "png").dotVersion();
|
||||
} else {
|
||||
else
|
||||
dotVersion = "Error:" + exeState.getTextMessage(dotExe);
|
||||
}
|
||||
|
||||
}
|
||||
return dotVersion;
|
||||
}
|
||||
@ -192,15 +192,15 @@ public class GraphvizUtils {
|
||||
}
|
||||
|
||||
public static int retrieveVersion(String s) {
|
||||
if (s == null) {
|
||||
if (s == null)
|
||||
return -1;
|
||||
}
|
||||
final Pattern p = Pattern.compile("\\s([12].\\d\\d)\\D");
|
||||
|
||||
final Pattern p = Pattern.compile("\\s([23])\\.(\\d\\d?)\\D");
|
||||
final Matcher m = p.matcher(s);
|
||||
if (m.find() == false) {
|
||||
if (m.find() == false)
|
||||
return -1;
|
||||
}
|
||||
return Integer.parseInt(m.group(1).replaceAll("\\.", ""));
|
||||
|
||||
return 100 * Integer.parseInt(m.group(1)) + Integer.parseInt(m.group(2));
|
||||
}
|
||||
|
||||
public static int getDotVersion() throws IOException, InterruptedException {
|
||||
@ -221,11 +221,11 @@ public class GraphvizUtils {
|
||||
result.add("VizJs library is used!");
|
||||
try {
|
||||
final String err = getTestCreateSimpleFile();
|
||||
if (err == null) {
|
||||
if (err == null)
|
||||
result.add(bold + "Installation seems OK. File generation OK");
|
||||
} else {
|
||||
else
|
||||
result.add(red + err);
|
||||
}
|
||||
|
||||
} catch (Exception e) {
|
||||
result.add(red + e.toString());
|
||||
e.printStackTrace();
|
||||
@ -237,11 +237,11 @@ public class GraphvizUtils {
|
||||
final File dotExe = GraphvizUtils.getDotExe();
|
||||
if (SecurityUtils.getSecurityProfile() == SecurityProfile.UNSECURE) {
|
||||
final String ent = GraphvizUtils.getenvGraphvizDot();
|
||||
if (ent == null) {
|
||||
if (ent == null)
|
||||
result.add("The environment variable GRAPHVIZ_DOT has not been set");
|
||||
} else {
|
||||
else
|
||||
result.add("The environment variable GRAPHVIZ_DOT has been set to " + ent);
|
||||
}
|
||||
|
||||
result.add("Dot executable is " + dotExe);
|
||||
}
|
||||
final ExeState exeState = ExeState.checkFile(dotExe);
|
||||
@ -285,19 +285,18 @@ public class GraphvizUtils {
|
||||
final Graphviz graphviz2 = GraphvizUtils.create(null, "digraph foo { test; }", "svg");
|
||||
final ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
final ProcessState state = graphviz2.createFile3(baos);
|
||||
if (state.differs(ProcessState.TERMINATED_OK())) {
|
||||
if (state.differs(ProcessState.TERMINATED_OK()))
|
||||
return "Error: timeout " + state;
|
||||
}
|
||||
|
||||
final byte data[] = baos.toByteArray();
|
||||
|
||||
if (data.length == 0) {
|
||||
if (data.length == 0)
|
||||
return "Error: dot generates empty file. Check you dot installation.";
|
||||
}
|
||||
|
||||
final String s = new String(data);
|
||||
if (s.indexOf("<svg") == -1) {
|
||||
if (s.indexOf("<svg") == -1)
|
||||
return "Error: dot generates unreadable SVG file. Check you dot installation.";
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
|
@ -36,6 +36,8 @@
|
||||
package net.sourceforge.plantuml.svek.image;
|
||||
|
||||
import net.sourceforge.plantuml.awt.geom.Dimension2D;
|
||||
|
||||
import java.awt.geom.Rectangle2D;
|
||||
import java.util.EnumMap;
|
||||
import java.util.Map;
|
||||
|
||||
@ -51,6 +53,7 @@ import net.sourceforge.plantuml.SkinParamUtils;
|
||||
import net.sourceforge.plantuml.Url;
|
||||
import net.sourceforge.plantuml.UseStyle;
|
||||
import net.sourceforge.plantuml.creole.Stencil;
|
||||
import net.sourceforge.plantuml.cucadiagram.Bodier;
|
||||
import net.sourceforge.plantuml.cucadiagram.Display;
|
||||
import net.sourceforge.plantuml.cucadiagram.EntityPortion;
|
||||
import net.sourceforge.plantuml.cucadiagram.ILeaf;
|
||||
@ -58,6 +61,7 @@ import net.sourceforge.plantuml.cucadiagram.PortionShower;
|
||||
import net.sourceforge.plantuml.cucadiagram.Stereotype;
|
||||
import net.sourceforge.plantuml.graphic.FontConfiguration;
|
||||
import net.sourceforge.plantuml.graphic.HorizontalAlignment;
|
||||
import net.sourceforge.plantuml.graphic.InnerStrategy;
|
||||
import net.sourceforge.plantuml.graphic.StringBounder;
|
||||
import net.sourceforge.plantuml.graphic.TextBlock;
|
||||
import net.sourceforge.plantuml.graphic.TextBlockEmpty;
|
||||
@ -203,11 +207,7 @@ public class EntityImageObject extends AbstractEntityImage implements Stencil, W
|
||||
ug.startGroup(typeIDent);
|
||||
ug.apply(stroke).draw(rect);
|
||||
|
||||
final ULayoutGroup header = new ULayoutGroup(new PlacementStrategyY1Y2(ug.getStringBounder()));
|
||||
if (stereo != null)
|
||||
header.add(stereo);
|
||||
|
||||
header.add(name);
|
||||
final ULayoutGroup header = getLayout(stringBounder);
|
||||
header.drawU(ug, dimTotal.getWidth(), dimTitle.getHeight());
|
||||
|
||||
final UGraphic ug2 = UGraphicStencil.create(ug, this, stroke);
|
||||
@ -219,6 +219,15 @@ public class EntityImageObject extends AbstractEntityImage implements Stencil, W
|
||||
ug.closeGroup();
|
||||
}
|
||||
|
||||
private ULayoutGroup getLayout(final StringBounder stringBounder) {
|
||||
final ULayoutGroup header = new ULayoutGroup(new PlacementStrategyY1Y2(stringBounder));
|
||||
if (stereo != null)
|
||||
header.add(stereo);
|
||||
|
||||
header.add(name);
|
||||
return header;
|
||||
}
|
||||
|
||||
private UStroke getStroke() {
|
||||
UStroke stroke = lineConfig.getColors().getSpecificLineStroke();
|
||||
if (stroke == null)
|
||||
@ -276,4 +285,11 @@ public class EntityImageObject extends AbstractEntityImage implements Stencil, W
|
||||
return new Ports();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Rectangle2D getInnerPosition(String member, StringBounder stringBounder, InnerStrategy strategy) {
|
||||
final Dimension2D dimTitle = getTitleDimension(stringBounder);
|
||||
final UTranslate translate = UTranslate.dy(dimTitle.getHeight());
|
||||
return translate.apply(fields.getInnerPosition(member, stringBounder, strategy));
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -108,7 +108,7 @@ public class MainWindow extends JFrame {
|
||||
}
|
||||
|
||||
private String getDefaultFileExtensions() {
|
||||
return "txt, tex, java, htm, html, c, h, cpp, apt, pu, puml, hpp, hh";
|
||||
return "txt, tex, java, htm, html, c, h, cpp, apt, pu, puml, hpp, hh, md";
|
||||
}
|
||||
|
||||
private void changeExtensions(String ext) {
|
||||
|
@ -80,7 +80,7 @@ public class Version {
|
||||
}
|
||||
|
||||
public static int beta() {
|
||||
final int beta = 0;
|
||||
final int beta = 1;
|
||||
return beta;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user