diff --git a/Base/Axis/IAxis.h b/Base/Axis/IAxis.h
index 58c16d58d79dd0c48d5f498088ffcc80aba5afe0..cb914425fc15af904d9dd2682fca351919121be4 100644
--- a/Base/Axis/IAxis.h
+++ b/Base/Axis/IAxis.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_BASE_AXIS_IAXIS_H
 #define BORNAGAIN_BASE_AXIS_IAXIS_H
 
@@ -104,4 +103,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_AXIS_IAXIS_H
-#endif // USER_API
diff --git a/Base/Axis/PointwiseAxis.h b/Base/Axis/PointwiseAxis.h
index 42b235a144355f340db7c133d70052488cea538d..89932f6f4a1187485ded5fb49260690607bacc85 100644
--- a/Base/Axis/PointwiseAxis.h
+++ b/Base/Axis/PointwiseAxis.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_BASE_AXIS_POINTWISEAXIS_H
 #define BORNAGAIN_BASE_AXIS_POINTWISEAXIS_H
 
@@ -87,4 +86,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_AXIS_POINTWISEAXIS_H
-#endif // USER_API
diff --git a/Base/Const/PhysicalConstants.h b/Base/Const/PhysicalConstants.h
index a7c73e267a5c1faf360afc3ee730bc398551782d..64e3e4a3e55d76b3e85efb0afe6ccdfeee410f0a 100644
--- a/Base/Const/PhysicalConstants.h
+++ b/Base/Const/PhysicalConstants.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_CONST_PHYSICALCONSTANTS_H
 #define BORNAGAIN_BASE_CONST_PHYSICALCONSTANTS_H
 
@@ -36,4 +34,3 @@ constexpr double g_factor_n = -3.82608545; //!< neutron g-factor
 } // namespace PhysConsts
 
 #endif // BORNAGAIN_BASE_CONST_PHYSICALCONSTANTS_H
-#endif // USER_API
diff --git a/Base/Element/DepthProbeElement.h b/Base/Element/DepthProbeElement.h
index 02ba32db6aa4d01bf425e4ef79361979654bf8d7..20799ac3bfa18baa9d9492dcc855ed2f5de29ad7 100644
--- a/Base/Element/DepthProbeElement.h
+++ b/Base/Element/DepthProbeElement.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_ELEMENT_DEPTHPROBEELEMENT_H
 #define BORNAGAIN_BASE_ELEMENT_DEPTHPROBEELEMENT_H
 
@@ -67,4 +65,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_ELEMENT_DEPTHPROBEELEMENT_H
-#endif // USER_API
diff --git a/Base/Element/IElement.h b/Base/Element/IElement.h
index f13670c362c547dcf064f4d5d06d203004dda5e7..bf323e45725bba654f1dc18dbdaada362231a6f9 100644
--- a/Base/Element/IElement.h
+++ b/Base/Element/IElement.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_ELEMENT_IELEMENT_H
 #define BORNAGAIN_BASE_ELEMENT_IELEMENT_H
 
@@ -41,4 +39,3 @@ protected:
 };
 
 #endif // BORNAGAIN_BASE_ELEMENT_IELEMENT_H
-#endif // USER_API
diff --git a/Base/Element/PolMatrices.h b/Base/Element/PolMatrices.h
index 817c07e659a412c15ff3c4d5f0842d634d88ab52..fb6daeca99c98f8480a1df2d7889ba95240582de 100644
--- a/Base/Element/PolMatrices.h
+++ b/Base/Element/PolMatrices.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_ELEMENT_POLMATRICES_H
 #define BORNAGAIN_BASE_ELEMENT_POLMATRICES_H
 
@@ -49,4 +47,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_ELEMENT_POLMATRICES_H
-#endif // USER_API
diff --git a/Base/Math/Bessel.h b/Base/Math/Bessel.h
index 841f9a5d17d1f71178fdada6fd97cf026b690022..10965c3eb080df841f07133d60db09b35cef3a51 100644
--- a/Base/Math/Bessel.h
+++ b/Base/Math/Bessel.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_BESSEL_H
 #define BORNAGAIN_BASE_MATH_BESSEL_H
 
@@ -54,4 +52,3 @@ complex_t J1c(complex_t z);
 } // namespace Math
 
 #endif // BORNAGAIN_BASE_MATH_BESSEL_H
-#endif // USER_API
diff --git a/Base/Math/Constants.h b/Base/Math/Constants.h
index 2a2080234049d8d0758ec1ba43ac32261d6d8d85..bcc8ac2c48258b39e340f8e1f8303a39a7f91ee5 100644
--- a/Base/Math/Constants.h
+++ b/Base/Math/Constants.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_CONSTANTS_H
 #define BORNAGAIN_BASE_MATH_CONSTANTS_H
 
@@ -54,4 +52,3 @@
 #define M_TWOPI 6.28318530717958647693
 
 #endif // BORNAGAIN_BASE_MATH_CONSTANTS_H
-#endif // USER_API
diff --git a/Base/Math/FourierTransform.h b/Base/Math/FourierTransform.h
index 30db4b8c757218f673e7ca832cf7ff98b00446d6..aa32cc27f26c24edd1db62539c688fc23bc77ce3 100644
--- a/Base/Math/FourierTransform.h
+++ b/Base/Math/FourierTransform.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_FOURIERTRANSFORM_H
 #define BORNAGAIN_BASE_MATH_FOURIERTRANSFORM_H
 
@@ -92,4 +90,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_MATH_FOURIERTRANSFORM_H
-#endif // USER_API
diff --git a/Base/Math/Functions.h b/Base/Math/Functions.h
index e80025d461e35356dcce5d82726d2b02e5808d29..c293005724f43620712e88f9b78b672e8c0c0df7 100644
--- a/Base/Math/Functions.h
+++ b/Base/Math/Functions.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_FUNCTIONS_H
 #define BORNAGAIN_BASE_MATH_FUNCTIONS_H
 
@@ -65,4 +63,3 @@ double GeneratePoissonRandom(double average);
 } // namespace Math
 
 #endif // BORNAGAIN_BASE_MATH_FUNCTIONS_H
-#endif // USER_API
diff --git a/Base/Math/IntegratorGK.h b/Base/Math/IntegratorGK.h
index 2c2f8b4552f8c31f5c2e0e6074228aedb75bc0aa..9add333507b69881225dda2a3a1580f5673f333b 100644
--- a/Base/Math/IntegratorGK.h
+++ b/Base/Math/IntegratorGK.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_INTEGRATORGK_H
 #define BORNAGAIN_BASE_MATH_INTEGRATORGK_H
 
@@ -51,4 +49,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_MATH_INTEGRATORGK_H
-#endif // USER_API
diff --git a/Base/Math/IntegratorMCMiser.h b/Base/Math/IntegratorMCMiser.h
index fd760aef911f6af627bce8c5740cdc5d55fd287a..7034bb306fbbceccc9fda4585193c424877be97b 100644
--- a/Base/Math/IntegratorMCMiser.h
+++ b/Base/Math/IntegratorMCMiser.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_INTEGRATORMCMISER_H
 #define BORNAGAIN_BASE_MATH_INTEGRATORMCMISER_H
 
@@ -128,4 +126,3 @@ double IntegratorMCMiser<T>::integrate(double* min_array, double* max_array, con
 }
 
 #endif // BORNAGAIN_BASE_MATH_INTEGRATORMCMISER_H
-#endif // USER_API
diff --git a/Base/Math/Numeric.h b/Base/Math/Numeric.h
index 04d3da7218685f652af57421c3953bb52c5d1c0f..a4c1f1a891c287312081bd4127fa791ae8460eb9 100644
--- a/Base/Math/Numeric.h
+++ b/Base/Math/Numeric.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_MATH_NUMERIC_H
 #define BORNAGAIN_BASE_MATH_NUMERIC_H
 
@@ -35,4 +33,3 @@ double GetLogDifference(double a, double b);
 } // namespace Numeric
 
 #endif // BORNAGAIN_BASE_MATH_NUMERIC_H
-#endif // USER_API
diff --git a/Base/Pixel/IPixel.h b/Base/Pixel/IPixel.h
index feca6d8723530e18c337fb5e85112012ff922384..263d10fd1731329985f04ce258ce23be5ef11e92 100644
--- a/Base/Pixel/IPixel.h
+++ b/Base/Pixel/IPixel.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PIXEL_IPIXEL_H
 #define BORNAGAIN_BASE_PIXEL_IPIXEL_H
 
@@ -38,4 +36,3 @@ public:
 };
 
 #endif // BORNAGAIN_BASE_PIXEL_IPIXEL_H
-#endif // USER_API
diff --git a/Base/Pixel/RectangularPixel.h b/Base/Pixel/RectangularPixel.h
index f11c1612f02f87316107e87b14da3f47d9cc22a5..82deddcc31da4ec5399a6708a716b08cfa637917 100644
--- a/Base/Pixel/RectangularPixel.h
+++ b/Base/Pixel/RectangularPixel.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PIXEL_RECTANGULARPIXEL_H
 #define BORNAGAIN_BASE_PIXEL_RECTANGULARPIXEL_H
 
@@ -51,4 +49,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_PIXEL_RECTANGULARPIXEL_H
-#endif // USER_API
diff --git a/Base/Pixel/SphericalPixel.h b/Base/Pixel/SphericalPixel.h
index cde289a3782d3ec9907f214f7da531858b3a246d..8476810924ce1aa7c925c00ec753bf58e2294afb 100644
--- a/Base/Pixel/SphericalPixel.h
+++ b/Base/Pixel/SphericalPixel.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PIXEL_SPHERICALPIXEL_H
 #define BORNAGAIN_BASE_PIXEL_SPHERICALPIXEL_H
 
@@ -45,4 +43,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_PIXEL_SPHERICALPIXEL_H
-#endif // USER_API
diff --git a/Base/Progress/DelayedProgressCounter.h b/Base/Progress/DelayedProgressCounter.h
index 18b9a19103cc2bb991263d82dd813d84efa855ea..c7f42b9c51105ab24f8fe8857d5bea7573b11cae 100644
--- a/Base/Progress/DelayedProgressCounter.h
+++ b/Base/Progress/DelayedProgressCounter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PROGRESS_DELAYEDPROGRESSCOUNTER_H
 #define BORNAGAIN_BASE_PROGRESS_DELAYEDPROGRESSCOUNTER_H
 
@@ -41,4 +39,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_PROGRESS_DELAYEDPROGRESSCOUNTER_H
-#endif // USER_API
diff --git a/Base/Progress/ProgressHandler.h b/Base/Progress/ProgressHandler.h
index 87d633e367ea2cea28b7e1908e151edac192178d..5c8b734bb6d3846c11b5524ac333906b9673ba4d 100644
--- a/Base/Progress/ProgressHandler.h
+++ b/Base/Progress/ProgressHandler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PROGRESS_PROGRESSHANDLER_H
 #define BORNAGAIN_BASE_PROGRESS_PROGRESSHANDLER_H
 
@@ -62,4 +60,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_PROGRESS_PROGRESSHANDLER_H
-#endif // USER_API
diff --git a/Base/Py/PyCore.h b/Base/Py/PyCore.h
index 87ea5646bea53746a706bfbe769322e3cf9713f4..9aa95b1f6f5859f88a960357365e095ca0b54038 100644
--- a/Base/Py/PyCore.h
+++ b/Base/Py/PyCore.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PY_PYCORE_H
 #define BORNAGAIN_BASE_PY_PYCORE_H
 
@@ -46,4 +44,3 @@
 #endif // BORNAGAIN_PYTHON
 
 #endif // BORNAGAIN_BASE_PY_PYCORE_H
-#endif // USER_API
diff --git a/Base/Py/PyFmt.h b/Base/Py/PyFmt.h
index 83d82883c35acd8b1bb12ac03a9575edb7e925a3..7072572f5550f4aa431eb7c5af4a1fb9a0a97f78 100644
--- a/Base/Py/PyFmt.h
+++ b/Base/Py/PyFmt.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PY_PYFMT_H
 #define BORNAGAIN_BASE_PY_PYFMT_H
 
@@ -75,4 +73,3 @@ std::string indent(size_t width = 4u);
 } // namespace Py::Fmt
 
 #endif // BORNAGAIN_BASE_PY_PYFMT_H
-#endif // USER_API
diff --git a/Base/Py/PyObject.h b/Base/Py/PyObject.h
index 52e56f1d519dcb507d99e53a8a8eb7c80f488d96..ed0aa1a34fbc304cdc10c58cdb50364c9d71c825 100644
--- a/Base/Py/PyObject.h
+++ b/Base/Py/PyObject.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PY_PYOBJECT_H
 #define BORNAGAIN_BASE_PY_PYOBJECT_H
 
@@ -28,4 +26,3 @@ typedef _object PyObject;
 #endif
 
 #endif // BORNAGAIN_BASE_PY_PYOBJECT_H
-#endif // USER_API
diff --git a/Base/Py/PyUtils.h b/Base/Py/PyUtils.h
index 5fa1954ecaf55b5be59f33587afe09fea34b0716..087598d37e73f6f9a9d8ecf3ee12986025f5d880 100644
--- a/Base/Py/PyUtils.h
+++ b/Base/Py/PyUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_PY_PYUTILS_H
 #define BORNAGAIN_BASE_PY_PYUTILS_H
 
@@ -57,4 +55,3 @@ PyObject* createNumpyArray(const std::vector<double>& data);
 #endif // BORNAGAIN_PYTHON
 
 #endif // BORNAGAIN_BASE_PY_PYUTILS_H
-#endif // USER_API
diff --git a/Base/Types/CloneableVector.h b/Base/Types/CloneableVector.h
index 4150b5fecdfe78a2d86d7d6129cf01dd2d0da0f9..a12b129508d7d1392868d2f9d816a1761f54031d 100644
--- a/Base/Types/CloneableVector.h
+++ b/Base/Types/CloneableVector.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_TYPES_CLONEABLEVECTOR_H
 #define BORNAGAIN_BASE_TYPES_CLONEABLEVECTOR_H
 
@@ -62,4 +60,3 @@ public:
 };
 
 #endif // BORNAGAIN_BASE_TYPES_CLONEABLEVECTOR_H
-#endif // USER_API
diff --git a/Base/Types/ICloneable.h b/Base/Types/ICloneable.h
index 22e533ee6358743e24438fde93df86b373c0d944..16decbcbac12df37295b5e85044a8022c1891b57 100644
--- a/Base/Types/ICloneable.h
+++ b/Base/Types/ICloneable.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_BASE_TYPES_ICLONEABLE_H
 #define BORNAGAIN_BASE_TYPES_ICLONEABLE_H
 
@@ -33,4 +32,3 @@ public:
 };
 
 #endif // BORNAGAIN_BASE_TYPES_ICLONEABLE_H
-#endif // USER_API
diff --git a/Base/Types/OwningVector.h b/Base/Types/OwningVector.h
index 55e7f75917bee5161b68ab3e0cb6d70e8a84e161..51f7bc4f4cdb9cf30fecdbdf8feadb28148f62f0 100644
--- a/Base/Types/OwningVector.h
+++ b/Base/Types/OwningVector.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_TYPES_OWNINGVECTOR_H
 #define BORNAGAIN_BASE_TYPES_OWNINGVECTOR_H
 
@@ -117,4 +115,3 @@ protected:
 };
 
 #endif // BORNAGAIN_BASE_TYPES_OWNINGVECTOR_H
-#endif // USER_API
diff --git a/Base/Types/Span.h b/Base/Types/Span.h
index 790f6f7d44936b75772d41fa2115e047777acfc7..0814414d6351b9f767a03382da944b1a1910241f 100644
--- a/Base/Types/Span.h
+++ b/Base/Types/Span.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_BASE_TYPES_SPAN_H
 #define BORNAGAIN_BASE_TYPES_SPAN_H
 
@@ -52,4 +51,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_TYPES_SPAN_H
-#endif // USER_API
diff --git a/Base/Util/Algorithms.h b/Base/Util/Algorithms.h
index f7512524be829d468c16820d45ed094708fcefeb..ed71de382e419e41c328a44d1419b7baf07e1a32 100644
--- a/Base/Util/Algorithms.h
+++ b/Base/Util/Algorithms.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_UTIL_ALGORITHMS_H
 #define BORNAGAIN_BASE_UTIL_ALGORITHMS_H
 
@@ -87,4 +85,3 @@ std::vector<T> BaseUtils::algo::concat(const std::vector<T>& v1, const std::vect
 }
 
 #endif // BORNAGAIN_BASE_UTIL_ALGORITHMS_H
-#endif // USER_API
diff --git a/Base/Util/Assert.h b/Base/Util/Assert.h
index 89d53195d4d54bdb5561250b60312dc89ad10114..5e2e882a95b589ed62acb2911944ef629521e050 100644
--- a/Base/Util/Assert.h
+++ b/Base/Util/Assert.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_UTIL_ASSERT_H
 #define BORNAGAIN_BASE_UTIL_ASSERT_H
 
@@ -52,4 +50,3 @@
 #endif // BA_DEBUG
 
 #endif // BORNAGAIN_BASE_UTIL_ASSERT_H
-#endif // USER_API
diff --git a/Base/Util/FileSystemUtils.h b/Base/Util/FileSystemUtils.h
index e10da5577a4a9861919701c4fa70a15d36039f29..f2594e95c3b9f697d141d3d4defd86e3991c158c 100644
--- a/Base/Util/FileSystemUtils.h
+++ b/Base/Util/FileSystemUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_UTIL_FILESYSTEMUTILS_H
 #define BORNAGAIN_BASE_UTIL_FILESYSTEMUTILS_H
 
@@ -70,4 +68,3 @@ bool IsFileExists(const std::string& path);
 } // namespace BaseUtils::Filesystem
 
 #endif // BORNAGAIN_BASE_UTIL_FILESYSTEMUTILS_H
-#endif // USER_API
diff --git a/Base/Util/IFactory.h b/Base/Util/IFactory.h
index 5d34a51fce6dc6c2d99720e46f150700cfec6f5c..d370cb26a575a94051b581e7fbb9ef38bdcc8509 100644
--- a/Base/Util/IFactory.h
+++ b/Base/Util/IFactory.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_BASE_UTIL_IFACTORY_H
 #define BORNAGAIN_BASE_UTIL_IFACTORY_H
 
@@ -79,4 +78,3 @@ T* create_new()
 }
 
 #endif // BORNAGAIN_BASE_UTIL_IFACTORY_H
-#endif // USER_API
diff --git a/Base/Util/StringUtils.h b/Base/Util/StringUtils.h
index 0063c07a393b310278578e34b50f30e11df25059..60cd1bebf14f249056034c64752c55bc9ab80420 100644
--- a/Base/Util/StringUtils.h
+++ b/Base/Util/StringUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_UTIL_STRINGUTILS_H
 #define BORNAGAIN_BASE_UTIL_STRINGUTILS_H
 
@@ -80,4 +78,3 @@ std::string BaseUtils::String::scientific(const T value, int n)
 }
 
 #endif // BORNAGAIN_BASE_UTIL_STRINGUTILS_H
-#endif // USER_API
diff --git a/Base/Util/SysUtils.h b/Base/Util/SysUtils.h
index cd17cd667b4437a3df01b8f01c6e426f4c64beb5..b37181e65ccbe1a890ea82ecba1b01fefe38511b 100644
--- a/Base/Util/SysUtils.h
+++ b/Base/Util/SysUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_UTIL_SYSUTILS_H
 #define BORNAGAIN_BASE_UTIL_SYSUTILS_H
 
@@ -34,4 +32,3 @@ std::string getenv(const std::string& name);
 } // namespace BaseUtils::System
 
 #endif // BORNAGAIN_BASE_UTIL_SYSUTILS_H
-#endif // USER_API
diff --git a/Base/Vector/WavevectorInfo.h b/Base/Vector/WavevectorInfo.h
index 39d124c225112a1a9a4707d2994d88fd6820100d..3595ef6b8b16de2b20c7b8e472450be0a7a0fc4e 100644
--- a/Base/Vector/WavevectorInfo.h
+++ b/Base/Vector/WavevectorInfo.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_BASE_VECTOR_WAVEVECTORINFO_H
 #define BORNAGAIN_BASE_VECTOR_WAVEVECTORINFO_H
 
@@ -44,4 +42,3 @@ private:
 };
 
 #endif // BORNAGAIN_BASE_VECTOR_WAVEVECTORINFO_H
-#endif // USER_API
diff --git a/CMakeLists.txt b/CMakeLists.txt
index c86e1f9dafbb9c54b8578b81e8240cac918c0293..60ee6cdc81079f2d517131e7ef0a19036224f7fa 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -61,9 +61,7 @@ option(BUILD_DEBIAN "Build a debian package" OFF)
 option(BA_APPLE_BUNDLE "Create a Mac OS X bundle" OFF)
 option(BA_CPP_API "Install header files" OFF)
 
-# note on two non-options:
-# macro SWIG is defined when code is processed by the tool Swig.
-# macros SWIG and USER_API are set by Doc/Doxygen/user/Doxyfile.in
+# note on a non-options: macro SWIG is defined when code is processed by the tool Swig.
 
 if(BA_TIDY AND BORNAGAIN_PYTHON)
     message(FATAL_ERROR "BA_TIDY is incompatible with BORNAGAIN_PYTHON")
diff --git a/Device/Coord/AxisNames.h b/Device/Coord/AxisNames.h
index 66d5405819e4feed087490670de04f5bc6f1d396..b67d5d637015b64618316e1bb2111971da7132ce 100644
--- a/Device/Coord/AxisNames.h
+++ b/Device/Coord/AxisNames.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_COORD_AXISNAMES_H
 #define BORNAGAIN_DEVICE_COORD_AXISNAMES_H
 
@@ -48,4 +46,3 @@ extern BA_DEVICE_API_ const std::map<Coords, std::string> sampleDepthAxis;
 } // namespace DataUtils::AxisNames
 
 #endif // BORNAGAIN_DEVICE_COORD_AXISNAMES_H
-#endif // USER_API
diff --git a/Device/Coord/CoordSystem1D.h b/Device/Coord/CoordSystem1D.h
index f954f6aadc92aafdf5804acdf421cda694c56ef1..34d9f580e9d9638959ffbf5533e7efe761683eac 100644
--- a/Device/Coord/CoordSystem1D.h
+++ b/Device/Coord/CoordSystem1D.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_COORD_COORDSYSTEM1D_H
 #define BORNAGAIN_DEVICE_COORD_COORDSYSTEM1D_H
 
@@ -116,4 +114,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_COORD_COORDSYSTEM1D_H
-#endif // USER_API
diff --git a/Device/Coord/CoordSystem2D.h b/Device/Coord/CoordSystem2D.h
index 84965bcad6f9d90376db6dbbc456e2319627cb23..dcdbd1c37f8d36f6c90ff3d1bcde1115c85ccbe5 100644
--- a/Device/Coord/CoordSystem2D.h
+++ b/Device/Coord/CoordSystem2D.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_COORD_COORDSYSTEM2D_H
 #define BORNAGAIN_DEVICE_COORD_COORDSYSTEM2D_H
 
@@ -150,4 +148,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_COORD_COORDSYSTEM2D_H
-#endif // USER_API
diff --git a/Device/Coord/ICoordSystem.h b/Device/Coord/ICoordSystem.h
index 2cb365901662347c29ba741719ebfe0ab9704964..fe9804e96a435728adadab2a95d222fc1bfa7ad8 100644
--- a/Device/Coord/ICoordSystem.h
+++ b/Device/Coord/ICoordSystem.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_COORD_ICOORDSYSTEM_H
 #define BORNAGAIN_DEVICE_COORD_ICOORDSYSTEM_H
 
@@ -71,4 +69,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_COORD_ICOORDSYSTEM_H
-#endif // USER_API
diff --git a/Device/Data/ArrayUtils.h b/Device/Data/ArrayUtils.h
index fb091a85460f84363a72f9190b307151d6f83924..0220ed5a000638f1b092f5e0748a75b43121e038 100644
--- a/Device/Data/ArrayUtils.h
+++ b/Device/Data/ArrayUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_DATA_ARRAYUTILS_H
 #define BORNAGAIN_DEVICE_DATA_ARRAYUTILS_H
 
@@ -45,4 +43,3 @@ std::vector<std::vector<double>> createVector2D(const Datafield& data);
 } // namespace DataUtils::Array
 
 #endif // BORNAGAIN_DEVICE_DATA_ARRAYUTILS_H
-#endif // USER_API
diff --git a/Device/Detector/SimulationAreaIterator.h b/Device/Detector/SimulationAreaIterator.h
index 0898abe122ea0cd7f936ec3bdfaacb6869c949c2..18c257f3ca15952c89684bd5bb65cc63527bcc01 100644
--- a/Device/Detector/SimulationAreaIterator.h
+++ b/Device/Detector/SimulationAreaIterator.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_DETECTOR_SIMULATIONAREAITERATOR_H
 #define BORNAGAIN_DEVICE_DETECTOR_SIMULATIONAREAITERATOR_H
 
@@ -82,4 +80,3 @@ inline bool SimulationAreaIterator::operator!=(const SimulationAreaIterator& rig
 }
 
 #endif // BORNAGAIN_DEVICE_DETECTOR_SIMULATIONAREAITERATOR_H
-#endif // USER_API
diff --git a/Device/IO/DataFormatUtils.h b/Device/IO/DataFormatUtils.h
index 8f577cfe1364451e5b2cb34db302cbd600cffe19..51afa77c2aec730703b715967a5da7ad785c2223 100644
--- a/Device/IO/DataFormatUtils.h
+++ b/Device/IO/DataFormatUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_DATAFORMATUTILS_H
 #define BORNAGAIN_DEVICE_IO_DATAFORMATUTILS_H
 
@@ -59,4 +57,3 @@ void readLineOfDoubles(std::vector<double>& buffer, std::istringstream& iss);
 } // namespace DataUtils::Format
 
 #endif // BORNAGAIN_DEVICE_IO_DATAFORMATUTILS_H
-#endif // USER_API
diff --git a/Device/IO/ReadReflectometry.h b/Device/IO/ReadReflectometry.h
index e2afa12accfe66e735e47ffbbb35603daff8579a..465a202453fcad94124408db1e237d19d3fddbbf 100644
--- a/Device/IO/ReadReflectometry.h
+++ b/Device/IO/ReadReflectometry.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_READREFLECTOMETRY_H
 #define BORNAGAIN_DEVICE_IO_READREFLECTOMETRY_H
 
@@ -32,4 +30,3 @@ public:
 };
 
 #endif // BORNAGAIN_DEVICE_IO_READREFLECTOMETRY_H
-#endif // USER_API
diff --git a/Device/IO/ReadWriteINT.h b/Device/IO/ReadWriteINT.h
index 62fa535a2d1c042733f0a3bd972600029b1e0241..5ed0ed75fec7296d9b98a342624ecae2bcf6f6c4 100644
--- a/Device/IO/ReadWriteINT.h
+++ b/Device/IO/ReadWriteINT.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_READWRITEINT_H
 #define BORNAGAIN_DEVICE_IO_READWRITEINT_H
 
@@ -39,4 +37,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_IO_READWRITEINT_H
-#endif // USER_API
diff --git a/Device/IO/ReadWriteNumpyTXT.h b/Device/IO/ReadWriteNumpyTXT.h
index 7d2b14f97f0140d51bd0b5770b3c4def06f732e4..f6914191e4282b65b5d2fb492bdba1205e4ac8ba 100644
--- a/Device/IO/ReadWriteNumpyTXT.h
+++ b/Device/IO/ReadWriteNumpyTXT.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_READWRITENUMPYTXT_H
 #define BORNAGAIN_DEVICE_IO_READWRITENUMPYTXT_H
 
@@ -39,4 +37,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_IO_READWRITENUMPYTXT_H
-#endif // USER_API
diff --git a/Device/IO/ReadWriteTiff.h b/Device/IO/ReadWriteTiff.h
index d99064b04c4875e8d67310bb8a3f50978919ebb7..cc94ab2e1dbe782c3b14db694c56170573e01f92 100644
--- a/Device/IO/ReadWriteTiff.h
+++ b/Device/IO/ReadWriteTiff.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_READWRITETIFF_H
 #define BORNAGAIN_DEVICE_IO_READWRITETIFF_H
 
@@ -56,4 +54,3 @@ private:
 #endif // BA_TIFF_SUPPORT
 
 #endif // BORNAGAIN_DEVICE_IO_READWRITETIFF_H
-#endif // USER_API
diff --git a/Device/IO/boost_streams.h b/Device/IO/boost_streams.h
index a40d7f793eace723129091351ad38f8d01fbe51d..f94ea5a0e7bdf2d9ea7537bdc3f5f02365ebc06b 100644
--- a/Device/IO/boost_streams.h
+++ b/Device/IO/boost_streams.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_IO_BOOST_STREAMS_H
 #define BORNAGAIN_DEVICE_IO_BOOST_STREAMS_H
 
@@ -33,4 +31,3 @@
 #endif
 
 #endif // BORNAGAIN_DEVICE_IO_BOOST_STREAMS_H
-#endif // USER_API
diff --git a/Device/Mask/InfinitePlane.h b/Device/Mask/InfinitePlane.h
index 0eccf4fc19039ab0e29933da428e112f53621bbe..736322788e7129522d6f198b42c1dfd875622f7d 100644
--- a/Device/Mask/InfinitePlane.h
+++ b/Device/Mask/InfinitePlane.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_MASK_INFINITEPLANE_H
 #define BORNAGAIN_DEVICE_MASK_INFINITEPLANE_H
 
@@ -38,4 +36,3 @@ public:
 };
 
 #endif // BORNAGAIN_DEVICE_MASK_INFINITEPLANE_H
-#endif // USER_API
diff --git a/Device/Pol/PolFilter.h b/Device/Pol/PolFilter.h
index bda519594802e8250da8fe0891e7db1fb7606e5b..aa86551b7e82295fc62b3fe6d6db9b5cd1827e72 100644
--- a/Device/Pol/PolFilter.h
+++ b/Device/Pol/PolFilter.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_DEVICE_POL_POLFILTER_H
 #define BORNAGAIN_DEVICE_POL_POLFILTER_H
 
@@ -51,4 +50,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_POL_POLFILTER_H
-#endif // USER_API
diff --git a/Device/Resolution/ConvolutionDetectorResolution.h b/Device/Resolution/ConvolutionDetectorResolution.h
index 1745d6fc0880242ca658350fcb5d0fd47f9a9e34..444743533ff49f63875b20de5f0329b5f335bbf8 100644
--- a/Device/Resolution/ConvolutionDetectorResolution.h
+++ b/Device/Resolution/ConvolutionDetectorResolution.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_RESOLUTION_CONVOLUTIONDETECTORRESOLUTION_H
 #define BORNAGAIN_DEVICE_RESOLUTION_CONVOLUTIONDETECTORRESOLUTION_H
 
@@ -71,4 +69,3 @@ inline const IResolutionFunction2D* ConvolutionDetectorResolution::getResolution
 }
 
 #endif // BORNAGAIN_DEVICE_RESOLUTION_CONVOLUTIONDETECTORRESOLUTION_H
-#endif // USER_API
diff --git a/Device/Resolution/Convolve.h b/Device/Resolution/Convolve.h
index ce957c0b36e254db2aaeb203345fbb29132f2b20..04ee582715de07f78cb1f2c4e86f007671cca3eb 100644
--- a/Device/Resolution/Convolve.h
+++ b/Device/Resolution/Convolve.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_DEVICE_RESOLUTION_CONVOLVE_H
 #define BORNAGAIN_DEVICE_RESOLUTION_CONVOLVE_H
 
@@ -121,4 +119,3 @@ private:
 };
 
 #endif // BORNAGAIN_DEVICE_RESOLUTION_CONVOLVE_H
-#endif // USER_API
diff --git a/Doc/Doxygen/CMakeLists.txt b/Doc/Doxygen/CMakeLists.txt
index d9251f5955de164711dc23719ac20090c7459bb1..a66e7bb9bb954fa844db960b0779af71f424fd0a 100644
--- a/Doc/Doxygen/CMakeLists.txt
+++ b/Doc/Doxygen/CMakeLists.txt
@@ -1,13 +1,13 @@
-# configure Doxyfiles; define targets doxy and doxy${flavor}
+# configure Doxyfiles; define targets doxy and doxy${section}
 find_package(Doxygen REQUIRED)
 set(AUTO_DOX_DIR ${CMAKE_BINARY_DIR}/doxygen)
 file(MAKE_DIRECTORY ${AUTO_DOX_DIR})
 file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/html)
-add_custom_target(doxy) # this target builds _all_ documentation flavors
-foreach(flavor user long gui)
-    configure_file(${flavor}/Doxyfile.in
-        ${AUTO_DOX_DIR}/Doxyfile.${flavor} @ONLY)
-    add_custom_target(doxy${flavor}
-        COMMAND Doxygen::doxygen ${AUTO_DOX_DIR}/Doxyfile.${flavor} )
-    add_dependencies(doxy doxy${flavor})
+add_custom_target(doxy) # this target builds _all_ documentation sections
+foreach(section core gui)
+    configure_file(${section}/Doxyfile.in
+        ${AUTO_DOX_DIR}/Doxyfile.${section} @ONLY)
+    add_custom_target(doxy${section}
+        COMMAND Doxygen::doxygen ${AUTO_DOX_DIR}/Doxyfile.${section} )
+    add_dependencies(doxy doxy${section})
 endforeach()
diff --git a/Doc/Doxygen/README.md b/Doc/Doxygen/README.md
index 0995e73e1b413085e980fd7501dabf7b603d857d..e9dc4e80bf672b86f89e867af7c0640db0bce454 100644
--- a/Doc/Doxygen/README.md
+++ b/Doc/Doxygen/README.md
@@ -1,17 +1,12 @@
-We support different flavors of Doxygen documentation:
-
-- "user", the BornAgain user API
-- "long", full C++ source documentation for developers
-
 To build the documentation,
 ```
 cd build
 # configure:
 cmake -DCONFIGURE_DOXY=ON ..
 # make:
-make doxyuser
-make doxylong
-make doxy     # to build both flavors
+make doxycore
+make doxygui
+make doxy     # to build all
 ```
 
 The configure step writes Doxyfiles to the directory
diff --git a/Doc/Doxygen/common/defgroups.dox b/Doc/Doxygen/common/defgroups.dox
index 03edb6e56de2266c8fd99c7c007593a33e473a7f..626f77999e1b8151f3b38194241dcfb13ddef654 100644
--- a/Doc/Doxygen/common/defgroups.dox
+++ b/Doc/Doxygen/common/defgroups.dox
@@ -74,11 +74,9 @@ Simulations are run, and results returned, through the function ISimulation::sim
 
 \defgroup input_output Input and output
 @brief Various routines for input/output.
-*/
 
-#ifndef USER_API
+// internals
 
-/*!
 \defgroup simulation_internal ISimulation and instrument internals
 @brief Internal classes concerned with simulations and instrument
 
@@ -103,5 +101,3 @@ Simulations are run, and results returned, through the function ISimulation::sim
 \defgroup input_output_internal
 @brief Input/output internal classes.
 */
