From b0238c23c6cb9e097d410d937afd40bbd65fcaf5 Mon Sep 17 00:00:00 2001
From: Riegel <alexander.riegel@hft-stuttgart.de>
Date: Thu, 8 Aug 2024 16:52:27 +0200
Subject: [PATCH] Created Documentation for CityDoctor Extensions

---
 CityDoctorParent/Extensions/README.md         | 122 ++++++++++++++++++
 CityDoctorParent/pom.xml                      |   5 +
 .../Badges/MaintenanceLevel_Abandoned.svg     |  23 ++++
 .../MaintenanceLevel_ActivelyDeveloped.svg    |  23 ++++
 .../MaintenanceLevel_ActivelyMaintained.svg   |  23 ++++
 .../Badges/MaintenanceLevel_Deprecated.svg    |  23 ++++
 .../MaintenanceLevel_InactivelyMaintained.svg |  23 ++++
 .../Badges/MaintenanceLevel_NotMaintained.svg |  23 ++++
 .../Badges/MaintenanceLevel_Obsolete.svg      |  23 ++++
 .../resources/Badges/Project_CD2.svg          |  22 ++++
 .../resources/Badges/Project_UDigiT.svg       |  22 ++++
 README.md                                     |   5 +-
 12 files changed, 336 insertions(+), 1 deletion(-)
 create mode 100644 CityDoctorParent/Extensions/README.md
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_Abandoned.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyDeveloped.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyMaintained.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_Deprecated.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_InactivelyMaintained.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_NotMaintained.svg
 create mode 100644 CityDoctorParent/resources/Badges/MaintenanceLevel_Obsolete.svg
 create mode 100644 CityDoctorParent/resources/Badges/Project_CD2.svg
 create mode 100644 CityDoctorParent/resources/Badges/Project_UDigiT.svg

