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;