I have very simple graph
strict digraph G {
;
;
;
If you are using the 1.4.1 SNAPSHOT release (or beyond), there's an easier way to obtain the desired result: simply use importer.setVertexFactory(id->id);
Only in case the user supplies such as factory, it is called with the vertex identifier from the file. The method given the vertex identifier from the file should return an actual graph vertex. The user returned vertex is added directly into the graph without using the vertex supplier.
If no such factory is provided, the default behavior is to acquire a new vertex from the graph vertex supplier and associate the original identifier from the file as an attribute of the new vertex.
Applying this to the above example, we get:
String input="strict digraph G {\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
"}";
Graph graph = new SimpleDirectedGraph<>(DefaultEdge.class);
DOTImporter importer = new DOTImporter<>();
importer.setVertexFactory(id->id);
importer.importGraph(graph, new StringReader(input));
System.out.println(graph);
Here's one way to do it. This approach uses 2 steps. In the first step, I read the graph as you did. The vertex names can be stored in an attribute map. In the second step I create a new graph which uses the structure of the first graph, but renames the vertices.
String input="strict digraph G {\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
" -> ;\n" +
"}";
Graph graph = new SimpleDirectedGraph<>(SupplierUtil.createStringSupplier(), SupplierUtil.DEFAULT_EDGE_SUPPLIER, false);
//Import the graph; the vertex names are stored as 'ID' in the attribute map
DOTImporter importer = new DOTImporter<>();
Map> attrs = new HashMap<>();
importer.addVertexAttributeConsumer((p, a) -> {
Map map = attrs.computeIfAbsent(p.getFirst(), k -> new HashMap<>());
map.put(p.getSecond(), a);
});
importer.importGraph(graph, new StringReader(input));
//Create a new graph, thereby creating String vertices equal to the ID attribute values
Graph labeledGraph=new SimpleDirectedGraph<>(DefaultEdge.class);
for(String v : graph.vertexSet())
labeledGraph.addVertex(attrs.get(v).get("ID").getValue());
for(DefaultEdge e : graph.edgeSet()){
String source = graph.getEdgeSource(e);
String target = graph.getEdgeTarget(e);
String sourceID=attrs.get(source).get("ID").getValue();
String targetID=attrs.get(target).get("ID").getValue();
labeledGraph.addEdge(sourceID, targetID);
}
System.out.println(labeledGraph);