diff --git a/CityDoctorParent/Extensions/README.md b/CityDoctorParent/Extensions/README.md
new file mode 100644
index 0000000..e3ce451
--- /dev/null
+++ b/CityDoctorParent/Extensions/README.md
@@ -0,0 +1,122 @@
+# CityDoctor2 Extensions
+Extension modules to the core functionality of CityDoctor2. 
+
+# Loading
+
+Except for CityDoctorGUI, all extension modules are not loaded into the Maven project by default.
+If you wish to load an extension, you can either import the respective Maven module directly, or adjust the CityDoctorParent
+pom.xml and move the respective modules out of the comment-block in the module list found at the end of the file.
+
+# Building
+
+All loaded modules will also be built upon building of the CityDoctorParent.
+
+# Module Information
+
+## CityDoctorAutoPro
+
+![Maintenance Level: Deprecated](../resources/Badges/MaintenanceLevel_Deprecated.svg)
+
+The AutoPro (short for automated processing) module is an interface for the conversion of the internal data model to a C++
+representation, to allow use of advanced functionalities of CGAL with CityDoctor2.
+
+### Usage
+
+The AutoPro module is deprecated and will be removed in a future release, once the C++ functionalities have been ported to Java.
+
+AutoPro requires a collection of .dll files to run, some of which are not available as open source projects. Access to the collection is only granted upon request. Contact a Maintainer for further information.
+
+## CityDoctorGUI
+![Maintenance Level: Actively Maintained](../resources/Badges/MaintenanceLevel_ActivelyMaintained.svg)
+
+The GUI module offers a graphical user interface for CityDoctor2, including a model viewer allowing for visual
+inspection of validation results and found errors.
+
+### View Plugins
+
+The GUI is expandable via plugins, enabling the creation of views for custom functionalities or extensions of the CityDoctor2 core.  
+Custom views can be created by extending the Abstract class `View` of the CityDoctorGUI and need to be registered by calling
+`ViewRegistration.registerView(View view);` before starting the GUI.
+
+### Usage
+
+> âš  CityDoctorGUI requires a JDK/JRE containing the JavaFX library to run.  
+
+Prebuilt binaries for the GUI are available in [CityDoctorReleases](https://transfer.hft-stuttgart.de/gitlab/citydoctor/citydoctorreleases).
+After extracting the archive the GUI can be started with **start.bat**.
+
+Binaries can be built with Maven using the create-binaries profile from the CityDoctorParent directory:  
+```
+mvn install -P create-binaries
+```   
+
+Lastly, the GUI can also be started by calling `MainWindow.main(args[])`.
+
+
+## CityDoctorHealer
+![Maintenance Level: Inactively Maintained](../resources/Badges/MaintenanceLevel_InactivelyMaintained.svg)
+
+CityDoctorHealer implements functionalities for the automated repair of geometries containing errors.
+The healer uses naive approaches to fix geometrical errors, and thus, it cannot be guaranteed that semantical
+correctness is maintained after the healing process.  
+
+
+### Usage
+
+Usage of CityDoctorHealer is similar to [CityDoctor](https://transfer.hft-stuttgart.de/gitlab/citydoctor/citydoctor2/-/tree/dev_GUI#usage).
+An example start command looks like this:
+```
+java -classpath libs/*;plugins/*;CityDoctorHealer-<version>.jar de.hft.stuttgart.citydoctor2.CityDoctorHealer -in <path-to-gml-file>.gml -config <path-to-validation-config>.yml -xmlReport <path-to-xml-output>.xml -pdfReport <path-to-pdf-output>.pdf -out <path-to-output-gml>.gml
+```
+Note: Unlike the CityDoctor core, the _-out_ argument is required
+
+To prevent infinite loops the `Healer` class has a limit for the number of healing iterations (default: 200). This limit
+can be changed by calling `Healer.setNumberOfIterations(int limit)`. 
+
+## CityDoctorHealerGenetic
+![Maintenance Level: Abandoned](../resources/Badges/MaintenanceLevel_Abandoned.svg)
+
+CityDoctorHealerGenetic uses a genetical algorithm to establish an optimal CityDoctorHealer healing-plan for geometries containing errors.
+
+### Usage
+> âš  This module has been abandoned. As of writing the module is still functional, but it may break at any time.
+>Issues, bug reports and suggestions for this module will not be processed. Use at your own discretion.
+
+Usage is nearly identical to CityDoctorHealer, only requiring changing the classpath to the HealerGenetic jar.
+
+A View for usage with CityDoctorGUI is included.
+
+## CityDoctorHealerGUI
+![Maintenance Level: Inactively Maintained](../resources/Badges/MaintenanceLevel_InactivelyMaintained.svg)
+
+CityDoctorGUI-view for CityDoctorHealer.
+
+### Usage
+
+See [CityDoctorGUI](#view-plugins)
+
+
+## CityDoctorWebService
+![Maintenance Level: Abandoned](../resources/Badges/MaintenanceLevel_Abandoned.svg)
+
+Web service API for CityDoctor.
+
+### Usage
+> âš  This module has been abandoned. As of writing the module is still functional, but it may break at any time.
+>Issues, bug reports and suggestions for this module will not be processed. Use at your own discretion.
+
+Run on a Tomcat Server.
+
+
+# Build
+
+Use [Maven](https://maven.apache.org/) to build CityDoctor2.
+
+```bash
+cd CityDoctorParent
+mvn install
+```
+
+
+## License
+[LGPL](http://www.gnu.org/licenses/lgpl-3.0.de.html)
diff --git a/CityDoctorParent/pom.xml b/CityDoctorParent/pom.xml
index afc82b4..1b8d4ca 100644
--- a/CityDoctorParent/pom.xml
+++ b/CityDoctorParent/pom.xml
@@ -258,15 +258,20 @@
         </dependency>
     </dependencies>
     <modules>
+        <!--CityDoctor2 Core Modules-->
         <module>CityDoctorModel</module>
         <module>CityDoctorValidation</module>
         <module>CityDoctorEdge</module>
         <module>CityDoctorCheckResult</module>
+
+        <!--CityDoctor2 Extension Modules-->
         <module>Extensions/CityDoctorGUI</module>
+        <!--
         <module>Extensions/CityDoctorAutoPro</module>
         <module>Extensions/CityDoctorHealer</module>
         <module>Extensions/CityDoctorHealerGenetic</module>
         <module>Extensions/CityDoctorHealerGUI</module>
         <module>Extensions/CityDoctorWebService</module>
+        -->
     </modules>
 </project>
\ No newline at end of file
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_Abandoned.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_Abandoned.svg
new file mode 100644
index 0000000..c677a00
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_Abandoned.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="194" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="194" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#FF0000" d="M121 0h73v20H121z"/>
+        <path fill="url(#b)" d="M0 0h194v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="158.5" y="15" fill="#010101" fill-opacity=".3">Abandoned</text>
+        <text x="157.5" y="14">Abandoned</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyDeveloped.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyDeveloped.svg
new file mode 100644
index 0000000..63a7480
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyDeveloped.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="243" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="243" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#228B22" d="M121 0h122v20H121z"/>
+        <path fill="url(#b)" d="M0 0h243v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="183.0" y="15" fill="#010101" fill-opacity=".3">Actively Developed</text>
+        <text x="182.0" y="14">Actively Developed</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyMaintained.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyMaintained.svg
new file mode 100644
index 0000000..7bc7454
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyMaintained.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="248" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="248" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#6B8E23" d="M121 0h127v20H121z"/>
+        <path fill="url(#b)" d="M0 0h248v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="185.5" y="15" fill="#010101" fill-opacity=".3">Actively Maintained</text>
+        <text x="184.5" y="14">Actively Maintained</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_Deprecated.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_Deprecated.svg
new file mode 100644
index 0000000..2041082
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_Deprecated.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="198" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="198" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#800000" d="M121 0h77v20H121z"/>
+        <path fill="url(#b)" d="M0 0h198v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="160.5" y="15" fill="#010101" fill-opacity=".3">Deprecated</text>
+        <text x="159.5" y="14">Deprecated</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_InactivelyMaintained.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_InactivelyMaintained.svg
new file mode 100644
index 0000000..320d7e4
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_InactivelyMaintained.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="260" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="260" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#A4A61D" d="M121 0h139v20H121z"/>
+        <path fill="url(#b)" d="M0 0h260v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="191.5" y="15" fill="#010101" fill-opacity=".3">Inactively Maintained</text>
+        <text x="190.5" y="14">Inactively Maintained</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_NotMaintained.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_NotMaintained.svg
new file mode 100644
index 0000000..b21cd9e
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_NotMaintained.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="219" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="219" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#FF4500" d="M121 0h98v20H121z"/>
+        <path fill="url(#b)" d="M0 0h219v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="171.0" y="15" fill="#010101" fill-opacity=".3">Not Maintained</text>
+        <text x="170.0" y="14">Not Maintained</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/MaintenanceLevel_Obsolete.svg b/CityDoctorParent/resources/Badges/MaintenanceLevel_Obsolete.svg
new file mode 100644
index 0000000..f26fd5a
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/MaintenanceLevel_Obsolete.svg
@@ -0,0 +1,23 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="185" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="185" height="20" rx="3" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#555" d="M0 0h121v20H0z"/>
+        <path fill="#000000" d="M121 0h64v20H121z"/>
+        <path fill="url(#b)" d="M0 0h185v20H0z"/>
+    </g>
+    <g fill="white" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="61.5" y="15" fill="#010101" fill-opacity=".3">Maintenance Level</text>
+        <text x="60.5" y="14">Maintenance Level</text>
+    </g>
+    <g fill="white" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="154.0" y="15" fill="#010101" fill-opacity=".3">Obsolete</text>
+        <text x="153.0" y="14">Obsolete</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/Project_CD2.svg b/CityDoctorParent/resources/Badges/Project_CD2.svg
new file mode 100644
index 0000000..1d815f5
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/Project_CD2.svg
@@ -0,0 +1,22 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="132" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="132" height="20" rx="10" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#FF0000" d="M0 0h132v20H0z"/>
+        <path fill="#262626" d="M53 2h70v16H53z"/>
+        <path fill="#262626" d="M122,18 a1,1 0 0,0 0,-16"/>
+        <path fill="url(#b)" d="M0 0h132v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="26.5" y="14">Project</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="92.5" y="14">CityDoctor2</text>
+    </g>
+</svg>
diff --git a/CityDoctorParent/resources/Badges/Project_UDigiT.svg b/CityDoctorParent/resources/Badges/Project_UDigiT.svg
new file mode 100644
index 0000000..6113343
--- /dev/null
+++ b/CityDoctorParent/resources/Badges/Project_UDigiT.svg
@@ -0,0 +1,22 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<svg xmlns="http://www.w3.org/2000/svg" width="144" height="20">
+    <linearGradient id="b" x2="0" y2="100%">
+        <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>
+        <stop offset="1" stop-opacity=".1"/>
+    </linearGradient>
+    <mask id="anybadge_1">
+        <rect width="144" height="20" rx="10" fill="#fff"/>
+    </mask>
+    <g mask="url(#anybadge_1)">
+        <path fill="#4169E1" d="M0 0h144v20H0z"/>
+        <path fill="#262626" d="M53 2h82v16H53z"/>
+        <path fill="#262626" d="M134,18 a1,1 0 0,0 0,-16"/>
+        <path fill="url(#b)" d="M0 0h144v20H0z"/>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="26.5" y="14">Project</text>
+    </g>
+    <g fill="#fff" text-anchor="middle" font-family="DejaVu Sans,Verdana,Geneva,sans-serif" font-size="11">
+        <text x="98.5" y="14">UDigiT-Doctor</text>
+    </g>
+</svg>
diff --git a/README.md b/README.md
index de17876..bd17d1b 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
 # CityDoctor2
 
-[![pipeline status](https://transfer.hft-stuttgart.de/gitlab/betzms/citydoctor2/badges/master/pipeline.svg)](https://transfer.hft-stuttgart.de/gitlab/betzms/citydoctor2/-/commits/master)
+[![pipeline status](https://transfer.hft-stuttgart.de/gitlab/betzms/citydoctor2/badges/master/pipeline.svg)](https://transfer.hft-stuttgart.de/gitlab/betzms/citydoctor2/-/commits/master) ![Maintenance Level: Actively Developed](/CityDoctorParent/resources/Badges/MaintenanceLevel_ActivelyDeveloped.svg)
 
 CityDoctor2 is a Java program for validating CityGML files. It checks whether certain criteria for e.g. geometries are met and outputs a report on the results.
 
@@ -42,6 +42,9 @@ java -classpath libs/*;plugins/*;CityDoctorValidation-<version>.jar de.hft.stutt
 Note:
 -xmlReport, -pdfReport and -out are optional
 
+## Extension
+
+Example extensions for CityDoctor are included in this repository, and can be found in the [Extensions subdirectory](./CityDoctorParent/Extensions)
 
 ## License
 [LGPL](http://www.gnu.org/licenses/lgpl-3.0.de.html)
-- 
GitLab