1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- //
- // Copyright (C) 2010 The Android Open Source Project
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- //
- #ifndef UPDATE_ENGINE_PAYLOAD_GENERATOR_TARJAN_H_
- #define UPDATE_ENGINE_PAYLOAD_GENERATOR_TARJAN_H_
- // This is an implementation of Tarjan's algorithm which finds all
- // Strongly Connected Components in a graph.
- // Note: a true Tarjan algorithm would find all strongly connected components
- // in the graph. This implementation will only find the strongly connected
- // component containing the vertex passed in.
- #include <vector>
- #include "update_engine/payload_generator/graph_types.h"
- namespace chromeos_update_engine {
- class TarjanAlgorithm {
- public:
- TarjanAlgorithm() : index_(0), required_vertex_(0) {}
- // 'out' is set to the result if there is one, otherwise it's untouched.
- void Execute(Vertex::Index vertex,
- Graph* graph,
- std::vector<Vertex::Index>* out);
- private:
- void Tarjan(Vertex::Index vertex, Graph* graph);
- Vertex::Index index_;
- Vertex::Index required_vertex_;
- std::vector<Vertex::Index> stack_;
- std::vector<std::vector<Vertex::Index>> components_;
- };
- } // namespace chromeos_update_engine
- #endif // UPDATE_ENGINE_PAYLOAD_GENERATOR_TARJAN_H_
|