DoxTransitiongraph.cpp
Go to the documentation of this file.
1 /*
2  * This file is part of ArmarX.
3  *
4  * Copyright (C) 2011-2016, High Performance Humanoid Technologies (H2T), Karlsruhe Institute of Technology (KIT), all rights reserved.
5  *
6  * ArmarX is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 as
8  * published by the Free Software Foundation.
9  *
10  * ArmarX is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  *
18  * @package
19  * @author
20  * @date
21  * @copyright http://www.gnu.org/licenses/gpl-2.0.txt
22  * GNU General Public License
23  */
24 #include "DoxTransitiongraph.h"
25 
26 #include <sstream>
27 
28 using namespace armarx;
29 
31 {
32 }
33 
34 void
36 {
37  transitions.push_back(transition);
38 }
39 
40 void
41 DoxTransitionGraph::addTransition(const std::string& from,
42  const std::string& to,
43  const std::string& eventName)
44 {
45  DoxTransitionPtr transition(new DoxTransition(from, to, eventName));
46  transitions.push_back(transition);
47 }
48 
49 void
50 DoxTransitionGraph::addNode(const std::string& name, const std::string& attrs)
51 {
53  nodes.push_back(node);
54 }
55 
56 int
58 {
59  return transitions.size();
60 }
61 
62 std::string
64 {
65  std::stringstream ss;
66  ss << "@dot\ndigraph States {\n";
67 
68  for (DoxTransitionGraphNodePtr node : nodes)
69  {
70  ss << " " << node->toString() << "\n";
71  }
72 
73  for (DoxTransitionPtr transition : transitions)
74  {
75  ss << " " << transition->toString() << "\n";
76  }
77 
78  ss << "}\n@enddot";
79  return ss.str();
80 }
81 
82 DoxTransition::DoxTransition(std::string from, std::string to, std::string eventName)
83 {
84  this->from = from;
85  this->to = to;
86  this->eventName = eventName;
87 }
88 
89 std::string
91 {
92  return "\"" + from + "\" -> \"" + to + "\" [ label=\"" + eventName + "\" ];";
93 }
94 
95 DoxTransitionGraphNode::DoxTransitionGraphNode(const std::string& name, const std::string& shape) :
96  name(name), attrs(shape)
97 {
98 }
99 
100 std::string
102 {
103  return "\"" + name + "\" [" + attrs + "]";
104 }
armarx::DoxTransitionGraph::getDoxString
std::string getDoxString() override
Definition: DoxTransitiongraph.cpp:63
DoxTransitiongraph.h
armarx::DoxTransitionGraphNode::toString
std::string toString()
Definition: DoxTransitiongraph.cpp:101
armarx::DoxTransitionGraphNode
Definition: DoxTransitiongraph.h:53
armarx::DoxTransition::toString
std::string toString()
Definition: DoxTransitiongraph.cpp:90
armarx::DoxTransitionGraph::addNode
void addNode(const std::string &name, const std::string &attrs)
Definition: DoxTransitiongraph.cpp:50
armarx::DoxTransitionGraph::addTransition
void addTransition(DoxTransitionPtr transition)
Definition: DoxTransitiongraph.cpp:35
armarx::DoxTransitionGraph::DoxTransitionGraph
DoxTransitionGraph()
Definition: DoxTransitiongraph.cpp:30
armarx::DoxTransitionGraphNodePtr
std::shared_ptr< DoxTransitionGraphNode > DoxTransitionGraphNodePtr
Definition: DoxTransitiongraph.h:51
armarx::DoxTransitionGraphNode::DoxTransitionGraphNode
DoxTransitionGraphNode(const std::string &name, const std::string &attrs)
Definition: DoxTransitiongraph.cpp:95
armarx::DoxTransitionGraph::transitionCount
int transitionCount()
Definition: DoxTransitiongraph.cpp:57
armarx::DoxTransitionPtr
std::shared_ptr< DoxTransition > DoxTransitionPtr
Definition: DoxTransitiongraph.h:36
armarx::DoxTransition
Definition: DoxTransitiongraph.h:38
armarx
This file offers overloads of toIce() and fromIce() functions for STL container types.
Definition: ArmarXTimeserver.cpp:27
armarx::DoxTransition::DoxTransition
DoxTransition(std::string from, std::string to, std::string eventName)
Definition: DoxTransitiongraph.cpp:82