-/*******************************************************************************\r
- * Copyright (c) 2012 Association for Decentralized Information Management in\r
- * 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.annotation.ui.wizard;\r
-\r
-import java.io.File;\r
-import java.io.IOException;\r
-import java.lang.reflect.InvocationTargetException;\r
-import java.util.Set;\r
-\r
-import org.eclipse.core.runtime.IProgressMonitor;\r
-import org.eclipse.core.runtime.NullProgressMonitor;\r
-import org.eclipse.core.runtime.SubMonitor;\r
-import org.eclipse.jface.operation.IRunnableWithProgress;\r
-import org.simantics.Simantics;\r
-import org.simantics.databoard.binding.error.BindingException;\r
-import org.simantics.databoard.binding.mutable.Variant;\r
-import org.simantics.databoard.container.DataContainer;\r
-import org.simantics.databoard.container.DataContainers;\r
-import org.simantics.databoard.serialization.SerializationException;\r
-import org.simantics.db.ReadGraph;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.Session;\r
-import org.simantics.db.common.utils.Logger;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.adapter.CopyHandler;\r
-import org.simantics.db.layer0.util.ClipboardUtils;\r
-import org.simantics.db.layer0.util.SimanticsClipboard;\r
-import org.simantics.db.layer0.util.SimanticsClipboard.Representation;\r
-import org.simantics.db.layer0.util.SimanticsClipboardImpl;\r
-import org.simantics.db.layer0.util.SimanticsKeys;\r
-import org.simantics.db.request.Read;\r
-import org.simantics.graph.representation.TransferableGraph1;\r
-import org.simantics.utils.ui.dialogs.ShowMessage;\r
-\r
-/**\r
- * @author Tuukka Lehtonen\r
- * @author Teemu Mätäsniemi\r
- */\r
-public class AnnotationTypeExporter implements IRunnableWithProgress {\r
-\r
- ExportPlan exportModel;\r
-\r
- public AnnotationTypeExporter(ExportPlan exportModel) {\r
- this.exportModel = exportModel;\r
- }\r
-\r
- @Override\r
- public void run(IProgressMonitor monitor) throws InvocationTargetException, InterruptedException {\r
- SubMonitor progress = SubMonitor.convert(monitor, 50);\r
- try {\r
- exportModel(progress.newChild(50, SubMonitor.SUPPRESS_NONE));\r
- } catch (IOException e) {\r
- throw new InvocationTargetException(e);\r
- } catch (DatabaseException e) {\r
- throw new InvocationTargetException(e);\r
- } catch (BindingException e) {\r
- throw new InvocationTargetException(e);\r
- } finally {\r
- monitor.done();\r
- }\r
- }\r
-\r
- void exportModel(SubMonitor mon) throws IOException, DatabaseException, SerializationException, BindingException{\r
- try {\r
- doExport(mon, exportModel.exportLocation, exportModel.model.getResource());\r
-\r
- } catch (DatabaseException e) {\r
- e.printStackTrace();\r
- Logger.defaultLogError(e);\r
- mon.setCanceled(true);\r
- ShowMessage.showError("Export failed.", "Internal application error in export. See log for details.");\r
- } finally {\r
- mon.setWorkRemaining(0);\r
- }\r
- }\r
- \r
- public static void doExport(File location, Resource annotation) throws DatabaseException, IOException {\r
- NullProgressMonitor monitor = new NullProgressMonitor();\r
- doExport(monitor, location, annotation);\r
- }\r
- \r
- public static void doExport(IProgressMonitor monitor, File location, final Resource annotation) throws DatabaseException, IOException {\r
- // TODO: figure out a way to make the TG go directly into a file\r
- // instead of having it all in memory at once.\r
-\r
- monitor.beginTask("Exporting annotation type...", 100);\r
- Session session = Simantics.getSession();\r
- SimanticsClipboard clipboard = session.syncRequest(new Read<SimanticsClipboard>() {\r
- @Override\r
- public SimanticsClipboard perform(ReadGraph graph) throws DatabaseException {\r
- CopyHandler ch = graph.adapt(annotation, CopyHandler.class);\r
- SimanticsClipboardImpl clipboard = new SimanticsClipboardImpl();\r
- ch.copyToClipboard(graph, clipboard);\r
- return clipboard;\r
- }\r
- });\r
- for (Set<Representation> object : clipboard.getContents()) {\r
- TransferableGraph1 tg = ClipboardUtils.accept(object, SimanticsKeys.KEY_TRANSFERABLE_GRAPH);\r
- monitor.worked(95);\r
-\r
- monitor.setTaskName("Writing transferable graph...");\r
- DataContainers.writeFile(location, new DataContainer(\r
- Constants.ANNOTATION_TYPE_FORMAT, Constants.ANNOTATION_TYPE_CURRENT_VERSION,\r
- new Variant(TransferableGraph1.BINDING, tg)));\r
-\r
- monitor.worked(5);\r
- }\r
- } \r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2012 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.annotation.ui.wizard;
+
+import java.io.File;
+import java.io.IOException;
+import java.lang.reflect.InvocationTargetException;
+import java.util.Set;
+
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.core.runtime.NullProgressMonitor;
+import org.eclipse.core.runtime.SubMonitor;
+import org.eclipse.jface.operation.IRunnableWithProgress;
+import org.simantics.Simantics;
+import org.simantics.databoard.binding.error.BindingException;
+import org.simantics.databoard.binding.mutable.Variant;
+import org.simantics.databoard.container.DataContainer;
+import org.simantics.databoard.container.DataContainers;
+import org.simantics.databoard.serialization.SerializationException;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.Session;
+import org.simantics.db.common.utils.Logger;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.adapter.CopyHandler;
+import org.simantics.db.layer0.util.ClipboardUtils;
+import org.simantics.db.layer0.util.SimanticsClipboard;
+import org.simantics.db.layer0.util.SimanticsClipboard.Representation;
+import org.simantics.db.layer0.util.SimanticsClipboardImpl;
+import org.simantics.db.layer0.util.SimanticsKeys;
+import org.simantics.db.request.Read;
+import org.simantics.graph.representation.TransferableGraph1;
+import org.simantics.utils.ui.dialogs.ShowMessage;
+
+/**
+ * @author Tuukka Lehtonen
+ * @author Teemu Mätäsniemi
+ */
+public class AnnotationTypeExporter implements IRunnableWithProgress {
+
+ ExportPlan exportModel;
+
+ public AnnotationTypeExporter(ExportPlan exportModel) {
+ this.exportModel = exportModel;
+ }
+
+ @Override
+ public void run(IProgressMonitor monitor) throws InvocationTargetException, InterruptedException {
+ SubMonitor progress = SubMonitor.convert(monitor, 50);
+ try {
+ exportModel(progress.newChild(50, SubMonitor.SUPPRESS_NONE));
+ } catch (IOException e) {
+ throw new InvocationTargetException(e);
+ } catch (DatabaseException e) {
+ throw new InvocationTargetException(e);
+ } catch (BindingException e) {
+ throw new InvocationTargetException(e);
+ } finally {
+ monitor.done();
+ }
+ }
+
+ void exportModel(SubMonitor mon) throws IOException, DatabaseException, SerializationException, BindingException{
+ try {
+ doExport(mon, exportModel.exportLocation, exportModel.model.getResource());
+
+ } catch (DatabaseException e) {
+ e.printStackTrace();
+ Logger.defaultLogError(e);
+ mon.setCanceled(true);
+ ShowMessage.showError("Export failed.", "Internal application error in export. See log for details.");
+ } finally {
+ mon.setWorkRemaining(0);
+ }
+ }
+
+ public static void doExport(File location, Resource annotation) throws DatabaseException, IOException {
+ NullProgressMonitor monitor = new NullProgressMonitor();
+ doExport(monitor, location, annotation);
+ }
+
+ public static void doExport(IProgressMonitor monitor, File location, final Resource annotation) throws DatabaseException, IOException {
+ // TODO: figure out a way to make the TG go directly into a file
+ // instead of having it all in memory at once.
+
+ monitor.beginTask("Exporting annotation type...", 100);
+ Session session = Simantics.getSession();
+ SimanticsClipboard clipboard = session.syncRequest(new Read<SimanticsClipboard>() {
+ @Override
+ public SimanticsClipboard perform(ReadGraph graph) throws DatabaseException {
+ CopyHandler ch = graph.adapt(annotation, CopyHandler.class);
+ SimanticsClipboardImpl clipboard = new SimanticsClipboardImpl();
+ ch.copyToClipboard(graph, clipboard);
+ return clipboard;
+ }
+ });
+ for (Set<Representation> object : clipboard.getContents()) {
+ TransferableGraph1 tg = ClipboardUtils.accept(object, SimanticsKeys.KEY_TRANSFERABLE_GRAPH);
+ monitor.worked(95);
+
+ monitor.setTaskName("Writing transferable graph...");
+ DataContainers.writeFile(location, new DataContainer(
+ Constants.ANNOTATION_TYPE_FORMAT, Constants.ANNOTATION_TYPE_CURRENT_VERSION,
+ new Variant(TransferableGraph1.BINDING, tg)));
+
+ monitor.worked(5);
+ }
+ }
+}