-/*******************************************************************************\r
- * Copyright (c) 2007, 2011 Association for Decentralized Information Management\r
- * in Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- * VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.issues.ui.handler;\r
-\r
-import java.io.File;\r
-import java.io.PrintStream;\r
-import java.lang.reflect.InvocationTargetException;\r
-import java.util.Collection;\r
-\r
-import org.eclipse.core.commands.AbstractHandler;\r
-import org.eclipse.core.commands.ExecutionEvent;\r
-import org.eclipse.core.commands.ExecutionException;\r
-import org.eclipse.core.runtime.IProgressMonitor;\r
-import org.eclipse.core.runtime.SubMonitor;\r
-import org.eclipse.core.runtime.preferences.InstanceScope;\r
-import org.eclipse.jface.operation.IRunnableWithProgress;\r
-import org.eclipse.swt.SWT;\r
-import org.eclipse.swt.widgets.FileDialog;\r
-import org.eclipse.swt.widgets.Shell;\r
-import org.eclipse.ui.IWorkbenchWindow;\r
-import org.eclipse.ui.handlers.HandlerUtil;\r
-import org.osgi.service.prefs.BackingStoreException;\r
-import org.osgi.service.prefs.Preferences;\r
-import org.simantics.Simantics;\r
-import org.simantics.browsing.ui.common.ErrorLogger;\r
-import org.simantics.databoard.Bindings;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.common.request.ObjectsWithType;\r
-import org.simantics.db.common.request.ReadRequest;\r
-import org.simantics.db.common.utils.NameUtils;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.variable.Variable;\r
-import org.simantics.db.request.Read;\r
-import org.simantics.issues.common.AllVisibleIssues;\r
-import org.simantics.issues.ui.internal.Activator;\r
-import org.simantics.operation.Layer0X;\r
-import org.simantics.simulation.ontology.SimulationResource;\r
-import org.simantics.utils.DataContainer;\r
-import org.simantics.utils.FileUtils;\r
-import org.simantics.utils.strings.StringUtils;\r
-import org.simantics.utils.ui.ExceptionUtils;\r
-\r
-/**\r
- * @author Tuukka Lehtonen\r
- */\r
-public class ExportIssuesAsCsv extends AbstractHandler {\r
-\r
- private static final String PROP_LAST_VALIDATION_REPORT_PATH= "validation.report.path";\r
-\r
- @Override\r
- public Object execute(ExecutionEvent event) throws ExecutionException {\r
- IWorkbenchWindow window = HandlerUtil.getActiveWorkbenchWindow(event);\r
-\r
- try {\r
- String fileName = generateFileName();\r
- validate(window, fileName);\r
- } catch (DatabaseException e) {\r
- ErrorLogger.defaultLogError(e);\r
- }\r
-\r
- return null;\r
- }\r
-\r
- private String generateFileName() throws DatabaseException {\r
- String generatedName = Simantics.getSession().syncRequest(new Read<String>() {\r
- @Override\r
- public String perform(ReadGraph graph) throws DatabaseException {\r
- Layer0X L0X = Layer0X.getInstance(graph);\r
- SimulationResource SIMU = SimulationResource.getInstance(graph);\r
- for (Resource model : graph.syncRequest(new ObjectsWithType(Simantics.getProjectResource(), L0X.Activates, SIMU.Model))) {\r
- return NameUtils.getSafeName(graph, model) + ".txt";\r
- }\r
- return "issues.txt";\r
- }\r
- });\r
-\r
- if (!FileUtils.isValidFileName(generatedName))\r
- generatedName = (String) Bindings.STR_VARIANT.createUnchecked(Bindings.STRING, generatedName);\r
-\r
- return generatedName;\r
- }\r
-\r
- public void validate(IWorkbenchWindow window, String fileName) {\r
- Preferences prefs = InstanceScope.INSTANCE.getNode(Activator.PLUGIN_ID);\r
- String lastReportPath = prefs.get(PROP_LAST_VALIDATION_REPORT_PATH, null);\r
-\r
- // Query for output path\r
- Shell parentShell = null;\r
- if (window != null)\r
- parentShell = window.getShell();\r
-\r
- final DataContainer<PrintStream> externalOutput = new DataContainer<PrintStream>();\r
-\r
- FileDialog fd = new FileDialog(parentShell, SWT.SAVE);\r
- fd.setText("Select Validation Output");\r
- fd.setFilterExtensions(new String[] { "*.txt", "*.*" });\r
- fd.setFilterNames(new String[] { "Comma-Separated Values (*.txt)", "All Files (*.*)" });\r
- if (lastReportPath != null)\r
- fd.setFilterPath(lastReportPath);\r
- fd.setFileName(fileName);\r
- final String path = fd.open();\r
- if (path != null) {\r
- prefs.put(PROP_LAST_VALIDATION_REPORT_PATH, path);\r
- try {\r
- prefs.flush();\r
- } catch (BackingStoreException e) {\r
- ExceptionUtils.logError(e);\r
- }\r
- } else {\r
-// boolean result = MessageDialog.openQuestion(parentShell, "Print to stdout?", "Would you like to perform model validation and print the results into stdout?");\r
-// if (!result)\r
-// return;\r
-// externalOutput.set(System.out);\r
- return;\r
- }\r
-\r
- try {\r
- window.getWorkbench().getProgressService().busyCursorWhile(new IRunnableWithProgress() {\r
- @Override\r
- public void run(IProgressMonitor monitor) throws InvocationTargetException, InterruptedException {\r
- try {\r
- if (externalOutput.get() == null)\r
- externalOutput.set(new PrintStream(new File(path)));\r
-\r
- final SubMonitor progress = SubMonitor.convert(monitor, "Export issues", IProgressMonitor.UNKNOWN);\r
- Simantics.getSession().syncRequest(new ReadRequest() {\r
- @Override\r
- public void run(ReadGraph graph) throws DatabaseException {\r
- PrintStream out = externalOutput.get();\r
-\r
- Collection<Variable> activeIssues = graph.syncRequest(new AllVisibleIssues(Simantics.getProjectResource()));\r
- out.println("# Exported issues (" + activeIssues.size() + ")");\r
- for (Variable issue : activeIssues) {\r
- String description = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "HasDescription") );\r
- String severity = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "severity") );\r
- String resource = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "resource") );\r
- String path = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "path") );\r
- out.println(description + ";" + severity + ";" + resource + ";" + path);\r
- progress.worked(1);\r
- }\r
- }\r
- });\r
- } catch (Exception e) {\r
- throw new InvocationTargetException(e);\r
- } finally {\r
- monitor.done();\r
- if (externalOutput.get() != System.out)\r
- FileUtils.uncheckedClose(externalOutput.get());\r
- }\r
- }\r
- });\r
- } catch (InvocationTargetException e) {\r
- ExceptionUtils.logAndShowError(e.getTargetException());\r
- } catch (InterruptedException e) {\r
- // Operation cancelled, ignore.\r
- }\r
- }\r
-\r
+/*******************************************************************************
+ * Copyright (c) 2007, 2011 Association for Decentralized Information Management
+ * in Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * VTT Technical Research Centre of Finland - initial API and implementation
+ *******************************************************************************/
+package org.simantics.issues.ui.handler;
+
+import java.io.File;
+import java.io.PrintStream;
+import java.lang.reflect.InvocationTargetException;
+import java.util.Collection;
+import java.util.Map;
+import java.util.Set;
+import java.util.TreeMap;
+
+import org.eclipse.core.commands.AbstractHandler;
+import org.eclipse.core.commands.ExecutionEvent;
+import org.eclipse.core.commands.ExecutionException;
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.core.runtime.SubMonitor;
+import org.eclipse.core.runtime.preferences.InstanceScope;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.widgets.FileDialog;
+import org.eclipse.swt.widgets.Shell;
+import org.eclipse.ui.IWorkbenchWindow;
+import org.eclipse.ui.handlers.HandlerUtil;
+import org.osgi.service.prefs.BackingStoreException;
+import org.osgi.service.prefs.Preferences;
+import org.simantics.Simantics;
+import org.simantics.browsing.ui.common.ErrorLogger;
+import org.simantics.databoard.Bindings;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.common.request.ObjectsWithType;
+import org.simantics.db.common.request.ReadRequest;
+import org.simantics.db.common.utils.NameUtils;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.variable.Variable;
+import org.simantics.db.request.Read;
+import org.simantics.issues.common.AllVisibleIssues;
+import org.simantics.issues.common.DynamicIssueSources;
+import org.simantics.issues.ui.internal.Activator;
+import org.simantics.operation.Layer0X;
+import org.simantics.simulation.ontology.SimulationResource;
+import org.simantics.utils.DataContainer;
+import org.simantics.utils.FileUtils;
+import org.simantics.utils.strings.StringUtils;
+import org.simantics.utils.ui.ExceptionUtils;
+
+/**
+ * @author Tuukka Lehtonen
+ */
+public class ExportIssuesAsCsv extends AbstractHandler {
+
+ private static final String PROP_LAST_VALIDATION_REPORT_PATH= "validation.report.path";
+
+ @Override
+ public Object execute(ExecutionEvent event) throws ExecutionException {
+ IWorkbenchWindow window = HandlerUtil.getActiveWorkbenchWindow(event);
+
+ try {
+ String fileName = generateFileName();
+ validate(window, fileName);
+ } catch (DatabaseException e) {
+ ErrorLogger.defaultLogError(e);
+ }
+
+ return null;
+ }
+
+ private String generateFileName() throws DatabaseException {
+ String generatedName = Simantics.getSession().syncRequest(new Read<String>() {
+ @Override
+ public String perform(ReadGraph graph) throws DatabaseException {
+ Layer0X L0X = Layer0X.getInstance(graph);
+ SimulationResource SIMU = SimulationResource.getInstance(graph);
+ for (Resource model : graph.syncRequest(new ObjectsWithType(Simantics.getProjectResource(), L0X.Activates, SIMU.Model))) {
+ return NameUtils.getSafeName(graph, model) + ".txt";
+ }
+ return "issues.txt";
+ }
+ });
+
+ if (!FileUtils.isValidFileName(generatedName))
+ generatedName = (String) Bindings.STR_VARIANT.createUnchecked(Bindings.STRING, generatedName);
+
+ return generatedName;
+ }
+
+ public void validate(IWorkbenchWindow window, String fileName) {
+ Preferences prefs = InstanceScope.INSTANCE.getNode(Activator.PLUGIN_ID);
+ String lastReportPath = prefs.get(PROP_LAST_VALIDATION_REPORT_PATH, null);
+
+ // Query for output path
+ Shell parentShell = null;
+ if (window != null)
+ parentShell = window.getShell();
+
+ final DataContainer<PrintStream> externalOutput = new DataContainer<PrintStream>();
+
+ FileDialog fd = new FileDialog(parentShell, SWT.SAVE);
+ fd.setText("Select Validation Output");
+ fd.setFilterExtensions(new String[] { "*.txt", "*.*" });
+ fd.setFilterNames(new String[] { "Comma-Separated Values (*.txt)", "All Files (*.*)" });
+ if (lastReportPath != null)
+ fd.setFilterPath(lastReportPath);
+ fd.setFileName(fileName);
+ final String path = fd.open();
+ if (path != null) {
+ prefs.put(PROP_LAST_VALIDATION_REPORT_PATH, path);
+ try {
+ prefs.flush();
+ } catch (BackingStoreException e) {
+ ExceptionUtils.logError(e);
+ }
+ } else {
+ return;
+ }
+
+ try {
+ window.getWorkbench().getProgressService().busyCursorWhile(monitor -> {
+ try (PrintStream out = new PrintStream(new File(path))) {
+ export(monitor, out);
+ } catch (Exception e) {
+ throw new InvocationTargetException(e);
+ } finally {
+ monitor.done();
+ }
+ });
+ } catch (InvocationTargetException e) {
+ ExceptionUtils.logAndShowError(e.getTargetException());
+ } catch (InterruptedException e) {
+ // Operation cancelled, ignore.
+ }
+ }
+
+ private void export(IProgressMonitor monitor, PrintStream out) throws DatabaseException {
+ SubMonitor progress = SubMonitor.convert(monitor, "Export issues", IProgressMonitor.UNKNOWN);
+ Simantics.getSession().syncRequest(new ReadRequest() {
+ @Override
+ public void run(ReadGraph graph) throws DatabaseException {
+ Collection<Variable> activeIssues = graph.syncRequest(new AllVisibleIssues(Simantics.getProjectResource()));
+ out.println("# Exported issues (" + activeIssues.size() + ")");
+ for (Variable issue : activeIssues) {
+ exportIssue(graph, issue, out, 0);
+ progress.worked(1);
+ }
+
+ Map<String, Variable> dynamicIssueSources = nameMap(graph,
+ graph.syncRequest(new DynamicIssueSources(Simantics.getProjectResource())));
+ if (!dynamicIssueSources.isEmpty()) {
+ out.println();
+ out.println("# Dynamic Issues");
+ for (Variable source : dynamicIssueSources.values()) {
+ exportDynamicIssueSource(progress, graph, source, out, 0);
+ }
+ }
+ }
+ });
+ }
+
+ private Map<String, Variable> nameMap(ReadGraph graph, Set<Variable> sources) throws DatabaseException {
+ TreeMap<String, Variable> sorted = new TreeMap<>();
+ for (Variable v : sources) {
+ String name = v.getPossiblePropertyValue(graph, "HasDescription", Bindings.STRING);
+ if (name == null)
+ name = v.getName(graph);
+ sorted.put(name, v);
+ }
+ return sorted;
+ }
+
+ protected void exportDynamicIssueSource(IProgressMonitor monitor, ReadGraph graph, Variable issue, PrintStream out, int startColumn) throws DatabaseException {
+ exportIssue(graph, issue, out, startColumn);
+ for (Variable child : issue.getChildren(graph)) {
+ exportDynamicIssueSource(monitor, graph, child, out, startColumn+1);
+ monitor.worked(1);
+ }
+ }
+
+ private void exportIssue(ReadGraph graph, Variable issue, PrintStream out, int startColumn) throws DatabaseException {
+ String description = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "HasDescription") );
+ String severity = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "severity") );
+ String resource = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "resource") );
+ String path = StringUtils.safeString( (String) issue.getPossiblePropertyValue(graph, "path") );
+ for (int i = 0; i < startColumn; ++i)
+ out.print(";");
+ out.println(description + ";" + severity + ";" + resource + ";" + path);
+ }
+
}
\ No newline at end of file