| Index: src/platform/update_engine/topological_sort.h
|
| diff --git a/src/platform/update_engine/topological_sort.h b/src/platform/update_engine/topological_sort.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d4a54464941d388143bd5a4ea195a80d33f8afc5
|
| --- /dev/null
|
| +++ b/src/platform/update_engine/topological_sort.h
|
| @@ -0,0 +1,30 @@
|
| +// Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef CHROMEOS_PLATFORM_UPDATE_ENGINE_TOPOLOGICAL_SORT_H__
|
| +#define CHROMEOS_PLATFORM_UPDATE_ENGINE_TOPOLOGICAL_SORT_H__
|
| +
|
| +
|
| +#include <vector>
|
| +#include "update_engine/graph_types.h"
|
| +
|
| +namespace chromeos_update_engine {
|
| +
|
| +// Performs a topological sort on the directed graph 'graph' and stores
|
| +// the nodes, in order visited, in 'out'.
|
| +// For example, this graph:
|
| +// A ---> C ----.
|
| +// \ v
|
| +// `--> B --> D
|
| +// Might result in this in 'out':
|
| +// out[0] = D
|
| +// out[1] = B
|
| +// out[2] = C
|
| +// out[3] = A
|
| +// Note: results are undefined if there is a cycle in the graph.
|
| +void TopologicalSort(const Graph& graph, std::vector<Vertex::Index>* out);
|
| +
|
| +} // namespace chromeos_update_engine
|
| +
|
| +#endif // CHROMEOS_PLATFORM_UPDATE_ENGINE_TOPOLOGICAL_SORT_H__
|
|
|