/* * Hibernate, Relational Persistence for Idiomatic Java * * License: GNU Lesser General Public License (LGPL), version 2.1 or later. * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.envers.internal.tools.graph; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.List; /** * Topological sorting of a graph - based on DFS. * * @author Adam Warski (adam at warski dot org) */ public class TopologicalSort<R> { private List<R> sorted; private int time; private void process(Vertex<R> v) { if ( v.getStartTime() != 0 ) { // alread processed return; } v.setStartTime( time++ ); for ( Vertex<R> n : v.getNeighbours() ) { process( n ); } v.setEndTime( time++ ); sorted.add( v.getRepresentation() ); } public List<R> sort(Collection<Vertex<R>> vertices) { sorted = new ArrayList<>( vertices.size() ); time = 1; for ( Vertex<R> v : vertices ) { if ( v.getEndTime() == 0 ) { process( v ); } } Collections.reverse( sorted ); return sorted; } }