Line data Source code
1 : //* This file is part of the MOOSE framework
2 : //* https://mooseframework.inl.gov
3 : //*
4 : //* All rights reserved, see COPYRIGHT for full restrictions
5 : //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 : //*
7 : //* Licensed under LGPL 2.1, please see LICENSE for details
8 : //* https://www.gnu.org/licenses/lgpl-2.1.html
9 :
10 : #include "SyntaxTree.h"
11 :
12 : #include "InputParameters.h"
13 : #include "MooseUtils.h"
14 : #include "Parser.h"
15 :
16 : #include <algorithm>
17 : #include <cctype>
18 :
19 69680 : SyntaxTree::SyntaxTree(bool use_long_names)
20 69680 : : SyntaxFormatterInterface(), _use_long_names(use_long_names)
21 : {
22 69680 : }
23 :
24 69680 : SyntaxTree::~SyntaxTree() = default;
25 :
26 : void
27 2133083 : SyntaxTree::insertNode(std::string syntax,
28 : const std::string & action,
29 : bool is_action_params,
30 : InputParameters * params)
31 : {
32 2133083 : if (!_root)
33 34865 : _root = std::make_unique<TreeNode>("", *this);
34 :
35 2133083 : _root->insertNode(syntax, action, is_action_params, params);
36 2133083 : }
37 :
38 : std::string
39 34865 : SyntaxTree::print(const std::string & search_string)
40 : {
41 34865 : bool found = false;
42 34865 : std::string output;
43 :
44 : // Clear the list of "seen" parameters before printing the tree
45 34865 : _params_printed.clear();
46 :
47 34865 : if (_root)
48 34865 : output = _root->print(-1, search_string, found);
49 :
50 34865 : if (found)
51 34865 : return preamble() + output + postscript();
52 : else
53 0 : return "";
54 34865 : }
55 :
56 : void
57 17718039 : SyntaxTree::seenIt(const std::string & prefix, const std::string & item)
58 : {
59 17718039 : _params_printed.insert(prefix + item);
60 17718039 : }
61 :
62 : bool
63 58628845 : SyntaxTree::haveSeenIt(const std::string & prefix, const std::string & item) const
64 : {
65 58628845 : return _params_printed.find(prefix + item) != _params_printed.end();
66 : }
67 :
68 708631 : SyntaxTree::TreeNode::TreeNode(const std::string & name,
69 : SyntaxTree & syntax_tree,
70 : const std::string * action,
71 : InputParameters * params,
72 708631 : TreeNode * parent)
73 708631 : : _name(name), _parent(parent), _syntax_tree(syntax_tree)
74 : {
75 708631 : if (action)
76 467165 : _action_params.emplace(*action, std::make_unique<InputParameters>(*params));
77 708631 : }
78 :
79 708631 : SyntaxTree::TreeNode::~TreeNode() = default;
80 :
81 : void
82 3088720 : SyntaxTree::TreeNode::insertNode(std::string & syntax,
83 : const std::string & action,
84 : bool is_action_params,
85 : InputParameters * params)
86 : {
87 3088720 : std::string::size_type pos = syntax.find_first_of("/");
88 3088720 : std::string item;
89 3088720 : bool is_leaf = true;
90 :
91 3088720 : item = syntax.substr(0, pos);
92 3088720 : if (pos != std::string::npos)
93 : {
94 955637 : syntax = syntax.substr(pos + 1);
95 955637 : is_leaf = false;
96 : }
97 :
98 3088720 : bool node_created = false;
99 3088720 : if (_children.find(item) == _children.end())
100 : {
101 1347532 : _children[item] = std::make_unique<TreeNode>(
102 1347532 : item, _syntax_tree, is_leaf && is_action_params ? &action : NULL, params, this);
103 673766 : if (is_leaf && !is_action_params)
104 44938 : _children[item]->insertParams(action, is_action_params, params);
105 673766 : node_created = true;
106 : }
107 :
108 3088720 : if (!is_leaf)
109 955637 : _children[item]->insertNode(syntax, action, is_action_params, params);
110 2133083 : else if (!node_created)
111 1620980 : _children[item]->insertParams(action, is_action_params, params);
112 3088720 : }
113 :
114 : void
115 1665918 : SyntaxTree::TreeNode::insertParams(const std::string & action,
116 : bool is_action_params,
117 : InputParameters * params)
118 : {
119 1665918 : if (is_action_params)
120 986793 : _action_params.emplace(action, std::make_unique<InputParameters>(*params));
121 : else
122 679125 : _moose_object_params.emplace(action, std::make_unique<InputParameters>(*params));
123 1665918 : }
124 :
125 : std::string
126 771095 : SyntaxTree::TreeNode::print(short depth, const std::string & search_string, bool & found)
127 : {
128 1542190 : std::string doc = "";
129 771095 : std::string long_name(getLongName());
130 771095 : std::string name(_syntax_tree.isLongNames() ? long_name : _name);
131 771095 : std::string out;
132 :
133 771095 : if (depth < 0)
134 : {
135 311245 : for (const auto & c_it : _children)
136 : {
137 276380 : bool local_found = false;
138 276380 : std::string local_out(c_it.second->print(depth + 1, search_string, local_found));
139 276380 : found |= local_found; // Update the current frame's found variable
140 276380 : if (local_found)
141 275656 : out += local_out;
142 276380 : }
143 34865 : return out;
144 : }
145 :
146 : // GlobalParamsAction is special - we need to just always print it out
147 : // if (_name == "GlobalParamsAction")
148 : // found = true;
149 :
150 736230 : std::string indent((depth + 1) * 2, ' ');
151 :
152 : std::multimap<std::string, std::unique_ptr<InputParameters>>::const_iterator it =
153 736230 : _moose_object_params.begin();
154 : do
155 : {
156 908328 : bool local_found = false;
157 908328 : std::string local_out;
158 :
159 : // Compare the block name, if it's matched we are going to pass an empty search string
160 : // which means match ALL parameters
161 908328 : std::string local_search_string;
162 908328 : if (MooseUtils::wildCardMatch(name, search_string))
163 885053 : found = true;
164 : else
165 23275 : local_search_string = search_string;
166 :
167 908328 : if (it != _moose_object_params.end())
168 741541 : doc = it->second->getClassDescription();
169 908328 : local_out += _syntax_tree.printBlockOpen(name, depth, doc);
170 :
171 4475000 : for (const auto & a_it : _action_params)
172 3566672 : if (a_it.first != "EmptyAction")
173 : {
174 7133224 : local_out += _syntax_tree.printParams(
175 7133224 : name, long_name, *(a_it.second), depth, local_search_string, local_found);
176 3566612 : found |= local_found; // Update the current frame's found variable
177 : // DEBUG
178 : // Moose::out << "\n" << indent << "(" << ait->first << ")";
179 : // DEBUG
180 : }
181 :
182 908328 : if (it != _moose_object_params.end())
183 : {
184 1483082 : local_out += _syntax_tree.printParams(
185 1483082 : name, long_name, *it->second, depth, local_search_string, local_found);
186 741541 : found |= local_found;
187 : // DEBUG
188 : // Moose::out << "\n" << indent << "{" << it->first << "}";
189 : // DEBUG
190 : }
191 :
192 908328 : local_out += _syntax_tree.preTraverse(depth);
193 :
194 1368178 : for (const auto & c_it : _children)
195 : {
196 459850 : bool child_found = false;
197 459850 : std::string child_out(c_it.second->print(depth + 1, local_search_string, child_found));
198 459850 : found |= child_found; // Update the current frame's found variable
199 :
200 459850 : if (child_found)
201 437299 : local_out += child_out;
202 459850 : }
203 :
204 908328 : local_out += _syntax_tree.printBlockClose(name, depth);
205 :
206 908328 : if (found)
207 885053 : out += local_out;
208 :
209 : // If there are no moose object params then we have to be careful about how we
210 : // increment the iterator. We only want to increment if we aren't already
211 : // at the end.
212 908328 : } while (it != _moose_object_params.end() && ++it != _moose_object_params.end());
213 :
214 736230 : return out;
215 771095 : }
216 :
217 : std::string
218 1994777 : SyntaxTree::TreeNode::getLongName(const std::string & delim) const
219 : {
220 1994777 : if (_parent)
221 2447364 : return _parent->getLongName(delim) + delim + _name;
222 : else
223 771095 : return _name;
224 : }
225 :
226 : bool
227 771095 : SyntaxTree::isLongNames() const
228 : {
229 771095 : return _use_long_names;
230 : }
|