diff --git a/Applications/FileIO/GocadIO/GocadSGridReader.cpp b/Applications/FileIO/GocadIO/GocadSGridReader.cpp index e3de81a29eef3767ef19f63c5433a346f9f7cbfc..931855b6ff60dfa37093d15d4ecbce8c32974a3a 100644 --- a/Applications/FileIO/GocadIO/GocadSGridReader.cpp +++ b/Applications/FileIO/GocadIO/GocadSGridReader.cpp @@ -20,6 +20,7 @@ #include "MeshLib/Elements/Hex.h" #include "MeshLib/Elements/Quad.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace FileIO { diff --git a/Applications/FileIO/SWMM/SWMMInterface.cpp b/Applications/FileIO/SWMM/SWMMInterface.cpp index c376b868d2de88d0d8b7b663c36e912bcaf09733..663eb8365620c99fc9a6c74118ab67755a09a122 100644 --- a/Applications/FileIO/SWMM/SWMMInterface.cpp +++ b/Applications/FileIO/SWMM/SWMMInterface.cpp @@ -27,6 +27,7 @@ #include "MeshLib/Mesh.h" #include "MeshLib/Node.h" #include "MeshLib/Properties.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace FileIO { diff --git a/Applications/Utils/MeshEdit/PVTU2VTU/PVTU2VTU.cpp b/Applications/Utils/MeshEdit/PVTU2VTU/PVTU2VTU.cpp index 6d6c70fbd8085f3e10e522ba46ccd12817b53bc7..90b937dc500667d5d77fce9d7731f949de59e12d 100644 --- a/Applications/Utils/MeshEdit/PVTU2VTU/PVTU2VTU.cpp +++ b/Applications/Utils/MeshEdit/PVTU2VTU/PVTU2VTU.cpp @@ -31,6 +31,7 @@ #include "MeshLib/Node.h" #include "MeshLib/Properties.h" #include "MeshLib/Utils/IntegrationPointWriter.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" struct MeshEntityMapInfo { diff --git a/ChemistryLib/PhreeqcIOData/CreateAqueousSolution.cpp b/ChemistryLib/PhreeqcIOData/CreateAqueousSolution.cpp index 8af4a7feca6dccfccbcde55ebe780773dce00a66..0863d739e7dc73281a48f1e1317fa873c721e842 100644 --- a/ChemistryLib/PhreeqcIOData/CreateAqueousSolution.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateAqueousSolution.cpp @@ -15,6 +15,7 @@ #include "ChemistryLib/Common/CreateChargeBalance.h" #include "CreateSolutionComponent.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/ChemistryLib/PhreeqcIOData/CreateEquilibriumReactants.cpp b/ChemistryLib/PhreeqcIOData/CreateEquilibriumReactants.cpp index 9e5ad34d4b697bc3d58781b7e78e553f0fc94ef5..ae9b9f6ad66b1316b18e5c4582f2a06cd69b3a7d 100644 --- a/ChemistryLib/PhreeqcIOData/CreateEquilibriumReactants.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateEquilibriumReactants.cpp @@ -15,6 +15,7 @@ #include "BaseLib/ConfigTree.h" #include "EquilibriumReactant.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/ChemistryLib/PhreeqcIOData/CreateExchange.cpp b/ChemistryLib/PhreeqcIOData/CreateExchange.cpp index 17e07f3e7f4f580b5bcd43a17f892c608bd8012d..2c8ce5a360a27e28f64b09e11f87aca384453e8a 100644 --- a/ChemistryLib/PhreeqcIOData/CreateExchange.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateExchange.cpp @@ -13,6 +13,7 @@ #include "BaseLib/ConfigTree.h" #include "Exchange.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/ChemistryLib/PhreeqcIOData/CreateKineticReactant.cpp b/ChemistryLib/PhreeqcIOData/CreateKineticReactant.cpp index 9dc6230d03fa1f759b7fd9bd630455ef55713f9d..665275baf1176c386b555ab075458616417474f9 100644 --- a/ChemistryLib/PhreeqcIOData/CreateKineticReactant.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateKineticReactant.cpp @@ -15,6 +15,7 @@ #include "BaseLib/ConfigTree.h" #include "KineticReactant.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/ChemistryLib/PhreeqcIOData/CreateSurface.cpp b/ChemistryLib/PhreeqcIOData/CreateSurface.cpp index 7ab6e64f9ca47f8ac97222cec8bfe99627a94e16..698807dfb488189258ce011494cc68b9182f2153 100644 --- a/ChemistryLib/PhreeqcIOData/CreateSurface.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateSurface.cpp @@ -12,6 +12,7 @@ #include "BaseLib/ConfigTree.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "Surface.h" namespace ChemistryLib diff --git a/ChemistryLib/PhreeqcIOData/CreateUserPunch.cpp b/ChemistryLib/PhreeqcIOData/CreateUserPunch.cpp index eae92d951e2294886ac92ccf6fc52fb06dc99cc0..4d2c7c1a58d2620c5399ae28c4831ba1f2420a57 100644 --- a/ChemistryLib/PhreeqcIOData/CreateUserPunch.cpp +++ b/ChemistryLib/PhreeqcIOData/CreateUserPunch.cpp @@ -12,6 +12,7 @@ #include "BaseLib/ConfigTree.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "UserPunch.h" namespace ChemistryLib diff --git a/ChemistryLib/PhreeqcKernelData/CreateEquilibriumReactants.cpp b/ChemistryLib/PhreeqcKernelData/CreateEquilibriumReactants.cpp index 287beeb3c2d9f3529f08dbdbb40dd662714f143a..c1ec1fc63642d40cad3a06706b03a28ec43b1c94 100644 --- a/ChemistryLib/PhreeqcKernelData/CreateEquilibriumReactants.cpp +++ b/ChemistryLib/PhreeqcKernelData/CreateEquilibriumReactants.cpp @@ -16,6 +16,7 @@ #include "BaseLib/ConfigTree.h" #include "EquilibriumReactants.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/ChemistryLib/PhreeqcKernelData/CreateKineticReactant.cpp b/ChemistryLib/PhreeqcKernelData/CreateKineticReactant.cpp index f3dfdb62578d3522c1288f748389be37fda6a724..543d159948407a353a12e699fc9ca92bf254c71d 100644 --- a/ChemistryLib/PhreeqcKernelData/CreateKineticReactant.cpp +++ b/ChemistryLib/PhreeqcKernelData/CreateKineticReactant.cpp @@ -16,6 +16,7 @@ #include "BaseLib/ConfigTree.h" #include "KineticReactant.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ChemistryLib { diff --git a/MeshGeoToolsLib/MeshEditing/ResetMeshElementProperty.h b/MeshGeoToolsLib/MeshEditing/ResetMeshElementProperty.h index 9a889f1673c646c69b599fef442ebc7be5065ed2..7a95be46d9e9e8f2fd1238198a5d46a96eea3823 100644 --- a/MeshGeoToolsLib/MeshEditing/ResetMeshElementProperty.h +++ b/MeshGeoToolsLib/MeshEditing/ResetMeshElementProperty.h @@ -22,6 +22,7 @@ #include "MeshLib/IO/writeMeshToFile.h" #include "MeshLib/Mesh.h" #include "MeshLib/Node.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace MeshGeoToolsLib { diff --git a/MeshLib/Mesh.h b/MeshLib/Mesh.h index f3eb9ffeca0ccd440d1dabe984ba20315fe3d612..d7bf4f610658b9daeba692056e2f4ef41a465062 100644 --- a/MeshLib/Mesh.h +++ b/MeshLib/Mesh.h @@ -175,62 +175,6 @@ inline bool operator!=(Mesh const& a, Mesh const& b) return !(a == b); } -/// \returns a PropertyVector of the corresponding type, name on nodes, or -/// cells, or integration points if such exists, or creates a new one. -/// \attention For the integration points the result's size is zero. -/// \see MeshLib::addPropertyToMesh() -template <typename T> -PropertyVector<T>* getOrCreateMeshProperty(Mesh& mesh, - std::string const& property_name, - MeshItemType const item_type, - int const number_of_components) -{ - if (property_name.empty()) - { - OGS_FATAL( - "Trying to get or to create a mesh property with empty name."); - } - - auto numberOfMeshItems = [&mesh, &item_type]() -> std::size_t { - switch (item_type) - { - case MeshItemType::Cell: - return mesh.getNumberOfElements(); - case MeshItemType::Node: - return mesh.getNumberOfNodes(); - case MeshItemType::IntegrationPoint: - return 0; // For the integration point data the size is - // variable - default: - OGS_FATAL( - "getOrCreateMeshProperty cannot handle other " - "types than Node, Cell, or IntegrationPoint."); - } - return 0; - }; - - if (mesh.getProperties().existsPropertyVector<T>(property_name)) - { - auto result = - mesh.getProperties().template getPropertyVector<T>(property_name); - assert(result); - if (item_type != MeshItemType::IntegrationPoint) - { - // Test the size if number of mesh items is known, which is not the - // case for the integration point data. - assert(result->size() == - numberOfMeshItems() * number_of_components); - } - return result; - } - - auto result = mesh.getProperties().template createNewPropertyVector<T>( - property_name, item_type, number_of_components); - assert(result); - result->resize(numberOfMeshItems() * number_of_components); - return result; -} - /// Returns the material ids property vector defined on the mesh. /// /// The material ids are always an \c int property named "MaterialIDs". diff --git a/MeshLib/Utils/IntegrationPointWriter.cpp b/MeshLib/Utils/IntegrationPointWriter.cpp index db45a4b313b3cb8672799e56c0892c43c5f45cff..ebf0a60bb565eeb819575bb059830700356e2f81 100644 --- a/MeshLib/Utils/IntegrationPointWriter.cpp +++ b/MeshLib/Utils/IntegrationPointWriter.cpp @@ -13,6 +13,7 @@ #include <nlohmann/json.hpp> #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" using nlohmann::json; diff --git a/MeshLib/Utils/getOrCreateMeshProperty.h b/MeshLib/Utils/getOrCreateMeshProperty.h new file mode 100644 index 0000000000000000000000000000000000000000..aac71f21f77db7df7a73f62e22a30a6f3eb95d46 --- /dev/null +++ b/MeshLib/Utils/getOrCreateMeshProperty.h @@ -0,0 +1,76 @@ +/** + * \file + * \copyright + * Copyright (c) 2012-2023, OpenGeoSys Community (http://www.opengeosys.org) + * Distributed under a Modified BSD License. + * See accompanying file LICENSE.txt or + * http://www.opengeosys.org/project/license + */ + +#pragma once +#include <string> + +#include "MeshLib/Location.h" +#include "MeshLib/Mesh.h" +#include "MeshLib/PropertyVector.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" + +namespace MeshLib +{ +/// \returns a PropertyVector of the corresponding type, name on nodes, or +/// cells, or integration points if such exists, or creates a new one. +/// \attention For the integration points the result's size is zero. +/// \see MeshLib::addPropertyToMesh() +template <typename T> +PropertyVector<T>* getOrCreateMeshProperty(Mesh& mesh, + std::string const& property_name, + MeshItemType const item_type, + int const number_of_components) +{ + if (property_name.empty()) + { + OGS_FATAL( + "Trying to get or to create a mesh property with empty name."); + } + + auto numberOfMeshItems = [&mesh, &item_type]() -> std::size_t + { + switch (item_type) + { + case MeshItemType::Cell: + return mesh.getNumberOfElements(); + case MeshItemType::Node: + return mesh.getNumberOfNodes(); + case MeshItemType::IntegrationPoint: + return 0; // For the integration point data the size is + // variable + default: + OGS_FATAL( + "getOrCreateMeshProperty cannot handle other " + "types than Node, Cell, or IntegrationPoint."); + } + return 0; + }; + + if (mesh.getProperties().existsPropertyVector<T>(property_name)) + { + auto result = + mesh.getProperties().template getPropertyVector<T>(property_name); + assert(result); + if (item_type != MeshItemType::IntegrationPoint) + { + // Test the size if number of mesh items is known, which is not the + // case for the integration point data. + assert(result->size() == + numberOfMeshItems() * number_of_components); + } + return result; + } + + auto result = mesh.getProperties().template createNewPropertyVector<T>( + property_name, item_type, number_of_components); + assert(result); + result->resize(numberOfMeshItems() * number_of_components); + return result; +} +} // namespace MeshLib diff --git a/MeshToolsLib/MeshSurfaceExtraction.cpp b/MeshToolsLib/MeshSurfaceExtraction.cpp index 9032b22bfaa0cdfaf6b173b4128f18f60ec15945..97621bf58a2a9bc533b52c8f8a6e453942d4a8d3 100644 --- a/MeshToolsLib/MeshSurfaceExtraction.cpp +++ b/MeshToolsLib/MeshSurfaceExtraction.cpp @@ -26,6 +26,7 @@ #include "MeshLib/MeshSearch/NodeSearch.h" #include "MeshLib/Utils/DuplicateMeshComponents.h" #include "MeshLib/Utils/addPropertyToMesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "MeshToolsLib/MeshEditing/RemoveMeshComponents.h" namespace MeshToolsLib diff --git a/ProcessLib/AssemblyMixin.cpp b/ProcessLib/AssemblyMixin.cpp index e814b8ab6914eb0f16b2bebb366e6b48d0ff77ac..d206fcb587b7e11cf449ca65762b9ef5573e97df 100644 --- a/ProcessLib/AssemblyMixin.cpp +++ b/ProcessLib/AssemblyMixin.cpp @@ -12,6 +12,7 @@ #include <unordered_set> +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/DOFTableUtil.h" namespace diff --git a/ProcessLib/BoundaryConditionAndSourceTerm/SolutionDependentDirichletBoundaryCondition.cpp b/ProcessLib/BoundaryConditionAndSourceTerm/SolutionDependentDirichletBoundaryCondition.cpp index 386d3b7d19a39da38cb29b8012e832f69c29c534..a2034c76416cdcf491ef112c969bedf5e3ed92e7 100644 --- a/ProcessLib/BoundaryConditionAndSourceTerm/SolutionDependentDirichletBoundaryCondition.cpp +++ b/ProcessLib/BoundaryConditionAndSourceTerm/SolutionDependentDirichletBoundaryCondition.cpp @@ -17,6 +17,7 @@ #include "BaseLib/Logging.h" #include "DirichletBoundaryConditionAuxiliaryFunctions.h" #include "MeshLib/Mesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/LocalToGlobalIndexMap.h" #include "ParameterLib/Utils.h" diff --git a/ProcessLib/ComponentTransport/ComponentTransportProcess.cpp b/ProcessLib/ComponentTransport/ComponentTransportProcess.cpp index 278c37b33056f20ca3c3da5e78fd2924f5c54ff1..f96c617a11e5f7723d047348a23132278590a732 100644 --- a/ProcessLib/ComponentTransport/ComponentTransportProcess.cpp +++ b/ProcessLib/ComponentTransport/ComponentTransportProcess.cpp @@ -19,6 +19,7 @@ #include "MathLib/LinAlg/FinalizeMatrixAssembly.h" #include "MathLib/LinAlg/FinalizeVectorAssembly.h" #include "MathLib/LinAlg/LinAlg.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "ProcessLib/SurfaceFlux/SurfaceFlux.h" #include "ProcessLib/SurfaceFlux/SurfaceFluxData.h" diff --git a/ProcessLib/HeatConduction/HeatConductionProcess.cpp b/ProcessLib/HeatConduction/HeatConductionProcess.cpp index f77e770877577163c915e812bc3448e5236da417..f7bde46a7602984824706299867fea5162cab03b 100644 --- a/ProcessLib/HeatConduction/HeatConductionProcess.cpp +++ b/ProcessLib/HeatConduction/HeatConductionProcess.cpp @@ -14,6 +14,7 @@ #include "MathLib/LinAlg/FinalizeMatrixAssembly.h" #include "MathLib/LinAlg/FinalizeVectorAssembly.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/DOFTableUtil.h" #include "ProcessLib/Utils/ComputeResiduum.h" #include "ProcessLib/Utils/CreateLocalAssemblers.h" diff --git a/ProcessLib/HydroMechanics/HydroMechanicsProcess.cpp b/ProcessLib/HydroMechanics/HydroMechanicsProcess.cpp index e7add25eb2612ea5c0df7fc4c3a86a61fe6ed917..c04fccacfba3e32df87ba13bd54fb5584eccfeff 100644 --- a/ProcessLib/HydroMechanics/HydroMechanicsProcess.cpp +++ b/ProcessLib/HydroMechanics/HydroMechanicsProcess.cpp @@ -15,6 +15,7 @@ #include "HydroMechanicsFEM.h" #include "HydroMechanicsProcessData.h" #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" #include "ProcessLib/Process.h" diff --git a/ProcessLib/LIE/Common/PostUtils.cpp b/ProcessLib/LIE/Common/PostUtils.cpp index 48f268dfce4429d03d9700db076b9c87631c9439..8519eaecc88c0d20ab5b681ad3c8585f5d9f055d 100644 --- a/ProcessLib/LIE/Common/PostUtils.cpp +++ b/ProcessLib/LIE/Common/PostUtils.cpp @@ -12,6 +12,7 @@ #include "MeshLib/Elements/Element.h" #include "MeshLib/Node.h" #include "MeshLib/Utils/DuplicateMeshComponents.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" namespace ProcessLib { diff --git a/ProcessLib/LIE/HydroMechanics/HydroMechanicsProcess.cpp b/ProcessLib/LIE/HydroMechanics/HydroMechanicsProcess.cpp index 13221eec57c504f3ad67453e93a4f84db426f995..1384f331e748515ab803f6bfb8779e10672ab027 100644 --- a/ProcessLib/LIE/HydroMechanics/HydroMechanicsProcess.cpp +++ b/ProcessLib/LIE/HydroMechanics/HydroMechanicsProcess.cpp @@ -19,6 +19,7 @@ #include "MeshLib/Elements/Utils.h" #include "MeshLib/Mesh.h" #include "MeshLib/Properties.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "MeshToolsLib/MeshInformation.h" #include "NumLib/DOF/DOFTableUtil.h" #include "NumLib/DOF/LocalToGlobalIndexMap.h" diff --git a/ProcessLib/LIE/SmallDeformation/SmallDeformationProcess.cpp b/ProcessLib/LIE/SmallDeformation/SmallDeformationProcess.cpp index 2dc874be5715518fed138c6518ae6082a2fb2efb..8f5ff3e2a6333e56a82b17d40861634edb95c6ad 100644 --- a/ProcessLib/LIE/SmallDeformation/SmallDeformationProcess.cpp +++ b/ProcessLib/LIE/SmallDeformation/SmallDeformationProcess.cpp @@ -13,6 +13,7 @@ #include "MeshLib/ElementCoordinatesMappingLocal.h" #include "MeshLib/Mesh.h" #include "MeshLib/Properties.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/LocalToGlobalIndexMap.h" #include "ProcessLib/LIE/Common/BranchProperty.h" #include "ProcessLib/LIE/Common/MeshUtils.h" diff --git a/ProcessLib/LiquidFlow/LiquidFlowProcess.cpp b/ProcessLib/LiquidFlow/LiquidFlowProcess.cpp index 569ad13dd3d7990fa97d9fd50a861242fe7b5da6..17308689cec96a13b35734aa5361815bcd58c26b 100644 --- a/ProcessLib/LiquidFlow/LiquidFlowProcess.cpp +++ b/ProcessLib/LiquidFlow/LiquidFlowProcess.cpp @@ -18,6 +18,7 @@ #include "MathLib/LinAlg/FinalizeMatrixAssembly.h" #include "MathLib/LinAlg/FinalizeVectorAssembly.h" #include "MeshLib/PropertyVector.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Utils/ComputeResiduum.h" #include "ProcessLib/Utils/CreateLocalAssemblers.h" diff --git a/ProcessLib/Output/AddProcessDataToMesh.cpp b/ProcessLib/Output/AddProcessDataToMesh.cpp index b08f300c2850e825f236be19025c991329532058..13a57345f440c4227a50cfd9d77b52b313f97b1f 100644 --- a/ProcessLib/Output/AddProcessDataToMesh.cpp +++ b/ProcessLib/Output/AddProcessDataToMesh.cpp @@ -12,6 +12,7 @@ #include "InfoLib/GitInfo.h" #include "MeshLib/Utils/IntegrationPointWriter.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Output/SecondaryVariable.h" #include "ProcessLib/ProcessVariable.h" #ifdef USE_PETSC diff --git a/ProcessLib/Output/Output.cpp b/ProcessLib/Output/Output.cpp index d6e057a40688bbd4fb595b7eff41690048547d40..efbfa78c607020171c4586d9f4ac476368786a67 100644 --- a/ProcessLib/Output/Output.cpp +++ b/ProcessLib/Output/Output.cpp @@ -20,6 +20,7 @@ #include "BaseLib/FileTools.h" #include "BaseLib/Logging.h" #include "BaseLib/RunTime.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Process.h" namespace ProcessLib diff --git a/ProcessLib/PhaseField/PhaseFieldProcess.cpp b/ProcessLib/PhaseField/PhaseFieldProcess.cpp index 74bf60895dc46c18cbea16b67aac5580879d4dc4..d34971c4ec2dfe1dfe6316f1b7b86a1dd392946d 100644 --- a/ProcessLib/PhaseField/PhaseFieldProcess.cpp +++ b/ProcessLib/PhaseField/PhaseFieldProcess.cpp @@ -12,6 +12,7 @@ #include <cassert> +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "PhaseFieldFEM.h" #include "ProcessLib/Process.h" diff --git a/ProcessLib/ProcessVariable.cpp b/ProcessLib/ProcessVariable.cpp index 0b825b7c488f27fcc30c9358b833d0f497f86206..5e9cde1fb803d7724cb7caa99a391962d933d496 100644 --- a/ProcessLib/ProcessVariable.cpp +++ b/ProcessLib/ProcessVariable.cpp @@ -18,6 +18,7 @@ #include "MeshGeoToolsLib/ConstructMeshesFromGeometries.h" #include "MeshLib/Mesh.h" #include "MeshLib/Node.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ParameterLib/Utils.h" #include "ProcessLib/BoundaryConditionAndSourceTerm/BoundaryCondition.h" #include "ProcessLib/BoundaryConditionAndSourceTerm/BoundaryConditionConfig.h" diff --git a/ProcessLib/RichardsMechanics/RichardsMechanicsProcess.cpp b/ProcessLib/RichardsMechanics/RichardsMechanicsProcess.cpp index 783912828cb0f7daab1f1009faa6d5ebf4cb1d9f..10c0f89debef9b189053b19f3c4c4eb3769f57f5 100644 --- a/ProcessLib/RichardsMechanics/RichardsMechanicsProcess.cpp +++ b/ProcessLib/RichardsMechanics/RichardsMechanicsProcess.cpp @@ -13,6 +13,7 @@ #include <cassert> #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" #include "ProcessLib/Utils/CreateLocalAssemblersTaylorHood.h" diff --git a/ProcessLib/SmallDeformation/SmallDeformationProcess.cpp b/ProcessLib/SmallDeformation/SmallDeformationProcess.cpp index ea587887a636a9b18f022e9b26643c0ebca877d7..1b7fdf3e04ee67bdf70069d69b3f0f3e600b1c90 100644 --- a/ProcessLib/SmallDeformation/SmallDeformationProcess.cpp +++ b/ProcessLib/SmallDeformation/SmallDeformationProcess.cpp @@ -13,6 +13,7 @@ #include <cassert> #include "MeshLib/Utils/IntegrationPointWriter.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" #include "ProcessLib/Process.h" #include "ProcessLib/SmallDeformation/CreateLocalAssemblers.h" diff --git a/ProcessLib/SmallDeformationNonlocal/SmallDeformationNonlocalProcess.cpp b/ProcessLib/SmallDeformationNonlocal/SmallDeformationNonlocalProcess.cpp index ad0a58b2f0b33da4dc9269e78720f6fbbb46dc8e..093424c03bdfdf6c722226d3581a9fa9e7f8e3b0 100644 --- a/ProcessLib/SmallDeformationNonlocal/SmallDeformationNonlocalProcess.cpp +++ b/ProcessLib/SmallDeformationNonlocal/SmallDeformationNonlocalProcess.cpp @@ -13,6 +13,7 @@ #include <iostream> #include "MeshLib/Utils/IntegrationPointWriter.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" // Reusing local assembler creation code. #include "ProcessLib/SmallDeformation/CreateLocalAssemblers.h" diff --git a/ProcessLib/StokesFlow/StokesFlowProcess.cpp b/ProcessLib/StokesFlow/StokesFlowProcess.cpp index c0c78aeb6ed5e6bd9395e8c36ed612ea7e88fc6f..61bdc07230b514292b86ee95e5ac2d46305ecd1d 100644 --- a/ProcessLib/StokesFlow/StokesFlowProcess.cpp +++ b/ProcessLib/StokesFlow/StokesFlowProcess.cpp @@ -13,6 +13,7 @@ #include <cassert> #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Utils/CreateLocalAssemblersTaylorHood.h" namespace ProcessLib diff --git a/ProcessLib/SurfaceFlux/SurfaceFluxData.cpp b/ProcessLib/SurfaceFlux/SurfaceFluxData.cpp index a61816d4a948692aea623f076dd829b1b716d3eb..316c748e6be970b2dfbb39b2827b06080f7ef43c 100644 --- a/ProcessLib/SurfaceFlux/SurfaceFluxData.cpp +++ b/ProcessLib/SurfaceFlux/SurfaceFluxData.cpp @@ -12,6 +12,7 @@ #include "BaseLib/ConfigTree.h" #include "BaseLib/Logging.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Process.h" #include "ProcessLib/SurfaceFlux/SurfaceFlux.h" diff --git a/ProcessLib/TH2M/TH2MProcess.cpp b/ProcessLib/TH2M/TH2MProcess.cpp index 5bf527af4e3aa90a3e7228c406fd240cf90becfd..57c2071bc873209345601091105a4d3dbd1c3c92 100644 --- a/ProcessLib/TH2M/TH2MProcess.cpp +++ b/ProcessLib/TH2M/TH2MProcess.cpp @@ -16,6 +16,7 @@ #include "MaterialLib/SolidModels/MechanicsBase.h" // for the instantiation of process data #include "MathLib/KelvinVector.h" #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/DOFTableUtil.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" #include "ProcessLib/Process.h" diff --git a/ProcessLib/ThermoHydroMechanics/ThermoHydroMechanicsProcess.cpp b/ProcessLib/ThermoHydroMechanics/ThermoHydroMechanicsProcess.cpp index 821e81e0d57d0cdfcda595f4ea519254ab2d5930..4e6f7214bba87687ceb9ead6924044327181f71a 100644 --- a/ProcessLib/ThermoHydroMechanics/ThermoHydroMechanicsProcess.cpp +++ b/ProcessLib/ThermoHydroMechanics/ThermoHydroMechanicsProcess.cpp @@ -13,6 +13,7 @@ #include <cassert> #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "ProcessLib/Process.h" #include "ProcessLib/Utils/CreateLocalAssemblersTaylorHood.h" diff --git a/ProcessLib/ThermoMechanics/ThermoMechanicsProcess.cpp b/ProcessLib/ThermoMechanics/ThermoMechanicsProcess.cpp index de19357e8d136eef1705de64a1255678b179c5bd..3a6208beb3678d16ead0a050a29e7b151db51bc5 100644 --- a/ProcessLib/ThermoMechanics/ThermoMechanicsProcess.cpp +++ b/ProcessLib/ThermoMechanics/ThermoMechanicsProcess.cpp @@ -13,6 +13,7 @@ #include <cassert> #include "MeshLib/Utils/IntegrationPointWriter.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "NumLib/DOF/DOFTableUtil.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" diff --git a/ProcessLib/ThermoRichardsFlow/ThermoRichardsFlowProcess.cpp b/ProcessLib/ThermoRichardsFlow/ThermoRichardsFlowProcess.cpp index e251502e9145a3b5e004137dad03c95763cd7f98..5d74dbeefc0b64815da65ea02851c0b48d6561fd 100644 --- a/ProcessLib/ThermoRichardsFlow/ThermoRichardsFlowProcess.cpp +++ b/ProcessLib/ThermoRichardsFlow/ThermoRichardsFlowProcess.cpp @@ -14,6 +14,7 @@ #include "BaseLib/Error.h" #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "NumLib/DOF/ComputeSparsityPattern.h" #include "ProcessLib/Process.h" #include "ProcessLib/Utils/CreateLocalAssemblers.h" diff --git a/ProcessLib/ThermoRichardsMechanics/ThermoRichardsMechanicsProcess.cpp b/ProcessLib/ThermoRichardsMechanics/ThermoRichardsMechanicsProcess.cpp index feebf63accb9db4e3701562712eeae8336c575bc..c6ff2e99dd266848eb2f5b3ebdd98472965d4861 100644 --- a/ProcessLib/ThermoRichardsMechanics/ThermoRichardsMechanicsProcess.cpp +++ b/ProcessLib/ThermoRichardsMechanics/ThermoRichardsMechanicsProcess.cpp @@ -15,6 +15,7 @@ #include "BaseLib/Error.h" #include "CreateThermoRichardsMechanicsLocalAssemblers.h" #include "MeshLib/Elements/Utils.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" #include "ProcessLib/Deformation/SolidMaterialInternalToSecondaryVariables.h" #include "ProcessLib/Process.h" #include "ProcessLib/Reflection/ReflectionForExtrapolation.h" diff --git a/Tests/MeshLib/TestCreateMaterialIDsBasedSubMesh.cpp b/Tests/MeshLib/TestCreateMaterialIDsBasedSubMesh.cpp index fb9ff0d9750f980048d3656b973b06895cb862da..a84bb4f6514ed1310c1540af03c10949b576aa16 100644 --- a/Tests/MeshLib/TestCreateMaterialIDsBasedSubMesh.cpp +++ b/Tests/MeshLib/TestCreateMaterialIDsBasedSubMesh.cpp @@ -14,8 +14,9 @@ #include "MeshLib/Mesh.h" #include "MeshLib/Node.h" -#include "MeshToolsLib/MeshGenerators/MeshGenerator.h" #include "MeshLib/Utils/createMaterialIDsBasedSubMesh.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" +#include "MeshToolsLib/MeshGenerators/MeshGenerator.h" using namespace MeshLib; diff --git a/Tests/MeshLib/TestGetMeshElementsForMaterialIDs.cpp b/Tests/MeshLib/TestGetMeshElementsForMaterialIDs.cpp index fe533912f256bfa2d16920d7ea11be790e502b52..14749d0e8828ed9ad392ca373e92808dbf86b244 100644 --- a/Tests/MeshLib/TestGetMeshElementsForMaterialIDs.cpp +++ b/Tests/MeshLib/TestGetMeshElementsForMaterialIDs.cpp @@ -15,8 +15,9 @@ #include "MeshLib/Elements/Element.h" #include "MeshLib/Mesh.h" #include "MeshLib/Node.h" -#include "MeshToolsLib/MeshGenerators/MeshGenerator.h" #include "MeshLib/Utils/getMeshElementsForMaterialIDs.h" +#include "MeshLib/Utils/getOrCreateMeshProperty.h" +#include "MeshToolsLib/MeshGenerators/MeshGenerator.h" using namespace MeshLib;