https://mooseframework.inl.gov
Registry.h
Go to the documentation of this file.
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 #pragma once
11 
12 #include "InputParameters.h"
13 
14 #include <string>
15 #include <vector>
16 #include <set>
17 #include <map>
18 #include <memory>
19 #include <optional>
20 
21 #include "libmesh/utility.h"
22 
23 #ifdef MOOSE_UNIT_TEST
24 #include <gtest/gtest.h>
25 #endif
26 
27 #define combineNames1(X, Y) X##Y
28 #define combineNames(X, Y) combineNames1(X, Y)
29 
34 #define registerKnownLabel(X) \
35  static char combineNames(dummy_var_for_known_label, __COUNTER__) = Registry::addKnownLabel(X)
36 
39 #define registerMooseAction(app, classname, task) \
40  static char combineNames(dummyvar_for_registering_action_##classname, __COUNTER__) = \
41  Registry::addAction<classname>({app, #classname, "", task, __FILE__, __LINE__, "", ""})
42 
45 #define registerMooseObject(app, classname) \
46  static char combineNames(dummyvar_for_registering_obj_##classname, __COUNTER__) = \
47  Registry::add<classname>({app, #classname, "", "", __FILE__, __LINE__, "", ""})
48 
49 #define registerADMooseObject(app, classname) registerMooseObject(app, classname)
50 
53 #define registerMooseObjectAliased(app, classname, alias) \
54  static char combineNames(dummyvar_for_registering_obj_##classname, __COUNTER__) = \
55  Registry::add<classname>({app, #classname, alias, "", __FILE__, __LINE__, "", ""})
56 
59 #define registerMooseObjectDeprecated(app, classname, time) \
60  static char combineNames(dummyvar_for_registering_obj_##classname, __COUNTER__) = \
61  Registry::add<classname>({app, #classname, "", "", __FILE__, __LINE__, time, ""})
62 
63 #define registerADMooseObjectDeprecated(app, classname, time) \
64  registerMooseObjectDeprecated(app, classname, time)
65 
68 #define registerMooseObjectReplaced(app, classname, time, replacement) \
69  static char combineNames(dummyvar_for_registering_obj_##classname, __COUNTER__) = \
70  Registry::add<classname>({app, #classname, "", "", __FILE__, __LINE__, time, #replacement})
71 
76 #define registerMooseObjectRenamed(app, orig_class, time, new_class) \
77  static char combineNames(dummyvar_for_registering_obj_##orig_class, __COUNTER__) = \
78  Registry::add<new_class>( \
79  {app, #new_class, #orig_class, #orig_class, __FILE__, __LINE__, time, #new_class})
80 
81 #define registerADMooseObjectRenamed(app, orig_class, time, new_class) \
82  registerMooseObjectRenamed(app, orig_class, time, new_class)
83 
85 #define registerNonAppDataFilePath(name, path) Registry::addDataFilePath(name, path, false)
86 #define registerNonAppDataFilePathWithInfo(name, path, info) \
88  Registry::addDataFilePath(name, path, false, info)
89 #define registerAppDataFilePath(app) Registry::addAppDataFilePath(app, __FILE__)
93 #define registerMissingDataFilePath(name, info) Registry::addMissingDataFilePath(name, info)
95 #define registerDataFilePath() Registry::addDeprecatedAppDataFilePath(__FILE__)
97 
98 #define registerRepository(repo_name, repo_url) Registry::addRepository(repo_name, repo_url);
99 
100 class Factory;
101 class ActionFactory;
102 class MooseObject;
103 class Action;
104 struct RegistryEntryBase;
105 
111 {
113  std::string _label;
115  std::string _classname;
118  std::string _alias;
120  std::string _name;
122  std::string _file;
124  int _line;
126  std::string _deprecated_time;
128  std::string _replaced_by;
129 };
130 
132 {
134  virtual ~RegistryEntryBase() {}
136  virtual std::unique_ptr<MooseObject> build(const InputParameters & parameters) = 0;
137  virtual std::shared_ptr<MooseObject> buildShared(const InputParameters & parameters) = 0;
138  virtual std::shared_ptr<Action> buildAction(const InputParameters & parameters) = 0;
139  virtual InputParameters buildParameters() = 0;
141  std::string name() const
142  {
143  std::string name = _name;
144  if (name.empty())
145  name = _alias;
146  if (name.empty())
147  name = _classname;
148  return name;
149  }
150 };
151 
152 template <typename T>
154 {
155  RegistryEntry(const RegistryEntryData & data);
156  virtual std::unique_ptr<MooseObject> build(const InputParameters & parameters) override;
157  virtual std::shared_ptr<MooseObject> buildShared(const InputParameters & parameters) override;
158  virtual std::shared_ptr<Action> buildAction(const InputParameters & parameters) override;
159  virtual InputParameters buildParameters() override;
160 };
161 
171 class Registry
172 {
173 public:
177  static Registry & getRegistry();
178 
182  template <typename T>
183  static char add(const RegistryEntryData & base_info)
184  {
185  const auto info = std::make_shared<RegistryEntry<T>>(base_info);
186  getRegistry()._per_label_objects[info->_label].push_back(info);
187  getRegistry()._type_to_classname[typeid(T).name()] = info->name();
188  return 0;
189  }
190 
194  template <typename T>
195  static char addAction(const RegistryEntryData & base_info)
196  {
197  const auto info = std::make_shared<RegistryEntry<T>>(base_info);
198  getRegistry()._per_label_actions[info->_label].push_back(info);
199  getRegistry()._type_to_classname[typeid(T).name()] = info->_classname;
200  return 0;
201  }
202 
203  template <typename T>
204  static std::string getClassName()
205  {
206  return libmesh_map_find(getRegistry()._type_to_classname, typeid(T).name());
207  }
208 
211  static void registerObjectsTo(Factory & f, const std::set<std::string> & labels);
212 
215  static void registerActionsTo(ActionFactory & f, const std::set<std::string> & labels);
216 
218  static char addKnownLabel(const std::string & label);
219 
221  static void addDataFilePath(const std::string & name,
222  const std::string & in_tree_path,
223  const bool app = true,
224  const std::optional<std::string> & info = {});
227  static void addAppDataFilePath(const std::string & app_name, const std::string & app_path);
229  static void addMissingDataFilePath(const std::string & name, const std::string & info);
231  static void addDeprecatedAppDataFilePath(const std::string & app_path);
232 
234  static void addRepository(const std::string & repo_name, const std::string & repo_url);
235 
237  static const std::map<std::string, std::vector<std::shared_ptr<RegistryEntryBase>>> & allObjects()
238  {
240  }
242  static const std::map<std::string, std::vector<std::shared_ptr<RegistryEntryBase>>> & allActions()
243  {
245  }
246 
247  static const RegistryEntryBase & objData(const std::string & name);
248 
252  static bool isRegisteredObj(const std::string & name)
253  {
254  return getRegistry()._name_to_entry.count(name);
255  }
256 
258  static const std::map<std::string, std::string> & getDataFilePaths()
259  {
260  return getRegistry()._data_file_paths;
261  }
267  static std::string getDataFilePath(const std::string & name);
268 
270  static const std::string & getRepositoryURL(const std::string & repo_name);
274  static const std::map<std::string, std::string> & getRepos() { return getRegistry()._repos; }
275 
277  template <typename T>
278  static std::string getRegisteredName();
279 
281  Registry(Registry const &) = delete;
282  Registry & operator=(Registry const &) = delete;
283 
284  Registry(Registry &&) = delete;
285  Registry & operator=(Registry &&) = delete;
287 
288 private:
289 #ifdef MOOSE_UNIT_TEST
290  friend class RegistryTest;
293  friend class DataFileUtilsTest;
294  FRIEND_TEST(RegistryTest, determineFilePath);
295  FRIEND_TEST(RegistryTest, determineFilePathFailed);
297  FRIEND_TEST(RegistryTest, appNameFromAppPathFailed);
300 #endif
301 
302  Registry() {};
303 
309  static void setDataFilePaths(const std::map<std::string, std::string> & data_file_paths)
310  {
311  getRegistry()._data_file_paths = data_file_paths;
312  }
318  static void setRepos(const std::map<std::string, std::string> & repos)
319  {
320  getRegistry()._repos = repos;
321  }
322 
324  static std::string determineDataFilePath(const std::string & name,
325  const std::string & in_tree_path);
326 
329  static std::string appNameFromAppPath(const std::string & app_path);
330 
332  static void checkDataFilePathName(const std::string & name);
333 
335  static void addDataFilePathCapability(const std::string & name,
336  const std::optional<std::string> & path = {},
337  const std::optional<std::string> & extra_info = {});
338 
339  std::map<std::string, std::shared_ptr<RegistryEntryBase>> _name_to_entry;
340  std::map<std::string, std::vector<std::shared_ptr<RegistryEntryBase>>> _per_label_objects;
341  std::map<std::string, std::vector<std::shared_ptr<RegistryEntryBase>>> _per_label_actions;
342  std::set<std::string> _known_labels;
344  std::map<std::string, std::string> _data_file_paths;
346  std::map<std::string, std::string> _repos;
347  std::map<std::string, std::string> _type_to_classname;
348 };
349 
350 template <typename T>
351 std::string
353 {
354  mooseDeprecated("Use Registry::getClassName() instead.");
355  return getClassName<T>();
356 }
357 
358 template <typename T>
360 {
361  static_assert(std::is_base_of_v<MooseObject, T> || std::is_base_of_v<Action, T>,
362  "Not derived from MooseObject or Action");
363 }
364 
365 template <typename T>
366 std::unique_ptr<MooseObject>
368 {
369  if constexpr (std::is_base_of_v<MooseObject, T>)
370  return std::make_unique<T>(parameters);
371  mooseError(MooseUtils::prettyCppType<T>(), " to be built is not a MooseObject.");
372 }
373 template <typename T>
374 std::shared_ptr<MooseObject>
376 {
377  if constexpr (std::is_base_of_v<MooseObject, T>)
378  return std::make_shared<T>(parameters);
379  mooseError(MooseUtils::prettyCppType<T>(), " to be built is not a MooseObject.");
380 }
381 
382 template <typename T>
383 std::shared_ptr<Action>
385 {
386  if constexpr (!std::is_base_of_v<Action, T>)
387  mooseError("The action to be built is not derived from Action.");
388  else
389  return std::make_shared<T>(parameters);
390 }
391 
392 template <typename T>
395 {
396  auto params = T::validParams();
397  return params;
398 }
std::string name(const ElemQuality q)
static std::string appNameFromAppPath(const std::string &app_path)
Internal helper for getting an application name from its path, for example: /path/to/FooBarBazApp.C -> foo_bar_baz, for use in addDeprecatedAppDataFilePath.
Definition: Registry.C:225
virtual std::shared_ptr< MooseObject > buildShared(const InputParameters &parameters) override
Definition: Registry.h:375
virtual std::shared_ptr< Action > buildAction(const InputParameters &parameters) override
Definition: Registry.h:384
virtual std::unique_ptr< MooseObject > build(const InputParameters &parameters)=0
proxy functions
static const RegistryEntryBase & objData(const std::string &name)
Definition: Registry.C:58
std::map< std::string, std::vector< std::shared_ptr< RegistryEntryBase > > > _per_label_actions
Definition: Registry.h:341
static Registry & getRegistry()
Get the global Registry singleton.
Definition: Registry.C:24
static void addDataFilePath(const std::string &name, const std::string &in_tree_path, const bool app=true, const std::optional< std::string > &info={})
register general search paths; "app" is whether or not the path is an app path
Definition: Registry.C:92
virtual InputParameters buildParameters()=0
MPI_Info info
Generic factory class for build all sorts of objects.
Definition: Factory.h:28
static std::string getDataFilePath(const std::string &name)
Gets a data path for the registered name.
Definition: Registry.C:166
void mooseError(Args &&... args)
Emit an error message with the given stringified, concatenated args and terminate the application...
Definition: MooseError.h:311
static void addAppDataFilePath(const std::string &app_name, const std::string &app_path)
register search paths for an application (path determined relative to app_path); app_path should be p...
Definition: Registry.C:144
Holds details and meta-data info for a particular MooseObject or Action for use in the use in the reg...
Definition: Registry.h:110
static const std::map< std::string, std::vector< std::shared_ptr< RegistryEntryBase > > > & allActions()
Returns a per-label keyed map of all Actions in the registry.
Definition: Registry.h:242
static std::string getRegisteredName()
returns the name() for a registered class
Definition: Registry.h:352
std::string _classname
name of the c++ class for the object.
Definition: Registry.h:115
static std::string determineDataFilePath(const std::string &name, const std::string &in_tree_path)
Internal helper for determing a root data file path (in-tree vs installed)
Definition: Registry.C:198
friend class RegistryTest
Friends for unit testing.
Definition: Registry.h:292
The main MOOSE class responsible for handling user-defined parameters in almost every MOOSE system...
static void registerObjectsTo(Factory &f, const std::set< std::string > &labels)
This registers all MooseObjects known to the registry that have the given label(s) with the factory f...
Definition: Registry.C:35
virtual std::shared_ptr< Action > buildAction(const InputParameters &parameters)=0
RegistryEntryBase(const RegistryEntryData &data)
Definition: Registry.h:133
Registry()
Definition: Registry.h:302
static const std::map< std::string, std::vector< std::shared_ptr< RegistryEntryBase > > > & allObjects()
Returns a per-label keyed map of all MooseObjects in the registry.
Definition: Registry.h:237
std::string _file
file path for the c++ file the object or action was added to the registry in.
Definition: Registry.h:122
static char addAction(const RegistryEntryData &base_info)
Adds information on an Action object to the registry.
Definition: Registry.h:195
Base class for actions.
Definition: Action.h:34
virtual ~RegistryEntryBase()
Definition: Registry.h:134
friend class DataFileUtilsTest
Definition: Registry.h:293
static void setDataFilePaths(const std::map< std::string, std::string > &data_file_paths)
Manually set the data file paths.
Definition: Registry.h:309
std::string _name
name that the object will be registered to factories under. If unspecified, _alias is used...
Definition: Registry.h:120
virtual std::shared_ptr< MooseObject > buildShared(const InputParameters &parameters)=0
static void addMissingDataFilePath(const std::string &name, const std::string &info)
register a data file path as missing, along with info about how it can be added
Definition: Registry.C:137
FRIEND_TEST(RegistryTest, determineFilePath)
static void registerActionsTo(ActionFactory &f, const std::set< std::string > &labels)
This registers all Actions known to the registry that have the given label(s) with the factory f...
Definition: Registry.C:69
static char add(const RegistryEntryData &base_info)
Adds information on a MooseObject to the registry.
Definition: Registry.h:183
std::string name() const
resolve the name from _classname, _alias, and _name
Definition: Registry.h:141
std::string _alias
an alternate name to register the object to factories under.
Definition: Registry.h:118
std::string _replaced_by
class name for an object that replaces this object if deprecated, blank otherwise.
Definition: Registry.h:128
Every object that can be built by the factory should be derived from this class.
Definition: MooseObject.h:28
static void addDataFilePathCapability(const std::string &name, const std::optional< std::string > &path={}, const std::optional< std::string > &extra_info={})
Add a data file path capability.
Definition: Registry.C:256
std::map< std::string, std::string > _data_file_paths
Data file registry; name -> in-tree path.
Definition: Registry.h:344
std::map< std::string, std::shared_ptr< RegistryEntryBase > > _name_to_entry
Definition: Registry.h:339
Specialized factory for generic Action System objects.
Definition: ActionFactory.h:48
static void checkDataFilePathName(const std::string &name)
Check a data file path for valid characters.
Definition: Registry.C:247
static std::string getClassName()
Definition: Registry.h:204
static void addRepository(const std::string &repo_name, const std::string &repo_url)
register a repository
Definition: Registry.C:176
virtual std::unique_ptr< MooseObject > build(const InputParameters &parameters) override
proxy functions
Definition: Registry.h:367
void mooseDeprecated(Args &&... args)
Emit a deprecated code/feature message with the given stringified, concatenated args.
Definition: MooseError.h:363
int _line
line number in the c++ file the object or action was added to the registry on.
Definition: Registry.h:124
static void setRepos(const std::map< std::string, std::string > &repos)
Manually set the repos.
Definition: Registry.h:318
std::string _label
label (usually app name - e.g. "YourAnimalApp") that the object or action is associated with...
Definition: Registry.h:113
std::set< std::string > _known_labels
Definition: Registry.h:342
std::map< std::string, std::string > _type_to_classname
Definition: Registry.h:347
static bool isRegisteredObj(const std::string &name)
Definition: Registry.h:252
std::string _deprecated_time
time in "mm/dd/yyyy HH:MM" format that the object is/becomes deprecated, blank otherwise.
Definition: Registry.h:126
RegistryEntry(const RegistryEntryData &data)
Definition: Registry.h:359
std::map< std::string, std::string > _repos
Repository name -> repository URL; used for mooseDocumentedError.
Definition: Registry.h:346
virtual InputParameters buildParameters() override
Definition: Registry.h:394
static const std::string & getRepositoryURL(const std::string &repo_name)
Returns the repository URL associated with repo_name.
Definition: Registry.C:189
static const std::map< std::string, std::string > & getDataFilePaths()
Returns a map of all registered data file paths (name -> path)
Definition: Registry.h:258
Registry & operator=(Registry const &)=delete
static void addDeprecatedAppDataFilePath(const std::string &app_path)
deprecated method; use addAppDataFilePath instead
Definition: Registry.C:154
The registry is used as a global singleton to collect information on all available MooseObject and Ac...
Definition: Registry.h:171
static const std::map< std::string, std::string > & getRepos()
Returns a map of all registered repositories.
Definition: Registry.h:274
std::map< std::string, std::vector< std::shared_ptr< RegistryEntryBase > > > _per_label_objects
Definition: Registry.h:340
InputParameters validParams()
static char addKnownLabel(const std::string &label)
addKnownLabel whitelists a label as valid for purposes of the checkLabels function.
Definition: Registry.C:85