-
-#endif // USER_API
\ No newline at end of file
diff --git a/Doc/Doxygen/long/Doxyfile.in b/Doc/Doxygen/core/Doxyfile.in
similarity index 100%
rename from Doc/Doxygen/long/Doxyfile.in
rename to Doc/Doxygen/core/Doxyfile.in
diff --git a/Doc/Doxygen/long/mainpage.md b/Doc/Doxygen/core/mainpage.md
similarity index 100%
rename from Doc/Doxygen/long/mainpage.md
rename to Doc/Doxygen/core/mainpage.md
diff --git a/Doc/Doxygen/user/Doxyfile.in b/Doc/Doxygen/user/Doxyfile.in
deleted file mode 100644
index f6b097a79dc8aa408df07367ded87a279743b6b1..0000000000000000000000000000000000000000
--- a/Doc/Doxygen/user/Doxyfile.in
+++ /dev/null
@@ -1,2693 +0,0 @@
-# Doxyfile 1.9.4
-
-# This file describes the settings to be used by the documentation system
-# doxygen (www.doxygen.org) for a project.
-#
-# All text after a double hash (##) is considered a comment and is placed in
-# front of the TAG it is preceding.
-#
-# All text after a single hash (#) is considered a comment and will be ignored.
-# The format is:
-# TAG = value [value, ...]
-# For lists, items can also be appended using:
-# TAG += value [value, ...]
-# Values that contain spaces should be placed between quotes (\" \").
-#
-# Note:
-#
-# Use doxygen to compare the used configuration file with the template
-# configuration file:
-# doxygen -x [configFile]
-# Use doxygen to compare the used configuration file with the template
-# configuration file without replacing the environment variables:
-# doxygen -x_noenv [configFile]
-
-#---------------------------------------------------------------------------
-# Project related configuration options
-#---------------------------------------------------------------------------
-
-# This tag specifies the encoding used for all characters in the configuration
-# file that follow. The default is UTF-8 which is also the encoding used for all
-# text before the first occurrence of this tag. Doxygen uses libiconv (or the
-# iconv built into libc) for the transcoding. See
-# https://www.gnu.org/software/libiconv/ for the list of possible encodings.
-# The default value is: UTF-8.
-
-DOXYFILE_ENCODING      = UTF-8
-
-# The PROJECT_NAME tag is a single word (or a sequence of words surrounded by
-# double-quotes, unless you are using Doxywizard) that should identify the
-# project for which the documentation is generated. This name is used in the
-# title of most generated pages and in a few other places.
-# The default value is: My Project.
-
-PROJECT_NAME           = BornAgain
-
-# The PROJECT_NUMBER tag can be used to enter a project or revision number. This
-# could be handy for archiving the generated documentation or if some version
-# control system is used.
-
-PROJECT_NUMBER         = @BornAgain_VERSION_MAJOR@.@BornAgain_VERSION_MINOR@.@BornAgain_VERSION_PATCH@
-
-# Using the PROJECT_BRIEF tag one can provide an optional one line description
-# for a project that appears at the top of each page and should give viewer a
-# quick idea about the purpose of the project. Keep the description short.
-
-PROJECT_BRIEF          = "Open-source research software to simulate and fit neutron and x-ray reflectometry and grazing-incidence small-angle scattering"
-
-# With the PROJECT_LOGO tag one can specify a logo or an icon that is included
-# in the documentation. The maximum height of the logo should not exceed 55
-# pixels and the maximum width should not exceed 200 pixels. Doxygen will copy
-# the logo to the output directory.
-
-PROJECT_LOGO           = @CMAKE_SOURCE_DIR@/hugo/static/img/bornagain-logo.png
-
-# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute) path
-# into which the generated documentation will be written. If a relative path is
-# entered, it will be relative to the location where doxygen was started. If
-# left blank the current directory will be used.
-
-OUTPUT_DIRECTORY       = @CMAKE_BINARY_DIR@
-
-# If the CREATE_SUBDIRS tag is set to YES then doxygen will create up to 4096
-# sub-directories (in 2 levels) under the output directory of each output format
-# and will distribute the generated files over these directories. Enabling this
-# option can be useful when feeding doxygen a huge amount of source files, where
-# putting all generated files in the same directory would otherwise causes
-# performance problems for the file system. Adapt CREATE_SUBDIRS_LEVEL to
-# control the number of sub-directories.
-# The default value is: NO.
-
-CREATE_SUBDIRS         = NO
-
-# Controls the number of sub-directories that will be created when
-# CREATE_SUBDIRS tag is set to YES. Level 0 represents 16 directories, and every
-# level increment doubles the number of directories, resulting in 4096
-# directories at level 8 which is the default and also the maximum value. The
-# sub-directories are organized in 2 levels, the first level always has a fixed
-# numer of 16 directories.
-# Minimum value: 0, maximum value: 8, default value: 8.
-# This tag requires that the tag CREATE_SUBDIRS is set to YES.
-
-CREATE_SUBDIRS_LEVEL   = 8
-
-# If the ALLOW_UNICODE_NAMES tag is set to YES, doxygen will allow non-ASCII
-# characters to appear in the names of generated files. If set to NO, non-ASCII
-# characters will be escaped, for example _xE3_x81_x84 will be used for Unicode
-# U+3044.
-# The default value is: NO.
-
-ALLOW_UNICODE_NAMES    = NO
-
-# The OUTPUT_LANGUAGE tag is used to specify the language in which all
-# documentation generated by doxygen is written. Doxygen will use this
-# information to generate all constant output in the proper language.
-# Possible values are: Afrikaans, Arabic, Armenian, Brazilian, Bulgarian,
-# Catalan, Chinese, Chinese-Traditional, Croatian, Czech, Danish, Dutch, English
-# (United States), Esperanto, Farsi (Persian), Finnish, French, German, Greek,
-# Hindi, Hungarian, Indonesian, Italian, Japanese, Japanese-en (Japanese with
-# English messages), Korean, Korean-en (Korean with English messages), Latvian,
-# Lithuanian, Macedonian, Norwegian, Persian (Farsi), Polish, Portuguese,
-# Romanian, Russian, Serbian, Serbian-Cyrillic, Slovak, Slovene, Spanish,
-# Swedish, Turkish, Ukrainian and Vietnamese.
-# The default value is: English.
-
-OUTPUT_LANGUAGE        = English
-
-# If the BRIEF_MEMBER_DESC tag is set to YES, doxygen will include brief member
-# descriptions after the members that are listed in the file and class
-# documentation (similar to Javadoc). Set to NO to disable this.
-# The default value is: YES.
-
-BRIEF_MEMBER_DESC      = YES
-
-# If the REPEAT_BRIEF tag is set to YES, doxygen will prepend the brief
-# description of a member or function before the detailed description
-#
-# Note: If both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the
-# brief descriptions will be completely suppressed.
-# The default value is: YES.
-
-REPEAT_BRIEF           = YES
-
-# This tag implements a quasi-intelligent brief description abbreviator that is
-# used to form the text in various listings. Each string in this list, if found
-# as the leading text of the brief description, will be stripped from the text
-# and the result, after processing the whole list, is used as the annotated
-# text. Otherwise, the brief description is used as-is. If left blank, the
-# following values are used ($name is automatically replaced with the name of
-# the entity):The $name class, The $name widget, The $name file, is, provides,
-# specifies, contains, represents, a, an and the.
-
-ABBREVIATE_BRIEF       =
-
-# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then
-# doxygen will generate a detailed section even if there is only a brief
-# description.
-# The default value is: NO.
-
-ALWAYS_DETAILED_SEC    = NO
-
-# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all
-# inherited members of a class in the documentation of that class as if those
-# members were ordinary class members. Constructors, destructors and assignment
-# operators of the base classes will not be shown.
-# The default value is: NO.
-
-INLINE_INHERITED_MEMB  = YES
-
-# If the FULL_PATH_NAMES tag is set to YES, doxygen will prepend the full path
-# before files name in the file list and in the header files. If set to NO the
-# shortest path that makes the file name unique will be used
-# The default value is: YES.
-
-FULL_PATH_NAMES        = YES
-
-# The STRIP_FROM_PATH tag can be used to strip a user-defined part of the path.
-# Stripping is only done if one of the specified strings matches the left-hand
-# part of the path. The tag can be used to show relative paths in the file list.
-# If left blank the directory from which doxygen is run is used as the path to
-# strip.
-#
-# Note that you can specify absolute paths here, but also relative paths, which
-# will be relative from the directory where doxygen is started.
-# This tag requires that the tag FULL_PATH_NAMES is set to YES.
-
-STRIP_FROM_PATH        =
-
-# The STRIP_FROM_INC_PATH tag can be used to strip a user-defined part of the
-# path mentioned in the documentation of a class, which tells the reader which
-# header file to include in order to use a class. If left blank only the name of
-# the header file containing the class definition is used. Otherwise one should
-# specify the list of include paths that are normally passed to the compiler
-# using the -I flag.
-
-STRIP_FROM_INC_PATH    =
-
-# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter (but
-# less readable) file names. This can be useful is your file systems doesn't
-# support long names like on DOS, Mac, or CD-ROM.
-# The default value is: NO.
-
-SHORT_NAMES            = NO
-
-# If the JAVADOC_AUTOBRIEF tag is set to YES then doxygen will interpret the
-# first line (until the first dot) of a Javadoc-style comment as the brief
-# description. If set to NO, the Javadoc-style will behave just like regular Qt-
-# style comments (thus requiring an explicit @brief command for a brief
-# description.)
-# The default value is: NO.
-
-JAVADOC_AUTOBRIEF      = NO
-
-# If the JAVADOC_BANNER tag is set to YES then doxygen will interpret a line
-# such as
-# /***************
-# as being the beginning of a Javadoc-style comment "banner". If set to NO, the
-# Javadoc-style will behave just like regular comments and it will not be
-# interpreted by doxygen.
-# The default value is: NO.
-
-JAVADOC_BANNER         = NO
-
-# If the QT_AUTOBRIEF tag is set to YES then doxygen will interpret the first
-# line (until the first dot) of a Qt-style comment as the brief description. If
-# set to NO, the Qt-style will behave just like regular Qt-style comments (thus
-# requiring an explicit \brief command for a brief description.)
-# The default value is: NO.
-
-QT_AUTOBRIEF           = NO
-
-# The MULTILINE_CPP_IS_BRIEF tag can be set to YES to make doxygen treat a
-# multi-line C++ special comment block (i.e. a block of //! or /// comments) as
-# a brief description. This used to be the default behavior. The new default is
-# to treat a multi-line C++ comment block as a detailed description. Set this
-# tag to YES if you prefer the old behavior instead.
-#
-# Note that setting this tag to YES also means that rational rose comments are
-# not recognized any more.
-# The default value is: NO.
-
-MULTILINE_CPP_IS_BRIEF = YES
-
-# By default Python docstrings are displayed as preformatted text and doxygen's
-# special commands cannot be used. By setting PYTHON_DOCSTRING to NO the
-# doxygen's special commands can be used and the contents of the docstring
-# documentation blocks is shown as doxygen documentation.
-# The default value is: YES.
-
-PYTHON_DOCSTRING       = YES
-
-# If the INHERIT_DOCS tag is set to YES then an undocumented member inherits the
-# documentation from any documented member that it re-implements.
-# The default value is: YES.
-
-INHERIT_DOCS           = YES
-
-# If the SEPARATE_MEMBER_PAGES tag is set to YES then doxygen will produce a new
-# page for each member. If set to NO, the documentation of a member will be part
-# of the file/class/namespace that contains it.
-# The default value is: NO.
-
-SEPARATE_MEMBER_PAGES  = NO
-
-# The TAB_SIZE tag can be used to set the number of spaces in a tab. Doxygen
-# uses this value to replace tabs by spaces in code fragments.
-# Minimum value: 1, maximum value: 16, default value: 4.
-
-TAB_SIZE               = 4
-
-# This tag can be used to specify a number of aliases that act as commands in
-# the documentation. An alias has the form:
-# name=value
-# For example adding
-# "sideeffect=@par Side Effects:^^"
-# will allow you to put the command \sideeffect (or @sideeffect) in the
-# documentation, which will result in a user-defined paragraph with heading
-# "Side Effects:". Note that you cannot put \n's in the value part of an alias
-# to insert newlines (in the resulting output). You can put ^^ in the value part
-# of an alias to insert a newline as if a physical newline was in the original
-# file. When you need a literal { or } or , in the value part of an alias you
-# have to escape them by means of a backslash (\), this can lead to conflicts
-# with the commands \{ and \} for these it is advised to use the version @{ and
-# @} or use a double escape (\\{ and \\})
-
-ALIASES                = "homepage=@par Homepage:\n" \
-                         "license=@par License:\n"
-
-# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources
-# only. Doxygen will then generate output that is more tailored for C. For
-# instance, some of the names that are used will be different. The list of all
-# members will be omitted, etc.
-# The default value is: NO.
-
-OPTIMIZE_OUTPUT_FOR_C  = NO
-
-# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java or
-# Python sources only. Doxygen will then generate output that is more tailored
-# for that language. For instance, namespaces will be presented as packages,
-# qualified scopes will look different, etc.
-# The default value is: NO.
-
-OPTIMIZE_OUTPUT_JAVA   = NO
-
-# Set the OPTIMIZE_FOR_FORTRAN tag to YES if your project consists of Fortran
-# sources. Doxygen will then generate output that is tailored for Fortran.
-# The default value is: NO.
-
-OPTIMIZE_FOR_FORTRAN   = NO
-
-# Set the OPTIMIZE_OUTPUT_VHDL tag to YES if your project consists of VHDL
-# sources. Doxygen will then generate output that is tailored for VHDL.
-# The default value is: NO.
-
-OPTIMIZE_OUTPUT_VHDL   = NO
-
-# Set the OPTIMIZE_OUTPUT_SLICE tag to YES if your project consists of Slice
-# sources only. Doxygen will then generate output that is more tailored for that
-# language. For instance, namespaces will be presented as modules, types will be
-# separated into more groups, etc.
-# The default value is: NO.
-
-OPTIMIZE_OUTPUT_SLICE  = NO
-
-# Doxygen selects the parser to use depending on the extension of the files it
-# parses. With this tag you can assign which parser to use for a given
-# extension. Doxygen has a built-in mapping, but you can override or extend it
-# using this tag. The format is ext=language, where ext is a file extension, and
-# language is one of the parsers supported by doxygen: IDL, Java, JavaScript,
-# Csharp (C#), C, C++, Lex, D, PHP, md (Markdown), Objective-C, Python, Slice,
-# VHDL, Fortran (fixed format Fortran: FortranFixed, free formatted Fortran:
-# FortranFree, unknown formatted Fortran: Fortran. In the later case the parser
-# tries to guess whether the code is fixed or free formatted code, this is the
-# default for Fortran type files). For instance to make doxygen treat .inc files
-# as Fortran files (default is PHP), and .f files as C (default is Fortran),
-# use: inc=Fortran f=C.
-#
-# Note: For files without extension you can use no_extension as a placeholder.
-#
-# Note that for custom extensions you also need to set FILE_PATTERNS otherwise
-# the files are not read by doxygen. When specifying no_extension you should add
-# * to the FILE_PATTERNS.
-#
-# Note see also the list of default file extension mappings.
-
-EXTENSION_MAPPING      =
-
-# If the MARKDOWN_SUPPORT tag is enabled then doxygen pre-processes all comments
-# according to the Markdown format, which allows for more readable
-# documentation. See https://daringfireball.net/projects/markdown/ for details.
-# The output of markdown processing is further processed by doxygen, so you can
-# mix doxygen, HTML, and XML commands with Markdown formatting. Disable only in
-# case of backward compatibilities issues.
-# The default value is: YES.
-
-MARKDOWN_SUPPORT       = YES
-
-# When the TOC_INCLUDE_HEADINGS tag is set to a non-zero value, all headings up
-# to that level are automatically included in the table of contents, even if
-# they do not have an id attribute.
-# Note: This feature currently applies only to Markdown headings.
-# Minimum value: 0, maximum value: 99, default value: 5.
-# This tag requires that the tag MARKDOWN_SUPPORT is set to YES.
-
-TOC_INCLUDE_HEADINGS   = 5
-
-# When enabled doxygen tries to link words that correspond to documented
-# classes, or namespaces to their corresponding documentation. Such a link can
-# be prevented in individual cases by putting a % sign in front of the word or
-# globally by setting AUTOLINK_SUPPORT to NO.
-# The default value is: YES.
-
-AUTOLINK_SUPPORT       = YES
-
-# If you use STL classes (i.e. std::string, std::vector, etc.) but do not want
-# to include (a tag file for) the STL sources as input, then you should set this
-# tag to YES in order to let doxygen match functions declarations and
-# definitions whose arguments contain STL classes (e.g. func(std::string);
-# versus func(std::string) {}). This also make the inheritance and collaboration
-# diagrams that involve STL classes more complete and accurate.
-# The default value is: NO.
-
-BUILTIN_STL_SUPPORT    = YES
-
-# If you use Microsoft's C++/CLI language, you should set this option to YES to
-# enable parsing support.
-# The default value is: NO.
-
-CPP_CLI_SUPPORT        = NO
-
-# Set the SIP_SUPPORT tag to YES if your project consists of sip (see:
-# https://www.riverbankcomputing.com/software/sip/intro) sources only. Doxygen
-# will parse them like normal C++ but will assume all classes use public instead
-# of private inheritance when no explicit protection keyword is present.
-# The default value is: NO.
-
-SIP_SUPPORT            = NO
-
-# For Microsoft's IDL there are propget and propput attributes to indicate
-# getter and setter methods for a property. Setting this option to YES will make
-# doxygen to replace the get and set methods by a property in the documentation.
-# This will only work if the methods are indeed getting or setting a simple
-# type. If this is not the case, or you want to show the methods anyway, you
-# should set this option to NO.
-# The default value is: YES.
-
-IDL_PROPERTY_SUPPORT   = YES
-
-# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC
-# tag is set to YES then doxygen will reuse the documentation of the first
-# member in the group (if any) for the other members of the group. By default
-# all members of a group must be documented explicitly.
-# The default value is: NO.
-
-DISTRIBUTE_GROUP_DOC   = NO
-
-# If one adds a struct or class to a group and this option is enabled, then also
-# any nested class or struct is added to the same group. By default this option
-# is disabled and one has to add nested compounds explicitly via \ingroup.
-# The default value is: NO.
-
-GROUP_NESTED_COMPOUNDS = NO
-
-# Set the SUBGROUPING tag to YES to allow class member groups of the same type
-# (for instance a group of public functions) to be put as a subgroup of that
-# type (e.g. under the Public Functions section). Set it to NO to prevent
-# subgrouping. Alternatively, this can be done per class using the
-# \nosubgrouping command.
-# The default value is: YES.
-
-SUBGROUPING            = YES
-
-# When the INLINE_GROUPED_CLASSES tag is set to YES, classes, structs and unions
-# are shown inside the group in which they are included (e.g. using \ingroup)
-# instead of on a separate page (for HTML and Man pages) or section (for LaTeX
-# and RTF).
-#
-# Note that this feature does not work in combination with
-# SEPARATE_MEMBER_PAGES.
-# The default value is: NO.
-
-INLINE_GROUPED_CLASSES = NO
-
-# When the INLINE_SIMPLE_STRUCTS tag is set to YES, structs, classes, and unions
-# with only public data fields or simple typedef fields will be shown inline in
-# the documentation of the scope in which they are defined (i.e. file,
-# namespace, or group documentation), provided this scope is documented. If set
-# to NO, structs, classes, and unions are shown on a separate page (for HTML and
-# Man pages) or section (for LaTeX and RTF).
-# The default value is: NO.
-
-INLINE_SIMPLE_STRUCTS  = NO
-
-# When TYPEDEF_HIDES_STRUCT tag is enabled, a typedef of a struct, union, or
-# enum is documented as struct, union, or enum with the name of the typedef. So
-# typedef struct TypeS {} TypeT, will appear in the documentation as a struct
-# with name TypeT. When disabled the typedef will appear as a member of a file,
-# namespace, or class. And the struct will be named TypeS. This can typically be
-# useful for C code in case the coding convention dictates that all compound
-# types are typedef'ed and only the typedef is referenced, never the tag name.
-# The default value is: NO.
-
-TYPEDEF_HIDES_STRUCT   = NO
-
-# The size of the symbol lookup cache can be set using LOOKUP_CACHE_SIZE. This
-# cache is used to resolve symbols given their name and scope. Since this can be
-# an expensive process and often the same symbol appears multiple times in the
-# code, doxygen keeps a cache of pre-resolved symbols. If the cache is too small
-# doxygen will become slower. If the cache is too large, memory is wasted. The
-# cache size is given by this formula: 2^(16+LOOKUP_CACHE_SIZE). The valid range
-# is 0..9, the default is 0, corresponding to a cache size of 2^16=65536
-# symbols. At the end of a run doxygen will report the cache usage and suggest
-# the optimal cache size from a speed point of view.
-# Minimum value: 0, maximum value: 9, default value: 0.
-
-LOOKUP_CACHE_SIZE      = 0
-
-# The NUM_PROC_THREADS specifies the number of threads doxygen is allowed to use
-# during processing. When set to 0 doxygen will based this on the number of
-# cores available in the system. You can set it explicitly to a value larger
-# than 0 to get more control over the balance between CPU load and processing
-# speed. At this moment only the input processing can be done using multiple
-# threads. Since this is still an experimental feature the default is set to 1,
-# which effectively disables parallel processing. Please report any issues you
-# encounter. Generating dot graphs in parallel is controlled by the
-# DOT_NUM_THREADS setting.
-# Minimum value: 0, maximum value: 32, default value: 1.
-
-NUM_PROC_THREADS       = 1
-
-#---------------------------------------------------------------------------
-# Build related configuration options
-#---------------------------------------------------------------------------
-
-# If the EXTRACT_ALL tag is set to YES, doxygen will assume all entities in
-# documentation are documented, even if no documentation was available. Private
-# class members and static file members will be hidden unless the
-# EXTRACT_PRIVATE respectively EXTRACT_STATIC tags are set to YES.
-# Note: This will also disable the warnings about undocumented members that are
-# normally produced when WARNINGS is set to YES.
-# The default value is: NO.
-
-EXTRACT_ALL            = YES
-
-# If the EXTRACT_PRIVATE tag is set to YES, all private members of a class will
-# be included in the documentation.
-# The default value is: NO.
-
-EXTRACT_PRIVATE        = NO
-
-# If the EXTRACT_PRIV_VIRTUAL tag is set to YES, documented private virtual
-# methods of a class will be included in the documentation.
-# The default value is: NO.
-
-EXTRACT_PRIV_VIRTUAL   = NO
-
-# If the EXTRACT_PACKAGE tag is set to YES, all members with package or internal
-# scope will be included in the documentation.
-# The default value is: NO.
-
-EXTRACT_PACKAGE        = NO
-
-# If the EXTRACT_STATIC tag is set to YES, all static members of a file will be
-# included in the documentation.
-# The default value is: NO.
-
-EXTRACT_STATIC         = YES
-
-# If the EXTRACT_LOCAL_CLASSES tag is set to YES, classes (and structs) defined
-# locally in source files will be included in the documentation. If set to NO,
-# only classes defined in header files are included. Does not have any effect
-# for Java sources.
-# The default value is: YES.
-
-EXTRACT_LOCAL_CLASSES  = NO
-
-# This flag is only useful for Objective-C code. If set to YES, local methods,
-# which are defined in the implementation section but not in the interface are
-# included in the documentation. If set to NO, only methods in the interface are
-# included.
-# The default value is: NO.
-
-EXTRACT_LOCAL_METHODS  = NO
-
-# If this flag is set to YES, the members of anonymous namespaces will be
-# extracted and appear in the documentation as a namespace called
-# 'anonymous_namespace{file}', where file will be replaced with the base name of
-# the file that contains the anonymous namespace. By default anonymous namespace
-# are hidden.
-# The default value is: NO.
-
-EXTRACT_ANON_NSPACES   = NO
-
-# If this flag is set to YES, the name of an unnamed parameter in a declaration
-# will be determined by the corresponding definition. By default unnamed
-# parameters remain unnamed in the output.
-# The default value is: YES.
-
-RESOLVE_UNNAMED_PARAMS = YES
-
-# If the HIDE_UNDOC_MEMBERS tag is set to YES, doxygen will hide all
-# undocumented members inside documented classes or files. If set to NO these
-# members will be included in the various overviews, but no documentation
-# section is generated. This option has no effect if EXTRACT_ALL is enabled.
-# The default value is: NO.
-
-HIDE_UNDOC_MEMBERS     = NO
-
-# If the HIDE_UNDOC_CLASSES tag is set to YES, doxygen will hide all
-# undocumented classes that are normally visible in the class hierarchy. If set
-# to NO, these classes will be included in the various overviews. This option
-# has no effect if EXTRACT_ALL is enabled.
-# The default value is: NO.
-
-HIDE_UNDOC_CLASSES     = NO
-
-# If the HIDE_FRIEND_COMPOUNDS tag is set to YES, doxygen will hide all friend
-# declarations. If set to NO, these declarations will be included in the
-# documentation.
-# The default value is: NO.
-
-HIDE_FRIEND_COMPOUNDS  = NO
-
-# If the HIDE_IN_BODY_DOCS tag is set to YES, doxygen will hide any
-# documentation blocks found inside the body of a function. If set to NO, these
-# blocks will be appended to the function's detailed documentation block.
-# The default value is: NO.
-
-HIDE_IN_BODY_DOCS      = YES
-
-# The INTERNAL_DOCS tag determines if documentation that is typed after a
-# \internal command is included. If the tag is set to NO then the documentation
-# will be excluded. Set it to YES to include the internal documentation.
-# The default value is: NO.
-
-INTERNAL_DOCS          = NO
-
-# With the correct setting of option CASE_SENSE_NAMES doxygen will better be
-# able to match the capabilities of the underlying filesystem. In case the
-# filesystem is case sensitive (i.e. it supports files in the same directory
-# whose names only differ in casing), the option must be set to YES to properly
-# deal with such files in case they appear in the input. For filesystems that
-# are not case sensitive the option should be set to NO to properly deal with
-# output files written for symbols that only differ in casing, such as for two
-# classes, one named CLASS and the other named Class, and to also support
-# references to files without having to specify the exact matching casing. On
-# Windows (including Cygwin) and MacOS, users should typically set this option
-# to NO, whereas on Linux or other Unix flavors it should typically be set to
-# YES.
-# The default value is: system dependent.
-
-CASE_SENSE_NAMES       = YES
-
-# If the HIDE_SCOPE_NAMES tag is set to NO then doxygen will show members with
-# their full class and namespace scopes in the documentation. If set to YES, the
-# scope will be hidden.
-# The default value is: NO.
-
-HIDE_SCOPE_NAMES       = NO
-
-# If the HIDE_COMPOUND_REFERENCE tag is set to NO (default) then doxygen will
-# append additional text to a page's title, such as Class Reference. If set to
-# YES the compound reference will be hidden.
-# The default value is: NO.
-
-HIDE_COMPOUND_REFERENCE= NO
-
-# If the SHOW_HEADERFILE tag is set to YES then the documentation for a class
-# will show which file needs to be included to use the class.
-# The default value is: YES.
-
-SHOW_HEADERFILE        = YES
-
-# If the SHOW_INCLUDE_FILES tag is set to YES then doxygen will put a list of
-# the files that are included by a file in the documentation of that file.
-# The default value is: YES.
-
-SHOW_INCLUDE_FILES     = NO
-
-# If the SHOW_GROUPED_MEMB_INC tag is set to YES then Doxygen will add for each
-# grouped member an include statement to the documentation, telling the reader
-# which file to include in order to use the member.
-# The default value is: NO.
-
-SHOW_GROUPED_MEMB_INC  = NO
-
-# If the FORCE_LOCAL_INCLUDES tag is set to YES then doxygen will list include
-# files with double quotes in the documentation rather than with sharp brackets.
-# The default value is: NO.
-
-FORCE_LOCAL_INCLUDES   = YES
-
-# If the INLINE_INFO tag is set to YES then a tag [inline] is inserted in the
-# documentation for inline members.
-# The default value is: YES.
-
-INLINE_INFO            = NO
-
-# If the SORT_MEMBER_DOCS tag is set to YES then doxygen will sort the
-# (detailed) documentation of file and class members alphabetically by member
-# name. If set to NO, the members will appear in declaration order.
-# The default value is: YES.
-
-SORT_MEMBER_DOCS       = YES
-
-# If the SORT_BRIEF_DOCS tag is set to YES then doxygen will sort the brief
-# descriptions of file, namespace and class members alphabetically by member
-# name. If set to NO, the members will appear in declaration order. Note that
-# this will also influence the order of the classes in the class list.
-# The default value is: NO.
-
-SORT_BRIEF_DOCS        = YES
-
-# If the SORT_MEMBERS_CTORS_1ST tag is set to YES then doxygen will sort the
-# (brief and detailed) documentation of class members so that constructors and
-# destructors are listed first. If set to NO the constructors will appear in the
-# respective orders defined by SORT_BRIEF_DOCS and SORT_MEMBER_DOCS.
-# Note: If SORT_BRIEF_DOCS is set to NO this option is ignored for sorting brief
-# member documentation.
-# Note: If SORT_MEMBER_DOCS is set to NO this option is ignored for sorting
-# detailed member documentation.
-# The default value is: NO.
-
-SORT_MEMBERS_CTORS_1ST = YES
-
-# If the SORT_GROUP_NAMES tag is set to YES then doxygen will sort the hierarchy
-# of group names into alphabetical order. If set to NO the group names will
-# appear in their defined order.
-# The default value is: NO.
-
-SORT_GROUP_NAMES       = YES
-
-# If the SORT_BY_SCOPE_NAME tag is set to YES, the class list will be sorted by
-# fully-qualified names, including namespaces. If set to NO, the class list will
-# be sorted only by class name, not including the namespace part.
-# Note: This option is not very useful if HIDE_SCOPE_NAMES is set to YES.
-# Note: This option applies only to the class list, not to the alphabetical
-# list.
-# The default value is: NO.
-
-SORT_BY_SCOPE_NAME     = NO
-
-# If the STRICT_PROTO_MATCHING option is enabled and doxygen fails to do proper
-# type resolution of all parameters of a function it will reject a match between
-# the prototype and the implementation of a member function even if there is
-# only one candidate or it is obvious which candidate to choose by doing a
-# simple string match. By disabling STRICT_PROTO_MATCHING doxygen will still
-# accept a match between prototype and implementation in such cases.
-# The default value is: NO.
-
-STRICT_PROTO_MATCHING  = NO
-
-# The GENERATE_TODOLIST tag can be used to enable (YES) or disable (NO) the todo
-# list. This list is created by putting \todo commands in the documentation.
-# The default value is: YES.
-
-GENERATE_TODOLIST      = NO
-
-# The GENERATE_TESTLIST tag can be used to enable (YES) or disable (NO) the test
-# list. This list is created by putting \test commands in the documentation.
-# The default value is: YES.
-
-GENERATE_TESTLIST      = NO
-
-# The GENERATE_BUGLIST tag can be used to enable (YES) or disable (NO) the bug
-# list. This list is created by putting \bug commands in the documentation.
-# The default value is: YES.
-
-GENERATE_BUGLIST       = NO
-
-# The GENERATE_DEPRECATEDLIST tag can be used to enable (YES) or disable (NO)
-# the deprecated list. This list is created by putting \deprecated commands in
-# the documentation.
-# The default value is: YES.
-
-GENERATE_DEPRECATEDLIST= YES
-
-# The ENABLED_SECTIONS tag can be used to enable conditional documentation
-# sections, marked by \if <section_label> ... \endif and \cond <section_label>
-# ... \endcond blocks.
-
-ENABLED_SECTIONS       =
-
-# The MAX_INITIALIZER_LINES tag determines the maximum number of lines that the
-# initial value of a variable or macro / define can have for it to appear in the
-# documentation. If the initializer consists of more lines than specified here
-# it will be hidden. Use a value of 0 to hide initializers completely. The
-# appearance of the value of individual variables and macros / defines can be
-# controlled using \showinitializer or \hideinitializer command in the
-# documentation regardless of this setting.
-# Minimum value: 0, maximum value: 10000, default value: 30.
-
-MAX_INITIALIZER_LINES  = 30
-
-# Set the SHOW_USED_FILES tag to NO to disable the list of files generated at
-# the bottom of the documentation of classes and structs. If set to YES, the
-# list will mention the files that were used to generate the documentation.
-# The default value is: YES.
-
-SHOW_USED_FILES        = NO
-
-# Set the SHOW_FILES tag to NO to disable the generation of the Files page. This
-# will remove the Files entry from the Quick Index and from the Folder Tree View
-# (if specified).
-# The default value is: YES.
-
-SHOW_FILES             = NO
-
-# Set the SHOW_NAMESPACES tag to NO to disable the generation of the Namespaces
-# page. This will remove the Namespaces entry from the Quick Index and from the
-# Folder Tree View (if specified).
-# The default value is: YES.
-
-SHOW_NAMESPACES        = NO
-
-# The FILE_VERSION_FILTER tag can be used to specify a program or script that
-# doxygen should invoke to get the current version for each file (typically from
-# the version control system). Doxygen will invoke the program by executing (via
-# popen()) the command command input-file, where command is the value of the
-# FILE_VERSION_FILTER tag, and input-file is the name of an input file provided
-# by doxygen. Whatever the program writes to standard output is used as the file
-# version. For an example see the documentation.
-
-FILE_VERSION_FILTER    =
-
-# The LAYOUT_FILE tag can be used to specify a layout file which will be parsed
-# by doxygen. The layout file controls the global structure of the generated
-# output files in an output format independent way. To create the layout file
-# that represents doxygen's defaults, run doxygen with the -l option. You can
-# optionally specify a file name after the option, if omitted DoxygenLayout.xml
-# will be used as the name of the layout file. See also section "Changing the
-# layout of pages" for information.
-#
-# Note that if you run doxygen from a directory containing a file called
-# DoxygenLayout.xml, doxygen will parse it automatically even if the LAYOUT_FILE
-# tag is left empty.
-
-LAYOUT_FILE            = @CMAKE_SOURCE_DIR@/Doc/Doxygen/user/layout.xml
-
-# The CITE_BIB_FILES tag can be used to specify one or more bib files containing
-# the reference definitions. This must be a list of .bib files. The .bib
-# extension is automatically appended if omitted. This requires the bibtex tool
-# to be installed. See also https://en.wikipedia.org/wiki/BibTeX for more info.
-# For LaTeX the style of the bibliography can be controlled using
-# LATEX_BIB_STYLE. To use this feature you need bibtex and perl available in the
-# search path. See also \cite for info how to create references.
-
-CITE_BIB_FILES         =
-
-#---------------------------------------------------------------------------
-# Configuration options related to warning and progress messages
-#---------------------------------------------------------------------------
-
-# The QUIET tag can be used to turn on/off the messages that are generated to
-# standard output by doxygen. If QUIET is set to YES this implies that the
-# messages are off.
-# The default value is: NO.
-
-QUIET                  = NO
-
-# The WARNINGS tag can be used to turn on/off the warning messages that are
-# generated to standard error (stderr) by doxygen. If WARNINGS is set to YES
-# this implies that the warnings are on.
-#
-# Tip: Turn warnings on while writing the documentation.
-# The default value is: YES.
-
-WARNINGS               = YES
-
-# If the WARN_IF_UNDOCUMENTED tag is set to YES then doxygen will generate
-# warnings for undocumented members. If EXTRACT_ALL is set to YES then this flag
-# will automatically be disabled.
-# The default value is: YES.
-
-WARN_IF_UNDOCUMENTED   = NO
-
-# If the WARN_IF_DOC_ERROR tag is set to YES, doxygen will generate warnings for
-# potential errors in the documentation, such as documenting some parameters in
-# a documented function twice, or documenting parameters that don't exist or
-# using markup commands wrongly.
-# The default value is: YES.
-
-WARN_IF_DOC_ERROR      = YES
-
-# If WARN_IF_INCOMPLETE_DOC is set to YES, doxygen will warn about incomplete
-# function parameter documentation. If set to NO, doxygen will accept that some
-# parameters have no documentation without warning.
-# The default value is: YES.
-
-WARN_IF_INCOMPLETE_DOC = YES
-
-# This WARN_NO_PARAMDOC option can be enabled to get warnings for functions that
-# are documented, but have no documentation for their parameters or return
-# value. If set to NO, doxygen will only warn about wrong parameter
-# documentation, but not about the absence of documentation. If EXTRACT_ALL is
-# set to YES then this flag will automatically be disabled. See also
-# WARN_IF_INCOMPLETE_DOC
-# The default value is: NO.
-
-WARN_NO_PARAMDOC       = NO
-
-# If the WARN_AS_ERROR tag is set to YES then doxygen will immediately stop when
-# a warning is encountered. If the WARN_AS_ERROR tag is set to FAIL_ON_WARNINGS
-# then doxygen will continue running as if WARN_AS_ERROR tag is set to NO, but
-# at the end of the doxygen process doxygen will return with a non-zero status.
-# Possible values are: NO, YES and FAIL_ON_WARNINGS.
-# The default value is: NO.
-
-WARN_AS_ERROR          = YES
-
-# The WARN_FORMAT tag determines the format of the warning messages that doxygen
-# can produce. The string should contain the $file, $line, and $text tags, which
-# will be replaced by the file and line number from which the warning originated
-# and the warning text. Optionally the format may contain $version, which will
-# be replaced by the version of the file (if it could be obtained via
-# FILE_VERSION_FILTER)
-# See also: WARN_LINE_FORMAT
-# The default value is: $file:$line: $text.
-
-WARN_FORMAT            = "$file:$line: $text"
-
-# In the $text part of the WARN_FORMAT command it is possible that a reference
-# to a more specific place is given. To make it easier to jump to this place
-# (outside of doxygen) the user can define a custom "cut" / "paste" string.
-# Example:
-# WARN_LINE_FORMAT = "'vi $file +$line'"
-# See also: WARN_FORMAT
-# The default value is: at line $line of file $file.
-
-WARN_LINE_FORMAT       = "at line $line of file $file"
-
-# The WARN_LOGFILE tag can be used to specify a file to which warning and error
-# messages should be written. If left blank the output is written to standard
-# error (stderr). In case the file specified cannot be opened for writing the
-# warning and error messages are written to standard error. When as file - is
-# specified the warning and error messages are written to standard output
-# (stdout).
-
-WARN_LOGFILE           =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the input files
-#---------------------------------------------------------------------------
-
-# The INPUT tag is used to specify the files and/or directories that contain
-# documented source files. You may enter file names like myfile.cpp or
-# directories like /usr/src/myproject. Separate the files or directories with
-# spaces. See also FILE_PATTERNS and EXTENSION_MAPPING
-# Note: If this tag is empty the current directory is searched.
-
-INPUT                  = @CMAKE_SOURCE_DIR@/Doc/Doxygen/user \
-                         @CMAKE_SOURCE_DIR@/Doc/Doxygen/common \
-                         @CMAKE_SOURCE_DIR@/Base \
-                         @CMAKE_SOURCE_DIR@/Fit/Param \
-                         @CMAKE_SOURCE_DIR@/Fit/Minimizer \
-                         @CMAKE_SOURCE_DIR@/Param \
-                         @CMAKE_SOURCE_DIR@/Sample \
-                         @CMAKE_SOURCE_DIR@/Device \
-                         @CMAKE_SOURCE_DIR@/Sim \
-                         @LibHeinz_INCLUDE_DIR@/heinz
-
-# This tag can be used to specify the character encoding of the source files
-# that doxygen parses. Internally doxygen uses the UTF-8 encoding. Doxygen uses
-# libiconv (or the iconv built into libc) for the transcoding. See the libiconv
-# documentation (see:
-# https://www.gnu.org/software/libiconv/) for the list of possible encodings.
-# The default value is: UTF-8.
-
-INPUT_ENCODING         = UTF-8
-
-# If the value of the INPUT tag contains directories, you can use the
-# FILE_PATTERNS tag to specify one or more wildcard patterns (like *.cpp and
-# *.h) to filter out the source-files in the directories.
-#
-# Note that for custom extensions or not directly supported extensions you also
-# need to set EXTENSION_MAPPING for the extension otherwise the files are not
-# read by doxygen.
-#
-# Note the list of default checked file patterns might differ from the list of
-# default file extension mappings.
-#
-# If left blank the following patterns are tested:*.c, *.cc, *.cxx, *.cpp,
-# *.c++, *.java, *.ii, *.ixx, *.ipp, *.i++, *.inl, *.idl, *.ddl, *.odl, *.h,
-# *.hh, *.hxx, *.hpp, *.h++, *.l, *.cs, *.d, *.php, *.php4, *.php5, *.phtml,
-# *.inc, *.m, *.markdown, *.md, *.mm, *.dox (to be provided as doxygen C
-# comment), *.py, *.pyw, *.f90, *.f95, *.f03, *.f08, *.f18, *.f, *.for, *.vhd,
-# *.vhdl, *.ucf, *.qsf and *.ice.
-
-FILE_PATTERNS          = *.h \
-                         *.dox \
-                         *.md
-
-# The RECURSIVE tag can be used to specify whether or not subdirectories should
-# be searched for input files as well.
-# The default value is: NO.
-
-RECURSIVE              = YES
-
-# The EXCLUDE tag can be used to specify files and/or directories that should be
-# excluded from the INPUT source files. This way you can easily exclude a
-# subdirectory from a directory tree whose root is specified with the INPUT tag.
-#
-# Note that relative paths are relative to the directory from which doxygen is
-# run.
-
-EXCLUDE                =
-
-# The EXCLUDE_SYMLINKS tag can be used to select whether or not files or
-# directories that are symbolic links (a Unix file system feature) are excluded
-# from the input.
-# The default value is: NO.
-
-EXCLUDE_SYMLINKS       = NO
-
-# If the value of the INPUT tag contains directories, you can use the
-# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude
-# certain files from those directories.
-#
-# Note that the wildcards are matched against the file with absolute path, so to
-# exclude all test directories for example use the pattern */test/*
-
-EXCLUDE_PATTERNS       = */3rdParty/* \
-                         */Test/*
-
-# The EXCLUDE_SYMBOLS tag can be used to specify one or more symbol names
-# (namespaces, classes, functions, etc.) that should be excluded from the
-# output. The symbol name can be a fully qualified name, a word, or if the
-# wildcard * is used, a substring. Examples: ANamespace, AClass,
-# ANamespace::AClass, ANamespace::*Test
-#
-# Note that the wildcards are matched against the file with absolute path, so to
-# exclude all test directories use the pattern */test/*
-
-EXCLUDE_SYMBOLS        = size_t
-
-# The EXAMPLE_PATH tag can be used to specify one or more files or directories
-# that contain example code fragments that are included (see the \include
-# command).
-
-EXAMPLE_PATH           =
-
-# If the value of the EXAMPLE_PATH tag contains directories, you can use the
-# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp and
-# *.h) to filter out the source-files in the directories. If left blank all
-# files are included.
-
-EXAMPLE_PATTERNS       =
-
-# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be
-# searched for input files to be used with the \include or \dontinclude commands
-# irrespective of the value of the RECURSIVE tag.
-# The default value is: NO.
-
-EXAMPLE_RECURSIVE      = NO
-
-# The IMAGE_PATH tag can be used to specify one or more files or directories
-# that contain images that are to be included in the documentation (see the
-# \image command).
-
-IMAGE_PATH             =
-
-# The INPUT_FILTER tag can be used to specify a program that doxygen should
-# invoke to filter for each input file. Doxygen will invoke the filter program
-# by executing (via popen()) the command:
-#
-# <filter> <input-file>
-#
-# where <filter> is the value of the INPUT_FILTER tag, and <input-file> is the
-# name of an input file. Doxygen will then use the output that the filter
-# program writes to standard output. If FILTER_PATTERNS is specified, this tag
-# will be ignored.
-#
-# Note that the filter must not add or remove lines; it is applied before the
-# code is scanned, but not when the output code is generated. If lines are added
-# or removed, the anchors will not be placed correctly.
-#
-# Note that for custom extensions or not directly supported extensions you also
-# need to set EXTENSION_MAPPING for the extension otherwise the files are not
-# properly processed by doxygen.
-
-INPUT_FILTER           =
-
-# The FILTER_PATTERNS tag can be used to specify filters on a per file pattern
-# basis. Doxygen will compare the file name with each pattern and apply the
-# filter if there is a match. The filters are a list of the form: pattern=filter
-# (like *.cpp=my_cpp_filter). See INPUT_FILTER for further information on how
-# filters are used. If the FILTER_PATTERNS tag is empty or if none of the
-# patterns match the file name, INPUT_FILTER is applied.
-#
-# Note that for custom extensions or not directly supported extensions you also
-# need to set EXTENSION_MAPPING for the extension otherwise the files are not
-# properly processed by doxygen.
-
-FILTER_PATTERNS        =
-
-# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using
-# INPUT_FILTER) will also be used to filter the input files that are used for
-# producing the source files to browse (i.e. when SOURCE_BROWSER is set to YES).
-# The default value is: NO.
-
-FILTER_SOURCE_FILES    = NO
-
-# The FILTER_SOURCE_PATTERNS tag can be used to specify source filters per file
-# pattern. A pattern will override the setting for FILTER_PATTERN (if any) and
-# it is also possible to disable source filtering for a specific pattern using
-# *.ext= (so without naming a filter).
-# This tag requires that the tag FILTER_SOURCE_FILES is set to YES.
-
-FILTER_SOURCE_PATTERNS =
-
-# If the USE_MDFILE_AS_MAINPAGE tag refers to the name of a markdown file that
-# is part of the input, its contents will be placed on the main page
-# (index.html). This can be useful if you have a project on for instance GitHub
-# and want to reuse the introduction page also for the doxygen output.
-
-USE_MDFILE_AS_MAINPAGE =
-
-#---------------------------------------------------------------------------
-# Configuration options related to source browsing
-#---------------------------------------------------------------------------
-
-# If the SOURCE_BROWSER tag is set to YES then a list of source files will be
-# generated. Documented entities will be cross-referenced with these sources.
-#
-# Note: To get rid of all source code in the generated output, make sure that
-# also VERBATIM_HEADERS is set to NO.
-# The default value is: NO.
-
-SOURCE_BROWSER         = NO
-
-# Setting the INLINE_SOURCES tag to YES will include the body of functions,
-# classes and enums directly into the documentation.
-# The default value is: NO.
-
-INLINE_SOURCES         = NO
-
-# Setting the STRIP_CODE_COMMENTS tag to YES will instruct doxygen to hide any
-# special comment blocks from generated source code fragments. Normal C, C++ and
-# Fortran comments will always remain visible.
-# The default value is: YES.
-
-STRIP_CODE_COMMENTS    = NO
-
-# If the REFERENCED_BY_RELATION tag is set to YES then for each documented
-# entity all documented functions referencing it will be listed.
-# The default value is: NO.
-
-REFERENCED_BY_RELATION = NO
-
-# If the REFERENCES_RELATION tag is set to YES then for each documented function
-# all documented entities called/used by that function will be listed.
-# The default value is: NO.
-
-REFERENCES_RELATION    = NO
-
-# If the REFERENCES_LINK_SOURCE tag is set to YES and SOURCE_BROWSER tag is set
-# to YES then the hyperlinks from functions in REFERENCES_RELATION and
-# REFERENCED_BY_RELATION lists will link to the source code. Otherwise they will
-# link to the documentation.
-# The default value is: YES.
-
-REFERENCES_LINK_SOURCE = NO
-
-# If SOURCE_TOOLTIPS is enabled (the default) then hovering a hyperlink in the
-# source code will show a tooltip with additional information such as prototype,
-# brief description and links to the definition and documentation. Since this
-# will make the HTML file larger and loading of large files a bit slower, you
-# can opt to disable this feature.
-# The default value is: YES.
-# This tag requires that the tag SOURCE_BROWSER is set to YES.
-
-SOURCE_TOOLTIPS        = YES
-
-# If the USE_HTAGS tag is set to YES then the references to source code will
-# point to the HTML generated by the htags(1) tool instead of doxygen built-in
-# source browser. The htags tool is part of GNU's global source tagging system
-# (see https://www.gnu.org/software/global/global.html). You will need version
-# 4.8.6 or higher.
-#
-# To use it do the following:
-# - Install the latest version of global
-# - Enable SOURCE_BROWSER and USE_HTAGS in the configuration file
-# - Make sure the INPUT points to the root of the source tree
-# - Run doxygen as normal
-#
-# Doxygen will invoke htags (and that will in turn invoke gtags), so these
-# tools must be available from the command line (i.e. in the search path).
-#
-# The result: instead of the source browser generated by doxygen, the links to
-# source code will now point to the output of htags.
-# The default value is: NO.
-# This tag requires that the tag SOURCE_BROWSER is set to YES.
-
-USE_HTAGS              = NO
-
-# If the VERBATIM_HEADERS tag is set the YES then doxygen will generate a
-# verbatim copy of the header file for each class for which an include is
-# specified. Set to NO to disable this.
-# See also: Section \class.
-# The default value is: YES.
-
-VERBATIM_HEADERS       = YES
-
-# If the CLANG_ASSISTED_PARSING tag is set to YES then doxygen will use the
-# clang parser (see:
-# http://clang.llvm.org/) for more accurate parsing at the cost of reduced
-# performance. This can be particularly helpful with template rich C++ code for
-# which doxygen's built-in parser lacks the necessary type information.
-# Note: The availability of this option depends on whether or not doxygen was
-# generated with the -Duse_libclang=ON option for CMake.
-# The default value is: NO.
-
-CLANG_ASSISTED_PARSING = NO
-
-# If the CLANG_ASSISTED_PARSING tag is set to YES and the CLANG_ADD_INC_PATHS
-# tag is set to YES then doxygen will add the directory of each input to the
-# include path.
-# The default value is: YES.
-# This tag requires that the tag CLANG_ASSISTED_PARSING is set to YES.
-
-CLANG_ADD_INC_PATHS    = YES
-
-# If clang assisted parsing is enabled you can provide the compiler with command
-# line options that you would normally use when invoking the compiler. Note that
-# the include paths will already be set by doxygen for the files and directories
-# specified with INPUT and INCLUDE_PATH.
-# This tag requires that the tag CLANG_ASSISTED_PARSING is set to YES.
-
-CLANG_OPTIONS          =
-
-# If clang assisted parsing is enabled you can provide the clang parser with the
-# path to the directory containing a file called compile_commands.json. This
-# file is the compilation database (see:
-# http://clang.llvm.org/docs/HowToSetupToolingForLLVM.html) containing the
-# options used when the source files were built. This is equivalent to
-# specifying the -p option to a clang tool, such as clang-check. These options
-# will then be passed to the parser. Any options specified with CLANG_OPTIONS
-# will be added as well.
-# Note: The availability of this option depends on whether or not doxygen was
-# generated with the -Duse_libclang=ON option for CMake.
-
-CLANG_DATABASE_PATH    =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the alphabetical class index
-#---------------------------------------------------------------------------
-
-# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index of all
-# compounds will be generated. Enable this if the project contains a lot of
-# classes, structs, unions or interfaces.
-# The default value is: YES.
-
-ALPHABETICAL_INDEX     = YES
-
-# In case all classes in a project start with a common prefix, all classes will
-# be put under the same header in the alphabetical index. The IGNORE_PREFIX tag
-# can be used to specify a prefix (or a list of prefixes) that should be ignored
-# while generating the index headers.
-# This tag requires that the tag ALPHABETICAL_INDEX is set to YES.
-
-IGNORE_PREFIX          =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the HTML output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_HTML tag is set to YES, doxygen will generate HTML output
-# The default value is: YES.
-
-GENERATE_HTML          = YES
-
-# The HTML_OUTPUT tag is used to specify where the HTML docs will be put. If a
-# relative path is entered the value of OUTPUT_DIRECTORY will be put in front of
-# it.
-# The default directory is: html.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_OUTPUT            = @CMAKE_BINARY_DIR@/html/user
-
-# The HTML_FILE_EXTENSION tag can be used to specify the file extension for each
-# generated HTML page (for example: .htm, .php, .asp).
-# The default value is: .html.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_FILE_EXTENSION    = .html
-
-# The HTML_HEADER tag can be used to specify a user-defined HTML header file for
-# each generated HTML page. If the tag is left blank doxygen will generate a
-# standard header.
-#
-# To get valid HTML the header file that includes any scripts and style sheets
-# that doxygen needs, which is dependent on the configuration options used (e.g.
-# the setting GENERATE_TREEVIEW). It is highly recommended to start with a
-# default header using
-# doxygen -w html new_header.html new_footer.html new_stylesheet.css
-# YourConfigFile
-# and then modify the file new_header.html. See also section "Doxygen usage"
-# for information on how to generate the default header that doxygen normally
-# uses.
-# Note: The header is subject to change so you typically have to regenerate the
-# default header when upgrading to a newer version of doxygen. For a description
-# of the possible markers and block names see the documentation.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_HEADER            =
-
-# The HTML_FOOTER tag can be used to specify a user-defined HTML footer for each
-# generated HTML page. If the tag is left blank doxygen will generate a standard
-# footer. See HTML_HEADER for more information on how to generate a default
-# footer and what special commands can be used inside the footer. See also
-# section "Doxygen usage" for information on how to generate the default footer
-# that doxygen normally uses.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_FOOTER            =
-
-# The HTML_STYLESHEET tag can be used to specify a user-defined cascading style
-# sheet that is used by each HTML page. It can be used to fine-tune the look of
-# the HTML output. If left blank doxygen will generate a default style sheet.
-# See also section "Doxygen usage" for information on how to generate the style
-# sheet that doxygen normally uses.
-# Note: It is recommended to use HTML_EXTRA_STYLESHEET instead of this tag, as
-# it is more robust and this tag (HTML_STYLESHEET) will in the future become
-# obsolete.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_STYLESHEET        =
-
-# The HTML_EXTRA_STYLESHEET tag can be used to specify additional user-defined
-# cascading style sheets that are included after the standard style sheets
-# created by doxygen. Using this option one can overrule certain style aspects.
-# This is preferred over using HTML_STYLESHEET since it does not replace the
-# standard style sheet and is therefore more robust against future updates.
-# Doxygen will copy the style sheet files to the output directory.
-# Note: The order of the extra style sheet files is of importance (e.g. the last
-# style sheet in the list overrules the setting of the previous ones in the
-# list). For an example see the documentation.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_EXTRA_STYLESHEET  =
-
-# The HTML_EXTRA_FILES tag can be used to specify one or more extra images or
-# other source files which should be copied to the HTML output directory. Note
-# that these files will be copied to the base HTML output directory. Use the
-# $relpath^ marker in the HTML_HEADER and/or HTML_FOOTER files to load these
-# files. In the HTML_STYLESHEET file, use the file name only. Also note that the
-# files will be copied as-is; there are no commands or markers available.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_EXTRA_FILES       =
-
-# The HTML_COLORSTYLE_HUE tag controls the color of the HTML output. Doxygen
-# will adjust the colors in the style sheet and background images according to
-# this color. Hue is specified as an angle on a color-wheel, see
-# https://en.wikipedia.org/wiki/Hue for more information. For instance the value
-# 0 represents red, 60 is yellow, 120 is green, 180 is cyan, 240 is blue, 300
-# purple, and 360 is red again.
-# Minimum value: 0, maximum value: 359, default value: 220.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_COLORSTYLE_HUE    = 220
-
-# The HTML_COLORSTYLE_SAT tag controls the purity (or saturation) of the colors
-# in the HTML output. For a value of 0 the output will use gray-scales only. A
-# value of 255 will produce the most vivid colors.
-# Minimum value: 0, maximum value: 255, default value: 100.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_COLORSTYLE_SAT    = 100
-
-# The HTML_COLORSTYLE_GAMMA tag controls the gamma correction applied to the
-# luminance component of the colors in the HTML output. Values below 100
-# gradually make the output lighter, whereas values above 100 make the output
-# darker. The value divided by 100 is the actual gamma applied, so 80 represents
-# a gamma of 0.8, The value 220 represents a gamma of 2.2, and 100 does not
-# change the gamma.
-# Minimum value: 40, maximum value: 240, default value: 80.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_COLORSTYLE_GAMMA  = 80
-
-# If the HTML_TIMESTAMP tag is set to YES then the footer of each generated HTML
-# page will contain the date and time when the page was generated. Setting this
-# to YES can help to show when doxygen was last run and thus if the
-# documentation is up to date.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_TIMESTAMP         = NO
-
-# If the HTML_DYNAMIC_MENUS tag is set to YES then the generated HTML
-# documentation will contain a main index with vertical navigation menus that
-# are dynamically created via JavaScript. If disabled, the navigation index will
-# consists of multiple levels of tabs that are statically embedded in every HTML
-# page. Disable this option to support browsers that do not have JavaScript,
-# like the Qt help browser.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_DYNAMIC_MENUS     = YES
-
-# If the HTML_DYNAMIC_SECTIONS tag is set to YES then the generated HTML
-# documentation will contain sections that can be hidden and shown after the
-# page has loaded.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_DYNAMIC_SECTIONS  = NO
-
-# With HTML_INDEX_NUM_ENTRIES one can control the preferred number of entries
-# shown in the various tree structured indices initially; the user can expand
-# and collapse entries dynamically later on. Doxygen will expand the tree to
-# such a level that at most the specified number of entries are visible (unless
-# a fully collapsed tree already exceeds this amount). So setting the number of
-# entries 1 will produce a full collapsed tree by default. 0 is a special value
-# representing an infinite number of entries and will result in a full expanded
-# tree by default.
-# Minimum value: 0, maximum value: 9999, default value: 100.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_INDEX_NUM_ENTRIES = 100
-
-# If the GENERATE_DOCSET tag is set to YES, additional index files will be
-# generated that can be used as input for Apple's Xcode 3 integrated development
-# environment (see:
-# https://developer.apple.com/xcode/), introduced with OSX 10.5 (Leopard). To
-# create a documentation set, doxygen will generate a Makefile in the HTML
-# output directory. Running make will produce the docset in that directory and
-# running make install will install the docset in
-# ~/Library/Developer/Shared/Documentation/DocSets so that Xcode will find it at
-# startup. See https://developer.apple.com/library/archive/featuredarticles/Doxy
-# genXcode/_index.html for more information.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-GENERATE_DOCSET        = NO
-
-# This tag determines the name of the docset feed. A documentation feed provides
-# an umbrella under which multiple documentation sets from a single provider
-# (such as a company or product suite) can be grouped.
-# The default value is: Doxygen generated docs.
-# This tag requires that the tag GENERATE_DOCSET is set to YES.
-
-DOCSET_FEEDNAME        = "Doxygen generated docs"
-
-# This tag determines the URL of the docset feed. A documentation feed provides
-# an umbrella under which multiple documentation sets from a single provider
-# (such as a company or product suite) can be grouped.
-# This tag requires that the tag GENERATE_DOCSET is set to YES.
-
-DOCSET_FEEDURL         =
-
-# This tag specifies a string that should uniquely identify the documentation
-# set bundle. This should be a reverse domain-name style string, e.g.
-# com.mycompany.MyDocSet. Doxygen will append .docset to the name.
-# The default value is: org.doxygen.Project.
-# This tag requires that the tag GENERATE_DOCSET is set to YES.
-
-DOCSET_BUNDLE_ID       = org.doxygen.Project
-
-# The DOCSET_PUBLISHER_ID tag specifies a string that should uniquely identify
-# the documentation publisher. This should be a reverse domain-name style
-# string, e.g. com.mycompany.MyDocSet.documentation.
-# The default value is: org.doxygen.Publisher.
-# This tag requires that the tag GENERATE_DOCSET is set to YES.
-
-DOCSET_PUBLISHER_ID    = org.doxygen.Publisher
-
-# The DOCSET_PUBLISHER_NAME tag identifies the documentation publisher.
-# The default value is: Publisher.
-# This tag requires that the tag GENERATE_DOCSET is set to YES.
-
-DOCSET_PUBLISHER_NAME  = Publisher
-
-# If the GENERATE_HTMLHELP tag is set to YES then doxygen generates three
-# additional HTML index files: index.hhp, index.hhc, and index.hhk. The
-# index.hhp is a project file that can be read by Microsoft's HTML Help Workshop
-# on Windows. In the beginning of 2021 Microsoft took the original page, with
-# a.o. the download links, offline the HTML help workshop was already many years
-# in maintenance mode). You can download the HTML help workshop from the web
-# archives at Installation executable (see:
-# http://web.archive.org/web/20160201063255/http://download.microsoft.com/downlo
-# ad/0/A/9/0A939EF6-E31C-430F-A3DF-DFAE7960D564/htmlhelp.exe).
-#
-# The HTML Help Workshop contains a compiler that can convert all HTML output
-# generated by doxygen into a single compiled HTML file (.chm). Compiled HTML
-# files are now used as the Windows 98 help format, and will replace the old
-# Windows help format (.hlp) on all Windows platforms in the future. Compressed
-# HTML files also contain an index, a table of contents, and you can search for
-# words in the documentation. The HTML workshop also contains a viewer for
-# compressed HTML files.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-GENERATE_HTMLHELP      = NO
-
-# The CHM_FILE tag can be used to specify the file name of the resulting .chm
-# file. You can add a path in front of the file if the result should not be
-# written to the html output directory.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-CHM_FILE               =
-
-# The HHC_LOCATION tag can be used to specify the location (absolute path
-# including file name) of the HTML help compiler (hhc.exe). If non-empty,
-# doxygen will try to run the HTML help compiler on the generated index.hhp.
-# The file has to be specified with full path.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-HHC_LOCATION           =
-
-# The GENERATE_CHI flag controls if a separate .chi index file is generated
-# (YES) or that it should be included in the main .chm file (NO).
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-GENERATE_CHI           = NO
-
-# The CHM_INDEX_ENCODING is used to encode HtmlHelp index (hhk), content (hhc)
-# and project file content.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-CHM_INDEX_ENCODING     =
-
-# The BINARY_TOC flag controls whether a binary table of contents is generated
-# (YES) or a normal table of contents (NO) in the .chm file. Furthermore it
-# enables the Previous and Next buttons.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-BINARY_TOC             = NO
-
-# The TOC_EXPAND flag can be set to YES to add extra items for group members to
-# the table of contents of the HTML help documentation and to the tree view.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTMLHELP is set to YES.
-
-TOC_EXPAND             = YES
-
-# If the GENERATE_QHP tag is set to YES and both QHP_NAMESPACE and
-# QHP_VIRTUAL_FOLDER are set, an additional index file will be generated that
-# can be used as input for Qt's qhelpgenerator to generate a Qt Compressed Help
-# (.qch) of the generated HTML documentation.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-GENERATE_QHP           = NO
-
-# If the QHG_LOCATION tag is specified, the QCH_FILE tag can be used to specify
-# the file name of the resulting .qch file. The path specified is relative to
-# the HTML output folder.
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QCH_FILE               =
-
-# The QHP_NAMESPACE tag specifies the namespace to use when generating Qt Help
-# Project output. For more information please see Qt Help Project / Namespace
-# (see:
-# https://doc.qt.io/archives/qt-4.8/qthelpproject.html#namespace).
-# The default value is: org.doxygen.Project.
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHP_NAMESPACE          = org.doxygen.Project
-
-# The QHP_VIRTUAL_FOLDER tag specifies the namespace to use when generating Qt
-# Help Project output. For more information please see Qt Help Project / Virtual
-# Folders (see:
-# https://doc.qt.io/archives/qt-4.8/qthelpproject.html#virtual-folders).
-# The default value is: doc.
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHP_VIRTUAL_FOLDER     = doc
-
-# If the QHP_CUST_FILTER_NAME tag is set, it specifies the name of a custom
-# filter to add. For more information please see Qt Help Project / Custom
-# Filters (see:
-# https://doc.qt.io/archives/qt-4.8/qthelpproject.html#custom-filters).
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHP_CUST_FILTER_NAME   =
-
-# The QHP_CUST_FILTER_ATTRS tag specifies the list of the attributes of the
-# custom filter to add. For more information please see Qt Help Project / Custom
-# Filters (see:
-# https://doc.qt.io/archives/qt-4.8/qthelpproject.html#custom-filters).
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHP_CUST_FILTER_ATTRS  =
-
-# The QHP_SECT_FILTER_ATTRS tag specifies the list of the attributes this
-# project's filter section matches. Qt Help Project / Filter Attributes (see:
-# https://doc.qt.io/archives/qt-4.8/qthelpproject.html#filter-attributes).
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHP_SECT_FILTER_ATTRS  =
-
-# The QHG_LOCATION tag can be used to specify the location (absolute path
-# including file name) of Qt's qhelpgenerator. If non-empty doxygen will try to
-# run qhelpgenerator on the generated .qhp file.
-# This tag requires that the tag GENERATE_QHP is set to YES.
-
-QHG_LOCATION           =
-
-# If the GENERATE_ECLIPSEHELP tag is set to YES, additional index files will be
-# generated, together with the HTML files, they form an Eclipse help plugin. To
-# install this plugin and make it available under the help contents menu in
-# Eclipse, the contents of the directory containing the HTML and XML files needs
-# to be copied into the plugins directory of eclipse. The name of the directory
-# within the plugins directory should be the same as the ECLIPSE_DOC_ID value.
-# After copying Eclipse needs to be restarted before the help appears.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-GENERATE_ECLIPSEHELP   = NO
-
-# A unique identifier for the Eclipse help plugin. When installing the plugin
-# the directory name containing the HTML and XML files should also have this
-# name. Each documentation set should have its own identifier.
-# The default value is: org.doxygen.Project.
-# This tag requires that the tag GENERATE_ECLIPSEHELP is set to YES.
-
-ECLIPSE_DOC_ID         = org.doxygen.Project
-
-# If you want full control over the layout of the generated HTML pages it might
-# be necessary to disable the index and replace it with your own. The
-# DISABLE_INDEX tag can be used to turn on/off the condensed index (tabs) at top
-# of each HTML page. A value of NO enables the index and the value YES disables
-# it. Since the tabs in the index contain the same information as the navigation
-# tree, you can set this option to YES if you also set GENERATE_TREEVIEW to YES.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-DISABLE_INDEX          = NO
-
-# The GENERATE_TREEVIEW tag is used to specify whether a tree-like index
-# structure should be generated to display hierarchical information. If the tag
-# value is set to YES, a side panel will be generated containing a tree-like
-# index structure (just like the one that is generated for HTML Help). For this
-# to work a browser that supports JavaScript, DHTML, CSS and frames is required
-# (i.e. any modern browser). Windows users are probably better off using the
-# HTML help feature. Via custom style sheets (see HTML_EXTRA_STYLESHEET) one can
-# further fine tune the look of the index (see "Fine-tuning the output"). As an
-# example, the default style sheet generated by doxygen has an example that
-# shows how to put an image at the root of the tree instead of the PROJECT_NAME.
-# Since the tree basically has the same information as the tab index, you could
-# consider setting DISABLE_INDEX to YES when enabling this option.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-GENERATE_TREEVIEW      = YES
-
-# When both GENERATE_TREEVIEW and DISABLE_INDEX are set to YES, then the
-# FULL_SIDEBAR option determines if the side bar is limited to only the treeview
-# area (value NO) or if it should extend to the full height of the window (value
-# YES). Setting this to YES gives a layout similar to
-# https://docs.readthedocs.io with more room for contents, but less room for the
-# project logo, title, and description. If either GENERATE_TREEVIEW or
-# DISABLE_INDEX is set to NO, this option has no effect.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-FULL_SIDEBAR           = NO
-
-# The ENUM_VALUES_PER_LINE tag can be used to set the number of enum values that
-# doxygen will group on one line in the generated HTML documentation.
-#
-# Note that a value of 0 will completely suppress the enum values from appearing
-# in the overview section.
-# Minimum value: 0, maximum value: 20, default value: 4.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-ENUM_VALUES_PER_LINE   = 4
-
-# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be used
-# to set the initial width (in pixels) of the frame in which the tree is shown.
-# Minimum value: 0, maximum value: 1500, default value: 250.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-TREEVIEW_WIDTH         = 250
-
-# If the EXT_LINKS_IN_WINDOW option is set to YES, doxygen will open links to
-# external symbols imported via tag files in a separate window.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-EXT_LINKS_IN_WINDOW    = NO
-
-# If the OBFUSCATE_EMAILS tag is set to YES, doxygen will obfuscate email
-# addresses.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-OBFUSCATE_EMAILS       = YES
-
-# If the HTML_FORMULA_FORMAT option is set to svg, doxygen will use the pdf2svg
-# tool (see https://github.com/dawbarton/pdf2svg) or inkscape (see
-# https://inkscape.org) to generate formulas as SVG images instead of PNGs for
-# the HTML output. These images will generally look nicer at scaled resolutions.
-# Possible values are: png (the default) and svg (looks nicer but requires the
-# pdf2svg or inkscape tool).
-# The default value is: png.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-HTML_FORMULA_FORMAT    = png
-
-# Use this tag to change the font size of LaTeX formulas included as images in
-# the HTML documentation. When you change the font size after a successful
-# doxygen run you need to manually remove any form_*.png images from the HTML
-# output directory to force them to be regenerated.
-# Minimum value: 8, maximum value: 50, default value: 10.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-FORMULA_FONTSIZE       = 10
-
-# Use the FORMULA_TRANSPARENT tag to determine whether or not the images
-# generated for formulas are transparent PNGs. Transparent PNGs are not
-# supported properly for IE 6.0, but are supported on all modern browsers.
-#
-# Note that when changing this option you need to delete any form_*.png files in
-# the HTML output directory before the changes have effect.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-FORMULA_TRANSPARENT    = YES
-
-# The FORMULA_MACROFILE can contain LaTeX \newcommand and \renewcommand commands
-# to create new LaTeX commands to be used in formulas as building blocks. See
-# the section "Including formulas" for details.
-
-FORMULA_MACROFILE      =
-
-# Enable the USE_MATHJAX option to render LaTeX formulas using MathJax (see
-# https://www.mathjax.org) which uses client side JavaScript for the rendering
-# instead of using pre-rendered bitmaps. Use this if you do not have LaTeX
-# installed or if you want to formulas look prettier in the HTML output. When
-# enabled you may also need to install MathJax separately and configure the path
-# to it using the MATHJAX_RELPATH option.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-USE_MATHJAX            = NO
-
-# With MATHJAX_VERSION it is possible to specify the MathJax version to be used.
-# Note that the different versions of MathJax have different requirements with
-# regards to the different settings, so it is possible that also other MathJax
-# settings have to be changed when switching between the different MathJax
-# versions.
-# Possible values are: MathJax_2 and MathJax_3.
-# The default value is: MathJax_2.
-# This tag requires that the tag USE_MATHJAX is set to YES.
-
-MATHJAX_VERSION        = MathJax_2
-
-# When MathJax is enabled you can set the default output format to be used for
-# the MathJax output. For more details about the output format see MathJax
-# version 2 (see:
-# http://docs.mathjax.org/en/v2.7-latest/output.html) and MathJax version 3
-# (see:
-# http://docs.mathjax.org/en/latest/web/components/output.html).
-# Possible values are: HTML-CSS (which is slower, but has the best
-# compatibility. This is the name for Mathjax version 2, for MathJax version 3
-# this will be translated into chtml), NativeMML (i.e. MathML. Only supported
-# for NathJax 2. For MathJax version 3 chtml will be used instead.), chtml (This
-# is the name for Mathjax version 3, for MathJax version 2 this will be
-# translated into HTML-CSS) and SVG.
-# The default value is: HTML-CSS.
-# This tag requires that the tag USE_MATHJAX is set to YES.
-
-MATHJAX_FORMAT         = HTML-CSS
-
-# When MathJax is enabled you need to specify the location relative to the HTML
-# output directory using the MATHJAX_RELPATH option. The destination directory
-# should contain the MathJax.js script. For instance, if the mathjax directory
-# is located at the same level as the HTML output directory, then
-# MATHJAX_RELPATH should be ../mathjax. The default value points to the MathJax
-# Content Delivery Network so you can quickly see the result without installing
-# MathJax. However, it is strongly recommended to install a local copy of
-# MathJax from https://www.mathjax.org before deployment. The default value is:
-# - in case of MathJax version 2: https://cdn.jsdelivr.net/npm/mathjax@2
-# - in case of MathJax version 3: https://cdn.jsdelivr.net/npm/mathjax@3
-# This tag requires that the tag USE_MATHJAX is set to YES.
-
-MATHJAX_RELPATH        = http://cdn.mathjax.org/mathjax/latest
-
-# The MATHJAX_EXTENSIONS tag can be used to specify one or more MathJax
-# extension names that should be enabled during MathJax rendering. For example
-# for MathJax version 2 (see
-# https://docs.mathjax.org/en/v2.7-latest/tex.html#tex-and-latex-extensions):
-# MATHJAX_EXTENSIONS = TeX/AMSmath TeX/AMSsymbols
-# For example for MathJax version 3 (see
-# http://docs.mathjax.org/en/latest/input/tex/extensions/index.html):
-# MATHJAX_EXTENSIONS = ams
-# This tag requires that the tag USE_MATHJAX is set to YES.
-
-MATHJAX_EXTENSIONS     =
-
-# The MATHJAX_CODEFILE tag can be used to specify a file with javascript pieces
-# of code that will be used on startup of the MathJax code. See the MathJax site
-# (see:
-# http://docs.mathjax.org/en/v2.7-latest/output.html) for more details. For an
-# example see the documentation.
-# This tag requires that the tag USE_MATHJAX is set to YES.
-
-MATHJAX_CODEFILE       =
-
-# When the SEARCHENGINE tag is enabled doxygen will generate a search box for
-# the HTML output. The underlying search engine uses javascript and DHTML and
-# should work on any modern browser. Note that when using HTML help
-# (GENERATE_HTMLHELP), Qt help (GENERATE_QHP), or docsets (GENERATE_DOCSET)
-# there is already a search function so this one should typically be disabled.
-# For large projects the javascript based search engine can be slow, then
-# enabling SERVER_BASED_SEARCH may provide a better solution. It is possible to
-# search using the keyboard; to jump to the search box use <access key> + S
-# (what the <access key> is depends on the OS and browser, but it is typically
-# <CTRL>, <ALT>/<option>, or both). Inside the search box use the <cursor down
-# key> to jump into the search results window, the results can be navigated
-# using the <cursor keys>. Press <Enter> to select an item or <escape> to cancel
-# the search. The filter options can be selected when the cursor is inside the
-# search box by pressing <Shift>+<cursor down>. Also here use the <cursor keys>
-# to select a filter and <Enter> or <escape> to activate or cancel the filter
-# option.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_HTML is set to YES.
-
-SEARCHENGINE           = YES
-
-# When the SERVER_BASED_SEARCH tag is enabled the search engine will be
-# implemented using a web server instead of a web client using JavaScript. There
-# are two flavors of web server based searching depending on the EXTERNAL_SEARCH
-# setting. When disabled, doxygen will generate a PHP script for searching and
-# an index file used by the script. When EXTERNAL_SEARCH is enabled the indexing
-# and searching needs to be provided by external tools. See the section
-# "External Indexing and Searching" for details.
-# The default value is: NO.
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-SERVER_BASED_SEARCH    = NO
-
-# When EXTERNAL_SEARCH tag is enabled doxygen will no longer generate the PHP
-# script for searching. Instead the search results are written to an XML file
-# which needs to be processed by an external indexer. Doxygen will invoke an
-# external search engine pointed to by the SEARCHENGINE_URL option to obtain the
-# search results.
-#
-# Doxygen ships with an example indexer (doxyindexer) and search engine
-# (doxysearch.cgi) which are based on the open source search engine library
-# Xapian (see:
-# https://xapian.org/).
-#
-# See the section "External Indexing and Searching" for details.
-# The default value is: NO.
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-EXTERNAL_SEARCH        = NO
-
-# The SEARCHENGINE_URL should point to a search engine hosted by a web server
-# which will return the search results when EXTERNAL_SEARCH is enabled.
-#
-# Doxygen ships with an example indexer (doxyindexer) and search engine
-# (doxysearch.cgi) which are based on the open source search engine library
-# Xapian (see:
-# https://xapian.org/). See the section "External Indexing and Searching" for
-# details.
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-SEARCHENGINE_URL       =
-
-# When SERVER_BASED_SEARCH and EXTERNAL_SEARCH are both enabled the unindexed
-# search data is written to a file for indexing by an external tool. With the
-# SEARCHDATA_FILE tag the name of this file can be specified.
-# The default file is: searchdata.xml.
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-SEARCHDATA_FILE        = searchdata.xml
-
-# When SERVER_BASED_SEARCH and EXTERNAL_SEARCH are both enabled the
-# EXTERNAL_SEARCH_ID tag can be used as an identifier for the project. This is
-# useful in combination with EXTRA_SEARCH_MAPPINGS to search through multiple
-# projects and redirect the results back to the right project.
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-EXTERNAL_SEARCH_ID     =
-
-# The EXTRA_SEARCH_MAPPINGS tag can be used to enable searching through doxygen
-# projects other than the one defined by this configuration file, but that are
-# all added to the same external search index. Each project needs to have a
-# unique id set via EXTERNAL_SEARCH_ID. The search mapping then maps the id of
-# to a relative location where the documentation can be found. The format is:
-# EXTRA_SEARCH_MAPPINGS = tagname1=loc1 tagname2=loc2 ...
-# This tag requires that the tag SEARCHENGINE is set to YES.
-
-EXTRA_SEARCH_MAPPINGS  =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the LaTeX output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_LATEX tag is set to YES, doxygen will generate LaTeX output.
-# The default value is: YES.
-
-GENERATE_LATEX         = NO
-
-# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put. If a
-# relative path is entered the value of OUTPUT_DIRECTORY will be put in front of
-# it.
-# The default directory is: latex.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_OUTPUT           = latex
-
-# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be
-# invoked.
-#
-# Note that when not enabling USE_PDFLATEX the default is latex when enabling
-# USE_PDFLATEX the default is pdflatex and when in the later case latex is
-# chosen this is overwritten by pdflatex. For specific output languages the
-# default can have been set differently, this depends on the implementation of
-# the output language.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_CMD_NAME         = latex
-
-# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to generate
-# index for LaTeX.
-# Note: This tag is used in the Makefile / make.bat.
-# See also: LATEX_MAKEINDEX_CMD for the part in the generated output file
-# (.tex).
-# The default file is: makeindex.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-MAKEINDEX_CMD_NAME     = makeindex
-
-# The LATEX_MAKEINDEX_CMD tag can be used to specify the command name to
-# generate index for LaTeX. In case there is no backslash (\) as first character
-# it will be automatically added in the LaTeX code.
-# Note: This tag is used in the generated output file (.tex).
-# See also: MAKEINDEX_CMD_NAME for the part in the Makefile / make.bat.
-# The default value is: makeindex.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_MAKEINDEX_CMD    = makeindex
-
-# If the COMPACT_LATEX tag is set to YES, doxygen generates more compact LaTeX
-# documents. This may be useful for small projects and may help to save some
-# trees in general.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-COMPACT_LATEX          = NO
-
-# The PAPER_TYPE tag can be used to set the paper type that is used by the
-# printer.
-# Possible values are: a4 (210 x 297 mm), letter (8.5 x 11 inches), legal (8.5 x
-# 14 inches) and executive (7.25 x 10.5 inches).
-# The default value is: a4.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-PAPER_TYPE             = a4
-
-# The EXTRA_PACKAGES tag can be used to specify one or more LaTeX package names
-# that should be included in the LaTeX output. The package can be specified just
-# by its name or with the correct syntax as to be used with the LaTeX
-# \usepackage command. To get the times font for instance you can specify :
-# EXTRA_PACKAGES=times or EXTRA_PACKAGES={times}
-# To use the option intlimits with the amsmath package you can specify:
-# EXTRA_PACKAGES=[intlimits]{amsmath}
-# If left blank no extra packages will be included.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-EXTRA_PACKAGES         =
-
-# The LATEX_HEADER tag can be used to specify a user-defined LaTeX header for
-# the generated LaTeX document. The header should contain everything until the
-# first chapter. If it is left blank doxygen will generate a standard header. It
-# is highly recommended to start with a default header using
-# doxygen -w latex new_header.tex new_footer.tex new_stylesheet.sty
-# and then modify the file new_header.tex. See also section "Doxygen usage" for
-# information on how to generate the default header that doxygen normally uses.
-#
-# Note: Only use a user-defined header if you know what you are doing!
-# Note: The header is subject to change so you typically have to regenerate the
-# default header when upgrading to a newer version of doxygen. The following
-# commands have a special meaning inside the header (and footer): For a
-# description of the possible markers and block names see the documentation.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_HEADER           =
-
-# The LATEX_FOOTER tag can be used to specify a user-defined LaTeX footer for
-# the generated LaTeX document. The footer should contain everything after the
-# last chapter. If it is left blank doxygen will generate a standard footer. See
-# LATEX_HEADER for more information on how to generate a default footer and what
-# special commands can be used inside the footer. See also section "Doxygen
-# usage" for information on how to generate the default footer that doxygen
-# normally uses. Note: Only use a user-defined footer if you know what you are
-# doing!
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_FOOTER           =
-
-# The LATEX_EXTRA_STYLESHEET tag can be used to specify additional user-defined
-# LaTeX style sheets that are included after the standard style sheets created
-# by doxygen. Using this option one can overrule certain style aspects. Doxygen
-# will copy the style sheet files to the output directory.
-# Note: The order of the extra style sheet files is of importance (e.g. the last
-# style sheet in the list overrules the setting of the previous ones in the
-# list).
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_EXTRA_STYLESHEET =
-
-# The LATEX_EXTRA_FILES tag can be used to specify one or more extra images or
-# other source files which should be copied to the LATEX_OUTPUT output
-# directory. Note that the files will be copied as-is; there are no commands or
-# markers available.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_EXTRA_FILES      =
-
-# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated is
-# prepared for conversion to PDF (using ps2pdf or pdflatex). The PDF file will
-# contain links (just like the HTML output) instead of page references. This
-# makes the output suitable for online browsing using a PDF viewer.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-PDF_HYPERLINKS         = YES
-
-# If the USE_PDFLATEX tag is set to YES, doxygen will use the engine as
-# specified with LATEX_CMD_NAME to generate the PDF file directly from the LaTeX
-# files. Set this option to YES, to get a higher quality PDF documentation.
-#
-# See also section LATEX_CMD_NAME for selecting the engine.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-USE_PDFLATEX           = YES
-
-# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \batchmode
-# command to the generated LaTeX files. This will instruct LaTeX to keep running
-# if errors occur, instead of asking the user for help.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_BATCHMODE        = NO
-
-# If the LATEX_HIDE_INDICES tag is set to YES then doxygen will not include the
-# index chapters (such as File Index, Compound Index, etc.) in the output.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_HIDE_INDICES     = NO
-
-# The LATEX_BIB_STYLE tag can be used to specify the style to use for the
-# bibliography, e.g. plainnat, or ieeetr. See
-# https://en.wikipedia.org/wiki/BibTeX and \cite for more info.
-# The default value is: plain.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_BIB_STYLE        = plain
-
-# If the LATEX_TIMESTAMP tag is set to YES then the footer of each generated
-# page will contain the date and time when the page was generated. Setting this
-# to NO can help when comparing the output of multiple runs.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_TIMESTAMP        = NO
-
-# The LATEX_EMOJI_DIRECTORY tag is used to specify the (relative or absolute)
-# path from which the emoji images will be read. If a relative path is entered,
-# it will be relative to the LATEX_OUTPUT directory. If left blank the
-# LATEX_OUTPUT directory will be used.
-# This tag requires that the tag GENERATE_LATEX is set to YES.
-
-LATEX_EMOJI_DIRECTORY  =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the RTF output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_RTF tag is set to YES, doxygen will generate RTF output. The
-# RTF output is optimized for Word 97 and may not look too pretty with other RTF
-# readers/editors.
-# The default value is: NO.
-
-GENERATE_RTF           = NO
-
-# The RTF_OUTPUT tag is used to specify where the RTF docs will be put. If a
-# relative path is entered the value of OUTPUT_DIRECTORY will be put in front of
-# it.
-# The default directory is: rtf.
-# This tag requires that the tag GENERATE_RTF is set to YES.
-
-RTF_OUTPUT             = rtf
-
-# If the COMPACT_RTF tag is set to YES, doxygen generates more compact RTF
-# documents. This may be useful for small projects and may help to save some
-# trees in general.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_RTF is set to YES.
-
-COMPACT_RTF            = NO
-
-# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated will
-# contain hyperlink fields. The RTF file will contain links (just like the HTML
-# output) instead of page references. This makes the output suitable for online
-# browsing using Word or some other Word compatible readers that support those
-# fields.
-#
-# Note: WordPad (write) and others do not support links.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_RTF is set to YES.
-
-RTF_HYPERLINKS         = NO
-
-# Load stylesheet definitions from file. Syntax is similar to doxygen's
-# configuration file, i.e. a series of assignments. You only have to provide
-# replacements, missing definitions are set to their default value.
-#
-# See also section "Doxygen usage" for information on how to generate the
-# default style sheet that doxygen normally uses.
-# This tag requires that the tag GENERATE_RTF is set to YES.
-
-RTF_STYLESHEET_FILE    =
-
-# Set optional variables used in the generation of an RTF document. Syntax is
-# similar to doxygen's configuration file. A template extensions file can be
-# generated using doxygen -e rtf extensionFile.
-# This tag requires that the tag GENERATE_RTF is set to YES.
-
-RTF_EXTENSIONS_FILE    =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the man page output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_MAN tag is set to YES, doxygen will generate man pages for
-# classes and files.
-# The default value is: NO.
-
-GENERATE_MAN           = NO
-
-# The MAN_OUTPUT tag is used to specify where the man pages will be put. If a
-# relative path is entered the value of OUTPUT_DIRECTORY will be put in front of
-# it. A directory man3 will be created inside the directory specified by
-# MAN_OUTPUT.
-# The default directory is: man.
-# This tag requires that the tag GENERATE_MAN is set to YES.
-
-MAN_OUTPUT             = man
-
-# The MAN_EXTENSION tag determines the extension that is added to the generated
-# man pages. In case the manual section does not start with a number, the number
-# 3 is prepended. The dot (.) at the beginning of the MAN_EXTENSION tag is
-# optional.
-# The default value is: .3.
-# This tag requires that the tag GENERATE_MAN is set to YES.
-
-MAN_EXTENSION          = .3
-
-# The MAN_SUBDIR tag determines the name of the directory created within
-# MAN_OUTPUT in which the man pages are placed. If defaults to man followed by
-# MAN_EXTENSION with the initial . removed.
-# This tag requires that the tag GENERATE_MAN is set to YES.
-
-MAN_SUBDIR             =
-
-# If the MAN_LINKS tag is set to YES and doxygen generates man output, then it
-# will generate one additional man file for each entity documented in the real
-# man page(s). These additional files only source the real man page, but without
-# them the man command would be unable to find the correct page.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_MAN is set to YES.
-
-MAN_LINKS              = NO
-
-#---------------------------------------------------------------------------
-# Configuration options related to the XML output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_XML tag is set to YES, doxygen will generate an XML file that
-# captures the structure of the code including all documentation.
-# The default value is: NO.
-
-GENERATE_XML           = NO
-
-# The XML_OUTPUT tag is used to specify where the XML pages will be put. If a
-# relative path is entered the value of OUTPUT_DIRECTORY will be put in front of
-# it.
-# The default directory is: xml.
-# This tag requires that the tag GENERATE_XML is set to YES.
-
-XML_OUTPUT             = xml
-
-# If the XML_PROGRAMLISTING tag is set to YES, doxygen will dump the program
-# listings (including syntax highlighting and cross-referencing information) to
-# the XML output. Note that enabling this will significantly increase the size
-# of the XML output.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_XML is set to YES.
-
-XML_PROGRAMLISTING     = YES
-
-# If the XML_NS_MEMB_FILE_SCOPE tag is set to YES, doxygen will include
-# namespace members in file scope as well, matching the HTML output.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_XML is set to YES.
-
-XML_NS_MEMB_FILE_SCOPE = NO
-
-#---------------------------------------------------------------------------
-# Configuration options related to the DOCBOOK output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_DOCBOOK tag is set to YES, doxygen will generate Docbook files
-# that can be used to generate PDF.
-# The default value is: NO.
-
-GENERATE_DOCBOOK       = NO
-
-# The DOCBOOK_OUTPUT tag is used to specify where the Docbook pages will be put.
-# If a relative path is entered the value of OUTPUT_DIRECTORY will be put in
-# front of it.
-# The default directory is: docbook.
-# This tag requires that the tag GENERATE_DOCBOOK is set to YES.
-
-DOCBOOK_OUTPUT         = docbook
-
-#---------------------------------------------------------------------------
-# Configuration options for the AutoGen Definitions output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_AUTOGEN_DEF tag is set to YES, doxygen will generate an
-# AutoGen Definitions (see http://autogen.sourceforge.net/) file that captures
-# the structure of the code including all documentation. Note that this feature
-# is still experimental and incomplete at the moment.
-# The default value is: NO.
-
-GENERATE_AUTOGEN_DEF   = NO
-
-#---------------------------------------------------------------------------
-# Configuration options related to the Perl module output
-#---------------------------------------------------------------------------
-
-# If the GENERATE_PERLMOD tag is set to YES, doxygen will generate a Perl module
-# file that captures the structure of the code including all documentation.
-#
-# Note that this feature is still experimental and incomplete at the moment.
-# The default value is: NO.
-
-GENERATE_PERLMOD       = NO
-
-# If the PERLMOD_LATEX tag is set to YES, doxygen will generate the necessary
-# Makefile rules, Perl scripts and LaTeX code to be able to generate PDF and DVI
-# output from the Perl module output.
-# The default value is: NO.
-# This tag requires that the tag GENERATE_PERLMOD is set to YES.
-
-PERLMOD_LATEX          = NO
-
-# If the PERLMOD_PRETTY tag is set to YES, the Perl module output will be nicely
-# formatted so it can be parsed by a human reader. This is useful if you want to
-# understand what is going on. On the other hand, if this tag is set to NO, the
-# size of the Perl module output will be much smaller and Perl will parse it
-# just the same.
-# The default value is: YES.
-# This tag requires that the tag GENERATE_PERLMOD is set to YES.
-
-PERLMOD_PRETTY         = YES
-
-# The names of the make variables in the generated doxyrules.make file are
-# prefixed with the string contained in PERLMOD_MAKEVAR_PREFIX. This is useful
-# so different doxyrules.make files included by the same Makefile don't
-# overwrite each other's variables.
-# This tag requires that the tag GENERATE_PERLMOD is set to YES.
-
-PERLMOD_MAKEVAR_PREFIX =
-
-#---------------------------------------------------------------------------
-# Configuration options related to the preprocessor
-#---------------------------------------------------------------------------
-
-# If the ENABLE_PREPROCESSING tag is set to YES, doxygen will evaluate all
-# C-preprocessor directives found in the sources and include files.
-# The default value is: YES.
-
-ENABLE_PREPROCESSING   = YES
-
-# If the MACRO_EXPANSION tag is set to YES, doxygen will expand all macro names
-# in the source code. If set to NO, only conditional compilation will be
-# performed. Macro expansion can be done in a controlled way by setting
-# EXPAND_ONLY_PREDEF to YES.
-# The default value is: NO.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-MACRO_EXPANSION        = NO
-
-# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES then
-# the macro expansion is limited to the macros specified with the PREDEFINED and
-# EXPAND_AS_DEFINED tags.
-# The default value is: NO.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-EXPAND_ONLY_PREDEF     = NO
-
-# If the SEARCH_INCLUDES tag is set to YES, the include files in the
-# INCLUDE_PATH will be searched if a #include is found.
-# The default value is: YES.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-SEARCH_INCLUDES        = YES
-
-# The INCLUDE_PATH tag can be used to specify one or more directories that
-# contain include files that are not input files but should be processed by the
-# preprocessor. Note that the INCLUDE_PATH is not recursive, so the setting of
-# RECURSIVE has no effect here.
-# This tag requires that the tag SEARCH_INCLUDES is set to YES.
-
-INCLUDE_PATH           =
-
-# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard
-# patterns (like *.h and *.hpp) to filter out the header-files in the
-# directories. If left blank, the patterns specified with FILE_PATTERNS will be
-# used.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-INCLUDE_FILE_PATTERNS  =
-
-# The PREDEFINED tag can be used to specify one or more macro names that are
-# defined before the preprocessor is started (similar to the -D option of e.g.
-# gcc). The argument of the tag is a list of macros of the form: name or
-# name=definition (no spaces). If the definition and the "=" are omitted, "=1"
-# is assumed. To prevent a macro definition from being undefined via #undef or
-# recursively expanded use the := operator instead of the = operator.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-PREDEFINED             = BORNAGAIN_PYTHON \
-                         SWIG \
-                         USER_API
-
-# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then this
-# tag can be used to specify a list of macro names that should be expanded. The
-# macro definition that is found in the sources will be used. Use the PREDEFINED
-# tag if you want to use a different macro definition that overrules the
-# definition found in the source code.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-EXPAND_AS_DEFINED      =
-
-# If the SKIP_FUNCTION_MACROS tag is set to YES then doxygen's preprocessor will
-# remove all references to function-like macros that are alone on a line, have
-# an all uppercase name, and do not end with a semicolon. Such function macros
-# are typically used for boiler-plate code, and will confuse the parser if not
-# removed.
-# The default value is: YES.
-# This tag requires that the tag ENABLE_PREPROCESSING is set to YES.
-
-SKIP_FUNCTION_MACROS   = YES
-
-#---------------------------------------------------------------------------
-# Configuration options related to external references
-#---------------------------------------------------------------------------
-
-# The TAGFILES tag can be used to specify one or more tag files. For each tag
-# file the location of the external documentation should be added. The format of
-# a tag file without this location is as follows:
-# TAGFILES = file1 file2 ...
-# Adding location for the tag files is done as follows:
-# TAGFILES = file1=loc1 "file2 = loc2" ...
-# where loc1 and loc2 can be relative or absolute paths or URLs. See the
-# section "Linking to external documentation" for more information about the use
-# of tag files.
-# Note: Each tag file must have a unique name (where the name does NOT include
-# the path). If a tag file is not located in the directory in which doxygen is
-# run, you must also specify the path to the tagfile here.
-
-TAGFILES               =
-
-# When a file name is specified after GENERATE_TAGFILE, doxygen will create a
-# tag file that is based on the input files it reads. See section "Linking to
-# external documentation" for more information about the usage of tag files.
-
-GENERATE_TAGFILE       =
-
-# If the ALLEXTERNALS tag is set to YES, all external class will be listed in
-# the class index. If set to NO, only the inherited external classes will be
-# listed.
-# The default value is: NO.
-
-ALLEXTERNALS           = NO
-
-# If the EXTERNAL_GROUPS tag is set to YES, all external groups will be listed
-# in the modules index. If set to NO, only the current project's groups will be
-# listed.
-# The default value is: YES.
-
-EXTERNAL_GROUPS        = NO
-
-# If the EXTERNAL_PAGES tag is set to YES, all external pages will be listed in
-# the related pages index. If set to NO, only the current project's pages will
-# be listed.
-# The default value is: YES.
-
-EXTERNAL_PAGES         = YES
-
-#---------------------------------------------------------------------------
-# Configuration options related to the dot tool
-#---------------------------------------------------------------------------
-
-# You can include diagrams made with dia in doxygen documentation. Doxygen will
-# then run dia to produce the diagram and insert it in the documentation. The
-# DIA_PATH tag allows you to specify the directory where the dia binary resides.
-# If left empty dia is assumed to be found in the default search path.
-
-DIA_PATH               =
-
-# If set to YES the inheritance and collaboration graphs will hide inheritance
-# and usage relations if the target is undocumented or is not a class.
-# The default value is: YES.
-
-HIDE_UNDOC_RELATIONS   = YES
-
-# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is
-# available from the path. This tool is part of Graphviz (see:
-# http://www.graphviz.org/), a graph visualization toolkit from AT&T and Lucent
-# Bell Labs. The other options in this section have no effect if this option is
-# set to NO
-# The default value is: YES.
-
-HAVE_DOT               = YES
-
-# The DOT_NUM_THREADS specifies the number of dot invocations doxygen is allowed
-# to run in parallel. When set to 0 doxygen will base this on the number of
-# processors available in the system. You can set it explicitly to a value
-# larger than 0 to get control over the balance between CPU load and processing
-# speed.
-# Minimum value: 0, maximum value: 32, default value: 0.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_NUM_THREADS        = 0
-
-# When you want a differently looking font in the dot files that doxygen
-# generates you can specify the font name using DOT_FONTNAME. You need to make
-# sure dot is able to find the font, which can be done by putting it in a
-# standard location or by setting the DOTFONTPATH environment variable or by
-# setting DOT_FONTPATH to the directory containing the font.
-# The default value is: Helvetica.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_FONTNAME           = Helvetica
-
-# The DOT_FONTSIZE tag can be used to set the size (in points) of the font of
-# dot graphs.
-# Minimum value: 4, maximum value: 24, default value: 10.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_FONTSIZE           = 10
-
-# By default doxygen will tell dot to use the default font as specified with
-# DOT_FONTNAME. If you specify a different font using DOT_FONTNAME you can set
-# the path where dot can find it using this tag.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_FONTPATH           =
-
-# If the CLASS_GRAPH tag is set to YES (or GRAPH) then doxygen will generate a
-# graph for each documented class showing the direct and indirect inheritance
-# relations. In case HAVE_DOT is set as well dot will be used to draw the graph,
-# otherwise the built-in generator will be used. If the CLASS_GRAPH tag is set
-# to TEXT the direct and indirect inheritance relations will be shown as texts /
-# links.
-# Possible values are: NO, YES, TEXT and GRAPH.
-# The default value is: YES.
-
-CLASS_GRAPH            = YES
-
-# If the COLLABORATION_GRAPH tag is set to YES then doxygen will generate a
-# graph for each documented class showing the direct and indirect implementation
-# dependencies (inheritance, containment, and class references variables) of the
-# class with other documented classes.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-COLLABORATION_GRAPH    = NO
-
-# If the GROUP_GRAPHS tag is set to YES then doxygen will generate a graph for
-# groups, showing the direct groups dependencies. See also the chapter Grouping
-# in the manual.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-GROUP_GRAPHS           = NO
-
-# If the UML_LOOK tag is set to YES, doxygen will generate inheritance and
-# collaboration diagrams in a style similar to the OMG's Unified Modeling
-# Language.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-UML_LOOK               = NO
-
-# If the UML_LOOK tag is enabled, the fields and methods are shown inside the
-# class node. If there are many fields or methods and many nodes the graph may
-# become too big to be useful. The UML_LIMIT_NUM_FIELDS threshold limits the
-# number of items for each type to make the size more manageable. Set this to 0
-# for no limit. Note that the threshold may be exceeded by 50% before the limit
-# is enforced. So when you set the threshold to 10, up to 15 fields may appear,
-# but if the number exceeds 15, the total amount of fields shown is limited to
-# 10.
-# Minimum value: 0, maximum value: 100, default value: 10.
-# This tag requires that the tag UML_LOOK is set to YES.
-
-UML_LIMIT_NUM_FIELDS   = 10
-
-# If the DOT_UML_DETAILS tag is set to NO, doxygen will show attributes and
-# methods without types and arguments in the UML graphs. If the DOT_UML_DETAILS
-# tag is set to YES, doxygen will add type and arguments for attributes and
-# methods in the UML graphs. If the DOT_UML_DETAILS tag is set to NONE, doxygen
-# will not generate fields with class member information in the UML graphs. The
-# class diagrams will look similar to the default class diagrams but using UML
-# notation for the relationships.
-# Possible values are: NO, YES and NONE.
-# The default value is: NO.
-# This tag requires that the tag UML_LOOK is set to YES.
-
-DOT_UML_DETAILS        = NO
-
-# The DOT_WRAP_THRESHOLD tag can be used to set the maximum number of characters
-# to display on a single line. If the actual line length exceeds this threshold
-# significantly it will wrapped across multiple lines. Some heuristics are apply
-# to avoid ugly line breaks.
-# Minimum value: 0, maximum value: 1000, default value: 17.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_WRAP_THRESHOLD     = 17
-
-# If the TEMPLATE_RELATIONS tag is set to YES then the inheritance and
-# collaboration graphs will show the relations between templates and their
-# instances.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-TEMPLATE_RELATIONS     = NO
-
-# If the INCLUDE_GRAPH, ENABLE_PREPROCESSING and SEARCH_INCLUDES tags are set to
-# YES then doxygen will generate a graph for each documented file showing the
-# direct and indirect include dependencies of the file with other documented
-# files.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-INCLUDE_GRAPH          = NO
-
-# If the INCLUDED_BY_GRAPH, ENABLE_PREPROCESSING and SEARCH_INCLUDES tags are
-# set to YES then doxygen will generate a graph for each documented file showing
-# the direct and indirect include dependencies of the file with other documented
-# files.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-INCLUDED_BY_GRAPH      = NO
-
-# If the CALL_GRAPH tag is set to YES then doxygen will generate a call
-# dependency graph for every global function or class method.
-#
-# Note that enabling this option will significantly increase the time of a run.
-# So in most cases it will be better to enable call graphs for selected
-# functions only using the \callgraph command. Disabling a call graph can be
-# accomplished by means of the command \hidecallgraph.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-CALL_GRAPH             = NO
-
-# If the CALLER_GRAPH tag is set to YES then doxygen will generate a caller
-# dependency graph for every global function or class method.
-#
-# Note that enabling this option will significantly increase the time of a run.
-# So in most cases it will be better to enable caller graphs for selected
-# functions only using the \callergraph command. Disabling a caller graph can be
-# accomplished by means of the command \hidecallergraph.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-CALLER_GRAPH           = NO
-
-# If the GRAPHICAL_HIERARCHY tag is set to YES then doxygen will graphical
-# hierarchy of all classes instead of a textual one.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-GRAPHICAL_HIERARCHY    = NO
-
-# If the DIRECTORY_GRAPH tag is set to YES then doxygen will show the
-# dependencies a directory has on other directories in a graphical way. The
-# dependency relations are determined by the #include relations between the
-# files in the directories.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DIRECTORY_GRAPH        = NO
-
-# The DIR_GRAPH_MAX_DEPTH tag can be used to limit the maximum number of levels
-# of child directories generated in directory dependency graphs by dot.
-# Minimum value: 1, maximum value: 25, default value: 1.
-# This tag requires that the tag DIRECTORY_GRAPH is set to YES.
-
-DIR_GRAPH_MAX_DEPTH    = 1
-
-# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images
-# generated by dot. For an explanation of the image formats see the section
-# output formats in the documentation of the dot tool (Graphviz (see:
-# http://www.graphviz.org/)).
-# Note: If you choose svg you need to set HTML_FILE_EXTENSION to xhtml in order
-# to make the SVG files visible in IE 9+ (other browsers do not have this
-# requirement).
-# Possible values are: png, jpg, jpg:cairo, jpg:cairo:gd, jpg:gd, jpg:gd:gd,
-# gif, gif:cairo, gif:cairo:gd, gif:gd, gif:gd:gd, svg, png:gd, png:gd:gd,
-# png:cairo, png:cairo:gd, png:cairo:cairo, png:cairo:gdiplus, png:gdiplus and
-# png:gdiplus:gdiplus.
-# The default value is: png.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_IMAGE_FORMAT       = svg
-
-# If DOT_IMAGE_FORMAT is set to svg, then this option can be set to YES to
-# enable generation of interactive SVG images that allow zooming and panning.
-#
-# Note that this requires a modern browser other than Internet Explorer. Tested
-# and working are Firefox, Chrome, Safari, and Opera.
-# Note: For IE 9+ you need to set HTML_FILE_EXTENSION to xhtml in order to make
-# the SVG files visible. Older versions of IE do not have SVG support.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-INTERACTIVE_SVG        = YES
-
-# The DOT_PATH tag can be used to specify the path where the dot tool can be
-# found. If left blank, it is assumed the dot tool can be found in the path.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_PATH               = @DOXYGEN_DOT_EXECUTABLE@
-
-# The DOTFILE_DIRS tag can be used to specify one or more directories that
-# contain dot files that are included in the documentation (see the \dotfile
-# command).
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOTFILE_DIRS           =
-
-# The MSCFILE_DIRS tag can be used to specify one or more directories that
-# contain msc files that are included in the documentation (see the \mscfile
-# command).
-
-MSCFILE_DIRS           =
-
-# The DIAFILE_DIRS tag can be used to specify one or more directories that
-# contain dia files that are included in the documentation (see the \diafile
-# command).
-
-DIAFILE_DIRS           =
-
-# When using plantuml, the PLANTUML_JAR_PATH tag should be used to specify the
-# path where java can find the plantuml.jar file or to the filename of jar file
-# to be used. If left blank, it is assumed PlantUML is not used or called during
-# a preprocessing step. Doxygen will generate a warning when it encounters a
-# \startuml command in this case and will not generate output for the diagram.
-
-PLANTUML_JAR_PATH      =
-
-# When using plantuml, the PLANTUML_CFG_FILE tag can be used to specify a
-# configuration file for plantuml.
-
-PLANTUML_CFG_FILE      =
-
-# When using plantuml, the specified paths are searched for files specified by
-# the !include statement in a plantuml block.
-
-PLANTUML_INCLUDE_PATH  =
-
-# The DOT_GRAPH_MAX_NODES tag can be used to set the maximum number of nodes
-# that will be shown in the graph. If the number of nodes in a graph becomes
-# larger than this value, doxygen will truncate the graph, which is visualized
-# by representing a node as a red box. Note that doxygen if the number of direct
-# children of the root node in a graph is already larger than
-# DOT_GRAPH_MAX_NODES then the graph will not be shown at all. Also note that
-# the size of a graph can be further restricted by MAX_DOT_GRAPH_DEPTH.
-# Minimum value: 0, maximum value: 10000, default value: 50.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_GRAPH_MAX_NODES    = 50
-
-# The MAX_DOT_GRAPH_DEPTH tag can be used to set the maximum depth of the graphs
-# generated by dot. A depth value of 3 means that only nodes reachable from the
-# root by following a path via at most 3 edges will be shown. Nodes that lay
-# further from the root node will be omitted. Note that setting this option to 1
-# or 2 may greatly reduce the computation time needed for large code bases. Also
-# note that the size of a graph can be further restricted by
-# DOT_GRAPH_MAX_NODES. Using a depth of 0 means no depth restriction.
-# Minimum value: 0, maximum value: 1000, default value: 0.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-MAX_DOT_GRAPH_DEPTH    = 0
-
-# Set the DOT_TRANSPARENT tag to YES to generate images with a transparent
-# background. This is disabled by default, because dot on Windows does not seem
-# to support this out of the box.
-#
-# Warning: Depending on the platform used, enabling this option may lead to
-# badly anti-aliased labels on the edges of a graph (i.e. they become hard to
-# read).
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_TRANSPARENT        = NO
-
-# Set the DOT_MULTI_TARGETS tag to YES to allow dot to generate multiple output
-# files in one run (i.e. multiple -o and -T options on the command line). This
-# makes dot run faster, but since only newer versions of dot (>1.8.10) support
-# this, this feature is disabled by default.
-# The default value is: NO.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-DOT_MULTI_TARGETS      = NO
-
-# If the GENERATE_LEGEND tag is set to YES doxygen will generate a legend page
-# explaining the meaning of the various boxes and arrows in the dot generated
-# graphs.
-# Note: This tag requires that UML_LOOK isn't set, i.e. the doxygen internal
-# graphical representation for inheritance and collaboration diagrams is used.
-# The default value is: YES.
-# This tag requires that the tag HAVE_DOT is set to YES.
-
-GENERATE_LEGEND        = NO
-
-# If the DOT_CLEANUP tag is set to YES, doxygen will remove the intermediate
-# files that are used to generate the various graphs.
-#
-# Note: This setting is not only used for dot files but also for msc temporary
-# files.
-# The default value is: YES.
-
-DOT_CLEANUP            = YES
diff --git a/Doc/Doxygen/user/layout.xml b/Doc/Doxygen/user/layout.xml
deleted file mode 100644
index b1137f2f4fed6d7cc51a1c002e81d406d2adbeb6..0000000000000000000000000000000000000000
--- a/Doc/Doxygen/user/layout.xml
+++ /dev/null
@@ -1,224 +0,0 @@
-<doxygenlayout version="1.0">
-  <!-- Generated by doxygen 1.9.1 -->
-  <!-- Navigation index tabs for HTML output -->
-  <navindex>
-    <tab type="mainpage" visible="yes" title=""/>
-    <tab type="pages" visible="yes" title="" intro=""/>
-    <tab type="modules" visible="no" title="" intro=""/>
-    <tab type="namespaces" visible="no" title="">
-      <tab type="namespacelist" visible="yes" title="" intro=""/>
-      <tab type="namespacemembers" visible="no" title="" intro=""/>
-    </tab>
-    <tab type="interfaces" visible="yes" title="">
-      <tab type="interfacelist" visible="yes" title="" intro=""/>
-      <tab type="interfaceindex" visible="$ALPHABETICAL_INDEX" title=""/>
-      <tab type="interfacehierarchy" visible="yes" title="" intro=""/>
-    </tab>
-    <tab type="classes" visible="yes" title="">
-      <tab type="classlist" visible="yes" title="" intro=""/>
-      <tab type="classindex" visible="$ALPHABETICAL_INDEX" title=""/>
-      <tab type="hierarchy" visible="yes" title="" intro=""/>
-      <tab type="classmembers" visible="yes" title="" intro=""/>
-    </tab>
-    <tab type="structs" visible="yes" title="">
-      <tab type="structlist" visible="yes" title="" intro=""/>
-      <tab type="structindex" visible="$ALPHABETICAL_INDEX" title=""/>
-    </tab>
-    <tab type="exceptions" visible="yes" title="">
-      <tab type="exceptionlist" visible="yes" title="" intro=""/>
-      <tab type="exceptionindex" visible="$ALPHABETICAL_INDEX" title=""/>
-      <tab type="exceptionhierarchy" visible="yes" title="" intro=""/>
-    </tab>
-    <tab type="files" visible="yes" title="">
-      <tab type="filelist" visible="yes" title="" intro=""/>
-      <tab type="globals" visible="yes" title="" intro=""/>
-    </tab>
-    <tab type="examples" visible="yes" title="" intro=""/>
-  </navindex>
-
-  <!-- Layout definition for a class page -->
-  <class>
-    <detaileddescription title="Description"/>
-    <includes visible="$SHOW_INCLUDE_FILES"/>
-    <inheritancegraph visible="$CLASS_GRAPH"/>
-    <collaborationgraph visible="$COLLABORATION_GRAPH"/>
-    <memberdecl>
-      <nestedclasses visible="yes" title=""/>
-      <publictypes title=""/>
-      <services title=""/>
-      <interfaces title=""/>
-      <publicslots title=""/>
-      <signals title=""/>
-      <publicmethods title=""/>
-      <publicstaticmethods title=""/>
-      <publicattributes title=""/>
-      <publicstaticattributes title=""/>
-      <protectedtypes title=""/>
-      <protectedslots title=""/>
-      <protectedmethods title=""/>
-      <protectedstaticmethods title=""/>
-      <protectedattributes title=""/>
-      <protectedstaticattributes title=""/>
-      <packagetypes title=""/>
-      <packagemethods title=""/>
-      <packagestaticmethods title=""/>
-      <packageattributes title=""/>
-      <packagestaticattributes title=""/>
-      <properties title=""/>
-      <events title=""/>
-      <privatetypes title=""/>
-      <privateslots title=""/>
-      <privatemethods title=""/>
-      <privatestaticmethods title=""/>
-      <privateattributes title=""/>
-      <privatestaticattributes title=""/>
-      <friends title=""/>
-      <related title="" subtitle=""/>
-      <membergroups visible="yes"/>
-    </memberdecl>
-    <memberdef>
-      <inlineclasses title=""/>
-      <typedefs title=""/>
-      <enums title=""/>
-      <services title=""/>
-      <interfaces title=""/>
-      <constructors title=""/>
-      <functions title=""/>
-      <related title=""/>
-      <variables title=""/>
-      <properties title=""/>
-      <events title=""/>
-    </memberdef>
-    <allmemberslink visible="yes"/>
-    <usedfiles visible="$SHOW_USED_FILES"/>
-    <authorsection visible="yes"/>
-  </class>
-
-  <!-- Layout definition for a namespace page -->
-  <namespace>
-    <briefdescription visible="yes"/>
-    <memberdecl>
-      <nestednamespaces visible="yes" title=""/>
-      <constantgroups visible="yes" title=""/>
-      <interfaces visible="yes" title=""/>
-      <classes visible="yes" title=""/>
-      <structs visible="yes" title=""/>
-      <exceptions visible="yes" title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <functions title=""/>
-      <variables title=""/>
-      <membergroups visible="yes"/>
-    </memberdecl>
-    <detaileddescription title=""/>
-    <memberdef>
-      <inlineclasses title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <functions title=""/>
-      <variables title=""/>
-    </memberdef>
-    <authorsection visible="yes"/>
-  </namespace>
-
-  <!-- Layout definition for a file page -->
-  <file>
-    <briefdescription visible="yes"/>
-    <includes visible="$SHOW_INCLUDE_FILES"/>
-    <includegraph visible="$INCLUDE_GRAPH"/>
-    <includedbygraph visible="$INCLUDED_BY_GRAPH"/>
-    <sourcelink visible="yes"/>
-    <memberdecl>
-      <interfaces visible="yes" title=""/>
-      <classes visible="yes" title=""/>
-      <structs visible="yes" title=""/>
-      <exceptions visible="yes" title=""/>
-      <namespaces visible="yes" title=""/>
-      <constantgroups visible="yes" title=""/>
-      <defines title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <functions title=""/>
-      <variables title=""/>
-      <membergroups visible="yes"/>
-    </memberdecl>
-    <detaileddescription title=""/>
-    <memberdef>
-      <inlineclasses title=""/>
-      <defines title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <functions title=""/>
-      <variables title=""/>
-    </memberdef>
-    <authorsection/>
-  </file>
-
-  <!-- Layout definition for a group page -->
-  <group>
-    <detaileddescription title="Description"/>
-    <groupgraph visible="$GROUP_GRAPHS"/>
-    <memberdecl>
-      <nestedgroups visible="yes" title=""/>
-      <dirs visible="yes" title=""/>
-      <files visible="yes" title=""/>
-      <namespaces visible="yes" title=""/>
-      <classes visible="yes" title=""/>
-      <defines title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <enumvalues title=""/>
-      <functions title=""/>
-      <variables title=""/>
-      <signals title=""/>
-      <publicslots title=""/>
-      <protectedslots title=""/>
-      <privateslots title=""/>
-      <events title=""/>
-      <properties title=""/>
-      <friends title=""/>
-      <membergroups visible="yes"/>
-    </memberdecl>
-    <memberdef>
-      <pagedocs/>
-      <inlineclasses title=""/>
-      <defines title=""/>
-      <typedefs title=""/>
-      <sequences title=""/>
-      <dictionaries title=""/>
-      <enums title=""/>
-      <enumvalues title=""/>
-      <functions title=""/>
-      <variables title=""/>
-      <signals title=""/>
-      <publicslots title=""/>
-      <protectedslots title=""/>
-      <privateslots title=""/>
-      <events title=""/>
-      <properties title=""/>
-      <friends title=""/>
-    </memberdef>
-    <authorsection visible="yes"/>
-  </group>
-
-  <!-- Layout definition for a directory page -->
-  <directory>
-    <briefdescription visible="yes"/>
-    <directorygraph visible="yes"/>
-    <memberdecl>
-      <dirs visible="yes"/>
-      <files visible="yes"/>
-    </memberdecl>
-    <detaileddescription title=""/>
-  </directory>
-</doxygenlayout>
diff --git a/Doc/Doxygen/user/mainpage.md b/Doc/Doxygen/user/mainpage.md
deleted file mode 100644
index b2f59567f451fdc9588930a49d0891d349cbd364..0000000000000000000000000000000000000000
--- a/Doc/Doxygen/user/mainpage.md
+++ /dev/null
@@ -1,63 +0,0 @@
-## BornAgain Python user reference {#mainpage}
-
-<a href="http://www.bornagainproject.org">BornAgain</a> is
-an open-source software to simulate and fit
-neutron and x-ray reflectometry and grazing-incidence small-angle scattering.
-
-
-The following structured list gives access to the documentation of
-all classes and functions that are needed for steering BornAgain
-through Python scripts.
-
-### Top-level
-
-* \ref simulation "Simulation"
-* \ref fitting "Fitting"
-
-### Instrument model
-
-* \ref beam "Beam and footprint"
-* \ref detector "Detector"
-  * \ref mask "Detector masks"
-* \ref background "Background"
-
-### Sample model
-
-* \ref materials "Materials"
-* \ref samples "Multilayer"
-* Distribution, decay, and interference functions
-  * \ref interference "Interference functions"
-  * \ref distributionFT  "Profiles"
-* \ref formfactors "Form factors"
-  * \ref hardParticle "Hard particles"
-  * \ref softParticle "Soft particles"
-  * \ref legacyGrating "Ripples"
-* \ref standard_samples "Standard samples"
-
-### Data and parameters
-
-* \ref input_output "Input and output"
-* \ref tools "Intensity tools" TODO: Sort differently
-* \ref paramDistribution "Parameter distributions"
-
-### See also
-
-* <https://bornagainproject.org>, project homepage;
-* <https://github.com/scgmlz/BornAgain>, source repository;
-
-### License
-
-[GNU General Public License v3 or higher](https://github.com/scgmlz/BornAgain/blob/master/COPYING)
-
-Copyright Forschungszentrum Jülich GmbH 2015-
-
-
-### Authors
-
-Scientific Computing Group at MLZ Garching.
-
-See file [AUTHORS](https://github.com/scgmlz/BornAgain/blob/master/AUTHORS).
-
-### Citation
-
-See file [CITATION](https://github.com/scgmlz/BornAgain/blob/master/CITATION).
diff --git a/Fit/Adapter/GSLLevenbergMarquardtMinimizer.h b/Fit/Adapter/GSLLevenbergMarquardtMinimizer.h
index 9e213a6fb3b82e484eec0fd349ad5e7a281e0517..2092e52305b0533b7c7b3bcdcb9f905f71ffb21e 100644
--- a/Fit/Adapter/GSLLevenbergMarquardtMinimizer.h
+++ b/Fit/Adapter/GSLLevenbergMarquardtMinimizer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_GSLLEVENBERGMARQUARDTMINIMIZER_H
 #define BORNAGAIN_FIT_ADAPTER_GSLLEVENBERGMARQUARDTMINIMIZER_H
 
@@ -65,4 +63,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_GSLLEVENBERGMARQUARDTMINIMIZER_H
-#endif // USER_API
diff --git a/Fit/Adapter/GSLMultiMinimizer.h b/Fit/Adapter/GSLMultiMinimizer.h
index 50cfe3a9cb3bb32cc50aa24dfbde5aea51add14a..3dd78265ec74efaa24a25d3ea9f59ec2067d9a3a 100644
--- a/Fit/Adapter/GSLMultiMinimizer.h
+++ b/Fit/Adapter/GSLMultiMinimizer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_GSLMULTIMINIMIZER_H
 #define BORNAGAIN_FIT_ADAPTER_GSLMULTIMINIMIZER_H
 
@@ -55,4 +53,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_GSLMULTIMINIMIZER_H
-#endif // USER_API
diff --git a/Fit/Adapter/GeneticMinimizer.h b/Fit/Adapter/GeneticMinimizer.h
index f262de411a3fd5edddbb4cd4caecc061eca0c157..b4b9390a70fe9d0180c916cf5264cef3d8a75f1c 100644
--- a/Fit/Adapter/GeneticMinimizer.h
+++ b/Fit/Adapter/GeneticMinimizer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_GENETICMINIMIZER_H
 #define BORNAGAIN_FIT_ADAPTER_GENETICMINIMIZER_H
 
@@ -72,4 +70,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_GENETICMINIMIZER_H
-#endif // USER_API
diff --git a/Fit/Adapter/IFunctionAdapter.h b/Fit/Adapter/IFunctionAdapter.h
index 2be5ba4ddf75a644abc11530c42401249786e5e9..db9dd0289cf6f980e47f25618df73fde168f8ad9 100644
--- a/Fit/Adapter/IFunctionAdapter.h
+++ b/Fit/Adapter/IFunctionAdapter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_IFUNCTIONADAPTER_H
 #define BORNAGAIN_FIT_ADAPTER_IFUNCTIONADAPTER_H
 
@@ -41,4 +39,3 @@ protected:
 } // namespace mumufit
 
 #endif // BORNAGAIN_FIT_ADAPTER_IFUNCTIONADAPTER_H
-#endif // USER_API
diff --git a/Fit/Adapter/MinimizerAdapter.h b/Fit/Adapter/MinimizerAdapter.h
index df74c6d649b86281d4167e8796e794fb286af805..89a71b225bb17d4637985eaafa4a7d895b5e5844 100644
--- a/Fit/Adapter/MinimizerAdapter.h
+++ b/Fit/Adapter/MinimizerAdapter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_MINIMIZERADAPTER_H
 #define BORNAGAIN_FIT_ADAPTER_MINIMIZERADAPTER_H
 
@@ -131,4 +129,3 @@ T MinimizerAdapter::optionValue(const std::string& optionName) const
 }
 
 #endif // BORNAGAIN_FIT_ADAPTER_MINIMIZERADAPTER_H
-#endif // USER_API
diff --git a/Fit/Adapter/Minuit2Minimizer.h b/Fit/Adapter/Minuit2Minimizer.h
index df0c9ee4fae0c700002e23466e998f2c5edf6b2c..16cea376be5365c0b74cf43eea0247c9630fea1d 100644
--- a/Fit/Adapter/Minuit2Minimizer.h
+++ b/Fit/Adapter/Minuit2Minimizer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_MINUIT2MINIMIZER_H
 #define BORNAGAIN_FIT_ADAPTER_MINUIT2MINIMIZER_H
 
@@ -85,4 +83,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_MINUIT2MINIMIZER_H
-#endif // USER_API
diff --git a/Fit/Adapter/ObjectiveFunctionAdapter.h b/Fit/Adapter/ObjectiveFunctionAdapter.h
index a9dfdc6935b09e70925cda88b860384ebcc8db3f..8e2565c582b8d2519ec8660c6ae41392dbad1189 100644
--- a/Fit/Adapter/ObjectiveFunctionAdapter.h
+++ b/Fit/Adapter/ObjectiveFunctionAdapter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_OBJECTIVEFUNCTIONADAPTER_H
 #define BORNAGAIN_FIT_ADAPTER_OBJECTIVEFUNCTIONADAPTER_H
 
@@ -54,4 +52,3 @@ private:
 } // namespace mumufit
 
 #endif // BORNAGAIN_FIT_ADAPTER_OBJECTIVEFUNCTIONADAPTER_H
-#endif // USER_API
diff --git a/Fit/Adapter/Report.h b/Fit/Adapter/Report.h
index 8b1d12089a2b2ab6397ac35f0c26111e6db2f8a4..351a6958ce6bc61a5e8a29eb5f48eee1ee3a4527 100644
--- a/Fit/Adapter/Report.h
+++ b/Fit/Adapter/Report.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_REPORT_H
 #define BORNAGAIN_FIT_ADAPTER_REPORT_H
 
@@ -34,4 +32,3 @@ std::string reportToString(const MinimizerAdapter& minimizer);
 } // namespace mumufit::internal
 
 #endif // BORNAGAIN_FIT_ADAPTER_REPORT_H
-#endif // USER_API
diff --git a/Fit/Adapter/ResidualFunctionAdapter.h b/Fit/Adapter/ResidualFunctionAdapter.h
index 4a9be343a3dda7840dc995185b06fa48af218b46..d47a8bec4b63ffb88ab946f75ffb6402d92f356e 100644
--- a/Fit/Adapter/ResidualFunctionAdapter.h
+++ b/Fit/Adapter/ResidualFunctionAdapter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_RESIDUALFUNCTIONADAPTER_H
 #define BORNAGAIN_FIT_ADAPTER_RESIDUALFUNCTIONADAPTER_H
 
@@ -62,4 +60,3 @@ private:
 } // namespace mumufit
 
 #endif // BORNAGAIN_FIT_ADAPTER_RESIDUALFUNCTIONADAPTER_H
-#endif // USER_API
diff --git a/Fit/Adapter/RootResidualFunction.h b/Fit/Adapter/RootResidualFunction.h
index e1ebe4a3528710bf440d475e0b28452c8c7480c3..65af33fdbf49a4c5a778cb54f8956a34a17697b1 100644
--- a/Fit/Adapter/RootResidualFunction.h
+++ b/Fit/Adapter/RootResidualFunction.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_ROOTRESIDUALFUNCTION_H
 #define BORNAGAIN_FIT_ADAPTER_ROOTRESIDUALFUNCTION_H
 
@@ -61,4 +59,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_ROOTRESIDUALFUNCTION_H
-#endif // USER_API
diff --git a/Fit/Adapter/RootScalarFunction.h b/Fit/Adapter/RootScalarFunction.h
index fd3db0b242dfa61cb994b10d28a355182c8d1894..4399bd8d8ade1e5fb2ace8b16ffee92f040ad1b0 100644
--- a/Fit/Adapter/RootScalarFunction.h
+++ b/Fit/Adapter/RootScalarFunction.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_ROOTSCALARFUNCTION_H
 #define BORNAGAIN_FIT_ADAPTER_ROOTSCALARFUNCTION_H
 
@@ -39,4 +37,3 @@ public:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_ROOTSCALARFUNCTION_H
-#endif // USER_API
diff --git a/Fit/Adapter/ScalarFunctionAdapter.h b/Fit/Adapter/ScalarFunctionAdapter.h
index bf72d50b1f6ecbb1bd4fdb94b88bcc821c7ac307..0894995ec5d1bec8ed793ede2105168d6696644a 100644
--- a/Fit/Adapter/ScalarFunctionAdapter.h
+++ b/Fit/Adapter/ScalarFunctionAdapter.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_SCALARFUNCTIONADAPTER_H
 #define BORNAGAIN_FIT_ADAPTER_SCALARFUNCTIONADAPTER_H
 
@@ -52,4 +50,3 @@ private:
 } // namespace mumufit
 
 #endif // BORNAGAIN_FIT_ADAPTER_SCALARFUNCTIONADAPTER_H
-#endif // USER_API
diff --git a/Fit/Adapter/SimAnMinimizer.h b/Fit/Adapter/SimAnMinimizer.h
index 38ad18b0befdecedbc56a187c972a89ffaf89fd9..0cd96315eddf7954aa64a13aae2f6f527dbac788 100644
--- a/Fit/Adapter/SimAnMinimizer.h
+++ b/Fit/Adapter/SimAnMinimizer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_ADAPTER_SIMANMINIMIZER_H
 #define BORNAGAIN_FIT_ADAPTER_SIMANMINIMIZER_H
 
@@ -78,4 +76,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_ADAPTER_SIMANMINIMIZER_H
-#endif // USER_API
diff --git a/Fit/Kernel/Kernel.h b/Fit/Kernel/Kernel.h
index 9067aaba3554177633551a83004876ea6a3e9410..a07877b34980687ab66f336b2d1b3a9563d7f46b 100644
--- a/Fit/Kernel/Kernel.h
+++ b/Fit/Kernel/Kernel.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_KERNEL_KERNEL_H
 #define BORNAGAIN_FIT_KERNEL_KERNEL_H
 
@@ -53,4 +51,3 @@ private:
 } // namespace mumufit
 
 #endif // BORNAGAIN_FIT_KERNEL_KERNEL_H
-#endif // USER_API
diff --git a/Fit/Minimizer/MinimizerCatalog.h b/Fit/Minimizer/MinimizerCatalog.h
index abd539f2bfacae802f417ea34cefdb7ffbd5f776..4d88c1a9f1e93e3eb6fb6bc1584734a1badce471 100644
--- a/Fit/Minimizer/MinimizerCatalog.h
+++ b/Fit/Minimizer/MinimizerCatalog.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_FIT_MINIMIZER_MINIMIZERCATALOG_H
 #define BORNAGAIN_FIT_MINIMIZER_MINIMIZERCATALOG_H
 
@@ -54,4 +53,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_MINIMIZER_MINIMIZERCATALOG_H
-#endif // USER_API
diff --git a/Fit/Minimizer/MinimizerInfo.h b/Fit/Minimizer/MinimizerInfo.h
index 565119adbb491ca2a4db5ef2f3d93815906f8920..89490e7d12acdd72e459891f86eb6465288eded7 100644
--- a/Fit/Minimizer/MinimizerInfo.h
+++ b/Fit/Minimizer/MinimizerInfo.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_FIT_MINIMIZER_MINIMIZERINFO_H
 #define BORNAGAIN_FIT_MINIMIZER_MINIMIZERINFO_H
 
@@ -78,4 +77,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_MINIMIZER_MINIMIZERINFO_H
-#endif // USER_API
diff --git a/Fit/Minimizer/MinimizerOptions.h b/Fit/Minimizer/MinimizerOptions.h
index c806b9b7a949e599d88790d41bade22ba2423386..8839f47db13b9d508b8548ad48aa35d13a1e862b 100644
--- a/Fit/Minimizer/MinimizerOptions.h
+++ b/Fit/Minimizer/MinimizerOptions.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_MINIMIZER_MINIMIZEROPTIONS_H
 #define BORNAGAIN_FIT_MINIMIZER_MINIMIZEROPTIONS_H
 
@@ -37,4 +35,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_MINIMIZER_MINIMIZEROPTIONS_H
-#endif // USER_API
diff --git a/Fit/Minimizer/Types.h b/Fit/Minimizer/Types.h
index 2ae44be5bbb4a88e9bc435bb952276645ed48aff..c1d79b536d0bc5d4f748486b56d2fda42cf72be2 100644
--- a/Fit/Minimizer/Types.h
+++ b/Fit/Minimizer/Types.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_MINIMIZER_TYPES_H
 #define BORNAGAIN_FIT_MINIMIZER_TYPES_H
 
@@ -41,4 +39,3 @@ using fcn_scalar_t = std::function<double(const mumufit::Parameters&)>;
 using fcn_residual_t = std::function<std::vector<double>(const mumufit::Parameters&)>;
 
 #endif // BORNAGAIN_FIT_MINIMIZER_TYPES_H
-#endif // USER_API
diff --git a/Fit/Param/Attributes.h b/Fit/Param/Attributes.h
index 497c874ddce5d954488155ddb91bc0b2903e11bf..00b9b7495ce2954c4f36300ee1a7b7eedc98750c 100644
--- a/Fit/Param/Attributes.h
+++ b/Fit/Param/Attributes.h
@@ -14,7 +14,6 @@
 
 // Swig: not %include'd, but #include'd
 
-#ifndef USER_API
 #ifndef BORNAGAIN_FIT_PARAM_ATTRIBUTES_H
 #define BORNAGAIN_FIT_PARAM_ATTRIBUTES_H
 
@@ -64,4 +63,3 @@ inline void Attributes::print(std::ostream& ostr) const
 }
 
 #endif // BORNAGAIN_FIT_PARAM_ATTRIBUTES_H
-#endif // USER_API
diff --git a/Fit/TestEngine/MinimizerTestPlan.h b/Fit/TestEngine/MinimizerTestPlan.h
index bd3c266a87b88d6c963350df5997d7400a27318f..921284b3b86b3a84601085c2c31fcae3dbdddd0f 100644
--- a/Fit/TestEngine/MinimizerTestPlan.h
+++ b/Fit/TestEngine/MinimizerTestPlan.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TESTENGINE_MINIMIZERTESTPLAN_H
 #define BORNAGAIN_FIT_TESTENGINE_MINIMIZERTESTPLAN_H
 
@@ -69,4 +67,3 @@ protected:
 };
 
 #endif // BORNAGAIN_FIT_TESTENGINE_MINIMIZERTESTPLAN_H
-#endif // USER_API
diff --git a/Fit/Tools/MinimizerUtils.h b/Fit/Tools/MinimizerUtils.h
index a60f7a858a3e56eea478653a9d0ee0a1adf0d0bd..38d076057f406bc9b1aff6d94f9bb5ff800323b1 100644
--- a/Fit/Tools/MinimizerUtils.h
+++ b/Fit/Tools/MinimizerUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TOOLS_MINIMIZERUTILS_H
 #define BORNAGAIN_FIT_TOOLS_MINIMIZERUTILS_H
 
@@ -41,4 +39,3 @@ std::string sectionString(const std::string& sectionName = "", size_t report_wid
 } // namespace mumufit::utils
 
 #endif // BORNAGAIN_FIT_TOOLS_MINIMIZERUTILS_H
-#endif // USER_API
diff --git a/Fit/Tools/MultiOption.h b/Fit/Tools/MultiOption.h
index c24bc393510e8c5a60c9ebc301f6dbaff792b0fd..4709f57c8aca256722966b3004f4ec4fe2ae15c9 100644
--- a/Fit/Tools/MultiOption.h
+++ b/Fit/Tools/MultiOption.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TOOLS_MULTIOPTION_H
 #define BORNAGAIN_FIT_TOOLS_MULTIOPTION_H
 
@@ -84,4 +82,3 @@ T MultiOption::getDefault() const
 }
 
 #endif // BORNAGAIN_FIT_TOOLS_MULTIOPTION_H
-#endif // USER_API
diff --git a/Fit/Tools/OptionContainer.h b/Fit/Tools/OptionContainer.h
index 44fce8139ee1b848e350b224c1457411570d901e..818a7451fe1652d32616ce185bbe4966cc938040 100644
--- a/Fit/Tools/OptionContainer.h
+++ b/Fit/Tools/OptionContainer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TOOLS_OPTIONCONTAINER_H
 #define BORNAGAIN_FIT_TOOLS_OPTIONCONTAINER_H
 
@@ -98,4 +96,3 @@ void OptionContainer::setOptionValue(const std::string& optionName, T value)
 }
 
 #endif // BORNAGAIN_FIT_TOOLS_OPTIONCONTAINER_H
-#endif // USER_API
diff --git a/Fit/Tools/StringUtils.h b/Fit/Tools/StringUtils.h
index 0889d56c3567524afe7fef84415c00ad6f458d98..6f99328efa325dc85f691c8d33fd6206cffe1eaf 100644
--- a/Fit/Tools/StringUtils.h
+++ b/Fit/Tools/StringUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TOOLS_STRINGUTILS_H
 #define BORNAGAIN_FIT_TOOLS_STRINGUTILS_H
 
@@ -47,4 +45,3 @@ std::string scientific(const T value, int n)
 } // namespace mumufit::stringUtils
 
 #endif // BORNAGAIN_FIT_TOOLS_STRINGUTILS_H
-#endif // USER_API
diff --git a/Fit/Tools/WallclockTimer.h b/Fit/Tools/WallclockTimer.h
index 8a893814673941d65d04fb4796ccbaa72dfd488d..25368afed2e2b4fac8c2ba50fcdd837dbacc1bfb 100644
--- a/Fit/Tools/WallclockTimer.h
+++ b/Fit/Tools/WallclockTimer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_FIT_TOOLS_WALLCLOCKTIMER_H
 #define BORNAGAIN_FIT_TOOLS_WALLCLOCKTIMER_H
 
@@ -42,4 +40,3 @@ private:
 };
 
 #endif // BORNAGAIN_FIT_TOOLS_WALLCLOCKTIMER_H
-#endif // USER_API
diff --git a/GUI/Model/Device/Instrument.h b/GUI/Model/Device/Instrument.h
index 7ab4fd26124718b9aab3b2dc0e048067a001ee9c..dcb8c0158f75e13257bf56d08208277c85a9127a 100644
--- a/GUI/Model/Device/Instrument.h
+++ b/GUI/Model/Device/Instrument.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_GUI_MODEL_DEVICE_INSTRUMENT_H
 #define BORNAGAIN_GUI_MODEL_DEVICE_INSTRUMENT_H
 
@@ -37,4 +36,3 @@ protected:
 };
 
 #endif // BORNAGAIN_GUI_MODEL_DEVICE_INSTRUMENT_H
-#endif // USER_API
diff --git a/Param/Distrib/DistributionHandler.h b/Param/Distrib/DistributionHandler.h
index 2008e17c69767768a1d97e0003fe69d6cd355915..3a7e607e726c7bb8c26cfc96cfa60e113cab49e6 100644
--- a/Param/Distrib/DistributionHandler.h
+++ b/Param/Distrib/DistributionHandler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_PARAM_DISTRIB_DISTRIBUTIONHANDLER_H
 #define BORNAGAIN_PARAM_DISTRIB_DISTRIBUTIONHANDLER_H
 
@@ -59,4 +57,3 @@ private:
 };
 
 #endif // BORNAGAIN_PARAM_DISTRIB_DISTRIBUTIONHANDLER_H
-#endif // USER_API
diff --git a/Param/Distrib/Distributions.h b/Param/Distrib/Distributions.h
index 48616f74d74a0b0bcb91dcd0ffe0a141f8fc4710..8414da5afe0765982456237e04144ca0222930c0 100644
--- a/Param/Distrib/Distributions.h
+++ b/Param/Distrib/Distributions.h
@@ -26,7 +26,6 @@ class ParameterSample;
 //  interface IDistribution1D
 //  ************************************************************************************************
 
-#ifndef USER_API
 
 //! Interface for one-dimensional distributions.
 
@@ -77,7 +76,6 @@ protected:
     generateSamplesFromValues(const std::vector<double>& sample_values) const;
 };
 
-#endif // USER_API
 
 //  ************************************************************************************************
 //  class DistributionGate
diff --git a/Param/Distrib/RangedDistributions.h b/Param/Distrib/RangedDistributions.h
index d5f80b21f63d525009234d58a4a141947b5a73c6..269773bb1167ab0fcb5c39abe6998b87fe8a5494 100644
--- a/Param/Distrib/RangedDistributions.h
+++ b/Param/Distrib/RangedDistributions.h
@@ -27,7 +27,6 @@ class ParameterSample;
 //  interface class IDistribution1D
 //  ************************************************************************************************
 
-#ifndef USER_API
 
 //! Interface for one-dimensional ranged distributions.
 //! All derived distributions
@@ -85,7 +84,6 @@ private:
     RealLimits m_limits;
 };
 
-#endif // USER_API
 
 //  ************************************************************************************************
 //  specific distribution classes
diff --git a/Param/Node/INode.h b/Param/Node/INode.h
index c5c1083f30901556477f2ee15ef939f71560b7e1..9a79969fbf664be01b038e66f571607dca4c757d 100644
--- a/Param/Node/INode.h
+++ b/Param/Node/INode.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_PARAM_NODE_INODE_H
 #define BORNAGAIN_PARAM_NODE_INODE_H
 
@@ -123,4 +122,3 @@ inline std::vector<const INode*>& operator<<(std::vector<const INode*>&& v_node,
 #endif // SWIG
 
 #endif // BORNAGAIN_PARAM_NODE_INODE_H
-#endif // USER_API
diff --git a/Param/Node/NodeUtils.h b/Param/Node/NodeUtils.h
index 3f39f1a3c11117b818c3c660a84de7162336a23b..12f0010a76c7a5bfb53991cc0b0577482d4c63bb 100644
--- a/Param/Node/NodeUtils.h
+++ b/Param/Node/NodeUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_PARAM_NODE_NODEUTILS_H
 #define BORNAGAIN_PARAM_NODE_NODEUTILS_H
 
@@ -64,4 +62,3 @@ std::vector<const T*> AllDescendantsOfType(const INode& node)
 } // namespace NodeUtils
 
 #endif // BORNAGAIN_PARAM_NODE_NODEUTILS_H
-#endif // USER_API
diff --git a/Resample/Coherence/CoheringSubparticles.h b/Resample/Coherence/CoheringSubparticles.h
index aa086657ea1173d119c2e94930f98eacb78742e3..742d51b0d9afb62a16cc4297dea8b1c2f9397266 100644
--- a/Resample/Coherence/CoheringSubparticles.h
+++ b/Resample/Coherence/CoheringSubparticles.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_COHERENCE_COHERINGSUBPARTICLES_H
 #define BORNAGAIN_RESAMPLE_COHERENCE_COHERINGSUBPARTICLES_H
 
@@ -49,4 +47,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_COHERENCE_COHERINGSUBPARTICLES_H
-#endif // USER_API
diff --git a/Resample/Element/DiffuseElement.h b/Resample/Element/DiffuseElement.h
index deda91f33ff67799dd1bc8f5a42e3f262cfd405f..8f896417410b9574f8c75af062937e362343b9ee 100644
--- a/Resample/Element/DiffuseElement.h
+++ b/Resample/Element/DiffuseElement.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_ELEMENT_DIFFUSEELEMENT_H
 #define BORNAGAIN_RESAMPLE_ELEMENT_DIFFUSEELEMENT_H
 
@@ -91,4 +89,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_ELEMENT_DIFFUSEELEMENT_H
-#endif // USER_API
diff --git a/Resample/Element/SpecularElement.h b/Resample/Element/SpecularElement.h
index b25c5465466101d629c0f9e4e87cf1e1e37422b0..03406a8896e520ccb60eea48cbf5a2abb777c288 100644
--- a/Resample/Element/SpecularElement.h
+++ b/Resample/Element/SpecularElement.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_ELEMENT_SPECULARELEMENT_H
 #define BORNAGAIN_RESAMPLE_ELEMENT_SPECULARELEMENT_H
 
@@ -62,4 +60,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_ELEMENT_SPECULARELEMENT_H
-#endif // USER_API
diff --git a/Resample/Flux/IFlux.h b/Resample/Flux/IFlux.h
index dd8e96a71c2655222ed370ada1f5762fc6b82ddf..bf28d2c2062c7b573ff16d802e8e1d783742a78f 100644
--- a/Resample/Flux/IFlux.h
+++ b/Resample/Flux/IFlux.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_FLUX_IFLUX_H
 #define BORNAGAIN_RESAMPLE_FLUX_IFLUX_H
 
@@ -47,4 +45,3 @@ public:
 class Fluxes : public OwningVector<IFlux> {};
 
 #endif // BORNAGAIN_RESAMPLE_FLUX_IFLUX_H
-#endif // USER_API
diff --git a/Resample/Flux/MatrixFlux.h b/Resample/Flux/MatrixFlux.h
index 2653224cabf7968bf2a0221b3fc03e27d13bfbf1..aefe82d966eddba19e8d93d9662438c55d117b83 100644
--- a/Resample/Flux/MatrixFlux.h
+++ b/Resample/Flux/MatrixFlux.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_FLUX_MATRIXFLUX_H
 #define BORNAGAIN_RESAMPLE_FLUX_MATRIXFLUX_H
 
@@ -72,4 +70,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_FLUX_MATRIXFLUX_H
-#endif // USER_API
diff --git a/Resample/Flux/ScalarFlux.h b/Resample/Flux/ScalarFlux.h
index 8ff88a9dc8b939ad8cdf31f7c3ed607e653c7e7e..56366a239e0ac449a8f09ae93e56e0a8db0ca24e 100644
--- a/Resample/Flux/ScalarFlux.h
+++ b/Resample/Flux/ScalarFlux.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_FLUX_SCALARFLUX_H
 #define BORNAGAIN_RESAMPLE_FLUX_SCALARFLUX_H
 
@@ -63,4 +61,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_FLUX_SCALARFLUX_H
-#endif // USER_API
diff --git a/Resample/Interparticle/DecouplingApproximationStrategy.h b/Resample/Interparticle/DecouplingApproximationStrategy.h
index 4d69b16fc28af943352c60b6880c3bc2f674533a..3d0ede0a8543743ed60773f99f7719159ffaf5f4 100644
--- a/Resample/Interparticle/DecouplingApproximationStrategy.h
+++ b/Resample/Interparticle/DecouplingApproximationStrategy.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_INTERPARTICLE_DECOUPLINGAPPROXIMATIONSTRATEGY_H
 #define BORNAGAIN_RESAMPLE_INTERPARTICLE_DECOUPLINGAPPROXIMATIONSTRATEGY_H
 
@@ -45,4 +43,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_INTERPARTICLE_DECOUPLINGAPPROXIMATIONSTRATEGY_H
-#endif // USER_API
diff --git a/Resample/Interparticle/IInterparticleStrategy.h b/Resample/Interparticle/IInterparticleStrategy.h
index 6f07fdd4dfedebb162896d73daab3877b764080d..266006bf123d8e11656b99941295f5da641b78f5 100644
--- a/Resample/Interparticle/IInterparticleStrategy.h
+++ b/Resample/Interparticle/IInterparticleStrategy.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_INTERPARTICLE_IINTERPARTICLESTRATEGY_H
 #define BORNAGAIN_RESAMPLE_INTERPARTICLE_IINTERPARTICLESTRATEGY_H
 
@@ -67,4 +65,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_INTERPARTICLE_IINTERPARTICLESTRATEGY_H
-#endif // USER_API
diff --git a/Resample/Interparticle/SSCAStrategy.h b/Resample/Interparticle/SSCAStrategy.h
index 3e8cded744bc1a296020b612bc27d6c1ffd7cab5..ff32076334164a8ad9fb4d7adf3f3fc339b9c381 100644
--- a/Resample/Interparticle/SSCAStrategy.h
+++ b/Resample/Interparticle/SSCAStrategy.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_INTERPARTICLE_SSCASTRATEGY_H
 #define BORNAGAIN_RESAMPLE_INTERPARTICLE_SSCASTRATEGY_H
 
@@ -48,4 +46,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_INTERPARTICLE_SSCASTRATEGY_H
-#endif // USER_API
diff --git a/Resample/Particle/IReParticle.h b/Resample/Particle/IReParticle.h
index db3f32b59904d99002589ed322d3601d2a311f12..0d9e0c9a6b40dc71c26bee4eb01e151b8df51638 100644
--- a/Resample/Particle/IReParticle.h
+++ b/Resample/Particle/IReParticle.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PARTICLE_IREPARTICLE_H
 #define BORNAGAIN_RESAMPLE_PARTICLE_IREPARTICLE_H
 
@@ -89,4 +87,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_PARTICLE_IREPARTICLE_H
-#endif // USER_API
diff --git a/Resample/Particle/ReCompound.h b/Resample/Particle/ReCompound.h
index 71e8cbf08d8a488b6470bc35bf242b337930d5e8..0ad67e1c4cf419af532ebb4c90cf2d1a35f28d08 100644
--- a/Resample/Particle/ReCompound.h
+++ b/Resample/Particle/ReCompound.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PARTICLE_RECOMPOUND_H
 #define BORNAGAIN_RESAMPLE_PARTICLE_RECOMPOUND_H
 
@@ -54,4 +52,3 @@ protected:
 };
 
 #endif // BORNAGAIN_RESAMPLE_PARTICLE_RECOMPOUND_H
-#endif // USER_API
diff --git a/Resample/Particle/ReMesocrystal.h b/Resample/Particle/ReMesocrystal.h
index e92922a5f89afd7f89a44623a4cbc022d65b9ece..50783f66de9db31e80df939c064df6b482fa47b0 100644
--- a/Resample/Particle/ReMesocrystal.h
+++ b/Resample/Particle/ReMesocrystal.h
@@ -14,8 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PARTICLE_REMESOCRYSTAL_H
 #define BORNAGAIN_RESAMPLE_PARTICLE_REMESOCRYSTAL_H
 
diff --git a/Resample/Particle/ReParticle.h b/Resample/Particle/ReParticle.h
index 39069f7f9747bc97bc2d057bc2c7bb4ed030d7b1..85e9a7f3ed9deab1e07901fccadbb48d734edd21 100644
--- a/Resample/Particle/ReParticle.h
+++ b/Resample/Particle/ReParticle.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PARTICLE_REPARTICLE_H
 #define BORNAGAIN_RESAMPLE_PARTICLE_REPARTICLE_H
 
@@ -69,4 +67,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_PARTICLE_REPARTICLE_H
-#endif // USER_API
diff --git a/Resample/Processed/ReLayout.h b/Resample/Processed/ReLayout.h
index 4bf1dc17cf184d73a91888c62e5acc0ab07fc2e4..f4a99993154a4d1f0f5975b326e8f208777c3869 100644
--- a/Resample/Processed/ReLayout.h
+++ b/Resample/Processed/ReLayout.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PROCESSED_RELAYOUT_H
 #define BORNAGAIN_RESAMPLE_PROCESSED_RELAYOUT_H
 
@@ -50,4 +48,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_PROCESSED_RELAYOUT_H
-#endif // USER_API
diff --git a/Resample/Processed/ReSample.h b/Resample/Processed/ReSample.h
index af73fa075924be7b2e2bf74fcece1cc1173efe57..66f14b49859949a6f7d7817c69c224fa63286c3f 100644
--- a/Resample/Processed/ReSample.h
+++ b/Resample/Processed/ReSample.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PROCESSED_RESAMPLE_H
 #define BORNAGAIN_RESAMPLE_PROCESSED_RESAMPLE_H
 
@@ -71,4 +69,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_PROCESSED_RESAMPLE_H
-#endif // USER_API
diff --git a/Resample/Processed/Slicer.h b/Resample/Processed/Slicer.h
index 219abe5f1bb0aeed397771dba6b3f0fa4914ef3c..ae3b5037aa401e1fb580bf71b83ee791a6a221a4 100644
--- a/Resample/Processed/Slicer.h
+++ b/Resample/Processed/Slicer.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_PROCESSED_SLICER_H
 #define BORNAGAIN_RESAMPLE_PROCESSED_SLICER_H
 
@@ -40,4 +38,3 @@ Span zSpan(const IParticle* particle);
 } // namespace Compute::Slicing
 
 #endif // BORNAGAIN_RESAMPLE_PROCESSED_SLICER_H
-#endif // USER_API
diff --git a/Resample/Slice/KzComputation.h b/Resample/Slice/KzComputation.h
index b6926f9592253c3d9007595c1ceae642992670a3..b4039c65c846038e475629347935af2ab4816b1b 100644
--- a/Resample/Slice/KzComputation.h
+++ b/Resample/Slice/KzComputation.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SLICE_KZCOMPUTATION_H
 #define BORNAGAIN_RESAMPLE_SLICE_KZCOMPUTATION_H
 
@@ -51,4 +49,3 @@ std::vector<complex_t> computeKzFromRefIndices(const SliceStack& slices, R3 k);
 } // namespace Compute::Kz
 
 #endif // BORNAGAIN_RESAMPLE_SLICE_KZCOMPUTATION_H
-#endif // USER_API
diff --git a/Resample/Slice/ProfileHelper.h b/Resample/Slice/ProfileHelper.h
index 349723914a0404a16b88d7bd4833a4cf7e0091f0..46cbb1abd17258953246f4c1cb733aced5f13439 100644
--- a/Resample/Slice/ProfileHelper.h
+++ b/Resample/Slice/ProfileHelper.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SLICE_PROFILEHELPER_H
 #define BORNAGAIN_RESAMPLE_SLICE_PROFILEHELPER_H
 
@@ -44,4 +42,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_SLICE_PROFILEHELPER_H
-#endif // USER_API
diff --git a/Resample/Slice/Slice.h b/Resample/Slice/Slice.h
index 3df5bff953081e98457d81e3e27584cdb2e27faa..53e9964e17d5bd8b6dc016f257e7b124d5b3597f 100644
--- a/Resample/Slice/Slice.h
+++ b/Resample/Slice/Slice.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SLICE_SLICE_H
 #define BORNAGAIN_RESAMPLE_SLICE_SLICE_H
 
@@ -67,4 +65,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_SLICE_SLICE_H
-#endif // USER_API
diff --git a/Resample/Slice/SliceStack.h b/Resample/Slice/SliceStack.h
index b7ee475cc31ca01ae1e7dcb85c6afece463df178..4a2a134c3179124547bc887938bea7f1e7bb239c 100644
--- a/Resample/Slice/SliceStack.h
+++ b/Resample/Slice/SliceStack.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SLICE_SLICESTACK_H
 #define BORNAGAIN_RESAMPLE_SLICE_SLICESTACK_H
 
@@ -61,4 +59,3 @@ private:
 };
 
 #endif // BORNAGAIN_RESAMPLE_SLICE_SLICESTACK_H
-#endif // USER_API
diff --git a/Resample/Slice/ZLimits.h b/Resample/Slice/ZLimits.h
index 5d26810d9d3f1faa1e039289c0341741045c9e74..c7fb210802d6b6cbfa0af5539b4920fb6ca91ecd 100644
--- a/Resample/Slice/ZLimits.h
+++ b/Resample/Slice/ZLimits.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SLICE_ZLIMITS_H
 #define BORNAGAIN_RESAMPLE_SLICE_ZLIMITS_H
 
@@ -56,4 +54,3 @@ bool operator==(const ZLimits& left, const ZLimits& right);
 bool operator!=(const ZLimits& left, const ZLimits& right);
 
 #endif // BORNAGAIN_RESAMPLE_SLICE_ZLIMITS_H
-#endif // USER_API
diff --git a/Resample/Specular/ComputeFluxMagnetic.h b/Resample/Specular/ComputeFluxMagnetic.h
index 256cac3e3b7930e9916599c08e0acfd1f64529fb..a5b99c7329c077ec753760fdc677a22ae9fc85a8 100644
--- a/Resample/Specular/ComputeFluxMagnetic.h
+++ b/Resample/Specular/ComputeFluxMagnetic.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXMAGNETIC_H
 #define BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXMAGNETIC_H
 
@@ -48,4 +46,3 @@ SpinMatrix topLayerR(const SliceStack& slices, const std::vector<complex_t>& kzs
 } // namespace Compute::SpecularMagnetic
 
 #endif // BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXMAGNETIC_H
-#endif // USER_API
diff --git a/Resample/Specular/ComputeFluxScalar.h b/Resample/Specular/ComputeFluxScalar.h
index 49683c1821669fe0e09722e35c320606908b393b..64d669cdd653228ef0011666878a8559413ac544 100644
--- a/Resample/Specular/ComputeFluxScalar.h
+++ b/Resample/Specular/ComputeFluxScalar.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXSCALAR_H
 #define BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXSCALAR_H
 
@@ -43,4 +41,3 @@ complex_t topLayerR(const SliceStack& slices, const std::vector<complex_t>& kz);
 } // namespace Compute::SpecularScalar
 
 #endif // BORNAGAIN_RESAMPLE_SPECULAR_COMPUTEFLUXSCALAR_H
-#endif // USER_API
diff --git a/Resample/Specular/TransitionMagneticNevot.h b/Resample/Specular/TransitionMagneticNevot.h
index 690c4bd81b2e10d555f36a0aafb105693f6d14a0..d44b3124675e5f80f48673959acd38263ac50bc4 100644
--- a/Resample/Specular/TransitionMagneticNevot.h
+++ b/Resample/Specular/TransitionMagneticNevot.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICNEVOT_H
 #define BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICNEVOT_H
 
@@ -39,4 +37,3 @@ std::pair<SpinMatrix, SpinMatrix> backwardsSubmatrices(const MatrixFlux& coeff_i
 }
 
 #endif // BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICNEVOT_H
-#endif // USER_API
diff --git a/Resample/Specular/TransitionMagneticTanh.h b/Resample/Specular/TransitionMagneticTanh.h
index 5461b001026a2cadf90bc693435e15056dcc79e4..6c0f24e1e59624b5c250e2ef35ad66c784e47279 100644
--- a/Resample/Specular/TransitionMagneticTanh.h
+++ b/Resample/Specular/TransitionMagneticTanh.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICTANH_H
 #define BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICTANH_H
 
@@ -39,4 +37,3 @@ std::pair<SpinMatrix, SpinMatrix> backwardsSubmatrices(const MatrixFlux& coeff_i
 }
 
 #endif // BORNAGAIN_RESAMPLE_SPECULAR_TRANSITIONMAGNETICTANH_H
-#endif // USER_API
diff --git a/Resample/Swig/MultiLayerFuncs.h b/Resample/Swig/MultiLayerFuncs.h
index a3b6279bd3f5539a8c7229dd74aabe167ea3fa15..6c1fb101a0dbae880cdb5cddec95c7e91573b196 100644
--- a/Resample/Swig/MultiLayerFuncs.h
+++ b/Resample/Swig/MultiLayerFuncs.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_RESAMPLE_SWIG_MULTILAYERFUNCS_H
 #define BORNAGAIN_RESAMPLE_SWIG_MULTILAYERFUNCS_H
 
@@ -39,4 +38,3 @@ std::pair<double, double> defaultMaterialProfileLimits(const MultiLayer& sample)
 } // namespace swigAPI
 
 #endif // BORNAGAIN_RESAMPLE_SWIG_MULTILAYERFUNCS_H
-#endif // USER_API
diff --git a/Sample/Aggregate/Interferences.h b/Sample/Aggregate/Interferences.h
index 744b5709e387024a1acdec6f1c746f1cfe7ea552..8ac831daddb217d0aea5584f864bce0e991fd2da 100644
--- a/Sample/Aggregate/Interferences.h
+++ b/Sample/Aggregate/Interferences.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_AGGREGATE_INTERFERENCES_H
 #define BORNAGAIN_SAMPLE_AGGREGATE_INTERFERENCES_H
 
@@ -30,4 +28,3 @@
 #include "Sample/Aggregate/InterferenceRadialParacrystal.h"
 
 #endif // BORNAGAIN_SAMPLE_AGGREGATE_INTERFERENCES_H
-#endif // USER_API
diff --git a/Sample/ComponentBuilder/FormFactorComponents.h b/Sample/ComponentBuilder/FormFactorComponents.h
index 3603ded1c6b1252b5ab962698d05361121ff758c..5ab10738f7b99af0cf5a605601816796209bbbc1 100644
--- a/Sample/ComponentBuilder/FormFactorComponents.h
+++ b/Sample/ComponentBuilder/FormFactorComponents.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_COMPONENTBUILDER_FORMFACTORCOMPONENTS_H
 #define BORNAGAIN_SAMPLE_COMPONENTBUILDER_FORMFACTORCOMPONENTS_H
 
@@ -32,4 +30,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_COMPONENTBUILDER_FORMFACTORCOMPONENTS_H
-#endif // USER_API
diff --git a/Sample/ComponentBuilder/IRegistry.h b/Sample/ComponentBuilder/IRegistry.h
index 7d9dd87a730c426d8c690da845a22f811383981f..430c2fc5da4e3985320bc91a5832c45b1fabd031 100644
--- a/Sample/ComponentBuilder/IRegistry.h
+++ b/Sample/ComponentBuilder/IRegistry.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_COMPONENTBUILDER_IREGISTRY_H
 #define BORNAGAIN_SAMPLE_COMPONENTBUILDER_IREGISTRY_H
 
@@ -61,4 +59,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_COMPONENTBUILDER_IREGISTRY_H
-#endif // USER_API
diff --git a/Sample/ComponentBuilder/Profile2DComponents.h b/Sample/ComponentBuilder/Profile2DComponents.h
index 362edaabf9eddaebd1f84946c88af53d547080c7..eb0dfc04651a662b773243d8a722258f43441c14 100644
--- a/Sample/ComponentBuilder/Profile2DComponents.h
+++ b/Sample/ComponentBuilder/Profile2DComponents.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_COMPONENTBUILDER_PROFILE2DCOMPONENTS_H
 #define BORNAGAIN_SAMPLE_COMPONENTBUILDER_PROFILE2DCOMPONENTS_H
 
@@ -32,4 +30,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_COMPONENTBUILDER_PROFILE2DCOMPONENTS_H
-#endif // USER_API
diff --git a/Sample/Correlations/IDistribution1DSampler.h b/Sample/Correlations/IDistribution1DSampler.h
index 073687619589857a05db2a8ec74d6332b8df1584..08819f1ffe65dbcafe404db7a15afae4a8c51422 100644
--- a/Sample/Correlations/IDistribution1DSampler.h
+++ b/Sample/Correlations/IDistribution1DSampler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION1DSAMPLER_H
 #define BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION1DSAMPLER_H
 
@@ -91,4 +89,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION1DSAMPLER_H
-#endif // USER_API
diff --git a/Sample/Correlations/IDistribution2DSampler.h b/Sample/Correlations/IDistribution2DSampler.h
index 9cbca8e25fce2db683caadee371ad6ab990226e9..ab83bc377b4f614f921865f14fc2fc4c7669dba2 100644
--- a/Sample/Correlations/IDistribution2DSampler.h
+++ b/Sample/Correlations/IDistribution2DSampler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION2DSAMPLER_H
 #define BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION2DSAMPLER_H
 
@@ -83,4 +81,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_CORRELATIONS_IDISTRIBUTION2DSAMPLER_H
-#endif // USER_API
diff --git a/Sample/Correlations/IPeakShape.h b/Sample/Correlations/IPeakShape.h
index 48114c44abc15c5ccb299bd4b67ce512063d75de..410b460465f708b62383733a1ad74deef6970c54 100644
--- a/Sample/Correlations/IPeakShape.h
+++ b/Sample/Correlations/IPeakShape.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_CORRELATIONS_IPEAKSHAPE_H
 #define BORNAGAIN_SAMPLE_CORRELATIONS_IPEAKSHAPE_H
 
@@ -186,4 +185,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_CORRELATIONS_IPEAKSHAPE_H
-#endif // USER_API
diff --git a/Sample/Correlations/Profiles1D.h b/Sample/Correlations/Profiles1D.h
index 2303a15a5cb7b5938415a98afad65e5ed5f3b1f2..7a0df0a0cdc5ef4055744af7689b483e631b9def 100644
--- a/Sample/Correlations/Profiles1D.h
+++ b/Sample/Correlations/Profiles1D.h
@@ -21,7 +21,6 @@
 #include "Sample/Correlations/IDistribution1DSampler.h"
 #endif // SWIG
 
-#ifndef USER_API
 
 //! Interface for a one-dimensional distribution, with normalization adjusted so that
 //! the Fourier transform standardizedFT(q) is a decay function that starts at standardizedFT(0)=1.
@@ -58,7 +57,6 @@ protected:
     const double& m_omega; //!< half-width
 };
 
-#endif // USER_API
 
 //! Exponential IProfile1D exp(-|omega*x|);
 //! its Fourier transform standardizedFT(q) is a Cauchy-Lorentzian starting at standardizedFT(0)=1.
diff --git a/Sample/Correlations/Profiles2D.h b/Sample/Correlations/Profiles2D.h
index becaa1a02fb73760671da58f598fe1f0a975c5ae..1d0036b3c60283619fb38f8d8be25f74711f84a2 100644
--- a/Sample/Correlations/Profiles2D.h
+++ b/Sample/Correlations/Profiles2D.h
@@ -22,7 +22,6 @@
 #include "Sample/Correlations/IDistribution2DSampler.h"
 #endif // SWIG
 
-#ifndef USER_API
 
 //! Interface for two-dimensional distributions in Fourier space.
 
@@ -68,7 +67,6 @@ protected:
     const double& m_gamma;   //!< direct-space orientation with respect to the first lattice vector
 };
 
-#endif // USER_API
 
 //! Two-dimensional Cauchy distribution in Fourier space;
 //! corresponds to a normalized exp(-r) in real space,
diff --git a/Sample/HardParticle/Bar.h b/Sample/HardParticle/Bar.h
index 24684684ab90e091b1092beef16b64eb99a25395..b37a13dd474129894d6a446da9c56c642b9a04ab 100644
--- a/Sample/HardParticle/Bar.h
+++ b/Sample/HardParticle/Bar.h
@@ -22,19 +22,14 @@
 class BarGauss : public IProfileRectangularRipple {
 public:
     BarGauss(double length, double width, double height);
-#ifndef USER_API
     BarGauss(std::vector<double> P);
     BarGauss* clone() const override;
-    std::string className() const final
-    {
-        return "BarGauss";
-    }
+    std::string className() const final { return "BarGauss"; }
 
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
     }
-#endif // USER_API
 
 private:
     complex_t factor_x(complex_t qx) const override;
@@ -45,18 +40,13 @@ private:
 class BarLorentz : public IProfileRectangularRipple {
 public:
     BarLorentz(double length, double width, double height);
-#ifndef USER_API
     BarLorentz(std::vector<double> P);
     BarLorentz* clone() const override;
-    std::string className() const final
-    {
-        return "BarLorentz";
-    }
+    std::string className() const final { return "BarLorentz"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
     }
-#endif // USER_API
 
 private:
     complex_t factor_x(complex_t qx) const override;
diff --git a/Sample/HardParticle/Cone.h b/Sample/HardParticle/Cone.h
index 97140bdae65b0f77ba51f24ebc6d1dd095edb4f9..16add2de96d4093d0b8121fa8e2c17cf6647e9af 100644
--- a/Sample/HardParticle/Cone.h
+++ b/Sample/HardParticle/Cone.h
@@ -23,45 +23,25 @@
 class Cone : public IFormFactor {
 public:
     Cone(double radius, double height, double alpha);
-#ifndef USER_API
     Cone(std::vector<double> P);
 
-    Cone* clone() const override
-    {
-        return new Cone(m_radius, m_height, m_alpha);
-    }
-    std::string className() const final
-    {
-        return "Cone";
-    }
+    Cone* clone() const override { return new Cone(m_radius, m_height, m_alpha); }
+    std::string className() const final { return "Cone"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Radius", "nm"}, {"Height", "nm"}, {"Alpha", "rad"}};
     }
 
-    double radius() const
-    {
-        return m_radius;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
+    double radius() const { return m_radius; }
+    double height() const { return m_height; }
+    double alpha() const { return m_alpha; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
     std::string validate() const override;
 
-#endif // USER_API
 
 private:
     const double& m_radius;
diff --git a/Sample/HardParticle/CosineRipple.h b/Sample/HardParticle/CosineRipple.h
index a36b71a9454a093b324644ed4d638dbaa11a92e9..5edf413c320eeaed3696ca5c304e73e1a1817a29 100644
--- a/Sample/HardParticle/CosineRipple.h
+++ b/Sample/HardParticle/CosineRipple.h
@@ -22,13 +22,9 @@
 class CosineRippleBox : public ICosineRipple {
 public:
     CosineRippleBox(double length, double width, double height);
-#ifndef USER_API
     CosineRippleBox(std::vector<double> P);
     CosineRippleBox* clone() const override;
-    std::string className() const final
-    {
-        return "CosineRippleBox";
-    }
+    std::string className() const final { return "CosineRippleBox"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
@@ -36,7 +32,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 //! The form factor for a cosine ripple, with Gaussian profile in elongation direction.
@@ -44,13 +39,9 @@ private:
 class CosineRippleGauss : public ICosineRipple {
 public:
     CosineRippleGauss(double length, double width, double height);
-#ifndef USER_API
     CosineRippleGauss(std::vector<double> P);
     CosineRippleGauss* clone() const override;
-    std::string className() const final
-    {
-        return "CosineRippleGauss";
-    }
+    std::string className() const final { return "CosineRippleGauss"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
@@ -58,7 +49,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 //! The form factor for a cosine ripple, with Lorentz form factor in elongation direction.
@@ -66,13 +56,9 @@ private:
 class CosineRippleLorentz : public ICosineRipple {
 public:
     CosineRippleLorentz(double length, double width, double height);
-#ifndef USER_API
     CosineRippleLorentz(std::vector<double> P);
     CosineRippleLorentz* clone() const override;
-    std::string className() const final
-    {
-        return "CosineRippleLorentz";
-    }
+    std::string className() const final { return "CosineRippleLorentz"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
@@ -80,7 +66,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_COSINERIPPLE_H
diff --git a/Sample/HardParticle/Cylinder.h b/Sample/HardParticle/Cylinder.h
index fbaa06b6aa982ddee3c013420534834eda544b75..c4526cda4c134203fb7b82e2358bf7d87b9e30c4 100644
--- a/Sample/HardParticle/Cylinder.h
+++ b/Sample/HardParticle/Cylinder.h
@@ -23,35 +23,16 @@
 class Cylinder : public IFormFactor {
 public:
     Cylinder(double radius, double height);
-#ifndef USER_API
     Cylinder(std::vector<double> P);
 
-    Cylinder* clone() const override
-    {
-        return new Cylinder(m_radius, m_height);
-    }
-    std::string className() const final
-    {
-        return "Cylinder";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Radius", "nm"}, {"Height", "nm"}};
-    }
+    Cylinder* clone() const override { return new Cylinder(m_radius, m_height); }
+    std::string className() const final { return "Cylinder"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Radius", "nm"}, {"Height", "nm"}}; }
 
-    double height() const
-    {
-        return m_height;
-    }
-    double radius() const
-    {
-        return m_radius;
-    }
+    double height() const { return m_height; }
+    double radius() const { return m_radius; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -60,7 +41,6 @@ public:
 private:
     const double& m_radius;
     const double& m_height;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_CYLINDER_H
diff --git a/Sample/HardParticle/EllipsoidalCylinder.h b/Sample/HardParticle/EllipsoidalCylinder.h
index f0e1da0fc359a64e6748b0f3d989126ee0ba15b6..150e1380d8061a904a87b5aa506a906cd2e9b174 100644
--- a/Sample/HardParticle/EllipsoidalCylinder.h
+++ b/Sample/HardParticle/EllipsoidalCylinder.h
@@ -23,34 +23,21 @@
 class EllipsoidalCylinder : public IFormFactor {
 public:
     EllipsoidalCylinder(double radius_x, double radius_y, double height);
-#ifndef USER_API
     EllipsoidalCylinder(std::vector<double> P);
 
     EllipsoidalCylinder* clone() const override
     {
         return new EllipsoidalCylinder(m_radius_x, m_radius_y, m_height);
     }
-    std::string className() const final
-    {
-        return "EllipsoidalCylinder";
-    }
+    std::string className() const final { return "EllipsoidalCylinder"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"RadiusX", "nm"}, {"RadiusY", "nm"}, {"Height", "nm"}};
     }
 
-    double radiusX() const
-    {
-        return m_radius_x;
-    }
-    double radiusY() const
-    {
-        return m_radius_y;
-    }
-    double height() const
-    {
-        return m_height;
-    }
+    double radiusX() const { return m_radius_x; }
+    double radiusY() const { return m_radius_y; }
+    double height() const { return m_height; }
 
     double radialExtension() const override;
 
@@ -62,7 +49,6 @@ private:
     const double& m_radius_x;
     const double& m_radius_y;
     const double& m_height;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_ELLIPSOIDALCYLINDER_H
diff --git a/Sample/HardParticle/HardParticles.h b/Sample/HardParticle/HardParticles.h
index b2d415e5bd294954dea8d0dfe773f0d59add005d..56d5981e021bd634efb979460f51926a6fb0cec5 100644
--- a/Sample/HardParticle/HardParticles.h
+++ b/Sample/HardParticle/HardParticles.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_HARDPARTICLE_HARDPARTICLES_H
 #define BORNAGAIN_SAMPLE_HARDPARTICLE_HARDPARTICLES_H
 
@@ -40,4 +38,3 @@
 #include "Sample/HardParticle/LongBoxLorentz.h"
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_HARDPARTICLES_H
-#endif // USER_API
diff --git a/Sample/HardParticle/HemiEllipsoid.h b/Sample/HardParticle/HemiEllipsoid.h
index 2dd28750a46937da2311984f236eff3c88bb8959..a8a75a6289181898580c8b1e7ff19b36c3786bf6 100644
--- a/Sample/HardParticle/HemiEllipsoid.h
+++ b/Sample/HardParticle/HemiEllipsoid.h
@@ -24,7 +24,6 @@
 class HemiEllipsoid : public IFormFactor {
 public:
     HemiEllipsoid(double radius_x, double radius_y, double height);
-#ifndef USER_API
     HemiEllipsoid(std::vector<double> P);
     ~HemiEllipsoid() override = default;
 
@@ -32,27 +31,15 @@ public:
     {
         return new HemiEllipsoid(m_radius_x, m_radius_y, m_height);
     }
-    std::string className() const final
-    {
-        return "HemiEllipsoid";
-    }
+    std::string className() const final { return "HemiEllipsoid"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"RadiusX", "nm"}, {"RadiusY", "nm"}, {"Height", "nm"}};
     }
 
-    double height() const
-    {
-        return m_height;
-    }
-    double radiusX() const
-    {
-        return m_radius_x;
-    }
-    double radiusY() const
-    {
-        return m_radius_y;
-    }
+    double height() const { return m_height; }
+    double radiusX() const { return m_radius_x; }
+    double radiusY() const { return m_radius_y; }
 
     double radialExtension() const override;
 
@@ -64,7 +51,6 @@ private:
     const double& m_radius_x;
     const double& m_radius_y;
     const double& m_height; //!< radius in +z direction
-#endif                      // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_HEMIELLIPSOID_H
diff --git a/Sample/HardParticle/HorizontalCylinder.h b/Sample/HardParticle/HorizontalCylinder.h
index 84df5812e2c4efa8cf690823e6c349cafeae67a4..cfd4e0d01086c17217d8a386482909c3dbec9503 100644
--- a/Sample/HardParticle/HorizontalCylinder.h
+++ b/Sample/HardParticle/HorizontalCylinder.h
@@ -24,43 +24,24 @@ class HorizontalCylinder : public IFormFactor {
 public:
     HorizontalCylinder(double radius, double length, double slice_bottom, double slice_top);
     HorizontalCylinder(double radius, double length);
-#ifndef USER_API
     HorizontalCylinder(std::vector<double> P);
 
     HorizontalCylinder* clone() const override
     {
         return new HorizontalCylinder(m_radius, m_length, m_slice_bottom, m_slice_top);
     }
-    std::string className() const final
-    {
-        return "HorizontalCylinder";
-    }
+    std::string className() const final { return "HorizontalCylinder"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Radius", "nm"}, {"Length", "nm"}, {"Slice_bottom", "nm"}, {"Slice_top", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double radius() const
-    {
-        return m_radius;
-    }
-    double slice_bottom() const
-    {
-        return m_slice_bottom;
-    }
-    double slice_top() const
-    {
-        return m_slice_top;
-    }
+    double length() const { return m_length; }
+    double radius() const { return m_radius; }
+    double slice_bottom() const { return m_slice_bottom; }
+    double slice_top() const { return m_slice_top; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -71,7 +52,6 @@ private:
     const double& m_length;
     const double& m_slice_bottom;
     const double& m_slice_top;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_HORIZONTALCYLINDER_H
diff --git a/Sample/HardParticle/IFormFactorPolyhedron.h b/Sample/HardParticle/IFormFactorPolyhedron.h
index aab6534fa319b791d8598ea391b0f5b4ac7138bb..a5359b483551b0715d3fc0bf8ad0365e4b7a109b 100644
--- a/Sample/HardParticle/IFormFactorPolyhedron.h
+++ b/Sample/HardParticle/IFormFactorPolyhedron.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPOLYHEDRON_H
 #define BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPOLYHEDRON_H
 
@@ -49,4 +48,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPOLYHEDRON_H
-#endif // USER_API
diff --git a/Sample/HardParticle/IFormFactorPrism.h b/Sample/HardParticle/IFormFactorPrism.h
index f14c2625406fd509d5905d89fa2e34c545fe5754..d2ad5b3d7e8f8cced8521601d6d60c6fc8604aeb 100644
--- a/Sample/HardParticle/IFormFactorPrism.h
+++ b/Sample/HardParticle/IFormFactorPrism.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPRISM_H
 #define BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPRISM_H
 
@@ -36,4 +35,3 @@ protected:
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_IFORMFACTORPRISM_H
-#endif // USER_API
diff --git a/Sample/HardParticle/IProfileRipple.h b/Sample/HardParticle/IProfileRipple.h
index fc305933837fedbface2bf3ee154fc2976115a8c..0682ade736a0fec223a54540bb0225ecd6042308 100644
--- a/Sample/HardParticle/IProfileRipple.h
+++ b/Sample/HardParticle/IProfileRipple.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_HARDPARTICLE_IPROFILERIPPLE_H
 #define BORNAGAIN_SAMPLE_HARDPARTICLE_IPROFILERIPPLE_H
 
@@ -78,4 +77,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_IPROFILERIPPLE_H
-#endif // USER_API
diff --git a/Sample/HardParticle/LongBoxGauss.h b/Sample/HardParticle/LongBoxGauss.h
index 5494c32c116763bc1d62b4a952a104df5ceb017f..c0361e3f73b9dd3b87ba915f2ff755047cb4a307 100644
--- a/Sample/HardParticle/LongBoxGauss.h
+++ b/Sample/HardParticle/LongBoxGauss.h
@@ -23,38 +23,19 @@
 class LongBoxGauss : public IFormFactor {
 public:
     LongBoxGauss(double length, double width, double height);
-#ifndef USER_API
     LongBoxGauss(std::vector<double> P);
 
-    LongBoxGauss* clone() const override
-    {
-        return new LongBoxGauss(m_length, m_width, m_height);
-    }
-    std::string className() const final
-    {
-        return "LongBoxGauss";
-    }
+    LongBoxGauss* clone() const override { return new LongBoxGauss(m_length, m_width, m_height); }
+    std::string className() const final { return "LongBoxGauss"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double width() const
-    {
-        return m_width;
-    }
-    double radialExtension() const override
-    {
-        return m_length / 2.0;
-    }
+    double length() const { return m_length; }
+    double height() const { return m_height; }
+    double width() const { return m_width; }
+    double radialExtension() const override { return m_length / 2.0; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -64,7 +45,6 @@ private:
     const double& m_length;
     const double& m_width;
     const double& m_height;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_LONGBOXGAUSS_H
diff --git a/Sample/HardParticle/LongBoxLorentz.h b/Sample/HardParticle/LongBoxLorentz.h
index d3e04a4d0961c5c15b469cc4775ccb9986f2fc9b..a3551b8c792fe567b76e8fde92fd725ddba92ea9 100644
--- a/Sample/HardParticle/LongBoxLorentz.h
+++ b/Sample/HardParticle/LongBoxLorentz.h
@@ -23,39 +23,23 @@
 class LongBoxLorentz : public IFormFactor {
 public:
     LongBoxLorentz(double length, double width, double height);
-#ifndef USER_API
     LongBoxLorentz(std::vector<double> P);
 
     LongBoxLorentz* clone() const override
     {
         return new LongBoxLorentz(m_length, m_width, m_height);
     }
-    std::string className() const final
-    {
-        return "LongBoxLorentz";
-    }
+    std::string className() const final { return "LongBoxLorentz"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double width() const
-    {
-        return m_width;
-    }
+    double length() const { return m_length; }
+    double height() const { return m_height; }
+    double width() const { return m_width; }
 
-    double radialExtension() const override
-    {
-        return m_length / 2.0;
-    }
+    double radialExtension() const override { return m_length / 2.0; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -65,7 +49,6 @@ private:
     const double& m_length;
     const double& m_width;
     const double& m_height;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_LONGBOXLORENTZ_H
diff --git a/Sample/HardParticle/Polyhedra.h b/Sample/HardParticle/Polyhedra.h
index 4179044e21fa384378ec3b99b127424f0b8ec4c2..fd57681850ecba6597493a7a5107a3d5095b6395 100644
--- a/Sample/HardParticle/Polyhedra.h
+++ b/Sample/HardParticle/Polyhedra.h
@@ -28,41 +28,24 @@
 class Box : public IFormFactorPrism {
 public:
     Box(double length, double width, double height);
-#ifndef USER_API
     Box(std::vector<double> P);
 
-    Box* clone() const override
-    {
-        return new Box(m_length, m_width, m_height);
-    }
-    std::string className() const final
-    {
-        return "Box";
-    }
+    Box* clone() const override { return new Box(m_length, m_width, m_height); }
+    std::string className() const final { return "Box"; }
 
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double width() const
-    {
-        return m_width;
-    }
-    double height() const override
-    {
-        return m_height;
-    }
+    double length() const { return m_length; }
+    double width() const { return m_width; }
+    double height() const override { return m_height; }
 
 private:
     const double& m_length;
     const double& m_width;
     const double& m_height;
-#endif // USER_API
 };
 
 //! A prism based on an equilateral triangle.
@@ -71,35 +54,18 @@ private:
 class Prism3 : public IFormFactorPrism {
 public:
     Prism3(double base_edge, double height);
-#ifndef USER_API
     Prism3(std::vector<double> P);
 
-    Prism3* clone() const override
-    {
-        return new Prism3(m_base_edge, m_height);
-    }
-    std::string className() const final
-    {
-        return "Prism3";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"BaseEdge", "nm"}, {"Height", "nm"}};
-    }
+    Prism3* clone() const override { return new Prism3(m_base_edge, m_height); }
+    std::string className() const final { return "Prism3"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"BaseEdge", "nm"}, {"Height", "nm"}}; }
 
-    double baseEdge() const
-    {
-        return m_base_edge;
-    }
-    double height() const override
-    {
-        return m_height;
-    }
+    double baseEdge() const { return m_base_edge; }
+    double height() const override { return m_height; }
 
 private:
     const double& m_base_edge;
     const double& m_height;
-#endif // USER_API
 };
 
 //! A prism based on a regular hexagonal.
@@ -108,35 +74,18 @@ private:
 class Prism6 : public IFormFactorPrism {
 public:
     Prism6(double base_edge, double height);
-#ifndef USER_API
     Prism6(std::vector<double> P);
 
-    Prism6* clone() const override
-    {
-        return new Prism6(m_base_edge, m_height);
-    }
-    std::string className() const final
-    {
-        return "Prism6";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"BaseEdge", "nm"}, {"Height", "nm"}};
-    }
+    Prism6* clone() const override { return new Prism6(m_base_edge, m_height); }
+    std::string className() const final { return "Prism6"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"BaseEdge", "nm"}, {"Height", "nm"}}; }
 
-    double baseEdge() const
-    {
-        return m_base_edge;
-    }
-    double height() const override
-    {
-        return m_height;
-    }
+    double baseEdge() const { return m_base_edge; }
+    double height() const override { return m_height; }
 
 private:
     const double& m_base_edge;
     const double& m_height;
-#endif // USER_API
 };
 
 //  ************************************************************************************************
@@ -149,34 +98,17 @@ private:
 class PlatonicTetrahedron : public IFormFactorPolyhedron {
 public:
     PlatonicTetrahedron(double edge);
-#ifndef USER_API
     PlatonicTetrahedron(std::vector<double> P);
 
-    PlatonicTetrahedron* clone() const override
-    {
-        return new PlatonicTetrahedron(m_edge);
-    }
-    std::string className() const final
-    {
-        return "PlatonicTetrahedron";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Edge", "nm"}};
-    }
+    PlatonicTetrahedron* clone() const override { return new PlatonicTetrahedron(m_edge); }
+    std::string className() const final { return "PlatonicTetrahedron"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Edge", "nm"}}; }
 
-    double edge() const
-    {
-        return m_edge;
-    }
-    double height() const
-    {
-        return sqrt(2. / 3) * m_edge;
-    }
+    double edge() const { return m_edge; }
+    double height() const { return sqrt(2. / 3) * m_edge; }
 
 private:
     const double& m_edge;
-#endif // USER_API
 };
 
 //! A truncated bifrustum with quadratic base.
@@ -185,34 +117,17 @@ private:
 class PlatonicOctahedron : public IFormFactorPolyhedron {
 public:
     PlatonicOctahedron(double edge);
-#ifndef USER_API
     PlatonicOctahedron(std::vector<double> P);
 
-    PlatonicOctahedron* clone() const override
-    {
-        return new PlatonicOctahedron(m_edge);
-    }
-    std::string className() const final
-    {
-        return "PlatonicOctahedron";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Edge", "nm"}};
-    }
+    PlatonicOctahedron* clone() const override { return new PlatonicOctahedron(m_edge); }
+    std::string className() const final { return "PlatonicOctahedron"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Edge", "nm"}}; }
 
-    double edge() const
-    {
-        return m_edge;
-    }
-    double height() const
-    {
-        return sqrt(1 / 2.) * m_edge;
-    }
+    double edge() const { return m_edge; }
+    double height() const { return sqrt(1 / 2.) * m_edge; }
 
 private:
     const double& m_edge;
-#endif // USER_API
 };
 
 //! A regular dodecahedron.
@@ -221,30 +136,16 @@ private:
 class Dodecahedron : public IFormFactorPolyhedron {
 public:
     Dodecahedron(double edge);
-#ifndef USER_API
     Dodecahedron(std::vector<double> P);
 
-    Dodecahedron* clone() const override
-    {
-        return new Dodecahedron(m_edge);
-    }
-    std::string className() const final
-    {
-        return "Dodecahedron";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Edge", "nm"}};
-    }
+    Dodecahedron* clone() const override { return new Dodecahedron(m_edge); }
+    std::string className() const final { return "Dodecahedron"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Edge", "nm"}}; }
 
-    double edge() const
-    {
-        return m_edge;
-    }
+    double edge() const { return m_edge; }
 
 private:
     const double& m_edge;
-#endif // USER_API
 };
 
 //! A regular icosahedron.
@@ -253,30 +154,16 @@ private:
 class Icosahedron : public IFormFactorPolyhedron {
 public:
     Icosahedron(double edge);
-#ifndef USER_API
     Icosahedron(std::vector<double> P);
 
-    Icosahedron* clone() const override
-    {
-        return new Icosahedron(m_edge);
-    }
-    std::string className() const final
-    {
-        return "Icosahedron";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Edge", "nm"}};
-    }
+    Icosahedron* clone() const override { return new Icosahedron(m_edge); }
+    std::string className() const final { return "Icosahedron"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Edge", "nm"}}; }
 
-    double edge() const
-    {
-        return m_edge;
-    }
+    double edge() const { return m_edge; }
 
 private:
     const double& m_edge;
-#endif // USER_API
 };
 
 //  ************************************************************************************************
@@ -289,45 +176,25 @@ private:
 class Pyramid2 : public IFormFactorPolyhedron {
 public:
     Pyramid2(double length, double width, double height, double alpha);
-#ifndef USER_API
     Pyramid2(std::vector<double> P);
 
-    Pyramid2* clone() const override
-    {
-        return new Pyramid2(m_length, m_width, m_height, m_alpha);
-    }
-    std::string className() const final
-    {
-        return "Pyramid2";
-    }
+    Pyramid2* clone() const override { return new Pyramid2(m_length, m_width, m_height, m_alpha); }
+    std::string className() const final { return "Pyramid2"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}, {"Alpha", "rad"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double width() const
-    {
-        return m_width;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
+    double length() const { return m_length; }
+    double width() const { return m_width; }
+    double height() const { return m_height; }
+    double alpha() const { return m_alpha; }
 
 private:
     const double& m_length;
     const double& m_width;
     const double& m_height;
     const double& m_alpha;
-#endif // USER_API
 };
 
 //! A frustum with equilateral trigonal base.
@@ -336,40 +203,23 @@ private:
 class Pyramid3 : public IFormFactorPolyhedron {
 public:
     Pyramid3(double base_edge, double height, double alpha);
-#ifndef USER_API
     Pyramid3(std::vector<double> P);
 
-    Pyramid3* clone() const override
-    {
-        return new Pyramid3(m_base_edge, m_height, m_alpha);
-    }
-    std::string className() const final
-    {
-        return "Pyramid3";
-    }
+    Pyramid3* clone() const override { return new Pyramid3(m_base_edge, m_height, m_alpha); }
+    std::string className() const final { return "Pyramid3"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"BaseEdge", "nm"}, {"Height", "nm"}, {"Alpha", "rad"}};
     }
 
-    double baseEdge() const
-    {
-        return m_base_edge;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
+    double baseEdge() const { return m_base_edge; }
+    double height() const { return m_height; }
+    double alpha() const { return m_alpha; }
 
 private:
     const double& m_base_edge;
     const double& m_height;
     const double& m_alpha;
-#endif // USER_API
 };
 
 //! A frustum with a quadratic base.
@@ -378,40 +228,23 @@ private:
 class Pyramid4 : public IFormFactorPolyhedron {
 public:
     Pyramid4(double base_edge, double height, double alpha);
-#ifndef USER_API
     Pyramid4(std::vector<double> P);
 
-    Pyramid4* clone() const override
-    {
-        return new Pyramid4(m_base_edge, m_height, m_alpha);
-    }
-    std::string className() const final
-    {
-        return "Pyramid4";
-    }
+    Pyramid4* clone() const override { return new Pyramid4(m_base_edge, m_height, m_alpha); }
+    std::string className() const final { return "Pyramid4"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"BaseEdge", "nm"}, {"Height", "nm"}, {"Alpha", "rad"}};
     }
 
-    double height() const
-    {
-        return m_height;
-    }
-    double baseEdge() const
-    {
-        return m_base_edge;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
+    double height() const { return m_height; }
+    double baseEdge() const { return m_base_edge; }
+    double alpha() const { return m_alpha; }
 
 private:
     const double& m_base_edge;
     const double& m_height;
     const double& m_alpha;
-#endif // USER_API
 };
 
 //! A frustum (truncated pyramid) with regular hexagonal base.
@@ -420,40 +253,23 @@ private:
 class Pyramid6 : public IFormFactorPolyhedron {
 public:
     Pyramid6(double base_edge, double height, double alpha);
-#ifndef USER_API
     Pyramid6(std::vector<double> P);
 
-    Pyramid6* clone() const override
-    {
-        return new Pyramid6(m_base_edge, m_height, m_alpha);
-    }
-    std::string className() const final
-    {
-        return "Pyramid6";
-    }
+    Pyramid6* clone() const override { return new Pyramid6(m_base_edge, m_height, m_alpha); }
+    std::string className() const final { return "Pyramid6"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"BaseEdge", "nm"}, {"Height", "nm"}, {"Alpha", "rad"}};
     }
 
-    double baseEdge() const
-    {
-        return m_base_edge;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
+    double baseEdge() const { return m_base_edge; }
+    double height() const { return m_height; }
+    double alpha() const { return m_alpha; }
 
 private:
     const double& m_base_edge;
     const double& m_height;
     const double& m_alpha;
-#endif // USER_API
 };
 
 //! A truncated bifrustum with quadratic base.
@@ -462,37 +278,20 @@ private:
 class Bipyramid4 : public IFormFactorPolyhedron {
 public:
     Bipyramid4(double length, double height, double height_ratio, double alpha);
-#ifndef USER_API
     Bipyramid4(std::vector<double> P);
     Bipyramid4* clone() const override
     {
         return new Bipyramid4(m_length, m_height, m_height_ratio, m_alpha);
     }
-    std::string className() const final
-    {
-        return "Bipyramid4";
-    }
+    std::string className() const final { return "Bipyramid4"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Height", "nm"}, {"HeightRatio", ""}, {"Alpha", "rad"}};
     }
-    double length() const
-    {
-        return m_length;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double heightRatio() const
-    {
-        return m_height_ratio;
-    }
-    double alpha() const
-    {
-        return m_alpha;
-    }
-#endif // USER_API
+    double length() const { return m_length; }
+    double height() const { return m_height; }
+    double heightRatio() const { return m_height_ratio; }
+    double alpha() const { return m_alpha; }
 
 private:
     const double& m_length;
@@ -511,31 +310,20 @@ private:
 class CantellatedCube : public IFormFactorPolyhedron {
 public:
     CantellatedCube(double length, double removed_length);
-#ifndef USER_API
     CantellatedCube(std::vector<double> P);
 
     CantellatedCube* clone() const override
     {
         return new CantellatedCube(m_length, m_removed_length);
     }
-    std::string className() const final
-    {
-        return "CantellatedCube";
-    }
+    std::string className() const final { return "CantellatedCube"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"RemovedLength", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double removedLength() const
-    {
-        return m_removed_length;
-    }
-#endif // USER_API
+    double length() const { return m_length; }
+    double removedLength() const { return m_removed_length; }
 
 private:
     const double& m_length;
@@ -548,35 +336,21 @@ private:
 class TruncatedCube : public IFormFactorPolyhedron {
 public:
     TruncatedCube(double length, double removed_length);
-#ifndef USER_API
     TruncatedCube(std::vector<double> P);
 
-    TruncatedCube* clone() const override
-    {
-        return new TruncatedCube(m_length, m_removed_length);
-    }
-    std::string className() const final
-    {
-        return "TruncatedCube";
-    }
+    TruncatedCube* clone() const override { return new TruncatedCube(m_length, m_removed_length); }
+    std::string className() const final { return "TruncatedCube"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"RemovedLength", "nm"}};
     }
 
-    double length() const
-    {
-        return m_length;
-    }
-    double removedLength() const
-    {
-        return m_removed_length;
-    }
+    double length() const { return m_length; }
+    double removedLength() const { return m_removed_length; }
 
 private:
     const double& m_length;
     const double& m_removed_length;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_POLYHEDRA_H
diff --git a/Sample/HardParticle/Ripples.h b/Sample/HardParticle/Ripples.h
index 27844a3c79f91192bcc5ebe7a18fd530e9df828f..7d51e9f09327b1ce11178da704edae51cf0ac605 100644
--- a/Sample/HardParticle/Ripples.h
+++ b/Sample/HardParticle/Ripples.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_HARDPARTICLE_RIPPLES_H
 #define BORNAGAIN_SAMPLE_HARDPARTICLE_RIPPLES_H
 
@@ -37,4 +35,3 @@ complex_t profile_yz_triangular(complex_t qy, complex_t qz, double width, double
 } // namespace ripples
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_RIPPLES_H
-#endif // USER_API
diff --git a/Sample/HardParticle/SawtoothRipple.h b/Sample/HardParticle/SawtoothRipple.h
index f1a7571e3cc664b450032a675cb0e3a6b4621b76..f79664c05d9c7a24fb278232d30c6642b226bff4 100644
--- a/Sample/HardParticle/SawtoothRipple.h
+++ b/Sample/HardParticle/SawtoothRipple.h
@@ -22,13 +22,9 @@
 class SawtoothRippleBox : public ISawtoothRipple {
 public:
     SawtoothRippleBox(double length, double width, double height, double asymmetry);
-#ifndef USER_API
     SawtoothRippleBox(std::vector<double> P);
     SawtoothRippleBox* clone() const override;
-    std::string className() const final
-    {
-        return "SawtoothRippleBox";
-    }
+    std::string className() const final { return "SawtoothRippleBox"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}, {"AsymmetryLength", "nm"}};
@@ -36,7 +32,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 //! The form factor for a cosine ripple, with Gaussian profile in elongation direction.
@@ -44,13 +39,9 @@ private:
 class SawtoothRippleGauss : public ISawtoothRipple {
 public:
     SawtoothRippleGauss(double length, double width, double height, double asymmetry);
-#ifndef USER_API
     SawtoothRippleGauss(std::vector<double> P);
     SawtoothRippleGauss* clone() const override;
-    std::string className() const final
-    {
-        return "SawtoothRippleGauss";
-    }
+    std::string className() const final { return "SawtoothRippleGauss"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}, {"AsymmetryLength", "nm"}};
@@ -58,7 +49,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 //! The form factor for a cosine ripple, with Lorentz form factor in elongation direction.
@@ -66,13 +56,9 @@ private:
 class SawtoothRippleLorentz : public ISawtoothRipple {
 public:
     SawtoothRippleLorentz(double length, double width, double height, double asymmetry);
-#ifndef USER_API
     SawtoothRippleLorentz(std::vector<double> P);
     SawtoothRippleLorentz* clone() const override;
-    std::string className() const final
-    {
-        return "SawtoothRippleLorentz";
-    }
+    std::string className() const final { return "SawtoothRippleLorentz"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Length", "nm"}, {"Width", "nm"}, {"Height", "nm"}, {"AsymmetryLength", "nm"}};
@@ -80,7 +66,6 @@ public:
 
 private:
     complex_t factor_x(complex_t qx) const override;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_SAWTOOTHRIPPLE_H
diff --git a/Sample/HardParticle/Sphere.h b/Sample/HardParticle/Sphere.h
index 3743e7f3ed98f4726a6c49f6cb8aa70b4e22d1b6..dd76ee45479a1401cba6be62bb36263c23f6cb81 100644
--- a/Sample/HardParticle/Sphere.h
+++ b/Sample/HardParticle/Sphere.h
@@ -23,48 +23,28 @@
 class Sphere : public IFormFactor {
 public:
     Sphere(double radius, bool position_at_center = false);
-#ifndef USER_API
     Sphere(std::vector<double> P, bool position_at_center = false);
 
-    Sphere* clone() const override
-    {
-        return new Sphere(m_radius, m_position_at_center);
-    }
-    std::string className() const final
-    {
-        return "Sphere";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Radius", "nm"}};
-    }
+    Sphere* clone() const override { return new Sphere(m_radius, m_position_at_center); }
+    std::string className() const final { return "Sphere"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Radius", "nm"}}; }
 
-    double radius() const
-    {
-        return m_radius;
-    }
+    double radius() const { return m_radius; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
     std::string validate() const override;
 
 protected:
-    bool canSliceAnalytically(const IRotation*) const override
-    {
-        return true;
-    }
+    bool canSliceAnalytically(const IRotation*) const override { return true; }
 
 private:
     Span exec_spanZ(const IRotation* rotation) const override;
 
     const double& m_radius;
     bool m_position_at_center;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_SPHERE_H
diff --git a/Sample/HardParticle/Spheroid.h b/Sample/HardParticle/Spheroid.h
index 17060cf42a83d851484f878a5ec7a779d7bb962d..551f20d8a68ed042b886284c1209e4b33f0d05db 100644
--- a/Sample/HardParticle/Spheroid.h
+++ b/Sample/HardParticle/Spheroid.h
@@ -23,35 +23,16 @@
 class Spheroid : public IFormFactor {
 public:
     Spheroid(double radius, double height);
-#ifndef USER_API
     Spheroid(std::vector<double> P);
 
-    Spheroid* clone() const override
-    {
-        return new Spheroid(m_radius, m_height);
-    }
-    std::string className() const final
-    {
-        return "Spheroid";
-    }
-    std::vector<ParaMeta> parDefs() const final
-    {
-        return {{"Radius", "nm"}, {"Height", "nm"}};
-    }
+    Spheroid* clone() const override { return new Spheroid(m_radius, m_height); }
+    std::string className() const final { return "Spheroid"; }
+    std::vector<ParaMeta> parDefs() const final { return {{"Radius", "nm"}, {"Height", "nm"}}; }
 
-    double height() const
-    {
-        return m_height;
-    }
-    double radius() const
-    {
-        return m_radius;
-    }
+    double height() const { return m_height; }
+    double radius() const { return m_radius; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -60,7 +41,6 @@ public:
 private:
     const double& m_radius;
     const double& m_height;
-#endif // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_SPHEROID_H
diff --git a/Sample/HardParticle/TruncatedSphere.h b/Sample/HardParticle/TruncatedSphere.h
index 14d9f20e437a4aee8b3353d0c3ade8ae2faa9bca..36473685f8094a266c813ff1687b883945e0816a 100644
--- a/Sample/HardParticle/TruncatedSphere.h
+++ b/Sample/HardParticle/TruncatedSphere.h
@@ -23,39 +23,23 @@
 class TruncatedSphere : public IFormFactor {
 public:
     TruncatedSphere(double radius, double height, double dh);
-#ifndef USER_API
     TruncatedSphere(std::vector<double> P);
 
     TruncatedSphere* clone() const override
     {
         return new TruncatedSphere(m_radius, m_height, m_dh);
     }
-    std::string className() const final
-    {
-        return "TruncatedSphere";
-    }
+    std::string className() const final { return "TruncatedSphere"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {{"Radius", "nm"}, {"Height", "nm"}, {"DeltaHeight", "nm"}};
     }
 
-    double height() const
-    {
-        return m_height;
-    }
-    double radius() const
-    {
-        return m_radius;
-    }
-    double removedTop() const
-    {
-        return m_dh;
-    }
+    double height() const { return m_height; }
+    double radius() const { return m_radius; }
+    double removedTop() const { return m_dh; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -65,7 +49,6 @@ private:
     const double& m_radius;
     const double& m_height; //!< height before removal of cap
     const double& m_dh;     //!< height of removed cap
-#endif                      // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_TRUNCATEDSPHERE_H
diff --git a/Sample/HardParticle/TruncatedSpheroid.h b/Sample/HardParticle/TruncatedSpheroid.h
index 1ebb01c08a7ca7455aa25135859fd911da4c0acc..5d3dc4d2f867f8604d3cf054973c7adcb6a04ab3 100644
--- a/Sample/HardParticle/TruncatedSpheroid.h
+++ b/Sample/HardParticle/TruncatedSpheroid.h
@@ -24,44 +24,25 @@
 class TruncatedSpheroid : public IFormFactor {
 public:
     TruncatedSpheroid(double radius, double height, double height_flattening, double dh);
-#ifndef USER_API
     TruncatedSpheroid(std::vector<double> P);
 
     TruncatedSpheroid* clone() const override
     {
         return new TruncatedSpheroid(m_radius, m_height, m_fp, m_dh);
     }
-    std::string className() const final
-    {
-        return "TruncatedSpheroid";
-    }
+    std::string className() const final { return "TruncatedSpheroid"; }
     std::vector<ParaMeta> parDefs() const final
     {
         return {
             {"Radius", "nm"}, {"Height", "nm"}, {"HeightFlattening", ""}, {"DeltaHeight", "nm"}};
     }
 
-    double radius() const
-    {
-        return m_radius;
-    }
-    double height() const
-    {
-        return m_height;
-    }
-    double heightFlattening() const
-    {
-        return m_fp;
-    }
-    double removedTop() const
-    {
-        return m_dh;
-    }
+    double radius() const { return m_radius; }
+    double height() const { return m_height; }
+    double heightFlattening() const { return m_fp; }
+    double removedTop() const { return m_dh; }
 
-    double radialExtension() const override
-    {
-        return m_radius;
-    }
+    double radialExtension() const override { return m_radius; }
 
     complex_t formfactor(C3 q) const override;
 
@@ -72,7 +53,6 @@ private:
     const double& m_height; //!< height before removal of cap
     const double& m_fp;     //!< ratio of vertical to horizontal radius
     const double& m_dh;     //!< height of removed cap
-#endif                      // USER_API
 };
 
 #endif // BORNAGAIN_SAMPLE_HARDPARTICLE_TRUNCATEDSPHEROID_H
diff --git a/Sample/Interface/LayerInterface.h b/Sample/Interface/LayerInterface.h
index 1aa7568a9083116ca00e595c989dfab3735ba050..44ace81002484bf7dc5c01f4e31fd9dfbb41782c 100644
--- a/Sample/Interface/LayerInterface.h
+++ b/Sample/Interface/LayerInterface.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_INTERFACE_LAYERINTERFACE_H
 #define BORNAGAIN_SAMPLE_INTERFACE_LAYERINTERFACE_H
 
@@ -81,4 +79,3 @@ inline const Layer* LayerInterface::bottomLayer() const
 }
 
 #endif // BORNAGAIN_SAMPLE_INTERFACE_LAYERINTERFACE_H
-#endif // USER_API
diff --git a/Sample/LibFF/SomeFormFactors.h b/Sample/LibFF/SomeFormFactors.h
index 3b91fc1a00625f8ba9802768b11e0a3ef12059a8..4041ee4488a979e3e5b1c41f0d45435a5a1abbe2 100644
--- a/Sample/LibFF/SomeFormFactors.h
+++ b/Sample/LibFF/SomeFormFactors.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_LIBFF_SOMEFORMFACTORS_H
 #define BORNAGAIN_SAMPLE_LIBFF_SOMEFORMFACTORS_H
 
@@ -36,4 +34,3 @@ complex_t ffSphere(C3 q, double R);
 } // namespace SampleUtils
 
 #endif // BORNAGAIN_SAMPLE_LIBFF_SOMEFORMFACTORS_H
-#endif // USER_API
diff --git a/Sample/Material/Admixtures.h b/Sample/Material/Admixtures.h
index 431e380ea7feeb73831d948f9eea7cdcae50f16c..376b77c08eaa60db4c8cd533a599faf75242b464 100644
--- a/Sample/Material/Admixtures.h
+++ b/Sample/Material/Admixtures.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_MATERIAL_ADMIXTURES_H
 #define BORNAGAIN_SAMPLE_MATERIAL_ADMIXTURES_H
 
@@ -39,4 +37,3 @@ struct OneAdmixture {
 class Admixtures : public std::vector<OneAdmixture> {};
 
 #endif // BORNAGAIN_SAMPLE_MATERIAL_ADMIXTURES_H
-#endif // USER_API
diff --git a/Sample/Material/Material.h b/Sample/Material/Material.h
index 063576b40d46da989c16c7f179804594c993ab59..61e3bcf8fdf588aeb87f86065c0c6c49ba04a458 100644
--- a/Sample/Material/Material.h
+++ b/Sample/Material/Material.h
@@ -70,7 +70,7 @@ public:
 #ifndef SWIG
     //! Returns the type of underlying material implementation
     MATERIAL_TYPES typeID() const;
-#endif // USER_API
+#endif // SWIG
 
     //! Get the magnetization (in A/m)
     R3 magnetization() const;
diff --git a/Sample/Material/MaterialUtils.cpp b/Sample/Material/MaterialUtils.cpp
index 9d126a1c16f4633b370e161db4aa26311c41b9f7..2096d698dbcdf0eba01989e75b99f01af80f60b9 100644
--- a/Sample/Material/MaterialUtils.cpp
+++ b/Sample/Material/MaterialUtils.cpp
@@ -36,8 +36,6 @@ const SpinMatrix Pauli_Z(1, 0, 0, -1);
 } // namespace
 
 
-#ifndef USER_API
-
 template <typename T>
 SpinMatrix MaterialUtils::MagnetizationCorrection(complex_t unit_factor, double magnetic_factor,
                                                   Vec3<T> polarization)
@@ -55,7 +53,6 @@ template SpinMatrix MaterialUtils::MagnetizationCorrection(complex_t unit_factor
 template SpinMatrix MaterialUtils::MagnetizationCorrection(complex_t unit_factor,
                                                            double magnetic_factor, C3 polarization);
 
-#endif // USER_API
 
 complex_t MaterialUtils::ScalarReducedPotential(complex_t n, R3 k, double n_ref)
 {
diff --git a/Sample/Material/MaterialUtils.h b/Sample/Material/MaterialUtils.h
index 9e4eea1e0471f10f698e5de5b70f9be6bee4fadc..51716e224e9c961a527724611d93d8175a9af9aa 100644
--- a/Sample/Material/MaterialUtils.h
+++ b/Sample/Material/MaterialUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_MATERIAL_MATERIALUTILS_H
 #define BORNAGAIN_SAMPLE_MATERIAL_MATERIALUTILS_H
 
@@ -60,4 +58,3 @@ Material averagedMaterial(const Material& base_mat, const Admixtures& admixtures
 } // namespace MaterialUtils
 
 #endif // BORNAGAIN_SAMPLE_MATERIAL_MATERIALUTILS_H
-#endif // USER_API
diff --git a/Sample/Multilayer/MultilayerUtils.h b/Sample/Multilayer/MultilayerUtils.h
index c3e23722038d99359286ddb6e73e0ab95252df47..a3914714497b5b3ce48812103c8f746b4d374bfa 100644
--- a/Sample/Multilayer/MultilayerUtils.h
+++ b/Sample/Multilayer/MultilayerUtils.h
@@ -14,9 +14,8 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
+#endif // SWIG
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_MULTILAYER_MULTILAYERUTILS_H
 #define BORNAGAIN_SAMPLE_MULTILAYER_MULTILAYERUTILS_H
 
@@ -41,4 +40,3 @@ bool hasRoughness(const MultiLayer& sample);
 } // namespace SampleUtils::Multilayer
 
 #endif // BORNAGAIN_SAMPLE_MULTILAYER_MULTILAYERUTILS_H
-#endif // USER_API
diff --git a/Sample/Multilayer/PyImport.h b/Sample/Multilayer/PyImport.h
index ed407d632783562e78b5da70cb2e1fb203e9a272..134e97ed82f404afda0b10a2f46ba3e55d0bca27 100644
--- a/Sample/Multilayer/PyImport.h
+++ b/Sample/Multilayer/PyImport.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_MULTILAYER_PYIMPORT_H
 #define BORNAGAIN_SAMPLE_MULTILAYER_PYIMPORT_H
 
@@ -51,4 +49,3 @@ std::vector<std::string> listOfFunctions(const std::string& script, const std::s
 #endif // BORNAGAIN_PYTHON
 
 #endif // BORNAGAIN_SAMPLE_MULTILAYER_PYIMPORT_H
-#endif // USER_API
diff --git a/Sample/Multilayer/RoughnessModels.h b/Sample/Multilayer/RoughnessModels.h
index 2dcb6cc9b47c0dbab8d4eaec196a2c89a37fed88..ff630c0560ab1f2514a27d5e0c1adf81abf2faa9 100644
--- a/Sample/Multilayer/RoughnessModels.h
+++ b/Sample/Multilayer/RoughnessModels.h
@@ -24,7 +24,7 @@ struct RoughnessModelWrap {
     // TODO: to automatize enum to string convertion, one can possibly use this solution
     // https://stackoverflow.com/questions/147267/easy-way-to-use-variables-of-enum-types-as-string-in-c#202511
     static std::string roughnessModelName(RoughnessModel model);
-#endif
+#endif // SWIG
 };
 using RoughnessModel = RoughnessModelWrap::RoughnessModel;
 
diff --git a/Sample/Particle/IFormFactor.h b/Sample/Particle/IFormFactor.h
index 69306604421df7f5b9ca9dcf7d4ded4cf792e9bd..d9a36016adfb2881bdc2a7ee67aed88ee89ec46b 100644
--- a/Sample/Particle/IFormFactor.h
+++ b/Sample/Particle/IFormFactor.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_PARTICLE_IFORMFACTOR_H
 #define BORNAGAIN_SAMPLE_PARTICLE_IFORMFACTOR_H
 
@@ -75,4 +74,3 @@ protected:
 };
 
 #endif // BORNAGAIN_SAMPLE_PARTICLE_IFORMFACTOR_H
-#endif // USER_API
diff --git a/Sample/Particle/IParticle.h b/Sample/Particle/IParticle.h
index 725464101c33e80467a680251740ebb46aa948b4..ab9a8d8e23696d2684281e07fbbf19a657e18277 100644
--- a/Sample/Particle/IParticle.h
+++ b/Sample/Particle/IParticle.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_PARTICLE_IPARTICLE_H
 #define BORNAGAIN_SAMPLE_PARTICLE_IPARTICLE_H
 
@@ -90,4 +89,3 @@ private:
 };
 
 #endif // BORNAGAIN_SAMPLE_PARTICLE_IPARTICLE_H
-#endif // USER_API
diff --git a/Sample/Particle/PolyhedralUtil.h b/Sample/Particle/PolyhedralUtil.h
index d94871290f829af808ad2a48749cf6543cbefc7d..16ed3c0093ea136fed2396bac3106462d9d3cad6 100644
--- a/Sample/Particle/PolyhedralUtil.h
+++ b/Sample/Particle/PolyhedralUtil.h
@@ -15,9 +15,7 @@
 // Cannot be exposed to Swig unless we have the default constructor
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_PARTICLE_POLYHEDRALUTIL_H
 #define BORNAGAIN_SAMPLE_PARTICLE_POLYHEDRALUTIL_H
 
@@ -35,4 +33,3 @@ Span spanZ(const std::vector<R3>& vertices, const IRotation* rotation);
 } // namespace PolyhedralUtil
 
 #endif // BORNAGAIN_SAMPLE_PARTICLE_POLYHEDRALUTIL_H
-#endif // USER_API
diff --git a/Sample/Scattering/ISampleNode.h b/Sample/Scattering/ISampleNode.h
index e39e6b5b2f4c7c1cfa03222272d5cd3b59fbcf62..24e2e2443bfb103d1eb56d8d043fbe8e578b4319 100644
--- a/Sample/Scattering/ISampleNode.h
+++ b/Sample/Scattering/ISampleNode.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SAMPLE_SCATTERING_ISAMPLENODE_H
 #define BORNAGAIN_SAMPLE_SCATTERING_ISAMPLENODE_H
 
@@ -43,4 +42,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_SCATTERING_ISAMPLENODE_H
-#endif // USER_API
diff --git a/Sample/Scattering/Rotations.h b/Sample/Scattering/Rotations.h
index 6029467470de7dfc8f530fd32e0b923537c68954..6916085e3021d5dbbbac274b3d7c7cbc03915409 100644
--- a/Sample/Scattering/Rotations.h
+++ b/Sample/Scattering/Rotations.h
@@ -20,7 +20,6 @@
 #include "Param/Node/INode.h"
 #include <heinz/Vectors3D.h>
 
-#ifndef USER_API
 
 //! Abstract base class for rotations.
 //! @ingroup samples
@@ -49,7 +48,6 @@ public:
 
 IRotation* createProduct(const IRotation& left, const IRotation& right);
 
-#endif // USER_API
 
 //! The identity rotation, which leaves everything in place.
 
diff --git a/Sample/Shapes/BoxNet.h b/Sample/Shapes/BoxNet.h
index 7ecb9e28f734ff8961f4535310f60e7a6707e984..b7c0f1894c2fd55dff88ae38534a383453abb3b3 100644
--- a/Sample/Shapes/BoxNet.h
+++ b/Sample/Shapes/BoxNet.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_BOXNET_H
 #define BORNAGAIN_SAMPLE_SHAPES_BOXNET_H
 
@@ -29,4 +27,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_SHAPES_BOXNET_H
-#endif // USER_API
diff --git a/Sample/Shapes/DoubleEllipse.h b/Sample/Shapes/DoubleEllipse.h
index 08d61c75a85491c3c116e9da7cd7c69df47cf5c9..99386e5f8161b6523ecd3042520502261f46c1f3 100644
--- a/Sample/Shapes/DoubleEllipse.h
+++ b/Sample/Shapes/DoubleEllipse.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_DOUBLEELLIPSE_H
 #define BORNAGAIN_SAMPLE_SHAPES_DOUBLEELLIPSE_H
 
@@ -35,4 +33,3 @@ public:
     ~DoubleEllipseX() override;
 };
 #endif // BORNAGAIN_SAMPLE_SHAPES_DOUBLEELLIPSE_H
-#endif // USER_API
diff --git a/Sample/Shapes/IShape3D.h b/Sample/Shapes/IShape3D.h
index caaf773109df71b5eac74f67854790adcb072928..e1163ffecc55dc5ad0b2b03c21b0baae7593456a 100644
--- a/Sample/Shapes/IShape3D.h
+++ b/Sample/Shapes/IShape3D.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_ISHAPE3D_H
 #define BORNAGAIN_SAMPLE_SHAPES_ISHAPE3D_H
 
@@ -55,4 +53,3 @@ std::vector<R3> EllipseVerticesZ(double r_x, double r_y, double z);
 std::vector<R3> EllipseVerticesXtrunc(double x, double r_y, double r_z, double z_b, double z_t);
 
 #endif // BORNAGAIN_SAMPLE_SHAPES_ISHAPE3D_H
-#endif // USER_API
diff --git a/Sample/Shapes/RippleCosineNet.h b/Sample/Shapes/RippleCosineNet.h
index 2e81d62f9c90f05c6498a36c82a7c362b99fbb22..d80951d683d17eec13d3f787bef7b91364cf5740 100644
--- a/Sample/Shapes/RippleCosineNet.h
+++ b/Sample/Shapes/RippleCosineNet.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_RIPPLECOSINENET_H
 #define BORNAGAIN_SAMPLE_SHAPES_RIPPLECOSINENET_H
 
@@ -29,4 +27,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_SHAPES_RIPPLECOSINENET_H
-#endif // USER_API
diff --git a/Sample/Shapes/RippleSawtoothNet.h b/Sample/Shapes/RippleSawtoothNet.h
index f69f742762ed51c91ec9b0f8e8f96b7833ba871b..fca8a4b9a3dd4870fb6d00d0fe6a964e672f6214 100644
--- a/Sample/Shapes/RippleSawtoothNet.h
+++ b/Sample/Shapes/RippleSawtoothNet.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_RIPPLESAWTOOTHNET_H
 #define BORNAGAIN_SAMPLE_SHAPES_RIPPLESAWTOOTHNET_H
 
@@ -29,4 +27,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_SHAPES_RIPPLESAWTOOTHNET_H
-#endif // USER_API
diff --git a/Sample/Shapes/TruncatedEllipsoidNet.h b/Sample/Shapes/TruncatedEllipsoidNet.h
index 92610abb9d24a80a58f7d1be6fd6212a3401b8f3..bc02dc861579ad9922bfb1ff4d255838a4f630cd 100644
--- a/Sample/Shapes/TruncatedEllipsoidNet.h
+++ b/Sample/Shapes/TruncatedEllipsoidNet.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SHAPES_TRUNCATEDELLIPSOIDNET_H
 #define BORNAGAIN_SAMPLE_SHAPES_TRUNCATEDELLIPSOIDNET_H
 
@@ -29,4 +27,3 @@ public:
 };
 
 #endif // BORNAGAIN_SAMPLE_SHAPES_TRUNCATEDELLIPSOIDNET_H
-#endif // USER_API
diff --git a/Sample/SoftParticle/SoftParticles.h b/Sample/SoftParticle/SoftParticles.h
index 7be7ba25c79bc171cd877b42419615eee6cbd668..745699cd974e0896898682e6dfa3301aa0447671 100644
--- a/Sample/SoftParticle/SoftParticles.h
+++ b/Sample/SoftParticle/SoftParticles.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_SOFTPARTICLE_SOFTPARTICLES_H
 #define BORNAGAIN_SAMPLE_SOFTPARTICLE_SOFTPARTICLES_H
 
@@ -24,4 +22,3 @@
 #include "Sample/SoftParticle/Gauss.h"
 
 #endif // BORNAGAIN_SAMPLE_SOFTPARTICLE_SOFTPARTICLES_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/BoxCompositionBuilder.h b/Sample/StandardSamples/BoxCompositionBuilder.h
index 44d5ff1cb536624c25d607dcdb9e7d7a37a6dbe4..e501882ce0ec02d9311547e0cd4a431191b03a58 100644
--- a/Sample/StandardSamples/BoxCompositionBuilder.h
+++ b/Sample/StandardSamples/BoxCompositionBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXCOMPOSITIONBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXCOMPOSITIONBUILDER_H
 
@@ -69,4 +67,3 @@ MultiLayer* createBoxStackComposition();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXCOMPOSITIONBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/BoxesSquareLatticeBuilder.h b/Sample/StandardSamples/BoxesSquareLatticeBuilder.h
index 2c6039cae5c1b2996abea55839ae366299ce9bbb..1fb28127fbb02216d1fef67db8f432f97e8cb383 100644
--- a/Sample/StandardSamples/BoxesSquareLatticeBuilder.h
+++ b/Sample/StandardSamples/BoxesSquareLatticeBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXESSQUARELATTICEBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXESSQUARELATTICEBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createBoxesSquareLattice2D();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_BOXESSQUARELATTICEBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/CompoundBuilder.h b/Sample/StandardSamples/CompoundBuilder.h
index 704d8ff8ccb3de06f6644f67c15a5c3633c7ede1..4f5e53b66c8d5a69bd5998f6aceaf77fd1a8c3f6 100644
--- a/Sample/StandardSamples/CompoundBuilder.h
+++ b/Sample/StandardSamples/CompoundBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_COMPOUNDBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_COMPOUNDBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createCompound();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_COMPOUNDBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/CoreAndShellBuilder.h b/Sample/StandardSamples/CoreAndShellBuilder.h
index 6800fc376156b8365e4ae803164d131a9fc8f9a5..89b3df6907711da1962fda7ed5dd27c7c8737065 100644
--- a/Sample/StandardSamples/CoreAndShellBuilder.h
+++ b/Sample/StandardSamples/CoreAndShellBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_COREANDSHELLBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_COREANDSHELLBUILDER_H
 
@@ -42,4 +40,3 @@ MultiLayer* createCoreShellBoxRotateZandY();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_COREANDSHELLBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/CustomMorphologyBuilder.h b/Sample/StandardSamples/CustomMorphologyBuilder.h
index a046d8357382f507006946b284fbd5385fe8b437..b9cae379ba72211589f58d12e81cb9a4ebf9deae 100644
--- a/Sample/StandardSamples/CustomMorphologyBuilder.h
+++ b/Sample/StandardSamples/CustomMorphologyBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_CUSTOMMORPHOLOGYBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_CUSTOMMORPHOLOGYBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createCustomMorphology();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_CUSTOMMORPHOLOGYBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/CylindersAndPrismsBuilder.h b/Sample/StandardSamples/CylindersAndPrismsBuilder.h
index 1e00118aa9ebe34946b0e42344b7c84d169c077b..c213bb31487f9a6cee4066422495a283a808fbfe 100644
--- a/Sample/StandardSamples/CylindersAndPrismsBuilder.h
+++ b/Sample/StandardSamples/CylindersAndPrismsBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSANDPRISMSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSANDPRISMSBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createCylindersAndPrisms();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSANDPRISMSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/CylindersBuilder.h b/Sample/StandardSamples/CylindersBuilder.h
index 8bfc058f8118ae033fb39922e31417329a7c855e..fb01c26073037fae54d486c7ff2897901b472e37 100644
--- a/Sample/StandardSamples/CylindersBuilder.h
+++ b/Sample/StandardSamples/CylindersBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSBUILDER_H
 
@@ -39,4 +37,3 @@ MultiLayer* createLargeCylindersInDWBA(double height = 1000, double radius = 500
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_CYLINDERSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/FeNiBilayerBuilder.cpp b/Sample/StandardSamples/FeNiBilayerBuilder.cpp
index 645d9127e5c9812182f920de635e0774b61334bc..3d3b7f5b9eb85eacee8ac2378bc4160f44e547cc 100644
--- a/Sample/StandardSamples/FeNiBilayerBuilder.cpp
+++ b/Sample/StandardSamples/FeNiBilayerBuilder.cpp
@@ -86,7 +86,6 @@ public:
     }
 };
 
-#ifndef USER_API
 
 //! Creates the sample demonstrating an Fe-Ni Bilayer with and without roughness
 //! @ingroup standard_samples
@@ -162,7 +161,6 @@ std::unique_ptr<MultiLayer> FeNiBilayer::constructSample()
     return sample;
 }
 
-#endif // USER_API
 
 MultiLayer* ExemplarySamples::createFeNiBilayer()
 {
diff --git a/Sample/StandardSamples/FeNiBilayerBuilder.h b/Sample/StandardSamples/FeNiBilayerBuilder.h
index 9b9aa83dec962e6fc12bd74aabde0039d0b673fd..4a37917f0f821cea4c68ab09d00d5abdcbaffecf 100644
--- a/Sample/StandardSamples/FeNiBilayerBuilder.h
+++ b/Sample/StandardSamples/FeNiBilayerBuilder.h
@@ -15,9 +15,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_FENIBILAYERBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_FENIBILAYERBUILDER_H
 
@@ -61,4 +59,3 @@ MultiLayer* createFeNiBilayerSpinFlipNC();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_FENIBILAYERBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/HomogeneousMultilayerBuilder.h b/Sample/StandardSamples/HomogeneousMultilayerBuilder.h
index 36b938befcfaab939348011dd4bef2dbc5978712..4d82b1a0d5ab494f39c40615c363ca999bd71970 100644
--- a/Sample/StandardSamples/HomogeneousMultilayerBuilder.h
+++ b/Sample/StandardSamples/HomogeneousMultilayerBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_HOMOGENEOUSMULTILAYERBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_HOMOGENEOUSMULTILAYERBUILDER_H
 
@@ -35,4 +33,3 @@ MultiLayer* createHomogeneousMultilayer();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_HOMOGENEOUSMULTILAYERBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/LatticeBuilder.h b/Sample/StandardSamples/LatticeBuilder.h
index 7e985a925108af8740b94a0494908094dda4481e..5c545a6e751539541ab56095d839740c57432916 100644
--- a/Sample/StandardSamples/LatticeBuilder.h
+++ b/Sample/StandardSamples/LatticeBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_LATTICEBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_LATTICEBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createLattice1D();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_LATTICEBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/LayersWithAbsorptionBuilder.h b/Sample/StandardSamples/LayersWithAbsorptionBuilder.h
index 730808a3f736d40308201b93ff07ced05ab093d1..32288f548d00aad65b8888e4f448f0c7ccd09d1a 100644
--- a/Sample/StandardSamples/LayersWithAbsorptionBuilder.h
+++ b/Sample/StandardSamples/LayersWithAbsorptionBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBUILDER_H
 
@@ -36,4 +34,3 @@ MultiLayer* createLayersWithAbsorptionWithFF(const IFormFactor*);
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/LayersWithAbsorptionBySLDBuilder.h b/Sample/StandardSamples/LayersWithAbsorptionBySLDBuilder.h
index 13a8b2f9e0c8b78ab0499b9b93ca07b0d68f60e1..9a359b6fe839a529db6903d1bf7f237bce2d2cca 100644
--- a/Sample/StandardSamples/LayersWithAbsorptionBySLDBuilder.h
+++ b/Sample/StandardSamples/LayersWithAbsorptionBySLDBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBYSLDBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBYSLDBUILDER_H
 
@@ -35,4 +33,3 @@ MultiLayer* createLayersWithAbsorptionBySLD();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_LAYERSWITHABSORPTIONBYSLDBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MagneticLayersBuilder.h b/Sample/StandardSamples/MagneticLayersBuilder.h
index df4aeead57408c87a383818be0e03ac69e3bea20..8aac1b03ee69e3be98aea9fe0399ee40dab0a6d5 100644
--- a/Sample/StandardSamples/MagneticLayersBuilder.h
+++ b/Sample/StandardSamples/MagneticLayersBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICLAYERSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICLAYERSBUILDER_H
 
@@ -70,4 +68,3 @@ MultiLayer* createMagneticRotation();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICLAYERSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MagneticParticlesBuilder.h b/Sample/StandardSamples/MagneticParticlesBuilder.h
index 469984db84bc6d49af06b88d51bec10465834941..4247d23f1ff4b84756e4b1633115671dbe22ed22 100644
--- a/Sample/StandardSamples/MagneticParticlesBuilder.h
+++ b/Sample/StandardSamples/MagneticParticlesBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICPARTICLESBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICPARTICLESBUILDER_H
 
@@ -51,4 +49,3 @@ MultiLayer* createMagneticSpheres();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MAGNETICPARTICLESBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MesocrystalBuilder.h b/Sample/StandardSamples/MesocrystalBuilder.h
index 2ca175b26b68c436b46c4e9d522d9219a1f10635..88c435e1cd04e2e94b1c82ed652566f19e85c5d9 100644
--- a/Sample/StandardSamples/MesocrystalBuilder.h
+++ b/Sample/StandardSamples/MesocrystalBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MESOCRYSTALBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MESOCRYSTALBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createMesocrystal();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MESOCRYSTALBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MultiLayerWithNCRoughnessBuilder.h b/Sample/StandardSamples/MultiLayerWithNCRoughnessBuilder.h
index 24f225cd3ad8b624f33e56659eb5f8a0e63f6249..0561740c6299440d995a99bfcbb1cd5c7543584e 100644
--- a/Sample/StandardSamples/MultiLayerWithNCRoughnessBuilder.h
+++ b/Sample/StandardSamples/MultiLayerWithNCRoughnessBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHNCROUGHNESSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHNCROUGHNESSBUILDER_H
 
@@ -34,4 +32,3 @@ MultiLayer* createMultiLayerWithNCRoughness();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHNCROUGHNESSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MultiLayerWithRoughnessBuilder.h b/Sample/StandardSamples/MultiLayerWithRoughnessBuilder.h
index c464f30f6f3b98ca07bfe404136b9a8aa8d8e774..3869812bec4d99d6646706911d5e571b7e6013ad 100644
--- a/Sample/StandardSamples/MultiLayerWithRoughnessBuilder.h
+++ b/Sample/StandardSamples/MultiLayerWithRoughnessBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHROUGHNESSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHROUGHNESSBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createMultiLayerWithRoughness();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTILAYERWITHROUGHNESSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/MultipleLayoutBuilder.h b/Sample/StandardSamples/MultipleLayoutBuilder.h
index cab1f32e4af58ccf69089972d6aa1053821e89c6..0e4962ff59c12dfbf73211a2828243d1a61a0193 100644
--- a/Sample/StandardSamples/MultipleLayoutBuilder.h
+++ b/Sample/StandardSamples/MultipleLayoutBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTIPLELAYOUTBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTIPLELAYOUTBUILDER_H
 
@@ -34,4 +32,3 @@ MultiLayer* createMultipleLayout();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_MULTIPLELAYOUTBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ParacrystalBuilder.h b/Sample/StandardSamples/ParacrystalBuilder.h
index ef0993c6ca63a6c576ffa12992e6fcea3a80b750..24fbfba437a186322247ec394251cc207eb2da50 100644
--- a/Sample/StandardSamples/ParacrystalBuilder.h
+++ b/Sample/StandardSamples/ParacrystalBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARACRYSTALBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARACRYSTALBUILDER_H
 
@@ -65,4 +63,3 @@ MultiLayer* createRectParacrystal();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARACRYSTALBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ParticleDistributionsBuilder.h b/Sample/StandardSamples/ParticleDistributionsBuilder.h
index 67e2f99875aa5c32f90507766881e7eda4664ab2..940a9d1909496e38623f3429f799e5cde6392a6d 100644
--- a/Sample/StandardSamples/ParticleDistributionsBuilder.h
+++ b/Sample/StandardSamples/ParticleDistributionsBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEDISTRIBUTIONSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEDISTRIBUTIONSBUILDER_H
 
@@ -78,4 +76,3 @@ MultiLayer* createLinkedBoxDistribution();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEDISTRIBUTIONSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ParticleInVacuumBuilder.h b/Sample/StandardSamples/ParticleInVacuumBuilder.h
index 8faeec1f48a4da8f9ac6456b2a85574d5326740a..e957c885e7ec77218c3036adab4a45c35d5e7d34 100644
--- a/Sample/StandardSamples/ParticleInVacuumBuilder.h
+++ b/Sample/StandardSamples/ParticleInVacuumBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEINVACUUMBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEINVACUUMBUILDER_H
 
@@ -34,4 +32,3 @@ MultiLayer* createParticleInVacuumWithFF(const IFormFactor*);
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_PARTICLEINVACUUMBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/PercusYevickBuilder.h b/Sample/StandardSamples/PercusYevickBuilder.h
index 25377baf8dd1de3aa2157a3f7d204bbd8932ea8b..2da4a7045ac665ad7383d03ce57a10f4048708a5 100644
--- a/Sample/StandardSamples/PercusYevickBuilder.h
+++ b/Sample/StandardSamples/PercusYevickBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_PERCUSYEVICKBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_PERCUSYEVICKBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createHardDisk();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_PERCUSYEVICKBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/PlainMultiLayerBySLDBuilder.h b/Sample/StandardSamples/PlainMultiLayerBySLDBuilder.h
index d558e075b352f18cf12bc612ecef7f21a8b1166d..242cf1a933551bedadbc8dbca21528e0cf3f41ef 100644
--- a/Sample/StandardSamples/PlainMultiLayerBySLDBuilder.h
+++ b/Sample/StandardSamples/PlainMultiLayerBySLDBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_PLAINMULTILAYERBYSLDBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_PLAINMULTILAYERBYSLDBUILDER_H
 
@@ -34,4 +32,3 @@ MultiLayer* createPlainMultiLayerBySLD(int n_layers = 10, double thick_ti = 3.0)
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_PLAINMULTILAYERBYSLDBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ReferenceMaterials.h b/Sample/StandardSamples/ReferenceMaterials.h
index bb42b173b20c272171cf2afae8895f794affa490..e3ceacf6e95b349e0696cdfc44d457ac2cafd060 100644
--- a/Sample/StandardSamples/ReferenceMaterials.h
+++ b/Sample/StandardSamples/ReferenceMaterials.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_REFERENCEMATERIALS_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_REFERENCEMATERIALS_H
 
@@ -41,4 +39,3 @@ static const Material Substrate2 = RefractiveMaterial("Substrate2", 3.212e-6, 3.
 } // namespace refMat
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_REFERENCEMATERIALS_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ResonatorBuilder.h b/Sample/StandardSamples/ResonatorBuilder.h
index f4543c4507b331b8322eb2d9fec9a3cc149f93eb..32dfda5334ffd60c043673476df1041c54aa5017 100644
--- a/Sample/StandardSamples/ResonatorBuilder.h
+++ b/Sample/StandardSamples/ResonatorBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_RESONATORBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_RESONATORBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createResonator(double ti_thickness = 13.0);
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_RESONATORBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/RipplesBuilder.h b/Sample/StandardSamples/RipplesBuilder.h
index 94486fe553c544b022c63696210ea5cc5385f72b..49dbca0b1b61966c90ce5cc35f175dfb0ff26f71 100644
--- a/Sample/StandardSamples/RipplesBuilder.h
+++ b/Sample/StandardSamples/RipplesBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_RIPPLESBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_RIPPLESBUILDER_H
 
@@ -48,4 +46,3 @@ MultiLayer* createAsymRipple();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_RIPPLESBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/RotatedPyramidsBuilder.h b/Sample/StandardSamples/RotatedPyramidsBuilder.h
index 70cc017d851571f42fce4920696015aaab8a471b..395178bdb2ef46c323bc298aac7e1b69d90be406 100644
--- a/Sample/StandardSamples/RotatedPyramidsBuilder.h
+++ b/Sample/StandardSamples/RotatedPyramidsBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_ROTATEDPYRAMIDSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_ROTATEDPYRAMIDSBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createRotatedPyramids();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_ROTATEDPYRAMIDSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/SizeDistributionModelsBuilder.h b/Sample/StandardSamples/SizeDistributionModelsBuilder.h
index 55b82f73bf51c859fca6bac3172999550a56ba75..64fa31b3ff67ca78c1b3a768f457f2ea8d7d82e0 100644
--- a/Sample/StandardSamples/SizeDistributionModelsBuilder.h
+++ b/Sample/StandardSamples/SizeDistributionModelsBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_SIZEDISTRIBUTIONMODELSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_SIZEDISTRIBUTIONMODELSBUILDER_H
 
@@ -63,4 +61,3 @@ MultiLayer* createCylindersInSSCA();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_SIZEDISTRIBUTIONMODELSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/SlicedCompositionBuilder.h b/Sample/StandardSamples/SlicedCompositionBuilder.h
index 71074e7cd4c3594b1c6c79710ff083cc318d5d25..4716f5f5d2d52f08b57afdc177ebcf42529c0e56 100644
--- a/Sample/StandardSamples/SlicedCompositionBuilder.h
+++ b/Sample/StandardSamples/SlicedCompositionBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCOMPOSITIONBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCOMPOSITIONBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createSlicedComposition();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCOMPOSITIONBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/SlicedCylindersBuilder.h b/Sample/StandardSamples/SlicedCylindersBuilder.h
index ff388b7b3d93b4756028ac664d5dfca3d95e591b..38bff85ff937e03fec03dda8d6044b1b3f6921e9 100644
--- a/Sample/StandardSamples/SlicedCylindersBuilder.h
+++ b/Sample/StandardSamples/SlicedCylindersBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCYLINDERSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCYLINDERSBUILDER_H
 
@@ -54,4 +52,3 @@ MultiLayer* createAveragedSlicedCylinders();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_SLICEDCYLINDERSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/ThickAbsorptiveSampleBuilder.h b/Sample/StandardSamples/ThickAbsorptiveSampleBuilder.h
index 8e8cc2fa4081f7ea2141e4a80967d13b7f3e8c9d..28c103be85b031e34b05ee5392af8ad45360a837 100644
--- a/Sample/StandardSamples/ThickAbsorptiveSampleBuilder.h
+++ b/Sample/StandardSamples/ThickAbsorptiveSampleBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_THICKABSORPTIVESAMPLEBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_THICKABSORPTIVESAMPLEBUILDER_H
 
@@ -30,4 +28,3 @@ MultiLayer* createThickAbsorptiveSample();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_THICKABSORPTIVESAMPLEBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/TransformationsBuilder.h b/Sample/StandardSamples/TransformationsBuilder.h
index cac21f5eda2bed19dd5d55043ff4ff89d4bb7dd3..e6a0da92321535688dc1e6034a767d2266a738eb 100644
--- a/Sample/StandardSamples/TransformationsBuilder.h
+++ b/Sample/StandardSamples/TransformationsBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_TRANSFORMATIONSBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_TRANSFORMATIONSBUILDER_H
 
@@ -33,4 +31,3 @@ MultiLayer* createTransformBox();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_TRANSFORMATIONSBUILDER_H
-#endif // USER_API
diff --git a/Sample/StandardSamples/TwoDimLatticeBuilder.h b/Sample/StandardSamples/TwoDimLatticeBuilder.h
index 28af754ce743ae18e7106d1e813956e13f8924d5..915555dc3e192df612a2daf52f334d7ce2e1e91c 100644
--- a/Sample/StandardSamples/TwoDimLatticeBuilder.h
+++ b/Sample/StandardSamples/TwoDimLatticeBuilder.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SAMPLE_STANDARDSAMPLES_TWODIMLATTICEBUILDER_H
 #define BORNAGAIN_SAMPLE_STANDARDSAMPLES_TWODIMLATTICEBUILDER_H
 
@@ -78,4 +76,3 @@ MultiLayer* createSuperLattice();
 } // namespace ExemplarySamples
 
 #endif // BORNAGAIN_SAMPLE_STANDARDSAMPLES_TWODIMLATTICEBUILDER_H
-#endif // USER_API
diff --git a/Sim/Computation/ComputationStatus.h b/Sim/Computation/ComputationStatus.h
index 7f79604042d63f5282d3cc841750589e06c593af..396e303dc6d7fd28ab95135f994a90c07b623731 100644
--- a/Sim/Computation/ComputationStatus.h
+++ b/Sim/Computation/ComputationStatus.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_COMPUTATION_COMPUTATIONSTATUS_H
 #define BORNAGAIN_SIM_COMPUTATION_COMPUTATIONSTATUS_H
 
@@ -50,4 +48,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_COMPUTATION_COMPUTATIONSTATUS_H
-#endif // USER_API
diff --git a/Sim/Computation/DWBAComputation.h b/Sim/Computation/DWBAComputation.h
index ea074ca36cd94cd03182b666455aa10107fe411b..726916514c5e98be75881e49bcb21fbf4557690f 100644
--- a/Sim/Computation/DWBAComputation.h
+++ b/Sim/Computation/DWBAComputation.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_COMPUTATION_DWBACOMPUTATION_H
 #define BORNAGAIN_SIM_COMPUTATION_DWBACOMPUTATION_H
 
@@ -58,4 +56,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_COMPUTATION_DWBACOMPUTATION_H
-#endif // USER_API
diff --git a/Sim/Computation/DepthProbeComputation.h b/Sim/Computation/DepthProbeComputation.h
index f7ca6e50b51811f844aa7e1ba902664381f19f56..04d3425f584c6d9a52b47496bf8076d493a143ba 100644
--- a/Sim/Computation/DepthProbeComputation.h
+++ b/Sim/Computation/DepthProbeComputation.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_COMPUTATION_DEPTHPROBECOMPUTATION_H
 #define BORNAGAIN_SIM_COMPUTATION_DEPTHPROBECOMPUTATION_H
 
@@ -46,4 +44,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_COMPUTATION_DEPTHPROBECOMPUTATION_H
-#endif // USER_API
diff --git a/Sim/Computation/IComputation.h b/Sim/Computation/IComputation.h
index 3accdf85dd55932a17d7cea08a36e0ae36741665..378bfcf7b04dae809b0a551478c9a8984f8a8787 100644
--- a/Sim/Computation/IComputation.h
+++ b/Sim/Computation/IComputation.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_COMPUTATION_ICOMPUTATION_H
 #define BORNAGAIN_SIM_COMPUTATION_ICOMPUTATION_H
 
@@ -63,4 +61,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_COMPUTATION_ICOMPUTATION_H
-#endif // USER_API
diff --git a/Sim/Computation/SpecularComputation.h b/Sim/Computation/SpecularComputation.h
index 564fea49845b7f481e776bcc1d58739c055fa41c..8a10a5c7c6e41d1ed980d5ec42f258c05eda848b 100644
--- a/Sim/Computation/SpecularComputation.h
+++ b/Sim/Computation/SpecularComputation.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_COMPUTATION_SPECULARCOMPUTATION_H
 #define BORNAGAIN_SIM_COMPUTATION_SPECULARCOMPUTATION_H
 
@@ -46,4 +44,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_COMPUTATION_SPECULARCOMPUTATION_H
-#endif // USER_API
diff --git a/Sim/Contrib/GISASSpecularContribution.h b/Sim/Contrib/GISASSpecularContribution.h
index fc92a27aeebce2f9ae8ccee9d5dec4f605f7d775..63bb638a65fa4b3de6eb62ce8571e607d4a66998 100644
--- a/Sim/Contrib/GISASSpecularContribution.h
+++ b/Sim/Contrib/GISASSpecularContribution.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_CONTRIB_GISASSPECULARCONTRIBUTION_H
 #define BORNAGAIN_SIM_CONTRIB_GISASSPECULARCONTRIBUTION_H
 
@@ -32,4 +30,3 @@ public:
 };
 
 #endif // BORNAGAIN_SIM_CONTRIB_GISASSPECULARCONTRIBUTION_H
-#endif // USER_API
diff --git a/Sim/Contrib/ParticleLayoutContribution.h b/Sim/Contrib/ParticleLayoutContribution.h
index 8022642d8c859d637acb5596b47019e5f937a081..cbc0aee31a2d995dcdf229198c0409ae22a818aa 100644
--- a/Sim/Contrib/ParticleLayoutContribution.h
+++ b/Sim/Contrib/ParticleLayoutContribution.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_CONTRIB_PARTICLELAYOUTCONTRIBUTION_H
 #define BORNAGAIN_SIM_CONTRIB_PARTICLELAYOUTCONTRIBUTION_H
 
@@ -44,4 +42,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_CONTRIB_PARTICLELAYOUTCONTRIBUTION_H
-#endif // USER_API
diff --git a/Sim/Contrib/RoughMultiLayerContribution.h b/Sim/Contrib/RoughMultiLayerContribution.h
index a32fbc92e0e653b526aab04cadde175e362eac34..c81f95560325064e0f3676e5bdcb67a74d354c61 100644
--- a/Sim/Contrib/RoughMultiLayerContribution.h
+++ b/Sim/Contrib/RoughMultiLayerContribution.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_CONTRIB_ROUGHMULTILAYERCONTRIBUTION_H
 #define BORNAGAIN_SIM_CONTRIB_ROUGHMULTILAYERCONTRIBUTION_H
 
@@ -42,4 +40,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_CONTRIB_ROUGHMULTILAYERCONTRIBUTION_H
-#endif // USER_API
diff --git a/Sim/Export/ComponentKeyHandler.h b/Sim/Export/ComponentKeyHandler.h
index 4bce5784a63a022520b96c8aabe4a72186f9b689..ecd45ec847a47b9272c5669fc9eec34544ecc106 100644
--- a/Sim/Export/ComponentKeyHandler.h
+++ b/Sim/Export/ComponentKeyHandler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_COMPONENTKEYHANDLER_H
 #define BORNAGAIN_SIM_EXPORT_COMPONENTKEYHANDLER_H
 
@@ -52,4 +50,3 @@ std::vector<const T*> ComponentKeyHandler::objectsOfType() const
 }
 
 #endif // BORNAGAIN_SIM_EXPORT_COMPONENTKEYHANDLER_H
-#endif // USER_API
diff --git a/Sim/Export/MaterialKeyHandler.h b/Sim/Export/MaterialKeyHandler.h
index 9b71f77f8d6e955c44e1e7ce883b4b20461fa748..90a3a62f6a6a38ee13dba27dbbd2817a4a8f2d97 100644
--- a/Sim/Export/MaterialKeyHandler.h
+++ b/Sim/Export/MaterialKeyHandler.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_MATERIALKEYHANDLER_H
 #define BORNAGAIN_SIM_EXPORT_MATERIALKEYHANDLER_H
 
@@ -40,4 +38,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_EXPORT_MATERIALKEYHANDLER_H
-#endif // USER_API
diff --git a/Sim/Export/PyFmt2.h b/Sim/Export/PyFmt2.h
index a4bfc80fa622d3e0572d7353e2219ebf490c221c..94f634d5c349a885e66d8a4a74663701872e9d81 100644
--- a/Sim/Export/PyFmt2.h
+++ b/Sim/Export/PyFmt2.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_PYFMT2_H
 #define BORNAGAIN_SIM_EXPORT_PYFMT2_H
 
@@ -47,4 +45,3 @@ std::string printRangedDistribution(const IRangedDistribution& distr);
 } // namespace Py::Fmt2
 
 #endif // BORNAGAIN_SIM_EXPORT_PYFMT2_H
-#endif // USER_API
diff --git a/Sim/Export/PyFmtLimits.h b/Sim/Export/PyFmtLimits.h
index fb74fbc1b02fc9187436217654cac39d0c031e22..36a472813233e0d5aebbcebd9980e3175264e8e9 100644
--- a/Sim/Export/PyFmtLimits.h
+++ b/Sim/Export/PyFmtLimits.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_PYFMTLIMITS_H
 #define BORNAGAIN_SIM_EXPORT_PYFMTLIMITS_H
 
@@ -34,4 +32,3 @@ std::string printRealLimitsArg(const RealLimits& limits, const std::string& unit
 } // namespace Py::Fmt
 
 #endif // BORNAGAIN_SIM_EXPORT_PYFMTLIMITS_H
-#endif // USER_API
diff --git a/Sim/Export/SampleToPython.h b/Sim/Export/SampleToPython.h
index c449a0f167a3e7625fc77e1fa59bc9c896c25a8c..e0c5363fe1728dfe63d9881c2a0845bba1888d68 100644
--- a/Sim/Export/SampleToPython.h
+++ b/Sim/Export/SampleToPython.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_SAMPLETOPYTHON_H
 #define BORNAGAIN_SIM_EXPORT_SAMPLETOPYTHON_H
 
@@ -36,4 +34,3 @@ public:
 };
 
 #endif // BORNAGAIN_SIM_EXPORT_SAMPLETOPYTHON_H
-#endif // USER_API
diff --git a/Sim/Export/SimulationToPython.h b/Sim/Export/SimulationToPython.h
index b4cc574374f1ecf4ec76583133211f81deb3a634..0a118bd2895152042b153d6b70ae55322617ed96 100644
--- a/Sim/Export/SimulationToPython.h
+++ b/Sim/Export/SimulationToPython.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_EXPORT_SIMULATIONTOPYTHON_H
 #define BORNAGAIN_SIM_EXPORT_SIMULATIONTOPYTHON_H
 
@@ -35,4 +33,3 @@ public:
 };
 
 #endif // BORNAGAIN_SIM_EXPORT_SIMULATIONTOPYTHON_H
-#endif // USER_API
diff --git a/Sim/Fitting/FitObjective.h b/Sim/Fitting/FitObjective.h
index 272621df0d20f96f0df5c69dbfc3b107d888caf6..c070bad336314d4a44ce976208c6529623ba95b3 100644
--- a/Sim/Fitting/FitObjective.h
+++ b/Sim/Fitting/FitObjective.h
@@ -15,7 +15,6 @@
 #ifndef BORNAGAIN_SIM_FITTING_FITOBJECTIVE_H
 #define BORNAGAIN_SIM_FITTING_FITOBJECTIVE_H
 
-#ifndef USER_API
 #include "Device/Data/ArrayUtils.h"
 #include "Sim/Fitting/FitTypes.h"
 
@@ -143,4 +142,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_FITTING_FITOBJECTIVE_H
-#endif // USER_API
diff --git a/Sim/Fitting/FitObserver.h b/Sim/Fitting/FitObserver.h
index dcd77ce267027ef9fa1a8691d6de43b68d824f16..e613af349978f0890e89e71b25261fb2c88ca204 100644
--- a/Sim/Fitting/FitObserver.h
+++ b/Sim/Fitting/FitObserver.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_FITOBSERVER_H
 #define BORNAGAIN_SIM_FITTING_FITOBSERVER_H
 
@@ -105,4 +103,3 @@ bool FitObserver<T>::need_notify(int every_nth)
 }
 
 #endif // BORNAGAIN_SIM_FITTING_FITOBSERVER_H
-#endif // USER_API
diff --git a/Sim/Fitting/FitPrintService.h b/Sim/Fitting/FitPrintService.h
index 54c822990308a1cebf5efcd6518982a2cc02f572..c8493e9503cd0031f8a2181bf8e2f1106600c193 100644
--- a/Sim/Fitting/FitPrintService.h
+++ b/Sim/Fitting/FitPrintService.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_FITPRINTSERVICE_H
 #define BORNAGAIN_SIM_FITTING_FITPRINTSERVICE_H
 
@@ -44,4 +42,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_FITTING_FITPRINTSERVICE_H
-#endif // USER_API
diff --git a/Sim/Fitting/FitStatus.h b/Sim/Fitting/FitStatus.h
index 8432cf0bd6cef8eb29d65e13e94b8d28eafa596d..a726b4bd2ed2ef09f351a832e2c14cdc88f6cf52 100644
--- a/Sim/Fitting/FitStatus.h
+++ b/Sim/Fitting/FitStatus.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_FITSTATUS_H
 #define BORNAGAIN_SIM_FITTING_FITSTATUS_H
 
@@ -69,4 +67,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_FITTING_FITSTATUS_H
-#endif // USER_API
diff --git a/Sim/Fitting/FitTypes.h b/Sim/Fitting/FitTypes.h
index 74f3137ee82cd5777b741b3beeb50cbd2e6afb17..9d252fc9974373b0a33636f5c7deac20a7ad4e0c 100644
--- a/Sim/Fitting/FitTypes.h
+++ b/Sim/Fitting/FitTypes.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_FITTYPES_H
 #define BORNAGAIN_SIM_FITTING_FITTYPES_H
 
@@ -36,4 +34,3 @@ using simulation_builder_t =
 using fit_observer_t = std::function<void(const FitObjective&)>;
 
 #endif // BORNAGAIN_SIM_FITTING_FITTYPES_H
-#endif // USER_API
diff --git a/Sim/Fitting/ObjectiveMetric.h b/Sim/Fitting/ObjectiveMetric.h
index fbe69463b0a0acb279f5d434cd57a4cb8016f046..137fcda19cd8e2bb65a94eec21f5c8c451036e31 100644
--- a/Sim/Fitting/ObjectiveMetric.h
+++ b/Sim/Fitting/ObjectiveMetric.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_OBJECTIVEMETRIC_H
 #define BORNAGAIN_SIM_FITTING_OBJECTIVEMETRIC_H
 
@@ -199,4 +197,3 @@ public:
 };
 
 #endif // BORNAGAIN_SIM_FITTING_OBJECTIVEMETRIC_H
-#endif // USER_API
diff --git a/Sim/Fitting/ObjectiveMetricUtils.h b/Sim/Fitting/ObjectiveMetricUtils.h
index 5124db2ed90734e03f3c2af6120f5085cf60b057..ecee869694e66df01c58f6a2e2b9ae2cedb6e363 100644
--- a/Sim/Fitting/ObjectiveMetricUtils.h
+++ b/Sim/Fitting/ObjectiveMetricUtils.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_OBJECTIVEMETRICUTILS_H
 #define BORNAGAIN_SIM_FITTING_OBJECTIVEMETRICUTILS_H
 
@@ -60,4 +58,3 @@ std::string defaultMetricName();
 } // namespace ObjectiveMetricUtils
 
 #endif // BORNAGAIN_SIM_FITTING_OBJECTIVEMETRICUTILS_H
-#endif // USER_API
diff --git a/Sim/Fitting/SimDataPair.h b/Sim/Fitting/SimDataPair.h
index acd82725a31698b1d8e95fc953df1545ba5f8cfa..6f5e424e389de40496805063b62c7c6b4bc7d543 100644
--- a/Sim/Fitting/SimDataPair.h
+++ b/Sim/Fitting/SimDataPair.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_SIM_FITTING_SIMDATAPAIR_H
 #define BORNAGAIN_SIM_FITTING_SIMDATAPAIR_H
 
@@ -102,4 +100,3 @@ private:
 };
 
 #endif // BORNAGAIN_SIM_FITTING_SIMDATAPAIR_H
-#endif // USER_API
diff --git a/Sim/Residual/VarianceFunctions.h b/Sim/Residual/VarianceFunctions.h
index 8d74550283e5d10777618f7b4f981ac0a4f8f4b9..fae0fe65f0326015cbdd0df5be03cfeb6340ee5b 100644
--- a/Sim/Residual/VarianceFunctions.h
+++ b/Sim/Residual/VarianceFunctions.h
@@ -15,7 +15,6 @@
 #ifndef BORNAGAIN_SIM_RESIDUAL_VARIANCEFUNCTIONS_H
 #define BORNAGAIN_SIM_RESIDUAL_VARIANCEFUNCTIONS_H
 
-#ifndef USER_API
 
 //! Variance function interface.
 
@@ -29,7 +28,6 @@ public:
     virtual IVarianceFunction* clone() const = 0;
     virtual double variance(double real_value, double simulated_value) const = 0;
 };
-#endif // USER_API
 
 //! Returns 1.0 as variance value
 //! @ingroup fitting
diff --git a/Sim/Scan/AlphaScan.h b/Sim/Scan/AlphaScan.h
index 98804d85cb7f0a6a30607d34e438c8cb6b3af177..3061791c4e3a87ef069a8caf68247c1f162273f2 100644
--- a/Sim/Scan/AlphaScan.h
+++ b/Sim/Scan/AlphaScan.h
@@ -74,7 +74,7 @@ public:
     {
         return m_inc_resolution.get();
     }
-#endif // USER_API
+#endif // SWIG
 
     double wavelength() const override
     {
diff --git a/Sim/Scan/ISpecularScan.h b/Sim/Scan/ISpecularScan.h
index 7519064bf80ebe6443a59bde63b944a4ea11800a..2d87d9819003d5790a3e1aa2faabe63b4f760b87 100644
--- a/Sim/Scan/ISpecularScan.h
+++ b/Sim/Scan/ISpecularScan.h
@@ -12,7 +12,6 @@
 //
 //  ************************************************************************************************
 
-#ifndef USER_API
 #ifndef BORNAGAIN_SIM_SCAN_ISPECULARSCAN_H
 #define BORNAGAIN_SIM_SCAN_ISPECULARSCAN_H
 
@@ -81,4 +80,3 @@ protected:
 };
 
 #endif // BORNAGAIN_SIM_SCAN_ISPECULARSCAN_H
-#endif // USER_API
diff --git a/Sim/Scan/QzScan.h b/Sim/Scan/QzScan.h
index e84c8a3dcb5331b95c8c21c35e57721c1c8a4071..7d4820efc36add61d9a35eb24166d2a1e7443dc9 100644
--- a/Sim/Scan/QzScan.h
+++ b/Sim/Scan/QzScan.h
@@ -71,7 +71,7 @@ public:
     //! Returns intensity vector corresponding to convolution of given simulation elements
     std::vector<double> createIntensities(const std::vector<SpecularElement>& eles) const override;
 
-#endif // USER_API
+#endif // SWIG
 
     //! Sets q resolution values via ScanResolution object.
     void setQResolution(const ScanResolution& resolution);
diff --git a/Sim/Scan/ScanResolution.h b/Sim/Scan/ScanResolution.h
index 84e4042dfc860d9b86e14d9da9e3869785be4c25..6d3d7dca00a4fe59e82a5be532ad3474bfa3a21b 100644
--- a/Sim/Scan/ScanResolution.h
+++ b/Sim/Scan/ScanResolution.h
@@ -59,7 +59,7 @@ public:
     virtual std::string name() const = 0;
     virtual double delta() const = 0;
 
-#endif // USER_API
+#endif // SWIG
 protected:
     ScanResolution();
     ScanResolution(const IRangedDistribution& distr);
diff --git a/Sim/Simulation/SpecularSimulation.h b/Sim/Simulation/SpecularSimulation.h
index 91e0495484f787edac76c64ff58fc6e029891e4a..70840ae25a6e570ac69f4fd428d168493d7d6bc2 100644
--- a/Sim/Simulation/SpecularSimulation.h
+++ b/Sim/Simulation/SpecularSimulation.h
@@ -86,7 +86,7 @@ private:
     std::unique_ptr<const ISpecularScan> m_scan;
     std::vector<SpecularElement> m_eles;
     std::vector<double> m_cache;
-#endif // USER_API
+#endif // SWIG
 };
 
 #endif // BORNAGAIN_SIM_SIMULATION_SPECULARSIMULATION_H
diff --git a/Tests/Functional/Suite/MakeSimulations.h b/Tests/Functional/Suite/MakeSimulations.h
index cdd2f8472686d2c55f09b30f1712026201444310..cbcd4d9c3b2c7e6cada42e5f08f2aafe85c14b0e 100644
--- a/Tests/Functional/Suite/MakeSimulations.h
+++ b/Tests/Functional/Suite/MakeSimulations.h
@@ -14,9 +14,7 @@
 
 #ifdef SWIG
 #error no need to expose this header to Swig
-#endif
-
-#ifndef USER_API
+#endif // SWIG
 #ifndef BORNAGAIN_TESTS_FUNCTIONAL_SUITE_MAKESIMULATIONS_H
 #define BORNAGAIN_TESTS_FUNCTIONAL_SUITE_MAKESIMULATIONS_H
 
@@ -74,4 +72,3 @@ std::unique_ptr<DepthProbeSimulation> BasicDepthProbe(const MultiLayer& sample);
 } // namespace test::makeSimulation
 
 #endif // BORNAGAIN_TESTS_FUNCTIONAL_SUITE_MAKESIMULATIONS_H
-#endif // USER_API