114cf0368Sopenharmony_ci/*
214cf0368Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
314cf0368Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
414cf0368Sopenharmony_ci * you may not use this file except in compliance with the License.
514cf0368Sopenharmony_ci * You may obtain a copy of the License at
614cf0368Sopenharmony_ci *
714cf0368Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
814cf0368Sopenharmony_ci *
914cf0368Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
1014cf0368Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
1114cf0368Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1214cf0368Sopenharmony_ci * See the License for the specific language governing permissions and
1314cf0368Sopenharmony_ci * limitations under the License.
1414cf0368Sopenharmony_ci */
1514cf0368Sopenharmony_ci
1614cf0368Sopenharmony_ci#ifndef UDMF_GRAPH_H
1714cf0368Sopenharmony_ci#define UDMF_GRAPH_H
1814cf0368Sopenharmony_ci
1914cf0368Sopenharmony_ci#include <map>
2014cf0368Sopenharmony_ci#include <vector>
2114cf0368Sopenharmony_ci#include <iostream>
2214cf0368Sopenharmony_ci#include <stack>
2314cf0368Sopenharmony_ci#include <string>
2414cf0368Sopenharmony_ci
2514cf0368Sopenharmony_cinamespace OHOS {
2614cf0368Sopenharmony_cinamespace UDMF {
2714cf0368Sopenharmony_cistruct EdgeNode {
2814cf0368Sopenharmony_ci    uint32_t adjIndex;
2914cf0368Sopenharmony_ci    EdgeNode* next;
3014cf0368Sopenharmony_ci};
3114cf0368Sopenharmony_ci
3214cf0368Sopenharmony_cistruct VertexNode {
3314cf0368Sopenharmony_ci    uint32_t value;
3414cf0368Sopenharmony_ci    EdgeNode* firstEdge;
3514cf0368Sopenharmony_ci};
3614cf0368Sopenharmony_ciclass Graph {
3714cf0368Sopenharmony_cipublic:
3814cf0368Sopenharmony_ci    explicit Graph(uint32_t vertexNum, const std::map<std::string, uint32_t> &typeIdIndex);
3914cf0368Sopenharmony_ci    ~Graph();
4014cf0368Sopenharmony_ci    using Action = std::function<bool(uint32_t node)>;
4114cf0368Sopenharmony_ci    void AddEdge(const std::string &startNode, const std::string &endNode);
4214cf0368Sopenharmony_ci    void AddEdge(uint32_t start, uint32_t end);
4314cf0368Sopenharmony_ci    bool Dfs(uint32_t startNode, Action action, bool isInit = true);
4414cf0368Sopenharmony_ci    bool DfsUnconnectedGraph(Action action);
4514cf0368Sopenharmony_ci    bool IsValidType(const std::string &node);
4614cf0368Sopenharmony_ci    int32_t GetIndex(const std::string &node);
4714cf0368Sopenharmony_ci    bool IsDAG();
4814cf0368Sopenharmony_ciprivate:
4914cf0368Sopenharmony_ci    uint32_t vertexNum_;
5014cf0368Sopenharmony_ci    std::vector<VertexNode> adjList_;  // Adjacency List
5114cf0368Sopenharmony_ci    std::vector<uint32_t> visited_;    // Determine whether the vertex has been accessed, index=vertex value
5214cf0368Sopenharmony_ci    std::map<std::string, uint32_t> typeIdIndex_;
5314cf0368Sopenharmony_ci};
5414cf0368Sopenharmony_ci} // namespace UDMF
5514cf0368Sopenharmony_ci} // namespace OHOS
5614cf0368Sopenharmony_ci#endif // UDMF_GRAPH_H
57