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