LCOV - code coverage report
Current view: top level - include/base - Moose.h (source / functions) Hit Total Coverage
Test: idaholab/moose framework: #32971 (54bef8) with base c6cf66 Lines: 9 9 100.0 %
Date: 2026-05-29 20:35:17 Functions: 7 8 87.5 %
Legend: Lines: hit not hit

          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             : #pragma once
      11             : 
      12             : #include "libMeshReducedNamespace.h"
      13             : #include "libmesh/perf_log.h"
      14             : #include "libmesh/libmesh_common.h"
      15             : #include "XTermConstants.h"
      16             : 
      17             : #include <limits>
      18             : #include <memory>
      19             : #include <set>
      20             : #include <string>
      21             : 
      22             : #define QUOTE(macro) stringifyName(macro)
      23             : #define stringifyName(name) #name
      24             : 
      25             : namespace libMesh
      26             : {
      27             : template <typename>
      28             : class NumericVector;
      29             : template <typename>
      30             : class SparseMatrix;
      31             : 
      32             : // This was deprecated in libMesh a year ago!  It was obsolete 5 years
      33             : // ago!  How are 6 apps in CI still using it!?
      34             : #ifdef LIBMESH_ENABLE_DEPRECATED
      35             : template <typename T>
      36             : using UniquePtr = std::unique_ptr<T>;
      37             : #endif
      38             : }
      39             : 
      40             : class ActionFactory;
      41             : class Factory;
      42             : class MooseEnumItem;
      43             : class ExecFlagEnum;
      44             : class MooseVariableFieldBase;
      45             : 
      46             : namespace hit
      47             : {
      48             : class Node;
      49             : }
      50             : 
      51             : void MooseVecView(libMesh::NumericVector<libMesh::Number> & vector);
      52             : void MooseVecView(const libMesh::NumericVector<libMesh::Number> & vector);
      53             : void MooseMatView(libMesh::SparseMatrix<libMesh::Number> & mat);
      54             : void MooseMatView(const libMesh::SparseMatrix<libMesh::Number> & mat);
      55             : 
      56             : /**
      57             :  * MOOSE now contains C++17 code, so give a reasonable error message
      58             :  * stating what the user can do to address this in their environment if C++17
      59             :  * compatibility isn't found.
      60             :  */
      61             : namespace Moose
      62             : {
      63             : static_assert(__cplusplus >= 201703L,
      64             :               "MOOSE requires a C++17 compatible compiler (GCC >= 7.5.0, Clang >= 5.0.2). Please "
      65             :               "update your compiler or, if compatible, add '-std=c++17' to your compiler flags "
      66             :               "and try again. If using the MOOSE conda package, please attempt a MOOSE environment "
      67             :               "update (using `mamba update moose-dev`). If this update is not successful, please "
      68             :               "create a new MOOSE environment (see "
      69             :               "https://mooseframework.inl.gov/getting_started/installation/"
      70             :               "conda.html#uninstall-conda-moose-environment).");
      71             : }
      72             : 
      73             : /**
      74             :  * Testing a condition on a local CPU that need to be propagated across all processes.
      75             :  *
      76             :  * If the condition 'cond' is satisfied, it gets propagated across all processes, so the parallel
      77             :  * code take the same path (if that is requires).
      78             :  */
      79             : #define parallel_if                                                                                \
      80             :   (cond) bool __local_bool__ = (cond);                                                             \
      81             :   Parallel::max<bool>(__local_bool__);                                                             \
      82             :   if (__local_bool__)
      83             : 
      84             : /**
      85             :  * Wrap all fortran function calls in this.
      86             :  */
      87             : #ifdef __bg__ // On Blue Gene Architectures there is no underscore
      88             : #define FORTRAN_CALL(name) name
      89             : #else // One underscore everywhere else
      90             : #define FORTRAN_CALL(name) name##_
      91             : #endif
      92             : 
      93             : /**
      94             :  * Function to mirror the behavior of the C++17 std::map::try_emplace() method (no hint).
      95             :  * @param m The std::map
      96             :  * @param k The key use to insert the pair
      97             :  * @param args The value to be inserted. This can be a moveable type but won't be moved
      98             :  *             if the insertion is successful.
      99             :  */
     100             : template <class M, class... Args>
     101             : std::pair<typename M::iterator, bool>
     102       44141 : moose_try_emplace(M & m, const typename M::key_type & k, Args &&... args)
     103             : {
     104       44141 :   auto it = m.lower_bound(k);
     105       44141 :   if (it == m.end() || m.key_comp()(k, it->first))
     106             :   {
     107        5528 :     return {m.emplace_hint(it,
     108             :                            std::piecewise_construct,
     109             :                            std::forward_as_tuple(k),
     110             :                            std::forward_as_tuple(std::forward<Args>(args)...)),
     111        5528 :             true};
     112             :   }
     113       38613 :   return {it, false};
     114             : }
     115             : 
     116             : // forward declarations
     117             : class Syntax;
     118             : class FEProblemBase;
     119             : 
     120             : // Define MOOSE execution flags, this cannot be done in MooseTypes because the registration calls
     121             : // must be in Moose.C to remain consistent with other registration calls.
     122             : using ExecFlagType = MooseEnumItem;
     123             : extern const ExecFlagType EXEC_NONE;
     124             : extern const ExecFlagType EXEC_INITIAL;
     125             : extern const ExecFlagType EXEC_LINEAR_CONVERGENCE;
     126             : extern const ExecFlagType EXEC_LINEAR;
     127             : extern const ExecFlagType EXEC_NONLINEAR_CONVERGENCE;
     128             : extern const ExecFlagType EXEC_NONLINEAR;
     129             : extern const ExecFlagType EXEC_POSTCHECK;
     130             : extern const ExecFlagType EXEC_TIMESTEP_END;
     131             : extern const ExecFlagType EXEC_TIMESTEP_BEGIN;
     132             : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_ITERATION_END;
     133             : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_BEGIN;
     134             : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_END;
     135             : extern const ExecFlagType EXEC_MULTIAPP_FIXED_POINT_CONVERGENCE;
     136             : extern const ExecFlagType EXEC_FINAL;
     137             : extern const ExecFlagType EXEC_FORCED;
     138             : extern const ExecFlagType EXEC_FAILED;
     139             : extern const ExecFlagType EXEC_CUSTOM;
     140             : extern const ExecFlagType EXEC_SUBDOMAIN;
     141             : extern const ExecFlagType EXEC_PRE_DISPLACE;
     142             : extern const ExecFlagType EXEC_SAME_AS_MULTIAPP;
     143             : extern const ExecFlagType EXEC_PRE_MULTIAPP_SETUP;
     144             : extern const ExecFlagType EXEC_TRANSFER;
     145             : extern const ExecFlagType EXEC_PRE_KERNELS;
     146             : extern const ExecFlagType EXEC_ALWAYS;
     147             : #ifdef LIBMESH_ENABLE_AMR
     148             : extern const ExecFlagType EXEC_POST_ADAPTIVITY;
     149             : #endif
     150             : 
     151             : namespace Moose
     152             : {
     153             : // MOOSE is not tested with LIBMESH_DIM != 3
     154             : static_assert(LIBMESH_DIM == 3,
     155             :               "MOOSE must be built with a libmesh library compiled without --enable-1D-only "
     156             :               "or --enable-2D-only");
     157             : 
     158             : /**
     159             :  * This is the dimension of all vector and tensor datastructures used in MOOSE.
     160             :  * We enforce LIBMESH_DIM == 3 through a static assertion above.
     161             :  * Note that lower dimensional simulations embedded in 3D space can always be requested at runtime.
     162             :  */
     163             : static constexpr std::size_t dim = LIBMESH_DIM;
     164             : 
     165             : /// Value for invalid size_t indices
     166             : inline constexpr std::size_t invalid_size_t = std::numeric_limits<std::size_t>::max();
     167             : 
     168             : /**
     169             :  * Used by the signal handler to determine if we should write a checkpoint file out at any point
     170             :  * during operation.
     171             :  */
     172             : extern int interrupt_signal_number;
     173             : 
     174             : /**
     175             :  * Set to false (the default) to display an error message only once for each error call code
     176             :  * location (as opposed to every time the code is executed).
     177             :  */
     178             : extern bool show_multiple;
     179             : 
     180             : /**
     181             :  * Perflog to be used by applications.
     182             :  * If the application prints this in the end they will get performance info.
     183             :  *
     184             :  * This is no longer instantiated in the framework and will be removed in the future.
     185             :  */
     186             : extern libMesh::PerfLog perf_log;
     187             : 
     188             : /**
     189             :  * Variable indicating whether we will enable FPE trapping for this run.
     190             :  */
     191             : extern bool _trap_fpe;
     192             : 
     193             : /**
     194             :  * Variable to toggle any warning into an error (includes deprecated code warnings)
     195             :  */
     196             : extern bool _warnings_are_errors;
     197             : 
     198             : /**
     199             :  * Variable to toggle only deprecated warnings as errors.
     200             :  */
     201             : extern bool _deprecated_is_error;
     202             : 
     203             : /**
     204             :  * Variable to turn on exceptions during mooseError(), should only be used within MOOSE unit tests
     205             :  * or when about to perform threaded operations because exception throwing in threaded regions is
     206             :  * safe while aborting is inherently not when singletons are involved (e.g. what thread is
     207             :  * responsible for destruction, or what do you do about mutexes?)
     208             :  */
     209             : extern bool _throw_on_error;
     210             : 
     211             : /**
     212             :  * Variable to turn on exceptions during mooseWarning(), should
     213             :  * only be used in MOOSE unit tests.
     214             :  */
     215             : extern bool _throw_on_warning;
     216             : 
     217             : /**
     218             :  * Storage for the registered execute flags. This is needed for the ExecuteMooseObjectWarehouse
     219             :  * to create the necessary storage containers on a per flag basis. This isn't something that
     220             :  * should be used by application developers.
     221             :  */
     222             : extern ExecFlagEnum execute_flags;
     223             : 
     224             : /**
     225             :  * Macros for coloring any output stream (_console, std::ostringstream, etc.)
     226             :  */
     227             : #define COLOR_BLACK (Moose::colorConsole() ? XTERM_BLACK : "")
     228             : #define COLOR_RED (Moose::colorConsole() ? XTERM_RED : "")
     229             : #define COLOR_GREEN (Moose::colorConsole() ? XTERM_GREEN : "")
     230             : #define COLOR_YELLOW (Moose::colorConsole() ? XTERM_YELLOW : "")
     231             : #define COLOR_BLUE (Moose::colorConsole() ? XTERM_BLUE : "")
     232             : #define COLOR_MAGENTA (Moose::colorConsole() ? XTERM_MAGENTA : "")
     233             : #define COLOR_CYAN (Moose::colorConsole() ? XTERM_CYAN : "")
     234             : #define COLOR_WHITE (Moose::colorConsole() ? XTERM_WHITE : "")
     235             : #define COLOR_DEFAULT (Moose::colorConsole() ? XTERM_DEFAULT : "")
     236             : 
     237             : /// Returns whether Console coloring is turned on (default: true).
     238             : bool colorConsole();
     239             : 
     240             : /// Turns color escape sequences on/off for info written to stdout.
     241             : /// Returns the the set value which may be different than use_color.
     242             : bool setColorConsole(bool use_color, bool force = false);
     243             : 
     244             : /**
     245             :  * Import libMesh::out, and libMesh::err for use in MOOSE.
     246             :  */
     247             : using libMesh::err;
     248             : using libMesh::out;
     249             : 
     250             : /**
     251             :  * Register objects that are in MOOSE
     252             :  */
     253             : 
     254             : void registerAll(Factory & f, ActionFactory & af, Syntax & s);
     255             : 
     256             : void registerObjects(Factory & factory, const std::set<std::string> & obj_labels);
     257             : void addActionTypes(Syntax & syntax);
     258             : void registerActions(Syntax & syntax, ActionFactory & action_factory);
     259             : void registerActions(Syntax & syntax,
     260             :                      ActionFactory & action_factory,
     261             :                      const std::set<std::string> & obj_labels);
     262             : 
     263             : void associateSyntax(Syntax & syntax, ActionFactory & action_factory);
     264             : 
     265             : void setSolverDefaults(FEProblemBase & problem);
     266             : 
     267             : /**
     268             :  * Swap the libMesh MPI communicator out for ours.  Note that you should usually use
     269             :  * the Moose::ScopedCommSwapper class instead of calling this function.
     270             :  */
     271             : MPI_Comm swapLibMeshComm(MPI_Comm new_comm);
     272             : 
     273             : class ScopedCommSwapper
     274             : {
     275             : public:
     276             :   /// Swaps the current libmesh MPI communicator for new_comm.  new_comm will be automatically
     277             :   /// swapped back in as the current libmesh communicator when this object is destructed.
     278      584218 :   ScopedCommSwapper(MPI_Comm new_comm) : _orig(swapLibMeshComm(new_comm)) {}
     279      584143 :   virtual ~ScopedCommSwapper() { swapLibMeshComm(_orig); }
     280             :   /// Forcibly swap the currently swapped-out communicator back in to libmesh.  Calling this
     281             :   /// function twice in a row leaves communicators exactly as they were before this function
     282             :   /// was called.  Usually you should not need/use this function because MPI communicators
     283             :   /// are swapped automatically when this object is constructed/destructed.
     284       35507 :   void forceSwap() { _orig = swapLibMeshComm(_orig); }
     285             : 
     286             : private:
     287             :   MPI_Comm _orig;
     288             : };
     289             : 
     290             : /**
     291             :  * Scoped helper for setting Moose::_throw_on_error during this scope.
     292             :  *
     293             :  * Cannot be used within threads.
     294             :  */
     295             : class ScopedThrowOnError
     296             : {
     297             : public:
     298             :   /**
     299             :    * Default constructor, which sets Moose::_throw_on_error = true
     300             :    */
     301             :   ScopedThrowOnError();
     302             : 
     303             :   /**
     304             :    * Specialized constructor, which sets Moose::_throw_on_error
     305             :    * based on the argument \p throw_on_error
     306             :    */
     307             :   ScopedThrowOnError(const bool throw_on_error);
     308             : 
     309             :   /**
     310             :    * Destructor, which sets Moose::_throw_on_error to what it
     311             :    * was upon construction
     312             :    */
     313             :   ~ScopedThrowOnError();
     314             : 
     315             : private:
     316             :   /// The value of Moose::_throw_on_error at construction
     317             :   const bool _throw_on_error_before;
     318             : };
     319             : 
     320             : /**
     321             :  * Scoped helper for setting Moose::_deprecated_is_error during this scope.
     322             :  *
     323             :  * Cannot be used within threads.
     324             :  */
     325             : class ScopedDeprecatedIsError
     326             : {
     327             : public:
     328             :   /**
     329             :    * Default constructor, which sets Moose::_deprecated_is_error = true
     330             :    */
     331             :   ScopedDeprecatedIsError();
     332             : 
     333             :   /**
     334             :    * Specialized constructor, which sets Moose::_deprecated_is_error
     335             :    * based on the argument \p deprecated_is_error
     336             :    */
     337             :   ScopedDeprecatedIsError(const bool deprecated_is_error);
     338             : 
     339             :   /**
     340             :    * Destructor, which sets Moose::_deprecated_is_error to what it
     341             :    * was upon construction
     342             :    */
     343             :   ~ScopedDeprecatedIsError();
     344             : 
     345             : private:
     346             :   /// The value of Moose::_throw_on_error at construction
     347             :   const bool _deprecated_is_error_before;
     348             : };
     349             : 
     350             : /**
     351             :  * Get the prefix to be associated with a hit node for a message
     352             :  */
     353             : std::string hitMessagePrefix(const hit::Node & node);
     354             : 
     355             : // MOOSE Requires PETSc to run, this CPP check will cause a compile error if PETSc is not found
     356             : #ifndef LIBMESH_HAVE_PETSC
     357             : #error PETSc has not been detected, please ensure your environment is set up properly then rerun the libmesh build script and try to compile MOOSE again.
     358             : #endif
     359             : 
     360             : } // namespace Moose
     361             : 
     362             : // If we are using MFEM, in addition to the checks we do as part of the build system in moose.mk,
     363             : // we check at compile time if both MOOSE and MFEM were built in dbg mode or not
     364             : #ifdef MOOSE_MFEM_ENABLED
     365             : #include "libmesh/ignore_warnings.h"
     366             : #include <mfem.hpp>
     367             : #include "libmesh/restore_warnings.h"
     368             : #ifdef MFEM_DEBUG
     369             : static_assert(std::string_view(QUOTE(METHOD)) == "dbg",
     370             :               "MFEM was built in dbg mode, but not MOOSE. Try reinstalling "
     371             :               "MFEM using the scripts/update_and_rebuild_mfem.sh script.");
     372             : #else
     373             : static_assert(std::string_view(QUOTE(METHOD)) != "dbg",
     374             :               "MOOSE was built in dbg mode, but not MFEM. Try reinstalling "
     375             :               "MFEM using the scripts/update_and_rebuild_mfem.sh script.");
     376             : #endif
     377             : #endif

Generated by: LCOV version 1.14