41 #include "wasphit/HITInterpreter.h" 42 #include "waspcore/utils.h" 43 #include "waspplot/CustomPlotSerialization.h" 52 : _moose_app(moose_app),
53 _connection(
std::make_shared<wasp::lsp::IOStreamConnection>(this)),
54 _formatting_tab_size(0),
55 _dist_plot_num_points(200),
56 _dist_plot_quantile_bound(1e-3)
66 enableExtension(
"plotting");
67 enableExtension(
"watcherRegistration");
78 std::string parse_file_path = document_path;
79 pcrecpp::RE(
"(.*://)(.*)").Replace(
"\\2", &parse_file_path);
84 const auto diagnostic = [
this, &diagnosticsList, &pass](
const std::string & message,
86 const int start_column,
87 const std::optional<int> end_line = {},
88 const std::optional<int> end_column = {})
90 diagnosticsList.push_back(wasp::DataObject());
91 auto & diagnostic = *diagnosticsList.back().to_object();
92 pass &= wasp::lsp::buildDiagnosticObject(diagnostic,
96 end_line ? *end_line : start_line,
97 end_column ? *end_column : start_column,
105 const auto zero_line_diagnostic = [&diagnostic](
const std::string & message)
106 { diagnostic(message, 0, 0); };
109 const auto hit_node_diagnostic = [&zero_line_diagnostic, &diagnostic, &parse_file_path](
110 const hit::Node *
const node,
const std::string & message)
113 if (!node || node->isRoot() || node->filename() != parse_file_path || !node->line() ||
115 zero_line_diagnostic(message);
118 diagnostic(message, node->line() - 1, node->column() - 1);
122 const auto hit_error_message_diagnostic =
123 [&diagnostic, &zero_line_diagnostic, &parse_file_path](
const hit::ErrorMessage &
err)
129 if (*
err.filename == parse_file_path)
132 if (
err.lineinfo &&
err.lineinfo->start_line &&
err.lineinfo->start_column &&
133 err.lineinfo->end_line &&
err.lineinfo->end_column)
135 diagnostic(
err.message,
136 err.lineinfo->start_line - 1,
137 err.lineinfo->start_column - 1,
138 err.lineinfo->end_line - 1,
139 err.lineinfo->end_column - 1);
149 zero_line_diagnostic(
err.prefixed_message);
155 const auto try_catch = [&hit_error_message_diagnostic,
156 &hit_node_diagnostic,
157 &zero_line_diagnostic](
const auto & action) ->
bool 169 for (
const auto & error_message :
err.error_messages)
170 hit_error_message_diagnostic(error_message);
176 hit_node_diagnostic(
err.getNode(),
err.what());
179 catch (std::exception &
err)
181 zero_line_diagnostic(
err.what());
191 if (command_line->hasArgument(
"--language-server"))
192 command_line->removeArgument(
"--language-server");
193 command_line->addArgument(
"--check-input");
194 command_line->addArgument(
"--error-unused");
195 command_line->addArgument(
"--error");
196 command_line->addArgument(
"--color=off");
197 command_line->addArgument(
"--disable-perf-graph-live");
198 command_line->parse();
201 auto parser = std::make_shared<Parser>(parse_file_path, document_text);
202 mooseAssert(parser->getInputFileNames()[0] == parse_file_path,
"Should be consistent");
203 parser->setCommandLineParams(command_line->buildHitParams());
204 parser->setThrowOnError(
true);
207 const bool parse_success = try_catch([&parser]() { parser->parse(); });
211 if (
auto parser_root_ptr = parser->queryRoot();
212 parser_root_ptr && !parser_root_ptr->getNodeView().is_null())
214 auto it_inserted_pair =
_check_state.emplace(document_path, parser);
215 mooseAssert(it_inserted_pair.second,
"Should not already exist");
216 state = &it_inserted_pair.first->second;
229 app_params.
set<std::shared_ptr<Parser>>(
"_parser") = parser;
230 app_params.
set<std::shared_ptr<CommandLine>>(
"_command_line") = std::move(command_line);
233 std::unique_ptr<MooseApp> app =
nullptr;
234 const auto do_build_app = [
this, &app_params, &app]()
241 if (!try_catch(do_build_app))
249 state->app = std::move(app);
253 if (!try_catch(do_run_app))
269 auto & root = *root_ptr;
272 if (!client_watcher_support)
276 wasp::HITNodeView view_root = root.getNodeView();
277 std::set<std::string> include_paths, filename_vals, resource_uris;
280 view_root.node_pool()->descendant_include_paths(include_paths);
281 for (
const auto & include_path : include_paths)
283 auto normalized = std::filesystem::path(include_path).lexically_normal().string();
285 resource_uris.insert(wasp::lsp::prefixUriScheme(normalized));
290 for (
const auto & filename_val : filename_vals)
292 auto input_path = wasp::lsp::removeUriScheme(document_path);
293 auto input_base = std::filesystem::path(input_path).parent_path();
294 auto fname_path = std::filesystem::path(filename_val);
295 auto fname_absl = fname_path.is_absolute() ? fname_path : (input_base / fname_path);
296 auto normalized = fname_absl.lexically_normal().string();
298 resource_uris.insert(wasp::lsp::prefixUriScheme(normalized));
302 setResourcesForBase(document_path, resource_uris);
309 static const std::set<std::string> filename_types = {
310 "FileName",
"FileNameNoExtension",
"MeshFileName",
"MatrixFileName"};
313 for (
const auto & child : parent)
315 if (child.type() == wasp::OBJECT)
318 wasp::HITNodeView object_node = child;
319 const std::string object_path = object_node.path();
320 wasp::HITNodeView type_node = object_node.first_child_by_name(
"type");
321 const std::string object_type =
322 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
326 std::set<std::string> obj_act_tasks;
330 for (
const auto & child : object_node)
332 if (child.type() == wasp::KEYED_VALUE || child.type() == wasp::ARRAY)
335 wasp::HITNodeView param_node = child;
336 std::string param_name = param_node.name();
342 std::string dirty_type = valid_params.
type(param_name);
344 pcrecpp::RE(
".+<([A-Za-z0-9_' ':]*)>.*").GlobalReplace(
"\\1", &clean_type);
347 if (filename_types.count(clean_type))
348 for (
const auto & child : param_node)
349 if (child.type() == wasp::VALUE)
350 filename_vals.insert(child.to_string());
363 bool & is_incomplete,
371 return addSubblocksToList(completionItems,
"/", line, character, line, character,
"",
false);
372 auto & root = *root_ptr;
375 auto is_request_in_open_block = [](wasp::HITNodeView request_context) {
376 return request_context.type() == wasp::OBJECT || request_context.type() == wasp::DOCUMENT_ROOT;
378 auto is_request_on_param_decl = [](wasp::HITNodeView request_context)
380 return request_context.type() == wasp::DECL && request_context.has_parent() &&
381 (request_context.parent().type() == wasp::KEYED_VALUE ||
382 request_context.parent().type() == wasp::ARRAY);
384 auto is_request_on_block_decl = [](wasp::HITNodeView request_context)
386 return request_context.type() == wasp::DECL && request_context.has_parent() &&
387 request_context.parent().type() == wasp::OBJECT;
391 wasp::HITNodeView view_root = root.getNodeView();
392 wasp::HITNodeView request_context;
395 if (line + 1 < (
int)view_root.last_line() ||
396 (line + 1 == (
int)view_root.last_line() && character <= (
int)view_root.last_column()))
397 request_context = wasp::findNodeUnderLineColumn(view_root, line + 1, character + 1);
403 wasp::findNodeUnderLineColumn(view_root, view_root.last_line(), view_root.last_column());
406 wasp::HITNodeView object_context = request_context;
407 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
408 object_context = object_context.parent();
409 if (request_context.type() == wasp::OBJECT_TERM && object_context.has_parent())
410 object_context = object_context.parent();
411 request_context = object_context;
415 if (is_request_in_open_block(request_context))
417 wasp::HITNodeView backup_context = request_context;
418 for (
int backup_char = character; backup_context == request_context && --backup_char > 0;)
419 backup_context = wasp::findNodeUnderLineColumn(request_context, line + 1, backup_char + 1);
420 if (backup_context.type() == wasp::ASSIGN || backup_context.type() == wasp::OVERRIDE_ASSIGN)
421 request_context = backup_context;
425 int replace_line_beg = line;
426 int replace_char_beg = character;
427 int replace_line_end = line;
428 int replace_char_end = character;
429 std::string filtering_prefix;
430 if (request_context.type() == wasp::DECL || request_context.type() == wasp::VALUE)
433 replace_line_beg = request_context.line() - 1;
434 replace_char_beg = request_context.column() - 1;
435 replace_line_end = request_context.last_line() - 1;
436 replace_char_end = request_context.last_column();
437 filtering_prefix = request_context.data();
440 if (is_request_on_block_decl(request_context) && filtering_prefix.empty())
448 const auto & parent_name = request_context.has_parent() ? request_context.parent().name() :
"";
451 wasp::HITNodeView object_context = request_context;
452 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
453 object_context = object_context.parent();
454 if (is_request_on_block_decl(request_context))
455 object_context = object_context.parent();
456 const std::string & object_path = object_context.path();
457 wasp::HITNodeView type_node = object_context.first_child_by_name(
"type");
458 const std::string & object_type =
459 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
462 std::set<std::string> existing_params, existing_subblocks;
469 std::set<std::string> obj_act_tasks;
477 if (is_request_in_open_block(request_context) || is_request_on_param_decl(request_context))
488 if (is_request_in_open_block(request_context) || is_request_on_param_decl(request_context) ||
489 is_request_on_block_decl(request_context))
497 is_request_on_block_decl(request_context));
500 if ((request_context.type() == wasp::VALUE || request_context.type() == wasp::ASSIGN ||
501 request_context.type() == wasp::OVERRIDE_ASSIGN) &&
515 is_incomplete = !pass;
522 std::set<std::string> & existing_params,
523 std::set<std::string> & existing_subblocks)
526 for (
auto itr = parent_node.begin(); itr != parent_node.end(); itr.next())
528 auto child_node = itr.get();
531 if (child_node.type() == wasp::KEYED_VALUE || child_node.type() == wasp::ARRAY)
532 existing_params.insert(child_node.name());
533 else if (child_node.type() == wasp::OBJECT)
534 existing_subblocks.insert(child_node.name());
540 const std::string & object_path,
541 const std::string & object_type,
542 std::set<std::string> & obj_act_tasks)
552 const std::string & object_path,
553 std::set<std::string> & obj_act_tasks)
560 std::string registered_syntax = syntax.
isAssociated(object_path, &is_parent);
566 auto action_range = syntax.
getActions(registered_syntax);
569 for (
auto action_iter = action_range.first; action_iter != action_range.second; action_iter++)
571 const std::string & action_name = action_iter->second._action;
579 if (action_params.
get<
bool>(
"isObjectAction"))
581 std::set<std::string> tasks_by_actions = action_factory.
getTasksByAction(action_name);
582 obj_act_tasks.insert(tasks_by_actions.begin(), tasks_by_actions.end());
586 action_params.
remove(
"isObjectAction");
590 valid_params += action_params;
597 std::string object_type,
598 const std::set<std::string> & obj_act_tasks)
604 if (object_type.empty() && valid_params.
have_parameter<std::string>(
"type") &&
605 !valid_params.
get<std::string>(
"type").empty())
607 object_type = valid_params.
get<std::string>(
"type");
622 const std::string & moose_base = object_params.
getBase();
624 for (
const auto & obj_act_task : obj_act_tasks)
629 valid_params += object_params;
637 if (valid_params.
have_parameter<std::vector<std::string>>(
"_object_params_set_by_action"))
639 auto names = valid_params.
get<std::vector<std::string>>(
"_object_params_set_by_action");
640 for (
const auto &
name : names)
644 valid_params.
remove(
"_object_params_set_by_action");
651 const std::set<std::string> & existing_params,
652 int replace_line_beg,
653 int replace_char_beg,
654 int replace_line_end,
655 int replace_char_end,
656 const std::string & filtering_prefix)
661 for (
const auto & valid_params_iter : valid_params)
663 const std::string & param_name = valid_params_iter.first;
664 bool deprecated = valid_params.isParamDeprecated(param_name);
665 bool is_private = valid_params.isPrivate(param_name);
668 if (deprecated || is_private || existing_params.count(param_name))
672 if (param_name.rfind(filtering_prefix, 0) != 0)
676 std::string dirty_type = valid_params.type(param_name);
679 std::string doc_string = valid_params.getDocString(param_name);
683 bool is_array = basic_type.compare(0, 6,
"Array:") == 0;
686 pcrecpp::RE(
"(Array:)*(.*)").GlobalReplace(
"\\2", &basic_type);
689 pcrecpp::RE(
".+<([A-Za-z0-9_' ':]*)>.*").GlobalReplace(
"\\1", &clean_type);
695 std::string default_value;
698 if (valid_params.isParamValid(param_name))
705 else if (valid_params.hasDefaultCoupledValue(param_name))
707 std::ostringstream oss;
708 oss << valid_params.defaultCoupledValue(param_name);
709 default_value = oss.str();
713 if (basic_type ==
"Boolean" && default_value ==
"1")
714 default_value =
"true";
715 else if (basic_type ==
"Boolean" && default_value ==
"0")
716 default_value =
"false";
719 std::string array_quote = is_array && !default_value.empty() ?
"'" :
"";
723 std::string insert_text;
724 if (client_snippet_support && !default_value.empty())
726 text_format = wasp::lsp::m_text_format_snippet;
727 insert_text = param_name +
" = " + array_quote +
"${1:" + default_value +
"}" + array_quote;
731 text_format = wasp::lsp::m_text_format_plaintext;
732 insert_text = param_name +
" = " + array_quote + default_value + array_quote;
737 completionItems.push_back(wasp::DataObject());
738 wasp::DataObject * item = completionItems.back().to_object();
739 pass &= wasp::lsp::buildCompletionObject(*item,
760 const std::string & object_path,
761 int replace_line_beg,
762 int replace_char_beg,
763 int replace_line_end,
764 int replace_char_end,
765 const std::string & filtering_prefix,
766 bool request_on_block_decl)
771 std::set<std::string> syntax_paths_processed;
778 std::string syntax_path =
"/" + syntax_path_iter.first;
781 if (!syntax_paths_processed.insert(syntax_path).second)
785 for (std::size_t last_sep; (last_sep = syntax_path.find_last_of(
"/")) != std::string::npos;)
787 std::string subblock_name = syntax_path.substr(last_sep + 1);
788 syntax_path = syntax_path.substr(0, last_sep);
800 if (!registered_syntax.empty() || object_path ==
"/")
803 int text_format = client_snippet_support ? wasp::lsp::m_text_format_snippet
804 : wasp::lsp::m_text_format_plaintext;
809 if (subblock_name !=
"*" && subblock_name.rfind(filtering_prefix, 0) != 0)
812 std::string doc_string;
813 std::string insert_text;
817 const std::string full_block_path = object_path +
"/" + subblock_name;
821 if (subblock_name ==
"*")
823 doc_string =
"custom user named block";
824 insert_text = (request_on_block_decl ?
"" :
"[") +
825 (filtering_prefix.size() ? filtering_prefix :
"block_name") +
"]" +
826 req_params +
"\n " + (client_snippet_support ?
"$0" :
"") +
"\n[]";
827 complete_kind = wasp::lsp::m_comp_kind_variable;
831 doc_string =
"application named block";
832 insert_text = (request_on_block_decl ?
"" :
"[") + subblock_name +
"]" + req_params +
833 "\n " + (client_snippet_support ?
"$0" :
"") +
"\n[]";
834 complete_kind = wasp::lsp::m_comp_kind_struct;
838 completionItems.push_back(wasp::DataObject());
839 wasp::DataObject * item = completionItems.back().to_object();
840 pass &= wasp::lsp::buildCompletionObject(*item,
863 const std::set<std::string> & existing_params,
864 const std::set<std::string> & existing_subblocks,
865 const std::string & param_name,
866 const std::set<std::string> & obj_act_tasks,
867 const std::string & object_path,
868 int replace_line_beg,
869 int replace_char_beg,
870 int replace_line_end,
871 int replace_char_end)
877 std::string dirty_type = valid_params.
type(param_name);
882 pcrecpp::RE(
"(Array:)*(.*)").GlobalReplace(
"\\2", &basic_type);
885 pcrecpp::RE(
".+<([A-Za-z0-9_' ':]*)>.*").GlobalReplace(
"\\1", &clean_type);
891 std::map<std::string, std::string> options_and_descs;
894 if (param_name ==
"active" || param_name ==
"inactive")
895 for (
const auto & subblock_name : existing_subblocks)
896 options_and_descs[subblock_name] =
"subblock name";
899 else if (basic_type ==
"Boolean")
901 options_and_descs[
"true"];
902 options_and_descs[
"false"];
912 else if (valid_params.
have_parameter<std::vector<MooseEnum>>(param_name))
913 getEnumsAndDocs(valid_params.
get<std::vector<MooseEnum>>(param_name)[0], options_and_descs);
916 else if (param_name ==
"type")
921 const std::string & object_name = objects_iter.first;
922 const InputParameters & object_params = objects_iter.second->buildParameters();
926 req_params += req_params.size() ?
"\n" + std::string(client_snippet_support ?
"$0" :
"") :
"";
931 const std::string & moose_base = object_params.
getBase();
934 for (
const auto & obj_act_task : obj_act_tasks)
940 options_and_descs[object_name + req_params] = type_description;
954 const std::string &
type = associated_types_iter.second;
955 const std::string & path = associated_types_iter.first;
965 wasp::HITNodeView view_root =
getRoot().getNodeView();
968 for (
const auto & input_path : input_path_iter->second)
971 wasp::SIRENInterpreter<> selector;
972 if (!selector.parseString(input_path))
974 wasp::SIRENResultSet<wasp::HITNodeView> results;
975 std::size_t count = selector.evaluate(view_root, results);
978 for (std::size_t i = 0; i < count; i++)
979 if (results.adapted(i).type() == wasp::OBJECT)
980 options_and_descs[results.adapted(i).name()] =
"from /" + input_path;
991 int text_format = client_snippet_support ? wasp::lsp::m_text_format_snippet
992 : wasp::lsp::m_text_format_plaintext;
997 for (
const auto & option_and_desc : options_and_descs)
999 const std::string & insert_text = option_and_desc.first;
1000 const std::string & option_name = insert_text.substr(0, insert_text.find(
'\n'));
1001 const std::string & description = option_and_desc.second;
1004 completionItems.push_back(wasp::DataObject());
1005 wasp::DataObject * item = completionItems.back().to_object();
1006 pass &= wasp::lsp::buildCompletionObject(*item,
1025 template <
typename MooseEnumType>
1028 std::map<std::string, std::string> & options_and_descs)
1031 const auto & enum_docs = moose_enum_param.getItemDocumentation();
1034 for (
const auto & item : moose_enum_param.items())
1035 options_and_descs[item.name()] = enum_docs.count(item) ? enum_docs.at(item) :
"";
1040 std::map<std::string, std::string> & options_and_descs)
1048 std::shared_ptr<FEProblemBase> &
problem = app_ptr->actionWarehouse().problemBase();
1052 if (param_type ==
"NonlinearVariableName")
1055 for (
const auto & nls_var_name :
problem->getNonlinearSystemBase(i).getVariableNames())
1056 options_and_descs[nls_var_name] =
"from NonlinearSystem VariableWarehouse";
1058 else if (param_type ==
"AuxVariableName")
1060 for (
const auto & aux_var_name :
problem->getAuxiliarySystem().getVariableNames())
1061 options_and_descs[aux_var_name] =
"from AuxiliarySystem VariableWarehouse";
1063 else if (param_type ==
"VariableName")
1066 for (
const auto & nls_var_name :
problem->getNonlinearSystemBase(i).getVariableNames())
1067 options_and_descs[nls_var_name] =
"from NonlinearSystem VariableWarehouse";
1068 for (
const auto & aux_var_name :
problem->getAuxiliarySystem().getVariableNames())
1069 options_and_descs[aux_var_name] =
"from AuxiliarySystem VariableWarehouse";
1071 else if (param_type ==
"MaterialPropertyName")
1073 const auto & mat_prop_registry =
problem->getMaterialPropertyRegistry();
1074 const std::vector<std::string> mat_prop_names(mat_prop_registry.idsToNamesBegin(),
1075 mat_prop_registry.idsToNamesEnd());
1076 for (
const auto & mat_prop_name : mat_prop_names)
1077 options_and_descs[mat_prop_name] =
"from MaterialPropertyRegistry";
1079 else if (param_type ==
"MaterialName")
1081 for (
const auto & material :
problem->getMaterialWarehouse().getObjects())
1082 options_and_descs[material->name()] =
"from MaterialWarehouse";
1084 else if (param_type ==
"FunctionName")
1086 for (
const auto &
function :
problem->getFunctionWarehouse().getObjects())
1087 options_and_descs[function->name()] =
"from FunctionWarehouse";
1089 else if (param_type ==
"OutputName")
1091 for (
const auto & output_name : app_ptr->getOutputWarehouse().getOutputNames<
Output>())
1092 options_and_descs[output_name] =
"from OutputWarehouse";
1093 for (
const auto & reserved_name : app_ptr->getOutputWarehouse().getReservedNames())
1094 options_and_descs[reserved_name] =
"from reserved names in OutputWarehouse";
1096 else if (param_type ==
"UserObjectName")
1098 std::vector<UserObject *> user_objects;
1102 .condition<AttribThread>(0)
1103 .queryIntoUnsorted(user_objects);
1104 for (
const auto & user_object : user_objects)
1105 options_and_descs[user_object->name()] =
"from UserObjectWarehouse";
1120 auto & root = *root_ptr;
1123 wasp::HITNodeView view_root = root.getNodeView();
1124 wasp::HITNodeView request_context =
1125 wasp::findNodeUnderLineColumn(view_root, line + 1, character + 1);
1128 if (request_context.type() != wasp::VALUE)
1132 std::string param_name = request_context.has_parent() ? request_context.parent().name() :
"";
1133 std::string val_string = request_context.last_as_string();
1136 if (param_name ==
"type" && factory.
isRegistered(val_string))
1142 if (!file_line_info.
isValid() ||
1147 auto location_uri = wasp::lsp::m_uri_prefix + file_line_info.
file();
1150 definitionLocations.push_back(wasp::DataObject());
1151 wasp::DataObject * location = definitionLocations.back().to_object();
1152 return wasp::lsp::buildLocationObject(*location,
1155 file_line_info.
line() - 1,
1157 file_line_info.
line() - 1,
1162 wasp::HITNodeView object_context = request_context;
1163 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
1164 object_context = object_context.parent();
1165 const std::string & object_path = object_context.path();
1166 wasp::HITNodeView type_node = object_context.first_child_by_name(
"type");
1167 const std::string & object_type =
1168 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
1174 std::set<std::string> obj_act_tasks;
1181 [](
const wasp::HITNodeView & l,
const wasp::HITNodeView & r)
1183 const std::string & l_file = l.node_pool()->stream_name();
1184 const std::string & r_file = r.node_pool()->stream_name();
1185 return (l_file < r_file || (l_file == r_file && l.line() < r.line()) ||
1186 (l_file == r_file && l.line() == r.line() && l.column() < r.column()));
1190 for (
const auto & valid_params_iter : valid_params)
1192 if (valid_params_iter.first == param_name)
1195 std::string dirty_type = valid_params.type(param_name);
1197 pcrecpp::RE(
".+<([A-Za-z0-9_' ':]*)>.*").GlobalReplace(
"\\1", &clean_type);
1206 if (location_nodes.empty() && request_context.has_parent() &&
1207 request_context.parent().child_count_by_name(
"decl"))
1208 location_nodes.insert(request_context.parent().first_child_by_name(
"decl"));
1216 const std::string & clean_type,
1217 const std::string & val_string)
1226 const std::string &
type = associated_types_iter.second;
1227 const std::string & path = associated_types_iter.first;
1240 wasp::HITNodeView view_root =
getRoot().getNodeView();
1243 for (
const auto & input_path : input_path_iter->second)
1246 wasp::SIRENInterpreter<> selector;
1247 if (!selector.parseString(input_path))
1249 wasp::SIRENResultSet<wasp::HITNodeView> results;
1250 std::size_t count = selector.evaluate(view_root, results);
1253 for (std::size_t i = 0; i < count; i++)
1254 if (results.adapted(i).type() == wasp::OBJECT && results.adapted(i).name() == val_string &&
1255 results.adapted(i).child_count_by_name(
"decl"))
1256 location_nodes.insert(results.adapted(i).first_child_by_name(
"decl"));
1267 for (
const auto & location_nodes_iter : location_nodes)
1270 auto location_uri = wasp::lsp::m_uri_prefix + location_nodes_iter.node_pool()->stream_name();
1273 defsOrRefsLocations.push_back(wasp::DataObject());
1274 wasp::DataObject * location = defsOrRefsLocations.back().to_object();
1275 pass &= wasp::lsp::buildLocationObject(*location,
1278 location_nodes_iter.line() - 1,
1279 location_nodes_iter.column() - 1,
1280 location_nodes_iter.last_line() - 1,
1281 location_nodes_iter.last_column());
1297 auto & root = *root_ptr;
1300 wasp::HITNodeView view_root = root.getNodeView();
1301 wasp::HITNodeView request_context =
1302 wasp::findNodeUnderLineColumn(view_root, line + 1, character + 1);
1305 if ((request_context.type() != wasp::DECL && request_context.type() != wasp::VALUE) ||
1306 !request_context.has_parent() ||
1307 (request_context.parent().type() != wasp::KEYED_VALUE &&
1308 request_context.parent().type() != wasp::ARRAY))
1312 std::string paramkey = request_context.parent().name();
1313 std::string paramval = request_context.last_as_string();
1316 wasp::HITNodeView object_context = request_context;
1317 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
1318 object_context = object_context.parent();
1319 const std::string object_path = object_context.path();
1320 wasp::HITNodeView type_node = object_context.first_child_by_name(
"type");
1321 const std::string object_type =
1322 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
1326 std::set<std::string> obj_act_tasks;
1330 if (request_context.type() == wasp::VALUE && paramkey ==
"type" && factory.
isRegistered(paramval))
1335 const std::string & moose_base = object_params.
getBase();
1336 for (
const auto & obj_act_task : obj_act_tasks)
1349 else if (request_context.type() == wasp::VALUE)
1351 std::map<std::string, std::string> options_and_descs;
1358 else if (valid_params.
have_parameter<std::vector<MooseEnum>>(paramkey))
1359 getEnumsAndDocs(valid_params.
get<std::vector<MooseEnum>>(paramkey)[0], options_and_descs);
1360 if (options_and_descs.count(paramval))
1362 display_text = options_and_descs.find(paramval)->second;
1368 else if (request_context.type() == wasp::DECL && valid_params.
getParametersList().count(paramkey))
1374 std::string doc_units = valid_params.
getDocUnit(paramkey);
1375 if (!doc_units.empty())
1376 display_text +=
"\n\nUnits: " + doc_units;
1382 if (!doc_range.empty())
1383 display_text +=
"\n\nRange: " + doc_range;
1394 bool include_declaration)
1402 auto & root = *root_ptr;
1405 wasp::HITNodeView view_root = root.getNodeView();
1406 wasp::HITNodeView request_context =
1407 wasp::findNodeUnderLineColumn(view_root, line + 1, character + 1);
1410 if ((request_context.type() != wasp::DECL && request_context.type() != wasp::DOT_SLASH &&
1411 request_context.type() != wasp::LBRACKET && request_context.type() != wasp::RBRACKET) ||
1412 !request_context.has_parent() || request_context.parent().type() != wasp::OBJECT)
1416 const std::string & block_path = request_context.parent().path();
1417 const std::string & block_name = request_context.parent().name();
1423 const std::string & path = associated_types_iter.first;
1424 const std::string &
type = associated_types_iter.second;
1441 [](
const wasp::HITNodeView & l,
const wasp::HITNodeView & r)
1443 const std::string & l_file = l.node_pool()->stream_name();
1444 const std::string & r_file = r.node_pool()->stream_name();
1445 return (l_file < r_file || (l_file == r_file && l.line() < r.line()) ||
1446 (l_file == r_file && l.line() == r.line() && l.column() < r.column()));
1453 if (match_nodes.empty())
1457 if (include_declaration && request_context.parent().child_count_by_name(
"decl"))
1458 match_nodes.insert(request_context.parent().first_child_by_name(
"decl"));
1466 wasp::HITNodeView view_parent,
1467 const std::string & target_value,
1468 const std::set<std::string> & target_types)
1471 for (
const auto & view_child : view_parent)
1474 if (view_child.type() == wasp::VALUE && view_child.to_string() == target_value)
1477 wasp::HITNodeView object_context = view_child;
1478 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
1479 object_context = object_context.parent();
1480 const std::string object_path = object_context.path();
1481 wasp::HITNodeView type_node = object_context.first_child_by_name(
"type");
1482 const std::string object_type =
1483 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
1487 std::set<std::string> obj_act_tasks;
1491 std::string param_name = view_child.has_parent() ? view_child.parent().name() :
"";
1494 std::string dirty_type = valid_params.
type(param_name);
1496 pcrecpp::RE(
".+<([A-Za-z0-9_' ':]*)>.*").GlobalReplace(
"\\1", &clean_type);
1499 if (target_types.count(clean_type))
1500 match_nodes.insert(view_child);
1504 if (!view_child.is_leaf())
1515 std::string parse_file_path = document_path;
1516 pcrecpp::RE(
"(.*://)(.*)").Replace(
"\\2", &parse_file_path);
1519 std::stringstream input_errors, input_stream(getDocumentText());
1520 wasp::DefaultHITInterpreter interpreter(input_errors);
1523 if (!interpreter.parseStream(input_stream, parse_file_path))
1527 if (interpreter.root().is_null())
1531 wasp::HITNodeView view_root = interpreter.root();
1532 int document_start_line = view_root.line() - 1;
1533 int document_start_char = view_root.column() - 1;
1534 int document_last_line = view_root.last_line() - 1;
1535 int document_last_char = view_root.last_column();
1539 std::size_t starting_line = view_root.line() - 1;
1540 std::string document_format =
formatDocument(view_root, starting_line, 0);
1543 document_format.erase(0, 1);
1546 formattingTextEdits.push_back(wasp::DataObject());
1547 wasp::DataObject * item = formattingTextEdits.back().to_object();
1548 bool pass = wasp::lsp::buildTextEditObject(*item,
1550 document_start_line,
1551 document_start_char,
1565 auto collapse_spaces = [](std::string string_copy)
1567 pcrecpp::RE(
"\\s+").Replace(
" ", &string_copy);
1572 std::string format_string;
1575 for (
const auto i :
make_range(parent.child_count()))
1578 wasp::HITNodeView child = parent.child_at(i);
1581 auto decl = child.child_count_by_name(
"decl") ? child.first_child_by_name(
"decl").data() :
"";
1584 std::string blank = child.line() > prev_line + 1 ?
"\n" :
"";
1587 if (child.type() == wasp::FILE)
1588 format_string += blank + newline_indent +
MooseUtils::trim(collapse_spaces(child.data()));
1591 else if (child.type() == wasp::COMMENT)
1592 format_string += (child.line() == prev_line ?
" " : blank + newline_indent) +
1596 else if (child.type() == wasp::OBJECT && decl.empty())
1600 else if (child.type() == wasp::OBJECT)
1601 format_string += blank + newline_indent +
"[" + decl +
"]" +
1602 formatDocument(child, prev_line, level + 1) + newline_indent +
"[]";
1605 else if (child.type() == wasp::KEYED_VALUE || child.type() == wasp::ARRAY)
1607 const std::string assign = wasp::is_override(child) ? child.child_at(1).data() :
"=";
1608 const std::string prefix = newline_indent + decl +
" " + assign +
" ";
1610 const std::string render_val = hit::extractValue(child.data());
1611 std::size_t val_column = child.child_count() > 2 ? child.child_at(2).column() : 0;
1612 std::size_t prefix_len = prefix.size() - 1;
1614 format_string += blank + prefix + hit::formatValue(render_val, val_column, prefix_len);
1618 prev_line = child.last_line();
1622 return format_string;
1632 auto & root = *root_ptr;
1634 wasp::HITNodeView view_root = root.getNodeView();
1639 for (
const auto i :
make_range(view_root.child_count()))
1642 wasp::HITNodeView view_child = view_root.child_at(i);
1645 std::string
name = view_child.name();
1646 int line = view_child.line() - 1;
1647 int column = view_child.column() - 1;
1648 int last_line = view_child.last_line() - 1;
1649 int last_column = view_child.last_column();
1651 std::string detail =
1652 !view_child.first_child_by_name(
"type").is_null()
1653 ? wasp::strip_quotes(hit::extractValue(view_child.first_child_by_name(
"type").data()))
1657 documentSymbols.push_back(wasp::DataObject());
1658 wasp::DataObject * data_child = documentSymbols.back().to_object();
1659 pass &= wasp::lsp::buildDocumentSymbolObject(*data_child,
1683 wasp::DataObject & data_parent)
1686 if (wasp::is_nested_file(view_parent))
1692 for (
const auto i :
make_range(view_parent.child_count()))
1695 wasp::HITNodeView view_child = view_parent.child_at(i);
1698 std::string
name = view_child.name();
1699 int line = view_child.line() - 1;
1700 int column = view_child.column() - 1;
1701 int last_line = view_child.last_line() - 1;
1702 int last_column = view_child.last_column();
1704 std::string detail =
1705 !view_child.first_child_by_name(
"type").is_null()
1706 ? wasp::strip_quotes(hit::extractValue(view_child.first_child_by_name(
"type").data()))
1710 wasp::DataObject & data_child = wasp::lsp::addDocumentSymbolChild(data_parent);
1711 pass &= wasp::lsp::buildDocumentSymbolObject(data_child,
1735 const std::string & param_name,
1736 const std::string & clean_type,
1743 return wasp::lsp::m_comp_kind_event;
1744 else if (param_name ==
"active" || param_name ==
"inactive")
1745 return wasp::lsp::m_comp_kind_class;
1746 else if (clean_type ==
"bool")
1747 return wasp::lsp::m_comp_kind_interface;
1752 return is_param ? wasp::lsp::m_comp_kind_enum : wasp::lsp::m_comp_kind_enum_member;
1753 else if (param_name ==
"type")
1754 return wasp::lsp::m_comp_kind_type_param;
1755 else if (std::find_if(associated_types.begin(),
1756 associated_types.end(),
1757 [&](
const auto & entry)
1758 {
return entry.second == clean_type; }) != associated_types.end())
1759 return wasp::lsp::m_comp_kind_reference;
1761 return is_param ? wasp::lsp::m_comp_kind_keyword : wasp::lsp::m_comp_kind_value;
1768 auto is_boolean = [](wasp::HITNodeView symbol_node)
1772 return (iss >> std::boolalpha >>
convert && !iss.fail());
1774 auto is_number = [](wasp::HITNodeView symbol_node)
1777 std::istringstream iss(symbol_node.last_as_string());
1778 return (iss >>
convert && iss.eof());
1782 if (symbol_node.type() == wasp::OBJECT)
1783 return wasp::lsp::m_symbol_kind_struct;
1784 else if (symbol_node.type() == wasp::FILE)
1785 return wasp::lsp::m_symbol_kind_file;
1786 else if (symbol_node.type() == wasp::ARRAY)
1787 return wasp::lsp::m_symbol_kind_array;
1788 else if (symbol_node.type() == wasp::KEYED_VALUE && symbol_node.name() == std::string(
"type"))
1789 return wasp::lsp::m_symbol_kind_type_param;
1790 else if (symbol_node.type() == wasp::KEYED_VALUE && is_boolean(symbol_node))
1791 return wasp::lsp::m_symbol_kind_boolean;
1792 else if (symbol_node.type() == wasp::KEYED_VALUE && is_number(symbol_node))
1793 return wasp::lsp::m_symbol_kind_number;
1794 else if (symbol_node.type() == wasp::KEYED_VALUE)
1795 return wasp::lsp::m_symbol_kind_key;
1796 else if (symbol_node.type() == wasp::VALUE)
1797 return wasp::lsp::m_symbol_kind_string;
1799 return wasp::lsp::m_symbol_kind_property;
1804 const std::string & subblock_type,
1805 const std::set<std::string> & existing_params,
1806 const std::string & indent_spaces)
1810 std::set<std::string> obj_act_tasks;
1814 std::string required_param_text;
1815 std::size_t param_index = 1;
1816 for (
const auto & valid_params_iter : valid_params)
1819 const std::string & param_name = valid_params_iter.first;
1820 if (!valid_params.isParamDeprecated(param_name) && !valid_params.isPrivate(param_name) &&
1821 !valid_params.isParamValid(param_name) && valid_params.isParamRequired(param_name) &&
1822 !existing_params.count(param_name))
1824 std::string tab_stop = client_snippet_support ?
"$" + std::to_string(param_index++) :
"";
1825 required_param_text +=
"\n" + indent_spaces + param_name +
" = " + tab_stop;
1829 return required_param_text;
1834 const std::string & extensionMethod,
1840 if (extensionMethod ==
"plotting")
1852 auto & root = *root_ptr;
1855 wasp::HITNodeView view_root = root.getNodeView();
1856 wasp::HITNodeView request_context =
1857 wasp::findNodeUnderLineColumn(view_root, line + 1, character + 1);
1860 wasp::HITNodeView object_context = request_context;
1861 while (object_context.type() != wasp::OBJECT && object_context.has_parent())
1862 object_context = object_context.parent();
1863 const std::string & object_name = object_context.name();
1864 wasp::HITNodeView type_node = object_context.first_child_by_name(
"type");
1865 const std::string & object_type =
1866 type_node.is_null() ?
"" : wasp::strip_quotes(hit::extractValue(type_node.data()));
1874 std::shared_ptr<FEProblemBase> &
problem = app_ptr->actionWarehouse().problemBase();
1879 if (
problem->hasFunction(object_name))
1883 else if (
problem->hasDistribution(object_name))
1892 const std::string & object_name,
1893 const std::string & object_type)
1901 if (pw_func->functionSize() == 0)
1905 std::vector<double> graph_keys, graph_vals;
1906 for (std::size_t i = 0; i < pw_func->functionSize(); i++)
1908 graph_keys.push_back(pw_func->domain(i));
1909 graph_vals.push_back(pw_func->range(i));
1913 std::string plot_title = object_name +
" " + object_type +
" Function";
1914 std::string x_axis_label =
"abscissa values";
1915 std::string y_axis_label =
"ordinate values";
1916 wasp::CustomPlot plot_object;
1917 buildLineGraphPlot(plot_object, plot_title, x_axis_label, y_axis_label, graph_keys, graph_vals);
1918 plotting_responses.push_back(wasp::serializeCustomPlot(plot_object));
1924 const std::string & object_name,
1925 const std::string & object_type)
1936 if (!std::isfinite(min_x) || !std::isfinite(max_x) || max_x <= min_x || !std::isfinite(del_x))
1947 graph_keys[i] = min_x + (i * del_x);
1948 pdf_values[i] = dist.
pdf(graph_keys[i]);
1949 cdf_values[i] = dist.
cdf(graph_keys[i]);
1952 if (!std::isfinite(pdf_values[i]) || !std::isfinite(cdf_values[i]))
1957 auto add_dist_to_plot = [&](
const std::string & dist_type,
const std::vector<double> & graph_vals)
1959 std::string plot_title = object_name +
" " + object_type +
" " + dist_type +
" Distribution";
1960 std::string x_axis_label =
"x values";
1961 std::string y_axis_label = dist_type +
" values";
1962 wasp::CustomPlot plot_object;
1963 buildLineGraphPlot(plot_object, plot_title, x_axis_label, y_axis_label, graph_keys, graph_vals);
1964 plotting_responses.push_back(wasp::serializeCustomPlot(plot_object));
1968 add_dist_to_plot(
"PDF", pdf_values);
1971 add_dist_to_plot(
"CDF", cdf_values);
1976 const std::string & plot_title,
1977 const std::string & x_axis_label,
1978 const std::string & y_axis_label,
1979 const std::vector<double> & graph_keys,
1980 const std::vector<double> & graph_vals)
1983 double min_key = *std::min_element(graph_keys.begin(), graph_keys.end());
1984 double max_key = *std::max_element(graph_keys.begin(), graph_keys.end());
1985 double min_val = *std::min_element(graph_vals.begin(), graph_vals.end());
1986 double max_val = *std::max_element(graph_vals.begin(), graph_vals.end());
1989 double pad_factor = 0.05;
1990 double pad_x_axis = (max_key - min_key) * pad_factor;
1991 double pad_y_axis = (max_val - min_val) * pad_factor;
1992 if (pad_y_axis == 0)
1993 pad_y_axis = pad_factor;
1994 min_key -= pad_x_axis;
1995 max_key += pad_x_axis;
1996 min_val -= pad_y_axis;
1997 max_val += pad_y_axis;
2000 plot_object.title().text(plot_title);
2001 plot_object.title().font().pointsize(18);
2002 plot_object.title().visible(
true);
2003 plot_object.legend().visible(
false);
2006 plot_object.x1Axis().label(x_axis_label);
2007 plot_object.x1Axis().rangeMin(min_key);
2008 plot_object.x1Axis().rangeMax(max_key);
2009 plot_object.x1Axis().scaleType(wasp::CustomPlot::stLinear);
2010 plot_object.x1Axis().labelType(wasp::CustomPlot::ltNumber);
2011 plot_object.x1Axis().labelFont().pointsize(18);
2012 plot_object.x1Axis().tickLabelFont().pointsize(16);
2015 plot_object.y1Axis().label(y_axis_label);
2016 plot_object.y1Axis().rangeMin(min_val);
2017 plot_object.y1Axis().rangeMax(max_val);
2018 plot_object.y1Axis().scaleType(wasp::CustomPlot::stLinear);
2019 plot_object.y1Axis().labelType(wasp::CustomPlot::ltNumber);
2020 plot_object.y1Axis().labelFont().pointsize(18);
2021 plot_object.y1Axis().tickLabelFont().pointsize(16);
2024 auto line_graph = std::make_shared<wasp::CustomPlot::Graph>();
2025 line_graph->keys() = graph_keys;
2026 line_graph->values() = graph_vals;
2027 line_graph->scatterShape(wasp::CustomPlot::ssDisc);
2028 plot_object.series().push_back(line_graph);
2038 mooseAssert(&app_ptr->parser() == parser_ptr,
"App should have this parser");
2040 if (
const auto root_ptr = parser_ptr->queryRoot())
2041 if (!root_ptr->getNodeView().is_null())
2051 return it ==
_check_state.end() ? nullptr : &it->second;
2064 return state ? state->parser.get() :
nullptr;
2070 return const_cast<Parser *
>(std::as_const(*this).queryCheckParser());
2077 return state->app.get();
2084 return const_cast<MooseApp *
>(std::as_const(*this).queryCheckApp());
2092 auto & app = *app_ptr;
2094 mooseAssert(&app.parser() ==
queryCheckParser(),
"Parser should be the app's parser");
2097 mooseError(
"MooseServer::getCheckApp(): App not available");
2105 mooseError(
"MooseServer::getRoot(): Root not available");
int getDocumentSymbolKind(wasp::HITNodeView symbol_node)
Get document symbol kind value that client may use for outline icon.
const std::multimap< std::string, std::string > & getAssociatedTypes() const
Get a multimap of registered associations of syntax with type.
std::pair< std::multimap< std::string, ActionInfo >::const_iterator, std::multimap< std::string, ActionInfo >::const_iterator > getActions(const std::string &syntax) const
Returns a pair of multimap iterators to all the ActionInfo objects associated with a given piece of s...
std::map< std::string, std::set< std::string > > _type_to_input_paths
_type_to_input_paths - map of parameter types to lookup paths
Function base which provides a piecewise approximation to a specified (x,y) point data set...
A MultiMooseEnum object to hold "execute_on" flags.
bool isRegistered(const std::string &obj_name) const
Returns a Boolean indicating whether an object type has been registered.
virtual Real pdf(const Real &x) const =0
Compute the probability with given probability distribution function (PDF) at x.
void addResourcesForDocument()
Add paths from includes and FileName parameters for client to watch.
void getInputLookupDefinitionNodes(SortedLocationNodes &location_nodes, const std::string &clean_type, const std::string &val_string)
Get set of nodes from associated path lookups matching value string.
const std::multimap< std::string, ActionInfo > & getAssociatedActions() const
Return all Syntax to Action associations.
std::string getRequiredParamsText(const std::string &subblock_path, const std::string &subblock_type, const std::set< std::string > &existing_params, const std::string &indent_spaces)
Get required parameter completion text list for given subblock path.
std::map< std::string, std::set< std::string > > _input_path_to_types
_type_to_input_paths - map of lookup paths to parameter types
Generic factory class for build all sorts of objects.
InputParameters getValidParams(const std::string &name)
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
std::shared_ptr< CommandLine > commandLine() const
Get the command line.
MooseServer(MooseApp &moose_app)
static const std::string main_app_name
The name for the "main" moose application.
bool addValuesToList(wasp::DataArray &completionItems, const InputParameters &valid_params, const std::set< std::string > &existing_params, const std::set< std::string > &existing_subblocks, const std::string ¶m_name, const std::set< std::string > &obj_act_tasks, const std::string &object_path, int replace_line_beg, int replace_char_beg, int replace_line_end, int replace_char_end)
Add parameter values to completion list for request line and column.
MooseApp & getCheckApp()
Public interface for writable check app reference with error checks.
bool gatherDocumentSymbols(wasp::DataArray &documentSymbols)
Gather document symbols - specific to this server implemention.
bool addParametersToList(wasp::DataArray &completionItems, const InputParameters &valid_params, const std::set< std::string > &existing_params, int replace_line_beg, int replace_char_beg, int replace_line_end, int replace_char_end, const std::string &filtering_prefix)
Add parameters that were previously gathered to list for completion.
const InputParameters & parameters() const
Get the parameters of the object.
std::set< std::string > getTasksByAction(const std::string &action) const
virtual void run()
Run the application.
static InputParameters validParams()
Parameters that are processed directly by the Parser and are valid anywhere in the input...
InputParameters getValidParams(const std::string &name) const
Get valid parameters for the object.
Base class for MOOSE-based applications.
const hit::Node & getRoot() const
double _dist_plot_quantile_bound
_dist_plot_quantile_bound - epsilon to bound plot range tails
All Distributions should inherit from this class.
Syntax & syntax()
Returns a writable reference to the syntax object.
bool getHoverDisplayText(std::string &display_text, int line, int character)
Get hover display text - logic specific to this server implemention.
ActionFactory & getActionFactory()
Retrieve a writable reference to the ActionFactory associated with this App.
Specialization of SubProblem for solving nonlinear equations plus auxiliary equations.
const CheckState * queryCheckState() const
FileLineInfo getLineInfo(const std::string &name) const
Gets file and line information where an object was initially registered.
Factory & getFactory()
Retrieve a writable reference to the Factory associated with this App.
bool convert(const std::string &str, T &value, const bool throw_on_failure)
Takes the string representation of a value and converts it to the value.
void buildLineGraphPlot(wasp::CustomPlot &plot_object, const std::string &plot_title, const std::string &x_axis_label, const std::string &y_axis_label, const std::vector< double > &graph_keys, const std::vector< double > &graph_vals)
Build CustomPlot graph with provided keys, values, and plot title.
std::set< wasp::HITNodeView, std::function< bool(const wasp::HITNodeView &, const wasp::HITNodeView &)> > SortedLocationNodes
SortedLocationNodes - type alias for set of nodes sorted by location.
void addObjectsFromWarehouses(const std::string ¶m_type, std::map< std::string, std::string > &options_and_descs)
Supplement completion list with objects in warehouses if applicable.
void getObjectParameters(InputParameters &valid_params, std::string object_type, const std::set< std::string > &obj_act_tasks)
Get all object parameters using requested object path to collection.
static std::unique_ptr< MooseApp > create(const std::string &app_type, const std::vector< std::string > &cli_args={})
Create an app with no input and command line arguments.
Based class for output objects.
void getNodesByValueAndTypes(SortedLocationNodes &match_nodes, wasp::HITNodeView view_parent, const std::string &target_value, const std::set< std::string > &target_types)
Recursively walk input to gather all nodes matching value and types.
static std::string buildOutputString(const std::iterator_traits< InputParameters::iterator >::value_type &p)
const std::string & name() const
Get the name of the class.
const Parser * queryCheckParser() const
void remove(std::string_view)
Specialized factory for generic Action System objects.
std::string trim(const std::string &str, const std::string &white_space=" \\\)
Standard scripting language trim function.
const std::string & type() const
Get the type of this class.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type It sho...
virtual Real cdf(const Real &x) const =0
Compute the cumulative probability with given cumulative probability distribution (CDF) at x...
const MooseApp * queryCheckApp() const
void getAllValidParameters(InputParameters &valid_params, const std::string &object_path, const std::string &object_type, std::set< std::string > &obj_act_tasks)
Get all global parameters, action parameters, and object parameters.
virtual Problem & problem()
Deprecated: Return a reference to this Executioner's Problem instance.
const auto & registeredObjects() const
Returns a reference to the map from names to RegistryEntryBase pointers.
Helper for storing the state for a single document.
std::string toLower(std::string name)
Convert supplied string to lower case.
bool gatherDocumentFormattingTextEdits(wasp::DataArray &formattingTextEdits, int tab_size, bool insert_spaces)
Gather formatting text edits - specific to this server implemention.
static std::string basicCppType(const std::string &cpp_type)
Utilities for making sense of c++ types.
Holds file and line information.
void getFileNameTypeValues(std::set< std::string > &filename_vals, wasp::HITNodeView parent)
Recursively walk input to gather all FileName type parameter values.
static AppFactory & instance()
Get the instance of the AppFactory.
std::string isAssociated(const std::string &real_id, bool *is_parent, const std::map< std::string, std::set< std::string >> &alt_map={}) const
Method for determining whether a piece of syntax is associated with an Action an optional syntax map ...
void getActionParameters(InputParameters &valid_params, const std::string &object_path, std::set< std::string > &obj_act_tasks)
Get all action parameters using requested object path to collection.
bool traverseParseTreeAndFillSymbols(wasp::HITNodeView view_parent, wasp::DataObject &data_parent)
Recursively fill document symbols from the given node.
void buildDistPlotResponses(wasp::DataArray &plotting_responses, FEProblemBase &problem, const std::string &object_name, const std::string &object_type)
Compute PDF and CDF, build CustomPlot objects, and add to responses.
bool gatherExtensionResponses(wasp::DataArray &extensionResponses, const std::string &extensionMethod, int line, int character)
Gather extension responses - specific to this server implemention.
MooseApp & _moose_app
_moose_app - reference to parent application that owns this server
bool addSubblocksToList(wasp::DataArray &completionItems, const std::string &object_path, int replace_line_beg, int replace_char_beg, int replace_line_end, int replace_char_end, const std::string &filtering_prefix, bool request_on_block_decl)
Add subblocks to completion list for request path, line, and column.
bool gatherDocumentCompletionItems(wasp::DataArray &completionItems, bool &is_incomplete, int line, int character)
Gather document completion items - specific to this server implemention.
bool gatherDocumentReferencesLocations(wasp::DataArray &referencesLocations, int line, int character, bool include_declaration)
Gather references locations - specific to this server implemention.
Scoped helper for setting Moose::_throw_on_error during this scope.
IntRange< T > make_range(T beg, T end)
Holding syntax for parsing input files.
bool gatherPlottingResponses(wasp::DataArray &plotting_responses, int line, int character)
Build CustomPlot extension responses when method name is plotting.
std::size_t _formatting_tab_size
_formatting_tab_size - number of indent spaces for formatting
void buildFuncPlotResponse(wasp::DataArray &plotting_responses, FEProblemBase &problem, const std::string &object_name, const std::string &object_type)
Gather function data, build CustomPlot object, and add to responses.
bool parseDocumentForDiagnostics(wasp::DataArray &diagnosticsList)
Parse document for diagnostics - specific to this server implemention.
bool verifyMooseObjectTask(const std::string &base, const std::string &task) const
Returns a Boolean indicating whether a task is associated with on of the MOOSE pluggable systems (BAS...
std::size_t _dist_plot_num_points
_dist_plot_num_points - distribution plot sampling resolution
bool gatherDocumentDefinitionLocations(wasp::DataArray &definitionLocations, int line, int character)
Gather definition locations - specific to this server implemention.
This is a "smart" enum class intended to replace many of the shortcomings in the C++ enum type...
bool addLocationNodesToList(wasp::DataArray &defsOrRefsLocations, const SortedLocationNodes &location_nodes)
Add set of nodes sorted by location to definition or reference list.
virtual Real quantile(const Real &y) const =0
Compute the inverse CDF (quantile function) value for given variable value y.
std::map< std::string, std::set< std::string > > _syntax_to_subblocks
_syntax_to_subblocks - map of syntax paths to valid subblocks
Exception to be thrown whenever we have _throw_on_error set and a mooseError() is emitted...
bool checkFileReadable(const std::string &filename, bool check_line_endings, bool throw_on_unreadable, bool check_for_git_lfs_pointer)
int getCompletionItemKind(const InputParameters &valid_params, const std::string ¶m_name, const std::string &clean_type, bool is_param)
Get completion item kind value that client may use for icon in list.
const std::shared_ptr< libMesh::Parallel::Communicator > getCommunicator() const
void getEnumsAndDocs(MooseEnumType &moose_enum_param, std::map< std::string, std::string > &options_and_descs)
Fill map of all options and descriptions if parameter is moose enum.
void ErrorVector unsigned int
Class for parsing input files.
std::map< std::string, CheckState > _check_state
_check_state - map from document paths to state (parser, app, text)
const hit::Node * queryRoot() const
std::string formatDocument(wasp::HITNodeView parent, std::size_t &prev_line, std::size_t level)
Recursively walk down whole nodeview tree while formatting document.
void escape(std::string &str)
void getExistingInput(wasp::HITNodeView parent_node, std::set< std::string > &existing_params, std::set< std::string > &existing_subblocks)
Get names of parameters and subblocks specified in given input node.
std::string prettyCppType(const std::string &cpp_type)