com.ibm.wala.util.graph.traverse.NumberedDFSFinishTimeIterator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.ibm.wala.util Show documentation
Show all versions of com.ibm.wala.util Show documentation
T. J. Watson Libraries for Analysis
The newest version!
/*
* Copyright (c) 2002 - 2006 IBM Corporation.
* 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:
* IBM Corporation - initial API and implementation
*/
package com.ibm.wala.util.graph.traverse;
import com.ibm.wala.util.collections.NonNullSingletonIterator;
import com.ibm.wala.util.graph.NumberedGraph;
import java.util.Arrays;
import java.util.Iterator;
import org.jspecify.annotations.Nullable;
/**
* This class implements depth-first search over a NumberedGraph, return an enumeration of the nodes
* of the graph in order of increasing discover time. This class follows the outNodes of the graph
* nodes to define the graph, but this behavior can be changed by overriding the getConnected
* method.
*/
public class NumberedDFSFinishTimeIterator extends DFSFinishTimeIterator {
public static final long serialVersionUID = 8737376661L;
/** An iterator of child nodes for each node being searched */
private Iterator[] pendingChildren;
/** The Graph being traversed */
private final NumberedGraph G;
/**
* Construct a depth-first enumerator starting with a particular node in a directed graph.
*
* @param G the graph whose nodes to enumerate
*/
@SuppressWarnings("unchecked")
NumberedDFSFinishTimeIterator(NumberedGraph G, T N) {
this.G = G;
pendingChildren = new Iterator[G.getMaxNumber() + 1];
init(G, new NonNullSingletonIterator<>(N));
}
/**
* Construct a depth-first enumerator across the (possibly improper) subset of nodes reachable
* from the nodes in the given enumeration.
*
* @param G the graph whose nodes to enumerate
* @param nodes the set of nodes from which to start searching
*/
@SuppressWarnings("unchecked")
NumberedDFSFinishTimeIterator(NumberedGraph G, Iterator extends T> nodes) {
this.G = G;
pendingChildren = new Iterator[G.getMaxNumber() + 1];
init(G, nodes);
}
/** Constructor DFSFinishTimeIterator. */
NumberedDFSFinishTimeIterator(NumberedGraph G) {
this(G, G.iterator());
}
@Override
@Nullable Iterator getPendingChildren(@Nullable T n) {
int number = G.getNumber(n);
if (number >= pendingChildren.length) {
// the graph is probably growing as we travserse
pendingChildren = Arrays.copyOf(pendingChildren, number * 2);
return null;
}
if (number < 0) {
assert false : "negative number for " + n + ' ' + n.getClass();
}
return pendingChildren[number];
}
/** Method setPendingChildren. */
@Override
void setPendingChildren(@Nullable T v, Iterator iterator) {
pendingChildren[G.getNumber(v)] = iterator;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy