X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.graph%2Fsrc%2Forg%2Fsimantics%2Fgraph%2Frefactoring%2FFixExportedOntology.java;h=33291cdf108e75cef32b35e64e69b19d8583c589;hb=HEAD;hp=65e7f956e48190c86201de421edbd4dff983de00;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.graph/src/org/simantics/graph/refactoring/FixExportedOntology.java b/bundles/org.simantics.graph/src/org/simantics/graph/refactoring/FixExportedOntology.java index 65e7f956e..33291cdf1 100644 --- a/bundles/org.simantics.graph/src/org/simantics/graph/refactoring/FixExportedOntology.java +++ b/bundles/org.simantics.graph/src/org/simantics/graph/refactoring/FixExportedOntology.java @@ -1,41 +1,81 @@ -package org.simantics.graph.refactoring; - -import java.io.BufferedInputStream; -import java.io.DataInput; -import java.io.DataInputStream; -import java.io.File; -import java.io.FileInputStream; -import java.io.InputStream; - -import org.simantics.databoard.binding.Binding; -import org.simantics.databoard.binding.mutable.Variant; -import org.simantics.databoard.container.DataContainer; -import org.simantics.databoard.container.DataContainers; -import org.simantics.graph.representation.TransferableGraph1; - -public class FixExportedOntology { - - public static void main(String[] args) throws Exception { - -// File input = new File("E:/work/workspace/apros-head/fi.semantum.simupedia.feature/rootfiles/sharedlibraries/SimupediaStandardLibrary-1.3-trunk.sharedLibrary"); - File input = new File("E:/work/workspace/apros-head/fi.semantum.simupedia.feature/rootfiles/sharedlibraries/AprosSimupedia-1.3-trunk.sharedLibrary"); - File output = new File(input.getParentFile(), input.getName() + ".fixed"); - InputStream is = new FileInputStream(input); - - is = new BufferedInputStream(is, 128*1024); - - DataInput dis = new DataInputStream(is); - org.simantics.databoard.container.DataContainer container = - DataContainers.readFile(dis); - Binding binding = TransferableGraph1.BINDING; - TransferableGraph1 graph = (TransferableGraph1)container.content.getValue(binding); - GraphRefactoringUtils.fixOntologyExport(graph); - - DataContainers.writeFile(output, new DataContainer( - container.format, container.version, - container.metadata, new Variant(TransferableGraph1.BINDING, graph))); - - } - - -} +package org.simantics.graph.refactoring; + +import java.io.BufferedInputStream; +import java.io.DataInputStream; +import java.io.InputStream; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.nio.file.StandardOpenOption; + +import org.simantics.databoard.binding.Binding; +import org.simantics.databoard.container.DataContainer; +import org.simantics.databoard.container.DataContainers; +import org.simantics.graph.representation.PrettyPrintTG; +import org.simantics.graph.representation.TransferableGraph1; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +/** + * @author Antti Villberg + * @since 1.24.0 + */ +public class FixExportedOntology { + + private static final Logger LOGGER = LoggerFactory.getLogger(FixExportedOntology.class); + + static TransferableGraph1 convertExportedSharedOntologyIntoBundleOntology(Path input, Path output) throws Exception { + LOGGER.info("Converting exported shared ontology\n\t{}\nto bundle-compatible ontology\n\t{}", input.toString(), output.toString()); + try (InputStream is = new BufferedInputStream(Files.newInputStream(input), 128*1024)) { + Binding tgBinding = TransferableGraph1.BINDING; + DataContainer container = DataContainers.readFile(new DataInputStream(is), tgBinding); + TransferableGraph1 graph = (TransferableGraph1) container.content.getValue(tgBinding); + + GraphRefactoringUtils.fixOntologyExport(graph); + container = TransferableGraphHasher.addHashToTG(container, graph); + + DataContainers.writeFile(output.toFile(), container); + return graph; + } + } + + private static Path replaceExtension(Path p, String newExtension) { + String newName = p.getFileName().toString(); + int lastDot = newName.lastIndexOf('.'); + if (lastDot > -1) + newName = newName.substring(0, lastDot); + return p.resolveSibling(newName + newExtension); + } + + private static void createTg(Path input, Path output) throws Exception { + convertExportedSharedOntologyIntoBundleOntology(input, output); + } + + public static void createTg(Path input) throws Exception { + createTg(input, replaceExtension(input, ".tg")); + } + + public static void createTGAndPGraph(Path input) throws Exception { + createTGAndPGraph(input, true); + } + + public static void createTGAndPGraph(Path input, boolean writePGraph) throws Exception { + TransferableGraph1 tg = convertExportedSharedOntologyIntoBundleOntology(input, replaceExtension(input, ".tg")); + if (writePGraph) { + String listing = PrettyPrintTG.print(tg, false); + Files.write(replaceExtension(input, ".pgraph"), listing.getBytes(),StandardOpenOption.CREATE); + } + } + + public static void main(String[] args) throws Exception { + if (args.length == 0) { + System.out.println("Required arguments: []"); + } else if (args.length == 1) { + Path input = Paths.get(args[0]); + createTGAndPGraph(input); + } else { + convertExportedSharedOntologyIntoBundleOntology(Paths.get(args[0]), Paths.get(args[1])); + } + } + +}