diff --git a/.idea/workspace.xml b/.idea/workspace.xml
index bd98c606..96f26e36 100644
--- a/.idea/workspace.xml
+++ b/.idea/workspace.xml
@@ -22,9 +22,50 @@
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
@@ -74,29 +115,29 @@
-
-
+
+
+
-
+
-
-
+
@@ -105,11 +146,11 @@
-
+
-
+
@@ -126,11 +167,11 @@
-
+
-
+
@@ -147,11 +188,11 @@
-
+
-
+
@@ -168,11 +209,11 @@
-
+
-
+
@@ -189,11 +230,11 @@
-
+
-
+
@@ -210,11 +251,11 @@
-
+
-
+
@@ -231,11 +272,11 @@
-
+
-
+
@@ -252,11 +293,11 @@
-
+
-
+
@@ -273,11 +314,11 @@
-
+
-
+
@@ -294,11 +335,11 @@
-
+
-
+
@@ -315,11 +356,11 @@
-
+
-
+
@@ -336,11 +377,11 @@
-
+
-
+
@@ -349,27 +390,6 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
@@ -378,11 +398,11 @@
-
+
-
+
@@ -463,7 +483,6 @@
-
@@ -485,41 +504,6 @@
1605881914521
-
- 1608125743068
-
-
-
- 1608125743068
-
-
- 1608127752645
-
-
-
- 1608127752645
-
-
- 1608127998033
-
-
-
- 1608127998034
-
-
- 1608128026922
-
-
-
- 1608128026922
-
-
- 1608133651981
-
-
-
- 1608133651982
-
1608136663213
@@ -828,7 +812,42 @@
1614958058304
-
+
+ 1614958287131
+
+
+
+ 1614958287131
+
+
+ 1614959039041
+
+
+
+ 1614959039041
+
+
+ 1614959606937
+
+
+
+ 1614959606937
+
+
+ 1614960552294
+
+
+
+ 1614960552294
+
+
+ 1614960859459
+
+
+
+ 1614960859459
+
+
@@ -844,10 +863,6 @@
-
-
-
-
@@ -869,7 +884,11 @@
-
+
+
+
+
+
diff --git a/cpl.json b/cpl.json
new file mode 100644
index 00000000..18807d27
--- /dev/null
+++ b/cpl.json
@@ -0,0 +1,43 @@
+{
+ "ProjectSettings": {
+ "name": "sh_cpl",
+ "version": {
+ "major": "2021",
+ "minor": "04",
+ "micro": "01"
+ },
+ "author": "Sven Heidemann",
+ "authorEmail": "sven.heidemann@sh-edraft.de",
+ "description": "sh-edraft Common Python library",
+ "longDescription": "sh-edraft Common Python library",
+ "url": "https://www.sh-edraft.de",
+ "copyrightDate": "2020",
+ "copyrightName": "sh-edraft.de",
+ "licenseName": "MIT",
+ "licenseDescription": "MIT, see LICENSE for more details.",
+ "dependencies": [
+ "discord.py",
+ "mysql-connector",
+ "SQLAlchemy",
+ "termcolor",
+ "pyfiglet",
+ "tabulate",
+ "smtplib"
+ ],
+ "pythonVersion": ">=3.8"
+ },
+ "BuildSettings": {
+ "sourcePath": "src/cpl",
+ "outputPath": "dist",
+ "main": "cpl_cli.main",
+ "entryPoint": "cpl",
+ "includePackageData": "False",
+ "included": [
+ "src/cpl_cli"
+ ],
+ "excluded": [
+ "*/__pycache__",
+ "*/logs"
+ ]
+ }
+}
\ No newline at end of file
diff --git a/docs/cli.md b/docs/cli.txt
similarity index 100%
rename from docs/cli.md
rename to docs/cli.txt
diff --git a/docs/install.md b/docs/install.txt
similarity index 100%
rename from docs/install.md
rename to docs/install.txt
diff --git a/docs/project_structure.txt b/docs/project_structure.txt
new file mode 100644
index 00000000..851a92d9
--- /dev/null
+++ b/docs/project_structure.txt
@@ -0,0 +1,5 @@
+/src/
+/.gitignore
+/cpl.json
+/LICENSE
+/README.md
diff --git a/docs/structure.md b/docs/structure.txt
similarity index 100%
rename from docs/structure.md
rename to docs/structure.txt
diff --git a/docs/todo.md b/docs/todo.txt
similarity index 100%
rename from docs/todo.md
rename to docs/todo.txt
diff --git a/publish_templates/all_template.txt b/publish_templates/all_template.txt
deleted file mode 100644
index 3b24f44f..00000000
--- a/publish_templates/all_template.txt
+++ /dev/null
@@ -1,25 +0,0 @@
-# -*- coding: utf-8 -*-
-
-"""
-$Name $Description
-~~~~~~~~~~~~~~~~~~~
-
-$LongDescription
-
-:copyright: (c) $CopyrightDate $CopyrightName
-:license: $LicenseName$LicenseDescription
-
-"""
-
-__title__ = '$Title'
-__author__ = '$Author'
-__license__ = '$LicenseName'
-__copyright__ = 'Copyright (c) $CopyrightDate $CopyrightName'
-__version__ = '$Version'
-
-from collections import namedtuple
-
-$Imports
-
-VersionInfo = namedtuple('VersionInfo', 'major minor micro')
-version_info = VersionInfo(major=$Major, minor=$Minor, micro=$Micro)
diff --git a/requirements.txt b/requirements.txt
deleted file mode 100644
index 8a422878..00000000
--- a/requirements.txt
+++ /dev/null
@@ -1,29 +0,0 @@
-aiohttp
-async-timeout
-attrs
-certifi
-chardet
-click
-dateutils
-discord
-discord.py
-Flask
-idna
-itsdangerous
-Jinja2
-keyboard
-MarkupSafe
-multidict
-mysql-connector
-overloading
-python-dateutil
-pytz
-six
-SQLAlchemy
-termcolor
-urllib3
-Werkzeug
-yarl
-setuptools
-pyfiglet
-tabulate
\ No newline at end of file
diff --git a/src/cpl.json b/src/cpl.json
deleted file mode 100644
index 03acc4cd..00000000
--- a/src/cpl.json
+++ /dev/null
@@ -1,26 +0,0 @@
-{
- "ProjectSettings": {
- "Name": "sh_cpl",
- "Author": "Sven Heidemann",
- "Description": "Common Python Library",
- "LongDescription": "Common Python Library",
- "CopyrightDate": "2020",
- "CopyrightName": "sh-edraft.de",
- "LicenseName": "MIT",
- "LicenseDescription": ", see LICENSE for more details.",
- "Version": {
- "Major": "2021",
- "Minor": "04",
- "Micro": "01"
- },
- "SourcePath": "./cpl",
- "DistPath": "../dist",
- "Included": [
- "./cpl_cli"
- ],
- "Excluded": [
- "__pycache__",
- "logs"
- ]
- }
-}
\ No newline at end of file
diff --git a/src/cpl/__init__.py b/src/cpl/__init__.py
index 073cc218..a736dee0 100644
--- a/src/cpl/__init__.py
+++ b/src/cpl/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'sh_cpl.cpl'
+__title__ = 'src.cpl'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/application/__init__.py b/src/cpl/application/__init__.py
index 9b85fd8e..fc043b5d 100644
--- a/src/cpl/application/__init__.py
+++ b/src/cpl/application/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.application'
+__title__ = 'src.cpl.application'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/configuration/__init__.py b/src/cpl/configuration/__init__.py
index ce47e3ae..52672b7d 100644
--- a/src/cpl/configuration/__init__.py
+++ b/src/cpl/configuration/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.configuration'
+__title__ = 'src.cpl.configuration'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/console/__init__.py b/src/cpl/console/__init__.py
index dc40c4e0..8ad9c8f0 100644
--- a/src/cpl/console/__init__.py
+++ b/src/cpl/console/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.console'
+__title__ = 'src.cpl.console'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/database/__init__.py b/src/cpl/database/__init__.py
index 89ac0399..48e6185b 100644
--- a/src/cpl/database/__init__.py
+++ b/src/cpl/database/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.database'
+__title__ = 'src.cpl.database'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/database/connection/__init__.py b/src/cpl/database/connection/__init__.py
index cc75ce70..96c0e84f 100644
--- a/src/cpl/database/connection/__init__.py
+++ b/src/cpl/database/connection/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.database.connection'
+__title__ = 'src.cpl.database.connection'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/database/context/__init__.py b/src/cpl/database/context/__init__.py
index c6833b12..2bf218a4 100644
--- a/src/cpl/database/context/__init__.py
+++ b/src/cpl/database/context/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.database.context'
+__title__ = 'src.cpl.database.context'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/dependency_injection/__init__.py b/src/cpl/dependency_injection/__init__.py
index 2b0243e8..6f9e64f4 100644
--- a/src/cpl/dependency_injection/__init__.py
+++ b/src/cpl/dependency_injection/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.dependency_injection'
+__title__ = 'src.cpl.dependency_injection'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/environment/__init__.py b/src/cpl/environment/__init__.py
index 52bec0c8..3df43e1c 100644
--- a/src/cpl/environment/__init__.py
+++ b/src/cpl/environment/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.environment'
+__title__ = 'src.cpl.environment'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/logging/__init__.py b/src/cpl/logging/__init__.py
index 09427137..380f6574 100644
--- a/src/cpl/logging/__init__.py
+++ b/src/cpl/logging/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.logging'
+__title__ = 'src.cpl.logging'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/mailing/__init__.py b/src/cpl/mailing/__init__.py
index efa58a3c..bde82ff4 100644
--- a/src/cpl/mailing/__init__.py
+++ b/src/cpl/mailing/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.mailing'
+__title__ = 'src.cpl.mailing'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/time/__init__.py b/src/cpl/time/__init__.py
index b8d63115..3d71982c 100644
--- a/src/cpl/time/__init__.py
+++ b/src/cpl/time/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.time'
+__title__ = 'src.cpl.time'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/utils/__init__.py b/src/cpl/utils/__init__.py
index 1c38125e..2cc12f8d 100644
--- a/src/cpl/utils/__init__.py
+++ b/src/cpl/utils/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.utils'
+__title__ = 'src.cpl.utils'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl/version/version_enum.py b/src/cpl/version/version_enum.py
deleted file mode 100644
index 8c294c1e..00000000
--- a/src/cpl/version/version_enum.py
+++ /dev/null
@@ -1,8 +0,0 @@
-from enum import Enum
-
-
-class VersionEnum(Enum):
-
- Major = 'Major'
- Minor = 'Minor'
- Micro = 'Micro'
diff --git a/src/cpl_cli/__init__.py b/src/cpl_cli/__init__.py
index bf8f2f5a..733d49a2 100644
--- a/src/cpl_cli/__init__.py
+++ b/src/cpl_cli/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'sh_cpl.cpl_cli'
+__title__ = 'src.cpl_cli'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl_cli/__main__.py b/src/cpl_cli/__main__.py
new file mode 100644
index 00000000..71a2066f
--- /dev/null
+++ b/src/cpl_cli/__main__.py
@@ -0,0 +1,4 @@
+from cpl_cli.main import main
+
+if __name__ == '__main__':
+ main()
diff --git a/src/cpl_cli/cli.py b/src/cpl_cli/cli.py
index 189f0470..e8cc4c52 100644
--- a/src/cpl_cli/cli.py
+++ b/src/cpl_cli/cli.py
@@ -2,6 +2,7 @@ from typing import Optional
from cpl.application.application_abc import ApplicationABC
from cpl_cli.command.build import Build
+from cpl_cli.command.publish import Publish
from cpl_cli.command_handler import CommandHandler
from cpl_cli.command_model import CommandModel
from cpl_cli.error import Error
@@ -21,6 +22,7 @@ class CLI(ApplicationABC):
self._command_handler.add_command(CommandModel('build', ['h', 'B'], Build))
self._command_handler.add_command(CommandModel('help', ['h', 'H'], Help))
+ self._command_handler.add_command(CommandModel('publish', ['p', 'P'], Publish))
self._command_handler.add_command(CommandModel('version', ['v', 'V'], Version))
def main(self):
diff --git a/src/cpl_cli/command/__init__.py b/src/cpl_cli/command/__init__.py
index ad8c2e2e..9a6fb98b 100644
--- a/src/cpl_cli/command/__init__.py
+++ b/src/cpl_cli/command/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl_cli.command'
+__title__ = 'src.cpl_cli.command'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl_cli/command/publish.py b/src/cpl_cli/command/publish.py
index e69de29b..483e7590 100644
--- a/src/cpl_cli/command/publish.py
+++ b/src/cpl_cli/command/publish.py
@@ -0,0 +1,13 @@
+from cpl_cli.command_abc import CommandABC
+from cpl_cli.publish.publisher_abc import PublisherABC
+
+
+class Publish(CommandABC):
+
+ def __init__(self, publisher: PublisherABC):
+ CommandABC.__init__(self)
+
+ self._publisher = publisher
+
+ def run(self, args: list[str]):
+ self._publisher.publish()
diff --git a/src/cpl/version/__init__.py b/src/cpl_cli/configuration/__init__.py
similarity index 70%
rename from src/cpl/version/__init__.py
rename to src/cpl_cli/configuration/__init__.py
index 711b96c5..61c5c16d 100644
--- a/src/cpl/version/__init__.py
+++ b/src/cpl_cli/configuration/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl.version'
+__title__ = 'src.cpl_cli.configuration'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl_cli/configuration/build_settings.py b/src/cpl_cli/configuration/build_settings.py
new file mode 100644
index 00000000..c044fbeb
--- /dev/null
+++ b/src/cpl_cli/configuration/build_settings.py
@@ -0,0 +1,65 @@
+import traceback
+from typing import Optional
+
+from cpl.configuration.configuration_model_abc import ConfigurationModelABC
+from cpl.console.console import Console
+from cpl.console.foreground_color import ForegroundColor
+from cpl_cli.configuration.build_settings_name import BuildSettingsName
+
+
+class BuildSettings(ConfigurationModelABC):
+
+ def __init__(self):
+ ConfigurationModelABC.__init__(self)
+
+ self._source_path: Optional[str] = None
+ self._output_path: Optional[str] = None
+ self._main: Optional[str] = None
+ self._entry_point: Optional[str] = None
+ self._include_package_data: Optional[bool] = None
+ self._included: Optional[list[str]] = None
+ self._excluded: Optional[list[str]] = None
+
+ @property
+ def source_path(self) -> str:
+ return self._source_path
+
+ @property
+ def output_path(self) -> str:
+ return self._output_path
+
+ @property
+ def main(self) -> str:
+ return self._main
+
+ @property
+ def entry_point(self) -> str:
+ return self._entry_point
+
+ @property
+ def include_package_data(self) -> bool:
+ return self._include_package_data
+
+ @property
+ def included(self) -> list[str]:
+ return self._included
+
+ @property
+ def excluded(self) -> list[str]:
+ return self._excluded
+
+ def from_dict(self, settings: dict):
+ try:
+ self._source_path = settings[BuildSettingsName.sourcePath.value]
+ self._output_path = settings[BuildSettingsName.outputPath.value]
+ self._include_package_data = bool(settings[BuildSettingsName.include_package_data.value])
+ self._main = settings[BuildSettingsName.main.value]
+ self._entry_point = settings[BuildSettingsName.entry_point.value]
+ self._included = settings[BuildSettingsName.included.value]
+ self._excluded = settings[BuildSettingsName.excluded.value]
+ except Exception as e:
+ Console.set_foreground_color(ForegroundColor.red)
+ Console.write_line(
+ f'[ ERROR ] [ {__name__} ]: Reading error in {BuildSettings.__name__} settings')
+ Console.write_line(f'[ EXCEPTION ] [ {__name__} ]: {e} -> {traceback.format_exc()}')
+ Console.set_foreground_color(ForegroundColor.default)
diff --git a/src/cpl_cli/configuration/build_settings_name.py b/src/cpl_cli/configuration/build_settings_name.py
new file mode 100644
index 00000000..91584bd5
--- /dev/null
+++ b/src/cpl_cli/configuration/build_settings_name.py
@@ -0,0 +1,12 @@
+from enum import Enum
+
+
+class BuildSettingsName(Enum):
+
+ sourcePath = 'sourcePath'
+ outputPath = 'outputPath'
+ main = 'main'
+ entry_point = 'entryPoint'
+ include_package_data = 'includePackageData'
+ included = 'included'
+ excluded = 'excluded'
diff --git a/src/cpl_cli/publish/project_settings.py b/src/cpl_cli/configuration/project_settings.py
similarity index 61%
rename from src/cpl_cli/publish/project_settings.py
rename to src/cpl_cli/configuration/project_settings.py
index 17edc634..e861fc7c 100644
--- a/src/cpl_cli/publish/project_settings.py
+++ b/src/cpl_cli/configuration/project_settings.py
@@ -4,8 +4,8 @@ from typing import Optional
from cpl.configuration.configuration_model_abc import ConfigurationModelABC
from cpl.console.console import Console
from cpl.console.foreground_color import ForegroundColor
-from cpl.version.version import Version
-from cpl_cli.publish.project_settings_name import ProjectSettingsName
+from cpl_cli.configuration.version import Version
+from cpl_cli.configuration.project_settings_name import ProjectSettingsName
class ProjectSettings(ConfigurationModelABC):
@@ -14,97 +14,89 @@ class ProjectSettings(ConfigurationModelABC):
ConfigurationModelABC.__init__(self)
self._name: Optional[str] = None
+ self._version: Optional[Version] = Version()
self._author: Optional[str] = None
+ self._author_email: Optional[str] = None
self._description: Optional[str] = None
self._long_description: Optional[str] = None
+ self._url: Optional[str] = None
self._copyright_date: Optional[str] = None
self._copyright_name: Optional[str] = None
self._license_name: Optional[str] = None
self._license_description: Optional[str] = None
- self._version: Optional[Version] = Version()
- self._source_path: Optional[str] = None
- self._dist_path: Optional[str] = None
- self._included: list[str] = []
- self._excluded: list[str] = []
-
+ self._dependencies: Optional[list[str]] = None
+ self._python_version: Optional[str] = None
+
@property
- def name(self) -> Optional[str]:
+ def name(self):
return self._name
@property
- def author(self) -> Optional[str]:
- return self._author
-
- @property
- def description(self) -> Optional[str]:
- return self._description
-
- @property
- def long_description(self) -> Optional[str]:
- return self._long_description
-
- @property
- def copyright_date(self) -> Optional[str]:
- return self._copyright_date
-
- @property
- def copyright_name(self) -> Optional[str]:
- return self._copyright_name
-
- @property
- def license_name(self) -> Optional[str]:
- return self._license_name
-
- @property
- def license_description(self) -> Optional[str]:
- return self._license_description
-
- @property
- def version(self) -> Optional[Version]:
+ def version(self) -> Version:
return self._version
@property
- def source_path(self) -> str:
- return self._source_path
-
- @source_path.setter
- def source_path(self, source_path: str):
- self._source_path = source_path
+ def author(self) -> str:
+ return self._author
@property
- def dist_path(self) -> str:
- return self._dist_path
-
- @dist_path.setter
- def dist_path(self, dist_path: str):
- self._dist_path = dist_path
+ def author_email(self) -> str:
+ return self._author_email
+
+ @property
+ def description(self) -> str:
+ return self._description
+
+ @property
+ def long_description(self) -> str:
+ return self._long_description
+
+ @property
+ def url(self) -> str:
+ return self._url
+
+ @property
+ def copyright_date(self) -> str:
+ return self._copyright_date
+
+ @property
+ def copyright_name(self) -> str:
+ return self._copyright_name
+
+ @property
+ def license_name(self) -> str:
+ return self._license_name
+
+ @property
+ def license_description(self) -> str:
+ return self._license_description
@property
- def included(self) -> list[str]:
- return self._included
-
+ def dependencies(self) -> list[str]:
+ return self._dependencies
+
@property
- def excluded(self) -> list[str]:
- return self._excluded
+ def python_version(self) -> str:
+ return self._python_version
def from_dict(self, settings: dict):
try:
self._name = settings[ProjectSettingsName.name.value]
+ self._version.from_dict(settings[ProjectSettingsName.version.value])
self._author = settings[ProjectSettingsName.author.value]
+ self._author_email = settings[ProjectSettingsName.author_email.value]
self._description = settings[ProjectSettingsName.description.value]
self._long_description = settings[ProjectSettingsName.long_description.value]
+ self._url = settings[ProjectSettingsName.url.value]
self._copyright_date = settings[ProjectSettingsName.copyright_date.value]
self._copyright_name = settings[ProjectSettingsName.copyright_name.value]
self._license_name = settings[ProjectSettingsName.license_name.value]
self._license_description = settings[ProjectSettingsName.license_description.value]
- self._version.from_dict(settings[ProjectSettingsName.version.value])
- self._source_path = settings[ProjectSettingsName.source_path.value]
- self._dist_path = settings[ProjectSettingsName.dist_path.value]
- self._included = settings[ProjectSettingsName.included.value]
- self._excluded = settings[ProjectSettingsName.excluded.value]
+ self._dependencies = settings[ProjectSettingsName.dependencies.value]
+ self._python_version = settings[ProjectSettingsName.python_version.value]
except Exception as e:
Console.set_foreground_color(ForegroundColor.red)
Console.write_line(
- f'[ ERROR ] [ {__name__} ]: Reading error in {ProjectSettingsName.project.value} settings')
+ f'[ ERROR ] [ {__name__} ]: Reading error in {ProjectSettings.__name__} settings')
Console.write_line(f'[ EXCEPTION ] [ {__name__} ]: {e} -> {traceback.format_exc()}')
Console.set_foreground_color(ForegroundColor.default)
diff --git a/src/cpl_cli/configuration/project_settings_name.py b/src/cpl_cli/configuration/project_settings_name.py
new file mode 100644
index 00000000..79ba89a9
--- /dev/null
+++ b/src/cpl_cli/configuration/project_settings_name.py
@@ -0,0 +1,18 @@
+from enum import Enum
+
+
+class ProjectSettingsName(Enum):
+
+ name = 'name'
+ version = 'version'
+ author = 'author'
+ author_email = 'authorEmail'
+ description = 'description'
+ long_description = 'longDescription'
+ url = 'url'
+ copyright_date = 'copyrightDate'
+ copyright_name = 'copyrightName'
+ license_name = 'licenseName'
+ license_description = 'licenseDescription'
+ dependencies = 'dependencies'
+ python_version = 'pythonVersion'
diff --git a/src/cpl/version/version.py b/src/cpl_cli/configuration/version.py
similarity index 65%
rename from src/cpl/version/version.py
rename to src/cpl_cli/configuration/version.py
index 138fd6b4..fccca7ae 100644
--- a/src/cpl/version/version.py
+++ b/src/cpl_cli/configuration/version.py
@@ -1,7 +1,7 @@
from typing import Optional
from cpl.configuration.configuration_model_abc import ConfigurationModelABC
-from cpl.version.version_enum import VersionEnum
+from cpl_cli.configuration.version_settings_name import VersionSettingsName
class Version(ConfigurationModelABC):
@@ -34,13 +34,13 @@ class Version(ConfigurationModelABC):
return f'{self._major}.{self._minor}.{self._micro}'
def from_dict(self, settings: dict):
- self._major = int(settings[VersionEnum.Major.value])
- self._minor = int(settings[VersionEnum.Minor.value])
- self._micro = int(settings[VersionEnum.Micro.value])
+ self._major = int(settings[VersionSettingsName.major.value])
+ self._minor = int(settings[VersionSettingsName.minor.value])
+ self._micro = int(settings[VersionSettingsName.micro.value])
def to_dict(self) -> dict:
return {
- VersionEnum.Major.value: self._major,
- VersionEnum.Minor.value: self._minor,
- VersionEnum.Micro.value: self._micro
+ VersionSettingsName.major.value: self._major,
+ VersionSettingsName.minor.value: self._minor,
+ VersionSettingsName.micro.value: self._micro
}
diff --git a/src/cpl_cli/configuration/version_settings_name.py b/src/cpl_cli/configuration/version_settings_name.py
new file mode 100644
index 00000000..4a6b6dc4
--- /dev/null
+++ b/src/cpl_cli/configuration/version_settings_name.py
@@ -0,0 +1,8 @@
+from enum import Enum
+
+
+class VersionSettingsName(Enum):
+
+ major = 'major'
+ minor = 'minor'
+ micro = 'micro'
diff --git a/src/cpl_cli/main.py b/src/cpl_cli/main.py
index 13fd4e62..6ffc9477 100644
--- a/src/cpl_cli/main.py
+++ b/src/cpl_cli/main.py
@@ -1,7 +1,8 @@
from cpl_cli.cli import CLI
from cpl_cli.startup import Startup
-if __name__ == '__main__':
+
+def main():
cli = CLI()
cli.use_startup(Startup)
cli.build()
diff --git a/src/cpl_cli/publish/__init__.py b/src/cpl_cli/publish/__init__.py
index a0fdf2ec..16675a50 100644
--- a/src/cpl_cli/publish/__init__.py
+++ b/src/cpl_cli/publish/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl Common Python Library
+sh_cpl sh-edraft Common Python library
~~~~~~~~~~~~~~~~~~~
-Common Python Library
+sh-edraft Common Python library
:copyright: (c) 2020 sh-edraft.de
-:license: MIT, see LICENSE for more details.
+:license: MITMIT, see LICENSE for more details.
"""
-__title__ = 'cpl_cli.publish'
+__title__ = 'src.cpl_cli.publish'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/cpl_cli/publish/project_settings_name.py b/src/cpl_cli/publish/project_settings_name.py
deleted file mode 100644
index 04aa83cf..00000000
--- a/src/cpl_cli/publish/project_settings_name.py
+++ /dev/null
@@ -1,19 +0,0 @@
-from enum import Enum
-
-
-class ProjectSettingsName(Enum):
-
- project = 'Project'
- name = 'Name'
- author = 'Author'
- description = 'Description'
- long_description = 'LongDescription'
- copyright_date = 'CopyrightDate'
- copyright_name = 'CopyrightName'
- license_name = 'LicenseName'
- license_description = 'LicenseDescription'
- version = 'Version'
- source_path = 'SourcePath'
- dist_path = 'DistPath'
- included = 'Included'
- excluded = 'Excluded'
diff --git a/src/cpl_cli/publish/publisher.py b/src/cpl_cli/publish/publisher.py
index 4cae7ed2..f324e8db 100644
--- a/src/cpl_cli/publish/publisher.py
+++ b/src/cpl_cli/publish/publisher.py
@@ -1,25 +1,32 @@
+import importlib
import os
import shutil
-import time
from string import Template as stringTemplate
+import setuptools
+from setuptools import sandbox
+
from cpl.application.application_runtime_abc import ApplicationRuntimeABC
from cpl.console.console import Console
-from cpl_cli.publish.project_settings import ProjectSettings
+from cpl_cli.configuration.build_settings import BuildSettings
+from cpl_cli.configuration.project_settings import ProjectSettings
from cpl_cli.publish.publisher_abc import PublisherABC
class Publisher(PublisherABC):
- def __init__(self, runtime: ApplicationRuntimeABC, project: ProjectSettings):
+ def __init__(self, runtime: ApplicationRuntimeABC, project: ProjectSettings, build: BuildSettings):
PublisherABC.__init__(self)
self._runtime = runtime
- self._project = project
- self._project.source_path = os.path.join(self._runtime.working_directory, self._project.source_path)
- self._project.dist_path = os.path.join(self._runtime.working_directory, self._project.dist_path)
+ self._project_settings = project
+ self._build_settings = build
+
+ self._source_path = os.path.join(self._runtime.working_directory, self._build_settings.source_path)
+ self._output_path = os.path.join(self._runtime.working_directory, self._build_settings.output_path)
self._included_files: list[str] = []
+ self._distributed_files: list[str] = []
@property
def source_path(self) -> str:
@@ -59,9 +66,18 @@ class Publisher(PublisherABC):
Console.error(f'{e}')
exit()
+ def _is_path_excluded(self, path: str) -> bool:
+ for excluded in self._build_settings.excluded:
+ if excluded.startswith('*'):
+ excluded = excluded.replace('*', '')
+
+ if excluded in path:
+ return True
+
+ return False
+
def _read_sources(self):
- time.sleep(2)
- for file in self._project.included:
+ for file in self._build_settings.included:
rel_path = os.path.relpath(file)
if os.path.isdir(rel_path):
for r, d, f in os.walk(rel_path):
@@ -69,15 +85,7 @@ class Publisher(PublisherABC):
relative_path = os.path.relpath(r)
file_path = os.path.join(relative_path, os.path.relpath(sub_file))
- is_excluded = False
- for excluded in self._project.excluded:
- if excluded in relative_path:
- is_excluded = True
-
- if relative_path in excluded:
- is_excluded = True
-
- if not is_excluded:
+ if not self._is_path_excluded(relative_path):
self._included_files.append(os.path.relpath(file_path))
elif os.path.isfile(rel_path):
@@ -86,12 +94,12 @@ class Publisher(PublisherABC):
else:
Console.error(f'Path not found: {rel_path}')
- for r, d, f in os.walk(self._project.source_path):
+ for r, d, f in os.walk(self._build_settings.source_path):
for file in f:
relative_path = os.path.relpath(r)
file_path = os.path.join(relative_path, os.path.relpath(file))
- if relative_path not in self._project.excluded:
+ if not self._is_path_excluded(relative_path):
self._included_files.append(os.path.relpath(file_path))
def _create_packages(self):
@@ -102,9 +110,9 @@ class Publisher(PublisherABC):
title = self._get_module_name_from_dirs(file)
if title == '':
- title = self._project.name
+ title = self._project_settings.name
elif not title.__contains__('.'):
- title = f'{self._project.name}.{title}'
+ title = f'{self._project_settings.name}.{title}'
module_py_lines: list[str] = []
imports = ''
@@ -129,19 +137,19 @@ class Publisher(PublisherABC):
with open(os.path.join(self._runtime.runtime_directory, 'templates/build/init.txt'), 'r') as template:
template_content = stringTemplate(template.read()).substitute(
- Name=self._project.name,
- Description=self._project.description,
- LongDescription=self._project.long_description,
- CopyrightDate=self._project.copyright_date,
- CopyrightName=self._project.copyright_name,
- LicenseName=self._project.license_name,
- LicenseDescription=self._project.license_description,
- Title=title if title is not None and title != '' else self._project.name,
- Author=self._project.author,
- Version=self._project.version.to_str(),
- Major=self._project.version.major,
- Minor=self._project.version.minor,
- Micro=self._project.version.micro,
+ Name=self._project_settings.name,
+ Description=self._project_settings.description,
+ LongDescription=self._project_settings.long_description,
+ CopyrightDate=self._project_settings.copyright_date,
+ CopyrightName=self._project_settings.copyright_name,
+ LicenseName=self._project_settings.license_name,
+ LicenseDescription=self._project_settings.license_description,
+ Title=title if title is not None and title != '' else self._project_settings.name,
+ Author=self._project_settings.author,
+ Version=self._project_settings.version.to_str(),
+ Major=self._project_settings.version.major,
+ Minor=self._project_settings.version.minor,
+ Micro=self._project_settings.version.micro,
Imports=imports
)
@@ -150,36 +158,132 @@ class Publisher(PublisherABC):
py_file.close()
def _dist_files(self):
- build_path = os.path.join(self._project.dist_path, 'build')
+ build_path = os.path.join(self._output_path)
self._delete_path(build_path)
self._create_path(build_path)
for file in self._included_files:
- output_path = os.path.join(build_path, os.path.dirname(file))
- output_file = os.path.join(build_path, file)
+ dist_file = file
+ if 'src/' in dist_file:
+ dist_file = dist_file.replace('src/', '')
+
+ output_path = os.path.join(build_path, os.path.dirname(dist_file))
+ output_file = os.path.join(build_path, dist_file)
try:
if not os.path.isdir(output_path):
os.makedirs(output_path, exist_ok=True)
except Exception as e:
Console.error(__name__, f'Cannot create directories: {output_path} -> {e}')
+ return
try:
+ self._distributed_files.append(output_file)
shutil.copy(os.path.abspath(file), output_file)
except Exception as e:
Console.error(__name__, f'Cannot copy file: {file} to {output_path} -> {e}')
+ return
+
+ def _clean_dist_files(self):
+ paths: list[str] = []
+ for file in self._distributed_files:
+ paths.append(os.path.dirname(file))
+
+ if os.path.isfile(file):
+ os.remove(file)
+
+ for path in paths:
+ if os.path.isdir(path):
+ shutil.rmtree(path)
+
+ def _create_setup(self):
+ setup_file = os.path.join(self._output_path, 'setup.py')
+ if os.path.isfile(setup_file):
+ os.remove(setup_file)
+
+ template_path = os.path.join(self._runtime.runtime_directory, 'templates/publish/setup.txt')
+ if not os.path.isfile(template_path):
+ Console.error(__name__, f'setup.py template not found in {template_path}')
+ return
+
+ template_string = ''
+ with open(template_path, 'r') as template_file:
+ template_string = template_file.read()
+ template_file.close()
+
+ main = None
+ try:
+ main = importlib.import_module(self._build_settings.main)
+ except Exception as e:
+ Console.error('Could not find entry point', str(e))
+
+ if main is None:
+ Console.error('Could not find entry point')
+ return
+
+ with open(setup_file, 'w+') as setup_py:
+ setup_string = stringTemplate(template_string).substitute(
+ Name=self._project_settings.name,
+ Version=self._project_settings.version.to_str(),
+ Packages=setuptools.find_packages(where=self._build_settings.source_path, exclude=self._build_settings.excluded),
+ URL=self._project_settings.url,
+ LicenseName=self._project_settings.license_name,
+ Author=self._project_settings.author,
+ AuthorMail=self._project_settings.author_email,
+ InstallPackageData=self._build_settings.include_package_data,
+ Description=self._project_settings.description,
+ PyRequires=self._project_settings.python_version,
+ Dependencies=self._project_settings.dependencies,
+ EntryPoints={
+ 'console_scripts': [
+ f'{self._build_settings.entry_point} = {main.__name__}:{main.main.__name__}'
+ ]
+ }
+ )
+ setup_py.write(setup_string)
+ setup_py.close()
+
+ def _run_setup(self):
+ setup_py = os.path.join(self._output_path, 'setup.py')
+ if not os.path.isfile(setup_py):
+ Console.error(__name__, f'setup.py not found in {self._output_path}')
+ return
+
+ try:
+ sandbox.run_setup(os.path.abspath(setup_py), [
+ 'sdist',
+ f'--dist-dir={os.path.join(self._output_path, "setup")}',
+ 'bdist_wheel',
+ f'--bdist-dir={os.path.join(self._output_path, "bdist")}',
+ f'--dist-dir={os.path.join(self._output_path, "setup")}'
+ ])
+ os.remove(setup_py)
+ except Exception as e:
+ Console.error('Executing setup.py failed', str(e))
def include(self, path: str):
- self._project.included.append(path)
+ self._build_settings.included.append(path)
def exclude(self, path: str):
- self._project.excluded.append(path)
+ self._build_settings.excluded.append(path)
def build(self):
+ self._output_path = os.path.join(self._output_path, 'build')
+
Console.spinner('Reading source files:', self._read_sources)
Console.spinner('Creating internal packages:', self._create_packages)
- Console.write_line('Building application:')
- self._dist_files()
+ Console.spinner('Building application:', self._dist_files)
def publish(self):
- pass
+ self._output_path = os.path.join(self._output_path, 'publish')
+
+ Console.write_line('Build:')
+ Console.spinner('Reading source files:', self._read_sources)
+ Console.spinner('Creating internal packages:', self._create_packages)
+ Console.spinner('Building application:', self._dist_files)
+
+ Console.write_line('\nPublish:')
+ Console.spinner('Generating setup.py:', self._create_setup)
+ Console.write_line('Running setup.py:\n')
+ self._run_setup()
+ Console.spinner('Cleaning dist path:', self._clean_dist_files)
diff --git a/src/cpl_cli/startup.py b/src/cpl_cli/startup.py
index 2ff3a3f9..265f6362 100644
--- a/src/cpl_cli/startup.py
+++ b/src/cpl_cli/startup.py
@@ -6,6 +6,7 @@ from cpl.application.startup_abc import StartupABC
from cpl.configuration.configuration_abc import ConfigurationABC
from cpl.dependency_injection.service_provider_base import ServiceProviderABC
from cpl_cli.command.build import Build
+from cpl_cli.command.publish import Publish
from cpl_cli.command_handler import CommandHandler
from cpl_cli.command.help import Help
from cpl_cli.command.version import Version
@@ -40,6 +41,7 @@ class Startup(StartupABC):
self._configuration.add_json_file('cpl.json', optional=True, output=False)
self._configuration.add_console_argument('', 'build', ['-b', '-B'], '')
self._configuration.add_console_argument('', 'help', ['-h', '-H'], '')
+ self._configuration.add_console_argument('', 'publish', ['-p', '-P'], '')
self._configuration.add_console_argument('', 'version', ['-v', '-V'], '')
self._configuration.add_console_arguments()
@@ -52,6 +54,7 @@ class Startup(StartupABC):
self._services.add_transient(Build)
self._services.add_transient(Help)
+ self._services.add_transient(Publish)
self._services.add_transient(Version)
return self._services
diff --git a/src/cpl_cli/templates/publish/setup.txt b/src/cpl_cli/templates/publish/setup.txt
new file mode 100644
index 00000000..a332470e
--- /dev/null
+++ b/src/cpl_cli/templates/publish/setup.txt
@@ -0,0 +1,21 @@
+"""
+ This file is generated by CPL CLI
+"""
+
+import setuptools
+
+setuptools.setup(
+ name='$Name',
+ version='$Version',
+ packages=$Packages,
+ url='$URL',
+ license='$LicenseName',
+ author='$Author',
+ author_email='$AuthorMail',
+ include_package_data=$InstallPackageData,
+ description='$Description',
+ package_dir = {'': 'cpl'},
+ python_requires='$PyRequires',
+ install_requires=$Dependencies,
+ entry_points=$EntryPoints
+)
diff --git a/src/tests/__init__.py b/src/tests/__init__.py
index b9fcf8ed..c91a0362 100644
--- a/src/tests/__init__.py
+++ b/src/tests/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl.tests Common Python Library CLI
+sh_cpl Common Python Library
~~~~~~~~~~~~~~~~~~~
-Common Python Library CLI
+Common Python Library
:copyright: (c) 2020 sh-edraft.de
:license: MIT, see LICENSE for more details.
"""
-__title__ = 'sh_cpl.tests'
+__title__ = 'src.tests'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'
diff --git a/src/tests/db/__init__.py b/src/tests/db/__init__.py
index b3561305..862072c8 100644
--- a/src/tests/db/__init__.py
+++ b/src/tests/db/__init__.py
@@ -1,17 +1,17 @@
# -*- coding: utf-8 -*-
"""
-sh_cpl.tests Common Python Library CLI
+sh_cpl Common Python Library
~~~~~~~~~~~~~~~~~~~
-Common Python Library CLI
+Common Python Library
:copyright: (c) 2020 sh-edraft.de
:license: MIT, see LICENSE for more details.
"""
-__title__ = 'sh_cpl.tests.db'
+__title__ = 'src.tests.db'
__author__ = 'Sven Heidemann'
__license__ = 'MIT'
__copyright__ = 'Copyright (c) 2020 sh-edraft.de'