diff --git a/java/src/main/java/org/softwareheritage/graph/Entry.java b/java/src/main/java/org/softwareheritage/graph/Entry.java --- a/java/src/main/java/org/softwareheritage/graph/Entry.java +++ b/java/src/main/java/org/softwareheritage/graph/Entry.java @@ -1,13 +1,13 @@ package org.softwareheritage.graph; -import com.fasterxml.jackson.databind.ObjectMapper; -import com.fasterxml.jackson.databind.PropertyNamingStrategy; - import java.io.DataOutputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.PropertyNamingStrategy; + public class Entry { private final long PATH_SEPARATOR_ID = -1; private Graph graph; @@ -112,24 +112,30 @@ } } - public void leaves(String direction, String edgesFmt, long srcNodeId) { + public void leaves(String direction, String edgesFmt, long srcNodeId, String returnTypes) { open(); - Traversal t = new Traversal(this.graph, direction, edgesFmt); - t.leavesVisitor(srcNodeId, this::writeNode); + Traversal t = new Traversal(this.graph, direction, edgesFmt, returnTypes); + for (Long nodeId : t.leaves(srcNodeId)) { + writeNode(nodeId); + } close(); } - public void neighbors(String direction, String edgesFmt, long srcNodeId) { + public void neighbors(String direction, String edgesFmt, long srcNodeId, String returnTypes) { open(); - Traversal t = new Traversal(this.graph, direction, edgesFmt); - t.neighborsVisitor(srcNodeId, this::writeNode); + Traversal t = new Traversal(this.graph, direction, edgesFmt, returnTypes); + for (Long nodeId : t.neighbors(srcNodeId)) { + writeNode(nodeId); + } close(); } - public void visit_nodes(String direction, String edgesFmt, long srcNodeId) { + public void visit_nodes(String direction, String edgesFmt, long srcNodeId, String returnTypes) { open(); - Traversal t = new Traversal(this.graph, direction, edgesFmt); - t.visitNodesVisitor(srcNodeId, this::writeNode); + Traversal t = new Traversal(this.graph, direction, edgesFmt, returnTypes); + for (Long nodeId : t.visitNodes(srcNodeId)) { + writeNode(nodeId); + } close(); } @@ -166,19 +172,21 @@ close(); } - public void random_walk(String direction, String edgesFmt, int retries, long srcNodeId, long dstNodeId) { + public void random_walk(String direction, String edgesFmt, int retries, long srcNodeId, long dstNodeId, + String returnTypes) { open(); - Traversal t = new Traversal(this.graph, direction, edgesFmt); + Traversal t = new Traversal(this.graph, direction, edgesFmt, returnTypes); for (Long nodeId : t.randomWalk(srcNodeId, dstNodeId, retries)) { writeNode(nodeId); } close(); } - public void random_walk_type(String direction, String edgesFmt, int retries, long srcNodeId, String dst) { + public void random_walk_type(String direction, String edgesFmt, int retries, long srcNodeId, String dst, + String returnTypes) { open(); Node.Type dstType = Node.Type.fromStr(dst); - Traversal t = new Traversal(this.graph, direction, edgesFmt); + Traversal t = new Traversal(this.graph, direction, edgesFmt, returnTypes); for (Long nodeId : t.randomWalk(srcNodeId, dstType, retries)) { writeNode(nodeId); } diff --git a/java/src/main/java/org/softwareheritage/graph/NodesFiltering.java b/java/src/main/java/org/softwareheritage/graph/NodesFiltering.java new file mode 100644 --- /dev/null +++ b/java/src/main/java/org/softwareheritage/graph/NodesFiltering.java @@ -0,0 +1,107 @@ +package org.softwareheritage.graph; + +import java.util.ArrayList; + +/** + *
+ * class that manages the filtering of nodes that have been returned after a visit of the graph. + * parameterized by a string that represents either no filtering (*) or a set of node types. + *
+ * + *+ * {@code + * Long id1 = .... // graph.getNodeType(id1) == CNT + * Long id2 = .... // graph.getNodeType(id2) == SNP + * Long id3 = .... // graph.getNodeType(id3) == ORI + * ArrayList+ */ + +public class NodesFiltering { + + boolean restricted; + ArrayListnodeIds = nez ArrayList (); + * nodeIds.add(id1); nodeIds.add(id2); nodeIds.add(id3); + * + * NodeFiltering nds = new NodesFiltering("snp,ori"); // we allow only snp node types to be shown + * System.out.println(nds.filterByNodeTypes(nodeIds,graph)); // will print id2, id3 + * + * nds = NodesFiltering("*"); + * System.out.println(nds.filterByNodeTypes(nodeIds,graph)); // will print id1, id2 id3 + * + * } + *
+ * the function that filters the nodes returned, we browse the list of nodes found after a visit and + * we create a new list with only the nodes that have a type that is contained in the list of + * allowed types (allowedNodesTypes) + *
+ * + * @param nodeIds the nodes founded during the visit + * @param g the graph in order to find the types of nodes from their id in nodeIds + * @return a new list with the id of node which have a type in allowedTypes + * + * + */ + public ArrayList
@@ -30,6 +40,9 @@
/** Number of edges accessed during traversal */
long nbEdgesAccessed;
+ /** The string represent the set of type restriction */
+ NodesFiltering ndsfilter;
+
/** random number generator, for random walks */
Random rng;
@@ -42,7 +55,12 @@
* "https://docs.softwareheritage.org/devel/swh-graph/api.html#terminology">allowed
* edges
*/
+
public Traversal(Graph graph, String direction, String edgesFmt) {
+ this(graph, direction, edgesFmt, "*");
+ }
+
+ public Traversal(Graph graph, String direction, String edgesFmt, String returnTypes) {
if (!direction.matches("forward|backward")) {
throw new IllegalArgumentException("Unknown traversal direction: " + direction);
}
@@ -58,6 +76,12 @@
this.parentNode = new HashMap<>();
this.nbEdgesAccessed = 0;
this.rng = new Random();
+
+ if (returnTypes.equals("*")) {
+ this.ndsfilter = new NodesFiltering();
+ } else {
+ this.ndsfilter = new NodesFiltering(returnTypes);
+ }
}
/**
@@ -115,8 +139,11 @@
* @return list of node ids corresponding to the leaves
*/
public ArrayList