[build-system] requires = ["hatchling"] build-backend = "hatchling.build" [project] name = "duckypad-twitch" dynamic = ["version"] description = '' readme = "README.md" requires-python = ">=3.7" license = "MIT" keywords = [] authors = [ { name = "onyx-and-iris", email = "75868496+onyx-and-iris@users.noreply.github.com" }, ] classifiers = [ "Development Status :: 4 - Beta", "Programming Language :: Python", "Programming Language :: Python :: 3.7", "Programming Language :: Python :: 3.8", "Programming Language :: Python :: 3.9", "Programming Language :: Python :: 3.10", "Programming Language :: Python :: 3.11", "Programming Language :: Python :: Implementation :: CPython", "Programming Language :: Python :: Implementation :: PyPy", ] dependencies = [ "tomli >= 2.0.1;python_version < '3.11'", "websocket-client", "keyboard", "voicemeeter-api", "xair-api", "slobs_websocket@git+https://git@github.com/onyx-and-iris/slobs_websocket@v0.1.4#egg=slobs_websocket", "obsws-python", "vban-cmd", ] [project.urls] Documentation = "https://github.com/unknown/duckypad-twitch#readme" Issues = "https://github.com/unknown/duckypad-twitch/issues" Source = "https://github.com/unknown/duckypad-twitch" [tool.hatch.metadata] allow-direct-references = true [tool.hatch.version] path = "duckypad_twitch/__about__.py" [tool.hatch.envs.default] dependencies = ["coverage[toml]>=6.5", "pytest"] [tool.hatch.envs.default.scripts] test = "pytest {args:tests}" test-cov = "coverage run -m pytest {args:tests}" cov-report = ["- coverage combine", "coverage report"] cov = ["test-cov", "cov-report"] [[tool.hatch.envs.all.matrix]] python = ["3.7", "3.8", "3.9", "3.10", "3.11"] [tool.hatch.envs.lint] detached = true dependencies = ["black>=23.1.0", "mypy>=1.0.0", "ruff>=0.0.243"] [tool.hatch.envs.lint.scripts] typing = "mypy --install-types --non-interactive {args:duckypad_twitch tests}" style = ["ruff {args:.}", "black --check --diff {args:.}"] fmt = ["black {args:.}", "ruff --fix {args:.}", "style"] all = ["style", "typing"] [tool.black] target-version = ["py37"] line-length = 120 skip-string-normalization = true [tool.ruff] target-version = "py37" line-length = 120 select = [ "A", "ARG", "B", "C", "DTZ", "E", "EM", "F", "FBT", "I", "ICN", "ISC", "N", "PLC", "PLE", "PLR", "PLW", "Q", "RUF", "S", "T", "TID", "UP", "W", "YTT", ] ignore = [ # Allow non-abstract empty methods in abstract base classes "B027", # Allow boolean positional values in function calls, like `dict.get(... True)` "FBT003", # Ignore checks for possible passwords "S105", "S106", "S107", # Ignore complexity "C901", "PLR0911", "PLR0912", "PLR0913", "PLR0915", ] unfixable = [ # Don't touch unused imports "F401", ] [tool.ruff.isort] known-first-party = ["duckypad_twitch"] [tool.ruff.flake8-tidy-imports] ban-relative-imports = "all" [tool.ruff.per-file-ignores] # Tests can use magic values, assertions, and relative imports "tests/**/*" = ["PLR2004", "S101", "TID252"] [tool.coverage.run] source_pkgs = ["duckypad_twitch", "tests"] branch = true parallel = true omit = ["duckypad_twitch/__about__.py"] [tool.coverage.paths] duckypad_twitch = ["duckypad_twitch", "*/duckypad-twitch/duckypad_twitch"] tests = ["tests", "*/duckypad-twitch/tests"] [tool.coverage.report] exclude_lines = ["no cov", "if __name__ == .__main__.:", "if TYPE_CHECKING:"]