import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.nio.file.Path;
-import java.nio.file.Paths;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.SubMonitor;
import org.simantics.Simantics;
import org.simantics.databoard.binding.error.BindingException;
import org.simantics.databoard.serialization.SerializationException;
-import org.simantics.db.common.utils.Logger;
+import org.simantics.db.ReadGraph;
import org.simantics.db.exception.DatabaseException;
import org.simantics.graph.refactoring.FixExportedOntology;
import org.simantics.modeling.ModelingUtils;
import org.simantics.modeling.ModelingUtils.LibraryInfo;
+import org.simantics.modeling.utils.DumpOntologyStructure;
import org.simantics.utils.ui.dialogs.ShowMessage;
import org.slf4j.LoggerFactory;
public class SharedOntologyExporter implements IRunnableWithProgress {
private static final org.slf4j.Logger LOGGER = LoggerFactory.getLogger(SharedOntologyExporter.class);
+
ExportPlan exportModel;
public SharedOntologyExporter(ExportPlan exportModel) {
void exportModel(SubMonitor mon) throws IOException, DatabaseException, SerializationException, BindingException{
try {
- doExport(mon, exportModel.exportLocation, exportModel.model, exportModel.tgAndPgraph);
-
+ doExport(mon, exportModel.exportLocation, exportModel.model, exportModel.writeTransferableGraph, exportModel.dumpStructure);
} catch (DatabaseException e) {
- e.printStackTrace();
- Logger.defaultLogError(e);
+ LOGGER.error("Failed to export shared ontology", 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(IProgressMonitor monitor, File location, final LibraryInfo info) throws DatabaseException, IOException {
- doExport(monitor, location, info, false);
+
+ public static void doExport(IProgressMonitor monitor, File location, LibraryInfo info) throws DatabaseException, IOException {
+ doExport(monitor, location, info, false, false);
}
-
- public static void doExport(IProgressMonitor monitor, File location, final LibraryInfo info, boolean pgraphAndTg) throws DatabaseException, IOException {
- ModelingUtils.exportSharedOntology(monitor, Simantics.getSession(), location,Constants.SHARED_LIBRARY_FORMAT, Constants.SHARED_LIBRARY_CURRENT_VERSION, info);
- if (pgraphAndTg) {
+
+ public static void doExport(IProgressMonitor monitor, File location, LibraryInfo info, boolean writeTg, boolean dumpStructure) throws DatabaseException, IOException {
+ int work = 1 + (writeTg ? 1 : 0) + (dumpStructure ? 1 : 0);
+ SubMonitor mon = SubMonitor.convert(monitor, work);
+
+ ModelingUtils.exportSharedOntology(mon.split(1, SubMonitor.SUPPRESS_NONE), Simantics.getSession(), location, Constants.SHARED_LIBRARY_FORMAT, Constants.SHARED_LIBRARY_CURRENT_VERSION, info);
+
+ Path input = location.toPath();
+
+ if (writeTg) {
try {
- Path input = Paths.get(location.toURI());
- FixExportedOntology.createTGAndPGraph(input);
+ mon.subTask("Writing transferable graph");
+ FixExportedOntology.createTGAndPGraph(input, false);
+ mon.worked(1);
} catch (Exception e) {
- LOGGER.error("Could not generate TG and Pgraph", e);
+ LOGGER.error("Could not generate Transferable Graph", e);
}
- }
+ }
+ if (dumpStructure) {
+ try {
+ monitor.subTask("Dumping library structure");
+ DumpOntologyStructure data = Simantics.getSession().syncRequest((ReadGraph graph) -> {
+ return new DumpOntologyStructure().read(graph, info.library.getResource());
+ });
+ data.write(new File(new File(location.getParent(), location.getName() + ".dump"), info.library.getName()));
+ mon.worked(1);
+ } catch (Exception e) {
+ LOGGER.error("Could not generate shared library structure dump", e);
+ }
+ }
}
-
+
}