From 2f166581410e229b648941d4aa09534dfd4e53cf Mon Sep 17 00:00:00 2001 From: Tobias Kunze Date: Thu, 2 Nov 2023 17:11:36 +0100 Subject: [PATCH] Migrate to pyproject.toml --- .github/workflows/style.yml | 44 +++++--------------------------- pretalx_media_ccc_de/__init__.py | 1 + pretalx_media_ccc_de/apps.py | 4 ++- pyproject.toml | 40 +++++++++++++++++++++++++++++ setup.py | 42 ------------------------------ 5 files changed, 50 insertions(+), 81 deletions(-) create mode 100644 pyproject.toml delete mode 100644 setup.py diff --git a/.github/workflows/style.yml b/.github/workflows/style.yml index 4ca26ea..2111adc 100644 --- a/.github/workflows/style.yml +++ b/.github/workflows/style.yml @@ -29,10 +29,8 @@ jobs: key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} restore-keys: | ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - - name: Install Dependencies - run: pip3 install isort -Ue . + - name: Install isort + run: pip3 install isort - name: Run isort run: isort -c . flake: @@ -50,10 +48,8 @@ jobs: key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} restore-keys: | ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - name: Install Dependencies - run: pip3 install flake8 flake8-bugbear -Ue . + run: pip3 install flake8 flake8-bugbear - name: Run flake8 run: flake8 . working-directory: . @@ -72,35 +68,11 @@ jobs: key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} restore-keys: | ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - name: Install Dependencies - run: pip3 install black -Ue . + run: pip3 install black - name: Run black run: black --check . working-directory: . - docformatter: - name: docformatter - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Set up Python 3.10 - uses: actions/setup-python@v1 - with: - python-version: "3.10" - - uses: actions/cache@v1 - with: - path: ~/.cache/pip - key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} - restore-keys: | - ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - - name: Install Dependencies - run: pip3 install docformatter -Ue . - - name: Run docformatter - run: docformatter --check -r . - working-directory: . djhtml: name: djhtml runs-on: ubuntu-latest @@ -116,10 +88,8 @@ jobs: key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} restore-keys: | ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - name: Install Dependencies - run: pip3 install djhtml -Ue . + run: pip3 install djhtml - name: Run docformatter run: find -name "*.html" | xargs djhtml -c working-directory: . @@ -138,15 +108,13 @@ jobs: key: ${{ runner.os }}-pip-${{ hashFiles('**/setup.py') }} restore-keys: | ${{ runner.os }}-pip- - - name: Install pretalx - run: pip3 install pretalx - name: Install Dependencies run: pip3 install twine check-manifest -Ue . - name: Run check-manifest run: check-manifest . working-directory: . - name: Build package - run: python setup.py sdist + run: python -m build working-directory: . - name: Check package run: twine check dist/* diff --git a/pretalx_media_ccc_de/__init__.py b/pretalx_media_ccc_de/__init__.py index e69de29..c68196d 100644 --- a/pretalx_media_ccc_de/__init__.py +++ b/pretalx_media_ccc_de/__init__.py @@ -0,0 +1 @@ +__version__ = "1.2.0" diff --git a/pretalx_media_ccc_de/apps.py b/pretalx_media_ccc_de/apps.py index 87d70a0..ae40d78 100644 --- a/pretalx_media_ccc_de/apps.py +++ b/pretalx_media_ccc_de/apps.py @@ -1,6 +1,8 @@ from django.apps import AppConfig from django.utils.translation import gettext_lazy +from pretalx_media_ccc_de import __version__ + class PluginApp(AppConfig): name = "pretalx_media_ccc_de" @@ -13,7 +15,7 @@ class PretalxPluginMeta: "Pull recordings from media.ccc.de and embed them in talk pages" ) visible = True - version = "1.2.0" + version = __version__ category = "RECORDING" def ready(self): diff --git a/pyproject.toml b/pyproject.toml new file mode 100644 index 0000000..fe35e40 --- /dev/null +++ b/pyproject.toml @@ -0,0 +1,40 @@ +[project] +name = "pretalx-media-ccc-de" +dynamic = ["version"] +description = "Pull recordings from media.ccc.de and embed them in talk pages." +readme = "README.rst" +license = {text = "Apache Software License"} +keywords = ["pretalx"] +authors = [ + {name = "Tobias Kunze", email = "r@rixx.de"}, +] +maintainers = [ + {name = "Tobias Kunze", email = "r@rixx.de"}, +] + +dependencies = [] + +[project.urls] +homepage = "https://github.com/pretalx/pretalx-media-ccc-de" +repository = "https://github.com/pretalx/pretalx-media-ccc-de.git" + +[project.entry-points."pretalx.plugin"] +pretalx_media_ccc_de = "pretalx_media_ccc_de:PretalxPluginMeta" + +[build-system] +build-backend = "setuptools.build_meta" +requires = ["setuptools", "wheel"] + +[tool.setuptools] +include-package-data = true + +[tool.setuptools.dynamic] +version = {attr = "pretalx_media_ccc_de.__version__"} + +[tool.setuptools.packages.find] +include = ["pretalx*"] + +[tool.check-manifest] +ignore = [ + ".*", +] diff --git a/setup.py b/setup.py deleted file mode 100644 index cc23cae..0000000 --- a/setup.py +++ /dev/null @@ -1,42 +0,0 @@ -import os -from distutils.command.build import build - -from django.core import management -from setuptools import find_packages, setup - -try: - with open( - os.path.join(os.path.dirname(__file__), "README.rst"), encoding="utf-8" - ) as f: - long_description = f.read() -except Exception: - long_description = "" - - -class CustomBuild(build): - def run(self): - management.call_command("compilemessages", verbosity=1) - build.run(self) - - -cmdclass = {"build": CustomBuild} - - -setup( - name="pretalx-media-ccc-de", - version="1.2.0", - description="Pull recordings from media.ccc.de and embed them in talk pages", - long_description=long_description, - url="https://github.com/pretalx/pretalx-media-ccc-de.git", - author="Tobias Kunze", - author_email="r@rixx.de", - license="Apache Software License", - install_requires=[], - packages=find_packages(exclude=["tests", "tests.*"]), - include_package_data=True, - cmdclass=cmdclass, - entry_points=""" -[pretalx.plugin] -pretalx_media_ccc_de=pretalx_media_ccc_de:PretalxPluginMeta -""", -)