~aleteoryx/muditaos

muditaos/module-sys/SystemManager/DependencyGraph.cpp -rw-r--r-- 990 bytes
a405cad6Aleteoryx trim readme 6 days ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// Copyright (c) 2017-2024, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/blob/master/LICENSE.md

#include <SystemManager/DependencyGraph.hpp>

#include <algorithm>
#include <cassert>

namespace sys
{
    namespace graph
    {
        Nodes nodesFrom(const std::vector<std::unique_ptr<BaseServiceCreator>> &services)
        {
            Nodes nodes;
            nodes.reserve(services.size());
            std::transform(services.begin(), services.end(), std::back_inserter(nodes), [](const auto &service) {
                return std::ref(*service);
            });
            return nodes;
        }
    } // namespace graph

    DependencyGraph::DependencyGraph(graph::Nodes nodes, std::unique_ptr<DependencySortingStrategy> &&strategy)
        : nodes{std::move(nodes)}, strategy{std::move(strategy)}
    {}

    auto DependencyGraph::sort() const -> graph::Nodes
    {
        return strategy->sort(nodes);
    }
} // namespace sys