From 218364ac46bde18a9f4bf4bb82f6a80e1d2cf2fa Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Sat, 8 Aug 2020 15:15:29 -0500 Subject: [PATCH 01/31] chore(docs): Remove unused releases config --- doc/conf.py | 5 ----- 1 file changed, 5 deletions(-) diff --git a/doc/conf.py b/doc/conf.py index 2f8a77879a2..1b1425485fc 100644 --- a/doc/conf.py +++ b/doc/conf.py @@ -32,11 +32,6 @@ 'sphinx_issues', ] -releases_unstable_prehistory = True -releases_document_name = ["history"] -releases_issue_uri = "https://github.com/tmux-python/tmuxp/issues/%s" -releases_release_uri = "https://github.com/tmux-python/tmuxp/tree/v%s" - issues_github_path = about['__github__'].replace('https://github.com/', '') templates_path = ['_templates'] From efc440b8f6e1bd7f5a8b7cd1bd2988f3335a486e Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:21:24 -0500 Subject: [PATCH 02/31] build(alagitpull): Update to 0.1.0 --- poetry.lock | 168 +++++++++++++++++++++++++++++++------------ pyproject.toml | 2 +- requirements/doc.txt | 2 +- 3 files changed, 125 insertions(+), 47 deletions(-) diff --git a/poetry.lock b/poetry.lock index de3e9409bb4..8f6d9fd1476 100644 --- a/poetry.lock +++ b/poetry.lock @@ -19,8 +19,8 @@ category = "dev" description = "Cleverly-named alabaster sub-theme for git-pull projects" name = "alagitpull" optional = false -python-versions = "*" -version = "0.0.23" +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" +version = "0.1.0" [package.dependencies] alabaster = "<0.8" @@ -28,6 +28,7 @@ alabaster = "<0.8" [[package]] category = "dev" description = "A small Python module for determining appropriate platform-specific dirs, e.g. a \"user data dir\"." +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "appdirs" optional = false python-versions = "*" @@ -36,6 +37,7 @@ version = "1.4.4" [[package]] category = "dev" description = "Atomic file writes." +marker = "python_version >= \"3\" and sys_platform == \"win32\" or sys_platform == \"win32\" or python_version < \"3\"" name = "atomicwrites" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -69,6 +71,7 @@ pytz = ">=2015.7" [[package]] category = "dev" description = "Backport of functools.lru_cache" +marker = "python_version < \"3.2\"" name = "backports.functools-lru-cache" optional = false python-versions = ">=2.6" @@ -81,6 +84,7 @@ testing = ["pytest (>=3.5,<3.7.3 || >3.7.3)", "pytest-checkdocs (>=1.2.3)", "pyt [[package]] category = "dev" description = "The uncompromising code formatter." +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "black" optional = false python-versions = ">=3.6" @@ -158,6 +162,7 @@ version = "0.4.3" [[package]] category = "dev" description = "Updated configparser from Python 3.7 for Python 2.6+." +marker = "python_version < \"3.2\"" name = "configparser" optional = false python-versions = ">=2.6" @@ -170,6 +175,7 @@ testing = ["pytest (>=3.5,<3.7.3 || >3.7.3)", "pytest-checkdocs (>=1.2)", "pytes [[package]] category = "dev" description = "Backports and enhancements for the contextlib module" +marker = "python_version < \"3.4\"" name = "contextlib2" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -213,6 +219,7 @@ version = "0.16" [[package]] category = "dev" description = "Python 3.4 Enum backported to 3.3, 3.2, 3.1, 2.7, 2.6, 2.5, and 2.4" +marker = "python_version < \"3.4\"" name = "enum34" optional = false python-versions = "*" @@ -230,15 +237,31 @@ version = "3.8.3" mccabe = ">=0.6.0,<0.7.0" pycodestyle = ">=2.6.0a1,<2.7.0" pyflakes = ">=2.2.0,<2.3.0" -configparser = {version = "*", markers = "python_version < \"3.2\""} -enum34 = {version = "*", markers = "python_version < \"3.4\""} -functools32 = {version = "*", markers = "python_version < \"3.2\""} -importlib-metadata = {version = "*", markers = "python_version < \"3.8\""} -typing = {version = "*", markers = "python_version < \"3.5\""} + +[package.dependencies.configparser] +python = "<3.2" +version = "*" + +[package.dependencies.enum34] +python = "<3.4" +version = "*" + +[package.dependencies.functools32] +python = "<3.2" +version = "*" + +[package.dependencies.importlib-metadata] +python = "<3.8" +version = "*" + +[package.dependencies.typing] +python = "<3.5" +version = "*" [[package]] category = "dev" description = "Python function signatures from PEP362 for Python 2.6, 2.7 and 3.2+" +marker = "python_version < \"3\"" name = "funcsigs" optional = false python-versions = "*" @@ -247,6 +270,7 @@ version = "1.0.2" [[package]] category = "dev" description = "Backport of the functools module from Python 3.2.3 for use on 2.7 and PyPy." +marker = "python_version < \"3.2\"" name = "functools32" optional = false python-versions = "*" @@ -255,6 +279,7 @@ version = "3.2.3-2" [[package]] category = "dev" description = "Backport of the concurrent.futures package from Python 3" +marker = "python_version < \"3.2\"" name = "futures" optional = false python-versions = ">=2.6, <3" @@ -279,6 +304,7 @@ version = "1.2.0" [[package]] category = "dev" description = "Read metadata from Python packages" +marker = "python_version < \"3.8\" or python_version >= \"3\" and python_version < \"3.8\"" name = "importlib-metadata" optional = false python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7" @@ -286,9 +312,18 @@ version = "1.7.0" [package.dependencies] zipp = ">=0.5" -configparser = {version = ">=3.5", markers = "python_version < \"3\""} -contextlib2 = {version = "*", markers = "python_version < \"3\""} -pathlib2 = {version = "*", markers = "python_version < \"3\""} + +[package.dependencies.configparser] +python = "<3" +version = ">=3.5" + +[package.dependencies.contextlib2] +python = "<3" +version = "*" + +[package.dependencies.pathlib2] +python = "<3" +version = "*" [package.extras] docs = ["sphinx", "rst.linker"] @@ -297,14 +332,20 @@ testing = ["packaging", "pep517", "importlib-resources (>=1.3)"] [[package]] category = "dev" description = "A Python utility / library to sort Python imports." +marker = "python_version < \"3.6\"" name = "isort" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" version = "4.3.21" [package.dependencies] -"backports.functools-lru-cache" = {version = "*", markers = "python_version < \"3.2\""} -futures = {version = "*", markers = "python_version < \"3.2\""} +[package.dependencies."backports.functools-lru-cache"] +python = "<3.2" +version = "*" + +[package.dependencies.futures] +python = "<3.2" +version = "*" [package.extras] pipfile = ["pipreqs", "requirementslib"] @@ -315,6 +356,7 @@ xdg_home = ["appdirs (>=1.4.0)"] [[package]] category = "dev" description = "A Python utility / library to sort Python imports." +marker = "python_version >= \"3.6\"" name = "isort" optional = false python-versions = ">=3.6,<4.0" @@ -376,6 +418,7 @@ version = "0.6.1" [[package]] category = "dev" description = "More routines for operating on iterables, beyond itertools" +marker = "python_version <= \"2.7\"" name = "more-itertools" optional = false python-versions = "*" @@ -384,14 +427,6 @@ version = "5.0.0" [package.dependencies] six = ">=1.0.0,<2.0.0" -[[package]] -category = "dev" -description = "More routines for operating on iterables, beyond itertools" -name = "more-itertools" -optional = false -python-versions = ">=3.5" -version = "8.3.0" - [[package]] category = "dev" description = "More routines for operating on iterables, beyond itertools" @@ -415,6 +450,7 @@ six = "*" [[package]] category = "dev" description = "Object-oriented filesystem paths" +marker = "python_version >= \"3\" and python_version < \"3.6\" or python_version < \"3.6\"" name = "pathlib2" optional = false python-versions = "*" @@ -422,11 +458,15 @@ version = "2.3.4" [package.dependencies] six = "*" -scandir = {version = "*", markers = "python_version < \"3.5\""} + +[package.dependencies.scandir] +python = "<3.5" +version = "*" [[package]] category = "dev" description = "Utility library for gitignore style pattern matching of file paths." +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "pathspec" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" @@ -443,6 +483,7 @@ version = "5.4.5" [[package]] category = "dev" description = "Python Imaging Library (Fork)" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "pillow" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" @@ -451,6 +492,7 @@ version = "6.2.2" [[package]] category = "dev" description = "Python Imaging Library (Fork)" +marker = "python_version >= \"3\"" name = "pillow" optional = false python-versions = ">=3.5" @@ -476,7 +518,9 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" version = "0.13.1" [package.dependencies] -importlib-metadata = {version = ">=0.12", markers = "python_version < \"3.8\""} +[package.dependencies.importlib-metadata] +python = "<3.8" +version = ">=0.12" [package.extras] dev = ["pre-commit", "tox"] @@ -537,18 +581,26 @@ pluggy = ">=0.12,<1.0" py = ">=1.5.0" six = ">=1.10.0" wcwidth = "*" -colorama = {version = "*", markers = "sys_platform == \"win32\" and python_version != \"3.4\""} -funcsigs = {version = ">=1.0", markers = "python_version < \"3.0\""} -importlib-metadata = {version = ">=0.12", markers = "python_version < \"3.8\""} -pathlib2 = {version = ">=2.2.0", markers = "python_version < \"3.6\""} -[[package.dependencies.more-itertools]] -markers = "python_version <= \"2.7\"" +[package.dependencies.colorama] +python = "<3.4.0 || >=3.5.0" +version = "*" + +[package.dependencies.funcsigs] +python = "<3.0" +version = ">=1.0" + +[package.dependencies.importlib-metadata] +python = "<3.8" +version = ">=0.12" + +[package.dependencies.more-itertools] +python = "<2.8" version = ">=4.0.0,<6.0.0" -[[package.dependencies.more-itertools]] -markers = "python_version > \"2.7\"" -version = ">=4.0.0" +[package.dependencies.pathlib2] +python = "<3.6" +version = ">=2.2.0" [package.extras] testing = ["argcomplete", "hypothesis (>=3.56)", "nose", "requests", "mock"] @@ -562,16 +614,22 @@ python-versions = ">=3.5" version = "5.4.3" [package.dependencies] +atomicwrites = ">=1.0" attrs = ">=17.4.0" +colorama = "*" more-itertools = ">=4.0.0" packaging = "*" pluggy = ">=0.12,<1.0" py = ">=1.5.0" wcwidth = "*" -atomicwrites = {version = ">=1.0", markers = "sys_platform == \"win32\""} -colorama = {version = "*", markers = "sys_platform == \"win32\""} -importlib-metadata = {version = ">=0.12", markers = "python_version < \"3.8\""} -pathlib2 = {version = ">=2.2.0", markers = "python_version < \"3.6\""} + +[package.dependencies.importlib-metadata] +python = "<3.8" +version = ">=0.12" + +[package.dependencies.pathlib2] +python = "<3.6" +version = ">=2.2.0" [package.extras] checkqa-mypy = ["mypy (v0.761)"] @@ -580,6 +638,7 @@ testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "requests", "xm [[package]] category = "dev" description = "Pytest plugin for measuring coverage." +marker = "python_version < \"3\" or python_version >= \"3\"" name = "pytest-cov" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" @@ -595,6 +654,7 @@ testing = ["fields", "hunter", "process-tests (2.0.2)", "six", "pytest-xdist", " [[package]] category = "dev" description = "Pytest plugin for measuring coverage." +marker = "python_version >= \"3\"" name = "pytest-cov" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" @@ -617,6 +677,7 @@ version = "8.0" [package.dependencies] pytest = ">=4.4" +setuptools = ">=40.0" [[package]] category = "dev" @@ -628,6 +689,7 @@ version = "9.0" [package.dependencies] pytest = ">=5.0" +setuptools = ">=40.0" [[package]] category = "dev" @@ -665,6 +727,7 @@ md = ["cmarkgfm (>=0.2.0)"] [[package]] category = "dev" description = "Alternative regular expression module, to replace re." +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "regex" optional = false python-versions = "*" @@ -713,6 +776,7 @@ docutils = ">=0.11,<1.0" [[package]] category = "dev" description = "scandir, a better directory iterator and faster os.walk()" +marker = "python_version < \"3\"" name = "scandir" optional = false python-versions = "*" @@ -747,15 +811,19 @@ Jinja2 = ">=2.3" Pygments = ">=2.0" alabaster = ">=0.7,<0.8" babel = ">=1.3,<2.0 || >2.0" +colorama = ">=0.3.5" docutils = ">=0.11" imagesize = "*" packaging = "*" requests = ">=2.0.0" +setuptools = "*" six = ">=1.5" snowballstemmer = ">=1.1" sphinxcontrib-websupport = "*" -colorama = {version = ">=0.3.5", markers = "sys_platform == \"win32\""} -typing = {version = "*", markers = "python_version < \"3.5\""} + +[package.dependencies.typing] +python = "<3.5" +version = "*" [package.extras] test = ["mock", "pytest", "pytest-cov", "html5lib", "flake8 (>=3.5.0)", "flake8-import-order", "enum34", "mypy", "typed-ast"] @@ -774,10 +842,12 @@ Jinja2 = ">=2.3" Pygments = ">=2.0" alabaster = ">=0.7,<0.8" babel = ">=1.3" +colorama = ">=0.3.5" docutils = ">=0.12" imagesize = "*" packaging = "*" requests = ">=2.5.0" +setuptools = "*" snowballstemmer = ">=1.1" sphinxcontrib-applehelp = "*" sphinxcontrib-devhelp = "*" @@ -785,7 +855,6 @@ sphinxcontrib-htmlhelp = "*" sphinxcontrib-jsmath = "*" sphinxcontrib-qthelp = "*" sphinxcontrib-serializinghtml = "*" -colorama = {version = ">=0.3.5", markers = "sys_platform == \"win32\""} [package.extras] docs = ["sphinxcontrib-websupport"] @@ -882,6 +951,7 @@ test = ["pytest"] [[package]] category = "dev" description = "Sphinx API for Web Apps" +marker = "python_version < \"3\"" name = "sphinxcontrib-websupport" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -905,6 +975,7 @@ six = ">=1.10.0" [[package]] category = "dev" description = "Python Library for Tom's Obvious, Minimal Language" +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "toml" optional = false python-versions = "*" @@ -934,6 +1005,7 @@ pkginfo = ">=1.4.2" readme-renderer = ">=21.0" requests = ">=2.5.0,<2.15 || >2.15,<2.16 || >2.16" requests-toolbelt = ">=0.8.0,<0.9.0 || >0.9.0" +setuptools = ">=0.7.0" tqdm = ">=4.14" [package.extras] @@ -943,6 +1015,7 @@ with-blake2 = ["pyblake2"] [[package]] category = "dev" description = "a fork of Python 2 and 3 ast modules with type comment support" +marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "typed-ast" optional = false python-versions = "*" @@ -951,6 +1024,7 @@ version = "1.4.1" [[package]] category = "dev" description = "Type Hints for Python" +marker = "python_version < \"3.5\"" name = "typing" optional = false python-versions = "*" @@ -978,7 +1052,9 @@ python-versions = "*" version = "0.2.5" [package.dependencies] -"backports.functools-lru-cache" = {version = ">=1.2.1", markers = "python_version < \"3.2\""} +[package.dependencies."backports.functools-lru-cache"] +python = "<3.2" +version = ">=1.2.1" [[package]] category = "dev" @@ -991,21 +1067,24 @@ version = "0.5.1" [[package]] category = "dev" description = "Backport of pathlib-compatible object wrapper for zip files" +marker = "python_version < \"3.8\" or python_version >= \"3\" and python_version < \"3.8\"" name = "zipp" optional = false python-versions = ">=2.7" version = "1.2.0" [package.dependencies] -contextlib2 = {version = "*", markers = "python_version < \"3.4\""} +[package.dependencies.contextlib2] +python = "<3.4" +version = "*" [package.extras] docs = ["sphinx", "jaraco.packaging (>=3.2)", "rst.linker (>=1.9)"] testing = ["pathlib2", "unittest2", "jaraco.itertools", "func-timeout"] [metadata] -content-hash = "4e4bec346cb084e426f1960c5d4a9e82ade5564535adef1c7a4adbda2c1c21ae" -lock-version = "1.1" +content-hash = "c53751f2463e3955e8d52153376ceeb666df6ba7036646dee8d92f54213fef82" +lock-version = "1.0" python-versions = "~2.7 || ^3.5" [metadata.files] @@ -1018,7 +1097,8 @@ alabaster = [ {file = "alabaster-0.7.12.tar.gz", hash = "sha256:a661d72d58e6ea8a57f7a86e37d86716863ee5e92788398526d58b26a4e4dc02"}, ] alagitpull = [ - {file = "alagitpull-0.0.23.tar.gz", hash = "sha256:a56c1672f17eb3bb55c63f93fc71e7914e0a7fa0707ceefbf8d5e422bf4a9f8a"}, + {file = "alagitpull-0.1.0-py2.py3-none-any.whl", hash = "sha256:5b9ed87ee410c6fa40a63a91d2f25919a10e20c6d39e080356b067f3ff6f379b"}, + {file = "alagitpull-0.1.0.tar.gz", hash = "sha256:f6076f81a738c3291b598d8016b248edf5adf25d1d348c2599eff92c1eedaed9"}, ] appdirs = [ {file = "appdirs-1.4.4-py2.py3-none-any.whl", hash = "sha256:a841dacd6b99318a741b166adb07e19ee71a274450e68237b4650ca1055ab128"}, @@ -1210,8 +1290,6 @@ more-itertools = [ {file = "more-itertools-5.0.0.tar.gz", hash = "sha256:38a936c0a6d98a38bcc2d03fdaaedaba9f412879461dd2ceff8d37564d6522e4"}, {file = "more_itertools-5.0.0-py2-none-any.whl", hash = "sha256:c0a5785b1109a6bd7fac76d6837fd1feca158e54e521ccd2ae8bfe393cc9d4fc"}, {file = "more_itertools-5.0.0-py3-none-any.whl", hash = "sha256:fe7a7cae1ccb57d33952113ff4fa1bc5f879963600ed74918f1236e212ee50b9"}, - {file = "more-itertools-8.3.0.tar.gz", hash = "sha256:558bb897a2232f5e4f8e2399089e35aecb746e1f9191b6584a151647e89267be"}, - {file = "more_itertools-8.3.0-py3-none-any.whl", hash = "sha256:7818f596b1e87be009031c7653d01acc46ed422e6656b394b0f765ce66ed4982"}, {file = "more-itertools-8.4.0.tar.gz", hash = "sha256:68c70cc7167bdf5c7c9d8f6954a7837089c6a36bf565383919bb595efb8a17e5"}, {file = "more_itertools-8.4.0-py3-none-any.whl", hash = "sha256:b78134b2063dd214000685165d81c154522c3ee0a1c0d4d113c80361c234c5a2"}, ] diff --git a/pyproject.toml b/pyproject.toml index 51af073f7a8..604f7895c78 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -16,7 +16,7 @@ libtmux = "<0.9" [tool.poetry.dev-dependencies] aafigure = "*" -alagitpull = "*" +alagitpull = "~=0.1.0" black = {version="==19.10b0", python="^3.6"} doc8 = "*" docutils = "*" diff --git a/requirements/doc.txt b/requirements/doc.txt index e0f7333f71b..f10de812e72 100644 --- a/requirements/doc.txt +++ b/requirements/doc.txt @@ -1,7 +1,7 @@ -r ./base.txt docutils>=0.14 sphinx>=2.0.0 -alagitpull>=0.0.21 +alagitpull>=0.1.0 sphinx_issues==1.2.0 aafigure>=0.6 doc8>=0.8.0 From 0cb93efaa2f3d4815d955355020da1df073a78fd Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:29:11 -0500 Subject: [PATCH 03/31] poetry(build): Sync more packages with requirements files --- poetry.lock | 669 +++++++++++++++++++++++++++++++++++++------------ pyproject.toml | 52 ++-- 2 files changed, 544 insertions(+), 177 deletions(-) diff --git a/poetry.lock b/poetry.lock index 8f6d9fd1476..8ce732469b8 100644 --- a/poetry.lock +++ b/poetry.lock @@ -37,7 +37,7 @@ version = "1.4.4" [[package]] category = "dev" description = "Atomic file writes." -marker = "python_version >= \"3\" and sys_platform == \"win32\" or sys_platform == \"win32\" or python_version < \"3\"" +marker = "python_version >= \"3\" and sys_platform == \"win32\" or python_version < \"3\"" name = "atomicwrites" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -46,6 +46,7 @@ version = "1.4.0" [[package]] category = "dev" description = "Classes Without Boilerplate" +marker = "python_version >= \"3.6\" and python_version < \"4.0\" or python_version >= \"3\" or python_version < \"3\"" name = "attrs" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -60,6 +61,7 @@ tests = ["coverage", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "zope.i [[package]] category = "dev" description = "Internationalization utilities" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "babel" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -123,6 +125,18 @@ optional = false python-versions = "*" version = "2020.6.20" +[[package]] +category = "dev" +description = "Foreign Function Interface for Python calling C code." +marker = "sys_platform == \"linux\"" +name = "cffi" +optional = false +python-versions = "*" +version = "1.14.1" + +[package.dependencies] +pycparser = "*" + [[package]] category = "dev" description = "Universal encoding detector for Python 2 and 3" @@ -145,20 +159,36 @@ description = "Hosted coverage reports for GitHub, Bitbucket and Gitlab" name = "codecov" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" -version = "2.1.7" +version = "2.1.8" [package.dependencies] coverage = "*" requests = ">=2.7.9" [[package]] -category = "dev" +category = "main" description = "Cross-platform colored terminal text." name = "colorama" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" version = "0.4.3" +[[package]] +category = "dev" +description = "Python parser for the CommonMark Markdown spec" +name = "commonmark" +optional = false +python-versions = "*" +version = "0.9.1" + +[package.dependencies] +[package.dependencies.future] +python = "<3" +version = ">=0.14.0" + +[package.extras] +test = ["flake8 (3.7.8)", "hypothesis (3.55.3)"] + [[package]] category = "dev" description = "Updated configparser from Python 3.7 for Python 2.6+." @@ -175,7 +205,7 @@ testing = ["pytest (>=3.5,<3.7.3 || >3.7.3)", "pytest-checkdocs (>=1.2)", "pytes [[package]] category = "dev" description = "Backports and enhancements for the contextlib module" -marker = "python_version < \"3.4\"" +marker = "python_version < \"3\"" name = "contextlib2" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -187,26 +217,31 @@ description = "Code coverage measurement for Python" name = "coverage" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, <4" -version = "5.1" +version = "5.2.1" [package.extras] toml = ["toml"] [[package]] category = "dev" -description = "Style checker for Sphinx (or other) RST documentation" -name = "doc8" +description = "cryptography is a package which provides cryptographic recipes and primitives to Python developers." +marker = "sys_platform == \"linux\"" +name = "cryptography" optional = false -python-versions = "*" -version = "0.8.1" +python-versions = ">=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*" +version = "3.0" [package.dependencies] -Pygments = "*" -chardet = "*" -docutils = "*" -restructuredtext-lint = ">=0.7" -six = "*" -stevedore = "*" +cffi = ">=1.8,<1.11.3 || >1.11.3" +six = ">=1.4.1" + +[package.extras] +docs = ["sphinx (>=1.6.5,<1.8.0 || >1.8.0,<3.1.0 || >3.1.0,<3.1.1 || >3.1.1)", "sphinx-rtd-theme"] +docstest = ["doc8", "pyenchant (>=1.6.11)", "twine (>=1.12.0)", "sphinxcontrib-spelling (>=4.0.1)"] +idna = ["idna (>=2.1)"] +pep8test = ["black", "flake8", "flake8-import-order", "pep8-naming"] +ssh = ["bcrypt (>=3.1.5)"] +test = ["pytest (>=3.6.0,<3.9.0 || >3.9.0,<3.9.1 || >3.9.1,<3.9.2 || >3.9.2)", "pretend", "iso8601", "pytz", "hypothesis (>=1.11.4,<3.79.2 || >3.79.2)"] [[package]] category = "dev" @@ -276,6 +311,15 @@ optional = false python-versions = "*" version = "3.2.3-2" +[[package]] +category = "dev" +description = "Clean single-source support for Python 3 and 2" +marker = "python_version < \"3\"" +name = "future" +optional = false +python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*" +version = "0.18.2" + [[package]] category = "dev" description = "Backport of the concurrent.futures package from Python 3" @@ -296,6 +340,7 @@ version = "2.10" [[package]] category = "dev" description = "Getting image size from png/jpeg/jpeg2000/gif file" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "imagesize" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -329,10 +374,19 @@ version = "*" docs = ["sphinx", "rst.linker"] testing = ["packaging", "pep517", "importlib-resources (>=1.3)"] +[[package]] +category = "dev" +description = "iniconfig: brain-dead simple config-ini parsing" +marker = "python_version >= \"3\"" +name = "iniconfig" +optional = false +python-versions = "*" +version = "1.0.1" + [[package]] category = "dev" description = "A Python utility / library to sort Python imports." -marker = "python_version < \"3.6\"" +marker = "python_version < \"3.6\" or python_version >= \"3.6\"" name = "isort" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -360,15 +414,29 @@ marker = "python_version >= \"3.6\"" name = "isort" optional = false python-versions = ">=3.6,<4.0" -version = "5.1.4" +version = "5.3.2" [package.extras] +colors = ["colorama (>=0.4.3,<0.5.0)"] pipfile_deprecated_finder = ["pipreqs", "requirementslib", "tomlkit (>=0.5.3)"] requirements_deprecated_finder = ["pipreqs", "pip-api"] +[[package]] +category = "dev" +description = "Low-level, pure Python DBus protocol wrapper." +marker = "sys_platform == \"linux\"" +name = "jeepney" +optional = false +python-versions = ">=3.5" +version = "0.4.3" + +[package.extras] +dev = ["testpath"] + [[package]] category = "dev" description = "A very fast and expressive template engine." +marker = "python_version < \"3\" or python_version >= \"3\"" name = "jinja2" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" @@ -391,6 +459,27 @@ version = "0.5.12" [package.dependencies] PyYAML = ">=3.13,<6" +[[package]] +category = "dev" +description = "Store and access your passwords safely." +name = "keyring" +optional = false +python-versions = ">=3.6" +version = "21.3.0" + +[package.dependencies] +SecretStorage = ">=3" +jeepney = ">=0.4.2" +pywin32-ctypes = "<0.1.0 || >0.1.0,<0.1.1 || >0.1.1" + +[package.dependencies.importlib-metadata] +python = "<3.8" +version = "*" + +[package.extras] +docs = ["sphinx", "jaraco.packaging (>=3.2)", "rst.linker (>=1.9)"] +testing = ["pytest (>=3.5,<3.7.3 || >3.7.3)", "pytest-checkdocs (>=1.2.3)", "pytest-flake8", "pytest-black (>=0.3.7)", "pytest-cov", "pytest-mypy"] + [[package]] category = "main" description = "scripting library / orm for tmux" @@ -402,6 +491,7 @@ version = "0.8.2" [[package]] category = "dev" description = "Safely add untrusted strings to HTML/XML markup." +marker = "python_version < \"3\" or python_version >= \"3\"" name = "markupsafe" optional = false python-versions = ">=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*" @@ -415,6 +505,27 @@ optional = false python-versions = "*" version = "0.6.1" +[[package]] +category = "dev" +description = "Rolling backport of unittest.mock for all Pythons" +marker = "python_version < \"3\"" +name = "mock" +optional = false +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +version = "3.0.5" + +[package.dependencies] +six = "*" + +[package.dependencies.funcsigs] +python = "<3.3" +version = ">=1" + +[package.extras] +build = ["twine", "wheel", "blurb"] +docs = ["sphinx"] +test = ["pytest", "pytest-cov"] + [[package]] category = "dev" description = "More routines for operating on iterables, beyond itertools" @@ -430,6 +541,7 @@ six = ">=1.0.0,<2.0.0" [[package]] category = "dev" description = "More routines for operating on iterables, beyond itertools" +marker = "python_version >= \"3\"" name = "more-itertools" optional = false python-versions = ">=3.5" @@ -450,7 +562,7 @@ six = "*" [[package]] category = "dev" description = "Object-oriented filesystem paths" -marker = "python_version >= \"3\" and python_version < \"3.6\" or python_version < \"3.6\"" +marker = "python_version < \"3\"" name = "pathlib2" optional = false python-versions = "*" @@ -463,6 +575,18 @@ six = "*" python = "<3.5" version = "*" +[[package]] +category = "dev" +description = "Object-oriented filesystem paths" +marker = "python_version >= \"3\" and python_version < \"3.6\"" +name = "pathlib2" +optional = false +python-versions = "*" +version = "2.3.5" + +[package.dependencies] +six = "*" + [[package]] category = "dev" description = "Utility library for gitignore style pattern matching of file paths." @@ -472,14 +596,6 @@ optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" version = "0.8.0" -[[package]] -category = "dev" -description = "Python Build Reasonableness" -name = "pbr" -optional = false -python-versions = "*" -version = "5.4.5" - [[package]] category = "dev" description = "Python Imaging Library (Fork)" @@ -496,7 +612,7 @@ marker = "python_version >= \"3\"" name = "pillow" optional = false python-versions = ">=3.5" -version = "7.1.2" +version = "7.2.0" [[package]] category = "dev" @@ -512,6 +628,7 @@ testing = ["nose", "coverage"] [[package]] category = "dev" description = "plugin and hook calling mechanisms for python" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "pluggy" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -528,6 +645,7 @@ dev = ["pre-commit", "tox"] [[package]] category = "dev" description = "library with cross-python path, ini-parsing, io, code, log facilities" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "py" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -541,6 +659,15 @@ optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" version = "2.6.0" +[[package]] +category = "dev" +description = "C parser in Python" +marker = "sys_platform == \"linux\"" +name = "pycparser" +optional = false +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +version = "2.20" + [[package]] category = "dev" description = "passive checker of Python programs" @@ -557,9 +684,18 @@ optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" version = "2.5.2" +[[package]] +category = "dev" +description = "Pygments is a syntax highlighting package written in Python." +name = "pygments" +optional = false +python-versions = ">=3.5" +version = "2.6.1" + [[package]] category = "dev" description = "Python parsing module" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "pyparsing" optional = false python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*" @@ -611,17 +747,18 @@ description = "pytest: simple powerful testing with Python" name = "pytest" optional = false python-versions = ">=3.5" -version = "5.4.3" +version = "6.0.1" [package.dependencies] atomicwrites = ">=1.0" attrs = ">=17.4.0" colorama = "*" +iniconfig = "*" more-itertools = ">=4.0.0" packaging = "*" pluggy = ">=0.12,<1.0" -py = ">=1.5.0" -wcwidth = "*" +py = ">=1.8.2" +toml = "*" [package.dependencies.importlib-metadata] python = "<3.8" @@ -632,7 +769,7 @@ python = "<3.6" version = ">=2.2.0" [package.extras] -checkqa-mypy = ["mypy (v0.761)"] +checkqa_mypy = ["mypy (0.780)"] testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "requests", "xmlschema"] [[package]] @@ -667,6 +804,40 @@ pytest = ">=4.6" [package.extras] testing = ["fields", "hunter", "process-tests (2.0.2)", "six", "pytest-xdist", "virtualenv"] +[[package]] +category = "dev" +description = "Thin-wrapper around the mock package for easier use with py.test" +marker = "python_version < \"3\" or python_version >= \"3\"" +name = "pytest-mock" +optional = false +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +version = "2.0.0" + +[package.dependencies] +pytest = ">=2.7" + +[package.dependencies.mock] +python = "<3.0" +version = "*" + +[package.extras] +dev = ["pre-commit", "tox"] + +[[package]] +category = "dev" +description = "Thin-wrapper around the mock package for easier use with pytest" +marker = "python_version >= \"3\"" +name = "pytest-mock" +optional = false +python-versions = ">=3.5" +version = "3.2.0" + +[package.dependencies] +pytest = ">=2.7" + +[package.extras] +dev = ["pre-commit", "tox", "pytest-asyncio"] + [[package]] category = "dev" description = "pytest plugin to re-run tests to eliminate flaky failures" @@ -694,11 +865,21 @@ setuptools = ">=40.0" [[package]] category = "dev" description = "World timezone definitions, modern and historical" +marker = "python_version < \"3\" or python_version >= \"3\"" name = "pytz" optional = false python-versions = "*" version = "2020.1" +[[package]] +category = "dev" +description = "" +marker = "sys_platform == \"win32\"" +name = "pywin32-ctypes" +optional = false +python-versions = "*" +version = "0.2.0" + [[package]] category = "main" description = "YAML parser and emitter for Python" @@ -724,6 +905,19 @@ six = "*" [package.extras] md = ["cmarkgfm (>=0.2.0)"] +[[package]] +category = "dev" +description = "A docutils-compatibility bridge to CommonMark, enabling you to write CommonMark inside of Docutils & Sphinx projects." +name = "recommonmark" +optional = false +python-versions = "*" +version = "0.6.0" + +[package.dependencies] +commonmark = ">=0.8.1" +docutils = ">=0.11" +sphinx = ">=1.3.1" + [[package]] category = "dev" description = "Alternative regular expression module, to replace re." @@ -731,7 +925,7 @@ marker = "python_version >= \"3.6\" and python_version < \"4.0\"" name = "regex" optional = false python-versions = "*" -version = "2020.6.8" +version = "2020.7.14" [[package]] category = "dev" @@ -764,14 +958,14 @@ requests = ">=2.0.1,<3.0.0" [[package]] category = "dev" -description = "reStructuredText linter" -name = "restructuredtext-lint" +description = "Validating URI References per RFC 3986" +name = "rfc3986" optional = false python-versions = "*" -version = "1.3.1" +version = "1.4.0" -[package.dependencies] -docutils = ">=0.11,<1.0" +[package.extras] +idna2008 = ["idna"] [[package]] category = "dev" @@ -782,6 +976,19 @@ optional = false python-versions = "*" version = "1.10.0" +[[package]] +category = "dev" +description = "Python bindings to FreeDesktop.org Secret Service API" +marker = "sys_platform == \"linux\"" +name = "secretstorage" +optional = false +python-versions = ">=3.5" +version = "3.1.2" + +[package.dependencies] +cryptography = "*" +jeepney = ">=0.4.2" + [[package]] category = "dev" description = "Python 2 and 3 compatibility utilities" @@ -793,6 +1000,7 @@ version = "1.15.0" [[package]] category = "dev" description = "This package provides 26 stemmers for 25 languages generated from Snowball algorithms." +marker = "python_version < \"3\" or python_version >= \"3\"" name = "snowballstemmer" optional = false python-versions = "*" @@ -835,7 +1043,7 @@ description = "Python documentation generator" name = "sphinx" optional = false python-versions = ">=3.5" -version = "3.1.1" +version = "3.2.0" [package.dependencies] Jinja2 = ">=2.3" @@ -880,6 +1088,7 @@ tests = ["pytest", "mock"] [[package]] category = "dev" description = "sphinxcontrib-applehelp is a sphinx extension which outputs Apple help books" +marker = "python_version >= \"3\"" name = "sphinxcontrib-applehelp" optional = false python-versions = ">=3.5" @@ -892,6 +1101,7 @@ test = ["pytest"] [[package]] category = "dev" description = "sphinxcontrib-devhelp is a sphinx extension which outputs Devhelp document." +marker = "python_version >= \"3\"" name = "sphinxcontrib-devhelp" optional = false python-versions = ">=3.5" @@ -904,6 +1114,7 @@ test = ["pytest"] [[package]] category = "dev" description = "sphinxcontrib-htmlhelp is a sphinx extension which renders HTML help files" +marker = "python_version >= \"3\"" name = "sphinxcontrib-htmlhelp" optional = false python-versions = ">=3.5" @@ -916,6 +1127,7 @@ test = ["pytest", "html5lib"] [[package]] category = "dev" description = "A sphinx extension which renders display math in HTML via JavaScript" +marker = "python_version >= \"3\"" name = "sphinxcontrib-jsmath" optional = false python-versions = ">=3.5" @@ -927,6 +1139,7 @@ test = ["pytest", "flake8", "mypy"] [[package]] category = "dev" description = "sphinxcontrib-qthelp is a sphinx extension which outputs QtHelp document." +marker = "python_version >= \"3\"" name = "sphinxcontrib-qthelp" optional = false python-versions = ">=3.5" @@ -939,6 +1152,7 @@ test = ["pytest"] [[package]] category = "dev" description = "sphinxcontrib-serializinghtml is a sphinx extension which outputs \"serialized\" HTML files (json and pickle)." +marker = "python_version >= \"3\"" name = "sphinxcontrib-serializinghtml" optional = false python-versions = ">=3.5" @@ -960,22 +1174,10 @@ version = "1.1.2" [package.extras] test = ["pytest", "mock"] -[[package]] -category = "dev" -description = "Manage dynamic plugins for Python applications" -name = "stevedore" -optional = false -python-versions = "*" -version = "1.32.0" - -[package.dependencies] -pbr = ">=2.0.0,<2.1.0 || >2.1.0" -six = ">=1.10.0" - [[package]] category = "dev" description = "Python Library for Tom's Obvious, Minimal Language" -marker = "python_version >= \"3.6\" and python_version < \"4.0\"" +marker = "python_version >= \"3.6\" and python_version < \"4.0\" or python_version >= \"3\"" name = "toml" optional = false python-versions = "*" @@ -987,7 +1189,7 @@ description = "Fast, Extensible Progress Meter" name = "tqdm" optional = false python-versions = ">=2.6, !=3.0.*, !=3.1.*" -version = "4.46.1" +version = "4.48.2" [package.extras] dev = ["py-make (>=0.1.0)", "twine", "argopt", "pydoc-markdown"] @@ -1012,6 +1214,29 @@ tqdm = ">=4.14" keyring = ["keyring"] with-blake2 = ["pyblake2"] +[[package]] +category = "dev" +description = "Collection of utilities for publishing packages on PyPI" +name = "twine" +optional = false +python-versions = ">=3.6" +version = "3.2.0" + +[package.dependencies] +colorama = ">=0.4.3" +keyring = ">=15.1" +pkginfo = ">=1.4.2" +readme-renderer = ">=21.0" +requests = ">=2.20" +requests-toolbelt = ">=0.8.0,<0.9.0 || >0.9.0" +rfc3986 = ">=1.4.0" +setuptools = ">=0.7.0" +tqdm = ">=4.14" + +[package.dependencies.importlib-metadata] +python = "<3.8" +version = "*" + [[package]] category = "dev" description = "a fork of Python 2 and 3 ast modules with type comment support" @@ -1027,8 +1252,8 @@ description = "Type Hints for Python" marker = "python_version < \"3.5\"" name = "typing" optional = false -python-versions = "*" -version = "3.7.4.1" +python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +version = "3.7.4.3" [[package]] category = "dev" @@ -1036,7 +1261,7 @@ description = "HTTP library with thread-safe connection pooling, file post, and name = "urllib3" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, <4" -version = "1.25.9" +version = "1.25.10" [package.extras] brotli = ["brotlipy (>=0.6.0)"] @@ -1046,6 +1271,7 @@ socks = ["PySocks (>=1.5.6,<1.5.7 || >1.5.7,<2.0)"] [[package]] category = "dev" description = "Measures the displayed width of unicode strings in a terminal" +marker = "python_version < \"3\"" name = "wcwidth" optional = false python-versions = "*" @@ -1067,7 +1293,7 @@ version = "0.5.1" [[package]] category = "dev" description = "Backport of pathlib-compatible object wrapper for zip files" -marker = "python_version < \"3.8\" or python_version >= \"3\" and python_version < \"3.8\"" +marker = "python_version >= \"3\" and python_version < \"3.8\" or python_version < \"3\"" name = "zipp" optional = false python-versions = ">=2.7" @@ -1082,8 +1308,29 @@ version = "*" docs = ["sphinx", "jaraco.packaging (>=3.2)", "rst.linker (>=1.9)"] testing = ["pathlib2", "unittest2", "jaraco.itertools", "func-timeout"] +[[package]] +category = "dev" +description = "Backport of pathlib-compatible object wrapper for zip files" +marker = "python_version >= \"3\" and python_version < \"3.8\"" +name = "zipp" +optional = false +python-versions = ">=3.6" +version = "3.1.0" + +[package.extras] +docs = ["sphinx", "jaraco.packaging (>=3.2)", "rst.linker (>=1.9)"] +testing = ["jaraco.itertools", "func-timeout"] + +[extras] +coverage = [] +deploy = [] +docs = [] +format = [] +lint = [] +test = [] + [metadata] -content-hash = "c53751f2463e3955e8d52153376ceeb666df6ba7036646dee8d92f54213fef82" +content-hash = "55071e1712036e5feedbdbbd08b46a2ff50bd9691fb9bf1ef2ae44386833ec91" lock-version = "1.0" python-versions = "~2.7 || ^3.5" @@ -1132,6 +1379,36 @@ certifi = [ {file = "certifi-2020.6.20-py2.py3-none-any.whl", hash = "sha256:8fc0819f1f30ba15bdb34cceffb9ef04d99f420f68eb75d901e9560b8749fc41"}, {file = "certifi-2020.6.20.tar.gz", hash = "sha256:5930595817496dd21bb8dc35dad090f1c2cd0adfaf21204bf6732ca5d8ee34d3"}, ] +cffi = [ + {file = "cffi-1.14.1-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:66dd45eb9530e3dde8f7c009f84568bc7cac489b93d04ac86e3111fb46e470c2"}, + {file = "cffi-1.14.1-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:4f53e4128c81ca3212ff4cf097c797ab44646a40b42ec02a891155cd7a2ba4d8"}, + {file = "cffi-1.14.1-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:833401b15de1bb92791d7b6fb353d4af60dc688eaa521bd97203dcd2d124a7c1"}, + {file = "cffi-1.14.1-cp27-cp27m-win32.whl", hash = "sha256:26f33e8f6a70c255767e3c3f957ccafc7f1f706b966e110b855bfe944511f1f9"}, + {file = "cffi-1.14.1-cp27-cp27m-win_amd64.whl", hash = "sha256:b87dfa9f10a470eee7f24234a37d1d5f51e5f5fa9eeffda7c282e2b8f5162eb1"}, + {file = "cffi-1.14.1-cp27-cp27mu-manylinux1_i686.whl", hash = "sha256:effd2ba52cee4ceff1a77f20d2a9f9bf8d50353c854a282b8760ac15b9833168"}, + {file = "cffi-1.14.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bac0d6f7728a9cc3c1e06d4fcbac12aaa70e9379b3025b27ec1226f0e2d404cf"}, + {file = "cffi-1.14.1-cp35-cp35m-macosx_10_9_x86_64.whl", hash = "sha256:d6033b4ffa34ef70f0b8086fd4c3df4bf801fee485a8a7d4519399818351aa8e"}, + {file = "cffi-1.14.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:8416ed88ddc057bab0526d4e4e9f3660f614ac2394b5e019a628cdfff3733849"}, + {file = "cffi-1.14.1-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:892daa86384994fdf4856cb43c93f40cbe80f7f95bb5da94971b39c7f54b3a9c"}, + {file = "cffi-1.14.1-cp35-cp35m-win32.whl", hash = "sha256:c991112622baee0ae4d55c008380c32ecfd0ad417bcd0417ba432e6ba7328caa"}, + {file = "cffi-1.14.1-cp35-cp35m-win_amd64.whl", hash = "sha256:fcf32bf76dc25e30ed793145a57426064520890d7c02866eb93d3e4abe516948"}, + {file = "cffi-1.14.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:f960375e9823ae6a07072ff7f8a85954e5a6434f97869f50d0e41649a1c8144f"}, + {file = "cffi-1.14.1-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:a6d28e7f14ecf3b2ad67c4f106841218c8ab12a0683b1528534a6c87d2307af3"}, + {file = "cffi-1.14.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:cda422d54ee7905bfc53ee6915ab68fe7b230cacf581110df4272ee10462aadc"}, + {file = "cffi-1.14.1-cp36-cp36m-win32.whl", hash = "sha256:4a03416915b82b81af5502459a8a9dd62a3c299b295dcdf470877cb948d655f2"}, + {file = "cffi-1.14.1-cp36-cp36m-win_amd64.whl", hash = "sha256:4ce1e995aeecf7cc32380bc11598bfdfa017d592259d5da00fc7ded11e61d022"}, + {file = "cffi-1.14.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:e23cb7f1d8e0f93addf0cae3c5b6f00324cccb4a7949ee558d7b6ca973ab8ae9"}, + {file = "cffi-1.14.1-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:ddff0b2bd7edcc8c82d1adde6dbbf5e60d57ce985402541cd2985c27f7bec2a0"}, + {file = "cffi-1.14.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:f90c2267101010de42f7273c94a1f026e56cbc043f9330acd8a80e64300aba33"}, + {file = "cffi-1.14.1-cp37-cp37m-win32.whl", hash = "sha256:3cd2c044517f38d1b577f05927fb9729d3396f1d44d0c659a445599e79519792"}, + {file = "cffi-1.14.1-cp37-cp37m-win_amd64.whl", hash = "sha256:4fa72a52a906425416f41738728268072d5acfd48cbe7796af07a923236bcf96"}, + {file = "cffi-1.14.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:267adcf6e68d77ba154334a3e4fc921b8e63cbb38ca00d33d40655d4228502bc"}, + {file = "cffi-1.14.1-cp38-cp38-manylinux1_i686.whl", hash = "sha256:d3148b6ba3923c5850ea197a91a42683f946dba7e8eb82dfa211ab7e708de939"}, + {file = "cffi-1.14.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:98be759efdb5e5fa161e46d404f4e0ce388e72fbf7d9baf010aff16689e22abe"}, + {file = "cffi-1.14.1-cp38-cp38-win32.whl", hash = "sha256:6923d077d9ae9e8bacbdb1c07ae78405a9306c8fd1af13bfa06ca891095eb995"}, + {file = "cffi-1.14.1-cp38-cp38-win_amd64.whl", hash = "sha256:b1d6ebc891607e71fd9da71688fcf332a6630b7f5b7f5549e6e631821c0e5d90"}, + {file = "cffi-1.14.1.tar.gz", hash = "sha256:b2a2b0d276a136146e012154baefaea2758ef1f56ae9f4e01c612b0831e0bd2f"}, +] chardet = [ {file = "chardet-3.0.4-py2.py3-none-any.whl", hash = "sha256:fc323ffcaeaed0e0a02bf4d117757b98aed530d9ed4531e3e15460124c106691"}, {file = "chardet-3.0.4.tar.gz", hash = "sha256:84ab92ed1c4d4f16916e05906b6b75a6c0fb5db821cc65e70cbd64a3e2a5eaae"}, @@ -1141,14 +1418,18 @@ click = [ {file = "click-7.1.2.tar.gz", hash = "sha256:d2b5255c7c6349bc1bd1e59e08cd12acbbd63ce649f2588755783aa94dfb6b1a"}, ] codecov = [ - {file = "codecov-2.1.7-py2.py3-none-any.whl", hash = "sha256:b67bb8029e8340a7bf22c71cbece5bd18c96261fdebc2f105ee4d5a005bc8728"}, - {file = "codecov-2.1.7-py3.8.egg", hash = "sha256:d8b8109f44edad03b24f5f189dac8de9b1e3dc3c791fa37eeaf8c7381503ec34"}, - {file = "codecov-2.1.7.tar.gz", hash = "sha256:491938ad774ea94a963d5d16354c7299e90422a33a353ba0d38d0943ed1d5091"}, + {file = "codecov-2.1.8-py2.py3-none-any.whl", hash = "sha256:65e8a8008e43eb45a9404bf68f8d4a60d36de3827ef2287971c94940128eba1e"}, + {file = "codecov-2.1.8-py3.8.egg", hash = "sha256:fa7985ac6a3886cf68e3420ee1b5eb4ed30c4bdceec0f332d17ab69f545fbc90"}, + {file = "codecov-2.1.8.tar.gz", hash = "sha256:0be9cd6358cc6a3c01a1586134b0fb524dfa65ccbec3a40e9f28d5f976676ba2"}, ] colorama = [ {file = "colorama-0.4.3-py2.py3-none-any.whl", hash = "sha256:7d73d2a99753107a36ac6b455ee49046802e59d9d076ef8e47b61499fa29afff"}, {file = "colorama-0.4.3.tar.gz", hash = "sha256:e96da0d330793e2cb9485e9ddfd918d456036c7149416295932478192f4436a1"}, ] +commonmark = [ + {file = "commonmark-0.9.1-py2.py3-none-any.whl", hash = "sha256:da2f38c92590f83de410ba1a3cbceafbc74fee9def35f9251ba9a971d6d66fd9"}, + {file = "commonmark-0.9.1.tar.gz", hash = "sha256:452f9dc859be7f06631ddcb328b6919c67984aca654e5fefb3914d54691aed60"}, +] configparser = [ {file = "configparser-4.0.2-py2.py3-none-any.whl", hash = "sha256:254c1d9c79f60c45dfde850850883d5aaa7f19a23f13561243a050d5a7c3fe4c"}, {file = "configparser-4.0.2.tar.gz", hash = "sha256:c7d282687a5308319bf3d2e7706e575c635b0a470342641c93bea0ea3b5331df"}, @@ -1158,41 +1439,61 @@ contextlib2 = [ {file = "contextlib2-0.6.0.post1.tar.gz", hash = "sha256:01f490098c18b19d2bd5bb5dc445b2054d2fa97f09a4280ba2c5f3c394c8162e"}, ] coverage = [ - {file = "coverage-5.1-cp27-cp27m-macosx_10_12_x86_64.whl", hash = "sha256:0cb4be7e784dcdc050fc58ef05b71aa8e89b7e6636b99967fadbdba694cf2b65"}, - {file = "coverage-5.1-cp27-cp27m-macosx_10_13_intel.whl", hash = "sha256:c317eaf5ff46a34305b202e73404f55f7389ef834b8dbf4da09b9b9b37f76dd2"}, - {file = "coverage-5.1-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:b83835506dfc185a319031cf853fa4bb1b3974b1f913f5bb1a0f3d98bdcded04"}, - {file = "coverage-5.1-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:5f2294dbf7875b991c381e3d5af2bcc3494d836affa52b809c91697449d0eda6"}, - {file = "coverage-5.1-cp27-cp27m-win32.whl", hash = "sha256:de807ae933cfb7f0c7d9d981a053772452217df2bf38e7e6267c9cbf9545a796"}, - {file = "coverage-5.1-cp27-cp27m-win_amd64.whl", hash = "sha256:bf9cb9a9fd8891e7efd2d44deb24b86d647394b9705b744ff6f8261e6f29a730"}, - {file = "coverage-5.1-cp27-cp27mu-manylinux1_i686.whl", hash = "sha256:acf3763ed01af8410fc36afea23707d4ea58ba7e86a8ee915dfb9ceff9ef69d0"}, - {file = "coverage-5.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:dec5202bfe6f672d4511086e125db035a52b00f1648d6407cc8e526912c0353a"}, - {file = "coverage-5.1-cp35-cp35m-macosx_10_12_x86_64.whl", hash = "sha256:7a5bdad4edec57b5fb8dae7d3ee58622d626fd3a0be0dfceda162a7035885ecf"}, - {file = "coverage-5.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:1601e480b9b99697a570cea7ef749e88123c04b92d84cedaa01e117436b4a0a9"}, - {file = "coverage-5.1-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:dbe8c6ae7534b5b024296464f387d57c13caa942f6d8e6e0346f27e509f0f768"}, - {file = "coverage-5.1-cp35-cp35m-win32.whl", hash = "sha256:a027ef0492ede1e03a8054e3c37b8def89a1e3c471482e9f046906ba4f2aafd2"}, - {file = "coverage-5.1-cp35-cp35m-win_amd64.whl", hash = "sha256:0e61d9803d5851849c24f78227939c701ced6704f337cad0a91e0972c51c1ee7"}, - {file = "coverage-5.1-cp36-cp36m-macosx_10_13_x86_64.whl", hash = "sha256:2d27a3f742c98e5c6b461ee6ef7287400a1956c11421eb574d843d9ec1f772f0"}, - {file = "coverage-5.1-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:66460ab1599d3cf894bb6baee8c684788819b71a5dc1e8fa2ecc152e5d752019"}, - {file = "coverage-5.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:5c542d1e62eece33c306d66fe0a5c4f7f7b3c08fecc46ead86d7916684b36d6c"}, - {file = "coverage-5.1-cp36-cp36m-win32.whl", hash = "sha256:2742c7515b9eb368718cd091bad1a1b44135cc72468c731302b3d641895b83d1"}, - {file = "coverage-5.1-cp36-cp36m-win_amd64.whl", hash = "sha256:dead2ddede4c7ba6cb3a721870f5141c97dc7d85a079edb4bd8d88c3ad5b20c7"}, - {file = "coverage-5.1-cp37-cp37m-macosx_10_13_x86_64.whl", hash = "sha256:01333e1bd22c59713ba8a79f088b3955946e293114479bbfc2e37d522be03355"}, - {file = "coverage-5.1-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:e1ea316102ea1e1770724db01998d1603ed921c54a86a2efcb03428d5417e489"}, - {file = "coverage-5.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:adeb4c5b608574a3d647011af36f7586811a2c1197c861aedb548dd2453b41cd"}, - {file = "coverage-5.1-cp37-cp37m-win32.whl", hash = "sha256:782caea581a6e9ff75eccda79287daefd1d2631cc09d642b6ee2d6da21fc0a4e"}, - {file = "coverage-5.1-cp37-cp37m-win_amd64.whl", hash = "sha256:00f1d23f4336efc3b311ed0d807feb45098fc86dee1ca13b3d6768cdab187c8a"}, - {file = "coverage-5.1-cp38-cp38-macosx_10_13_x86_64.whl", hash = "sha256:402e1744733df483b93abbf209283898e9f0d67470707e3c7516d84f48524f55"}, - {file = "coverage-5.1-cp38-cp38-manylinux1_i686.whl", hash = "sha256:a3f3654d5734a3ece152636aad89f58afc9213c6520062db3978239db122f03c"}, - {file = "coverage-5.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:6402bd2fdedabbdb63a316308142597534ea8e1895f4e7d8bf7476c5e8751fef"}, - {file = "coverage-5.1-cp38-cp38-win32.whl", hash = "sha256:8fa0cbc7ecad630e5b0f4f35b0f6ad419246b02bc750de7ac66db92667996d24"}, - {file = "coverage-5.1-cp38-cp38-win_amd64.whl", hash = "sha256:79a3cfd6346ce6c13145731d39db47b7a7b859c0272f02cdb89a3bdcbae233a0"}, - {file = "coverage-5.1-cp39-cp39-win32.whl", hash = "sha256:a82b92b04a23d3c8a581fc049228bafde988abacba397d57ce95fe95e0338ab4"}, - {file = "coverage-5.1-cp39-cp39-win_amd64.whl", hash = "sha256:bb28a7245de68bf29f6fb199545d072d1036a1917dca17a1e75bbb919e14ee8e"}, - {file = "coverage-5.1.tar.gz", hash = "sha256:f90bfc4ad18450c80b024036eaf91e4a246ae287701aaa88eaebebf150868052"}, -] -doc8 = [ - {file = "doc8-0.8.1-py2.py3-none-any.whl", hash = "sha256:4d58a5c8c56cedd2b2c9d6e3153be5d956cf72f6051128f0f2255c66227df721"}, - {file = "doc8-0.8.1.tar.gz", hash = "sha256:4d1df12598807cf08ffa9a1d5ef42d229ee0de42519da01b768ff27211082c12"}, + {file = "coverage-5.2.1-cp27-cp27m-macosx_10_13_intel.whl", hash = "sha256:40f70f81be4d34f8d491e55936904db5c527b0711b2a46513641a5729783c2e4"}, + {file = "coverage-5.2.1-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:675192fca634f0df69af3493a48224f211f8db4e84452b08d5fcebb9167adb01"}, + {file = "coverage-5.2.1-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:2fcc8b58953d74d199a1a4d633df8146f0ac36c4e720b4a1997e9b6327af43a8"}, + {file = "coverage-5.2.1-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:64c4f340338c68c463f1b56e3f2f0423f7b17ba6c3febae80b81f0e093077f59"}, + {file = "coverage-5.2.1-cp27-cp27m-win32.whl", hash = "sha256:52f185ffd3291196dc1aae506b42e178a592b0b60a8610b108e6ad892cfc1bb3"}, + {file = "coverage-5.2.1-cp27-cp27m-win_amd64.whl", hash = "sha256:30bc103587e0d3df9e52cd9da1dd915265a22fad0b72afe54daf840c984b564f"}, + {file = "coverage-5.2.1-cp27-cp27mu-manylinux1_i686.whl", hash = "sha256:9ea749fd447ce7fb1ac71f7616371f04054d969d412d37611716721931e36efd"}, + {file = "coverage-5.2.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:ce7866f29d3025b5b34c2e944e66ebef0d92e4a4f2463f7266daa03a1332a651"}, + {file = "coverage-5.2.1-cp35-cp35m-macosx_10_13_x86_64.whl", hash = "sha256:4869ab1c1ed33953bb2433ce7b894a28d724b7aa76c19b11e2878034a4e4680b"}, + {file = "coverage-5.2.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:a3ee9c793ffefe2944d3a2bd928a0e436cd0ac2d9e3723152d6fd5398838ce7d"}, + {file = "coverage-5.2.1-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:28f42dc5172ebdc32622a2c3f7ead1b836cdbf253569ae5673f499e35db0bac3"}, + {file = "coverage-5.2.1-cp35-cp35m-win32.whl", hash = "sha256:e26c993bd4b220429d4ec8c1468eca445a4064a61c74ca08da7429af9bc53bb0"}, + {file = "coverage-5.2.1-cp35-cp35m-win_amd64.whl", hash = "sha256:4186fc95c9febeab5681bc3248553d5ec8c2999b8424d4fc3a39c9cba5796962"}, + {file = "coverage-5.2.1-cp36-cp36m-macosx_10_13_x86_64.whl", hash = "sha256:b360d8fd88d2bad01cb953d81fd2edd4be539df7bfec41e8753fe9f4456a5082"}, + {file = "coverage-5.2.1-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:1adb6be0dcef0cf9434619d3b892772fdb48e793300f9d762e480e043bd8e716"}, + {file = "coverage-5.2.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:098a703d913be6fbd146a8c50cc76513d726b022d170e5e98dc56d958fd592fb"}, + {file = "coverage-5.2.1-cp36-cp36m-win32.whl", hash = "sha256:962c44070c281d86398aeb8f64e1bf37816a4dfc6f4c0f114756b14fc575621d"}, + {file = "coverage-5.2.1-cp36-cp36m-win_amd64.whl", hash = "sha256:b1ed2bdb27b4c9fc87058a1cb751c4df8752002143ed393899edb82b131e0546"}, + {file = "coverage-5.2.1-cp37-cp37m-macosx_10_13_x86_64.whl", hash = "sha256:c890728a93fffd0407d7d37c1e6083ff3f9f211c83b4316fae3778417eab9811"}, + {file = "coverage-5.2.1-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:538f2fd5eb64366f37c97fdb3077d665fa946d2b6d95447622292f38407f9258"}, + {file = "coverage-5.2.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:27ca5a2bc04d68f0776f2cdcb8bbd508bbe430a7bf9c02315cd05fb1d86d0034"}, + {file = "coverage-5.2.1-cp37-cp37m-win32.whl", hash = "sha256:aab75d99f3f2874733946a7648ce87a50019eb90baef931698f96b76b6769a46"}, + {file = "coverage-5.2.1-cp37-cp37m-win_amd64.whl", hash = "sha256:c2ff24df02a125b7b346c4c9078c8936da06964cc2d276292c357d64378158f8"}, + {file = "coverage-5.2.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:304fbe451698373dc6653772c72c5d5e883a4aadaf20343592a7abb2e643dae0"}, + {file = "coverage-5.2.1-cp38-cp38-manylinux1_i686.whl", hash = "sha256:c96472b8ca5dc135fb0aa62f79b033f02aa434fb03a8b190600a5ae4102df1fd"}, + {file = "coverage-5.2.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:8505e614c983834239f865da2dd336dcf9d72776b951d5dfa5ac36b987726e1b"}, + {file = "coverage-5.2.1-cp38-cp38-win32.whl", hash = "sha256:700997b77cfab016533b3e7dbc03b71d33ee4df1d79f2463a318ca0263fc29dd"}, + {file = "coverage-5.2.1-cp38-cp38-win_amd64.whl", hash = "sha256:46794c815e56f1431c66d81943fa90721bb858375fb36e5903697d5eef88627d"}, + {file = "coverage-5.2.1-cp39-cp39-macosx_10_13_x86_64.whl", hash = "sha256:16042dc7f8e632e0dcd5206a5095ebd18cb1d005f4c89694f7f8aafd96dd43a3"}, + {file = "coverage-5.2.1-cp39-cp39-manylinux1_i686.whl", hash = "sha256:c1bbb628ed5192124889b51204de27c575b3ffc05a5a91307e7640eff1d48da4"}, + {file = "coverage-5.2.1-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:4f6428b55d2916a69f8d6453e48a505c07b2245653b0aa9f0dee38785939f5e4"}, + {file = "coverage-5.2.1-cp39-cp39-win32.whl", hash = "sha256:9e536783a5acee79a9b308be97d3952b662748c4037b6a24cbb339dc7ed8eb89"}, + {file = "coverage-5.2.1-cp39-cp39-win_amd64.whl", hash = "sha256:b8f58c7db64d8f27078cbf2a4391af6aa4e4767cc08b37555c4ae064b8558d9b"}, + {file = "coverage-5.2.1.tar.gz", hash = "sha256:a34cb28e0747ea15e82d13e14de606747e9e484fb28d63c999483f5d5188e89b"}, +] +cryptography = [ + {file = "cryptography-3.0-cp27-cp27m-macosx_10_10_x86_64.whl", hash = "sha256:ab49edd5bea8d8b39a44b3db618e4783ef84c19c8b47286bf05dfdb3efb01c83"}, + {file = "cryptography-3.0-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:124af7255ffc8e964d9ff26971b3a6153e1a8a220b9a685dc407976ecb27a06a"}, + {file = "cryptography-3.0-cp27-cp27m-manylinux2010_x86_64.whl", hash = "sha256:51e40123083d2f946794f9fe4adeeee2922b581fa3602128ce85ff813d85b81f"}, + {file = "cryptography-3.0-cp27-cp27m-win32.whl", hash = "sha256:dea0ba7fe6f9461d244679efa968d215ea1f989b9c1957d7f10c21e5c7c09ad6"}, + {file = "cryptography-3.0-cp27-cp27m-win_amd64.whl", hash = "sha256:8ecf9400d0893836ff41b6f977a33972145a855b6efeb605b49ee273c5e6469f"}, + {file = "cryptography-3.0-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:0c608ff4d4adad9e39b5057de43657515c7da1ccb1807c3a27d4cf31fc923b4b"}, + {file = "cryptography-3.0-cp27-cp27mu-manylinux2010_x86_64.whl", hash = "sha256:bec7568c6970b865f2bcebbe84d547c52bb2abadf74cefce396ba07571109c67"}, + {file = "cryptography-3.0-cp35-abi3-macosx_10_10_x86_64.whl", hash = "sha256:0cbfed8ea74631fe4de00630f4bb592dad564d57f73150d6f6796a24e76c76cd"}, + {file = "cryptography-3.0-cp35-abi3-manylinux1_x86_64.whl", hash = "sha256:a09fd9c1cca9a46b6ad4bea0a1f86ab1de3c0c932364dbcf9a6c2a5eeb44fa77"}, + {file = "cryptography-3.0-cp35-abi3-manylinux2010_x86_64.whl", hash = "sha256:ce82cc06588e5cbc2a7df3c8a9c778f2cb722f56835a23a68b5a7264726bb00c"}, + {file = "cryptography-3.0-cp35-cp35m-win32.whl", hash = "sha256:9367d00e14dee8d02134c6c9524bb4bd39d4c162456343d07191e2a0b5ec8b3b"}, + {file = "cryptography-3.0-cp35-cp35m-win_amd64.whl", hash = "sha256:384d7c681b1ab904fff3400a6909261cae1d0939cc483a68bdedab282fb89a07"}, + {file = "cryptography-3.0-cp36-cp36m-win32.whl", hash = "sha256:4d355f2aee4a29063c10164b032d9fa8a82e2c30768737a2fd56d256146ad559"}, + {file = "cryptography-3.0-cp36-cp36m-win_amd64.whl", hash = "sha256:45741f5499150593178fc98d2c1a9c6722df88b99c821ad6ae298eff0ba1ae71"}, + {file = "cryptography-3.0-cp37-cp37m-win32.whl", hash = "sha256:8ecef21ac982aa78309bb6f092d1677812927e8b5ef204a10c326fc29f1367e2"}, + {file = "cryptography-3.0-cp37-cp37m-win_amd64.whl", hash = "sha256:4b9303507254ccb1181d1803a2080a798910ba89b1a3c9f53639885c90f7a756"}, + {file = "cryptography-3.0-cp38-cp38-win32.whl", hash = "sha256:8713ddb888119b0d2a1462357d5946b8911be01ddbf31451e1d07eaa5077a261"}, + {file = "cryptography-3.0-cp38-cp38-win_amd64.whl", hash = "sha256:bea0b0468f89cdea625bb3f692cd7a4222d80a6bdafd6fb923963f2b9da0e15f"}, + {file = "cryptography-3.0.tar.gz", hash = "sha256:8e924dbc025206e97756e8903039662aa58aa9ba357d8e1d8fc29e3092322053"}, ] docutils = [ {file = "docutils-0.16-py2.py3-none-any.whl", hash = "sha256:0c5b78adfbf7762415433f5515cd5c9e762339e23369dbe8000d84a4bf4ab3af"}, @@ -1215,6 +1516,9 @@ functools32 = [ {file = "functools32-3.2.3-2.tar.gz", hash = "sha256:f6253dfbe0538ad2e387bd8fdfd9293c925d63553f5813c4e587745416501e6d"}, {file = "functools32-3.2.3-2.zip", hash = "sha256:89d824aa6c358c421a234d7f9ee0bd75933a67c29588ce50aaa3acdf4d403fa0"}, ] +future = [ + {file = "future-0.18.2.tar.gz", hash = "sha256:b1bead90b70cf6ec3f0710ae53a525360fa360d306a86583adc6bf83a4db537d"}, +] futures = [ {file = "futures-3.3.0-py2-none-any.whl", hash = "sha256:49b3f5b064b6e3afc3316421a3f25f66c137ae88f068abbf72830170033c5e16"}, {file = "futures-3.3.0.tar.gz", hash = "sha256:7e033af76a5e35f58e56da7a91e687706faf4e7bdfb2cbc3f2cca6b9bcda9794"}, @@ -1231,11 +1535,19 @@ importlib-metadata = [ {file = "importlib_metadata-1.7.0-py2.py3-none-any.whl", hash = "sha256:dc15b2969b4ce36305c51eebe62d418ac7791e9a157911d58bfb1f9ccd8e2070"}, {file = "importlib_metadata-1.7.0.tar.gz", hash = "sha256:90bb658cdbbf6d1735b6341ce708fc7024a3e14e99ffdc5783edea9f9b077f83"}, ] +iniconfig = [ + {file = "iniconfig-1.0.1-py3-none-any.whl", hash = "sha256:80cf40c597eb564e86346103f609d74efce0f6b4d4f30ec8ce9e2c26411ba437"}, + {file = "iniconfig-1.0.1.tar.gz", hash = "sha256:e5f92f89355a67de0595932a6c6c02ab4afddc6fcdc0bfc5becd0d60884d3f69"}, +] isort = [ {file = "isort-4.3.21-py2.py3-none-any.whl", hash = "sha256:6e811fcb295968434526407adb8796944f1988c5b65e8139058f2014cbe100fd"}, {file = "isort-4.3.21.tar.gz", hash = "sha256:54da7e92468955c4fceacd0c86bd0ec997b0e1ee80d97f67c35a78b719dccab1"}, - {file = "isort-5.1.4-py3-none-any.whl", hash = "sha256:ae3007f72a2e9da36febd3454d8be4b175d6ca17eb765841d5fe3d038aede79d"}, - {file = "isort-5.1.4.tar.gz", hash = "sha256:145072eedc4927cc9c1f9478f2d83b2fc1e6469df4129c02ef4e8c742207a46c"}, + {file = "isort-5.3.2-py3-none-any.whl", hash = "sha256:5196bd2f5b23dc91215734b1c96c6d28390061d69860a948094c12635d6d64e6"}, + {file = "isort-5.3.2.tar.gz", hash = "sha256:ba83762132a8661d3525f87a86549712fb7d8da79eeb452e01f327ada9e87920"}, +] +jeepney = [ + {file = "jeepney-0.4.3-py3-none-any.whl", hash = "sha256:d6c6b49683446d2407d2fe3acb7a368a77ff063f9182fe427da15d622adc24cf"}, + {file = "jeepney-0.4.3.tar.gz", hash = "sha256:3479b861cc2b6407de5188695fa1a8d57e5072d7059322469b62628869b8e36e"}, ] jinja2 = [ {file = "Jinja2-2.11.2-py2.py3-none-any.whl", hash = "sha256:f0a4641d3cf955324a89c04f3d94663aa4d638abe8f733ecd3582848e1c37035"}, @@ -1244,6 +1556,10 @@ jinja2 = [ kaptan = [ {file = "kaptan-0.5.12.tar.gz", hash = "sha256:1abd1f56731422fce5af1acc28801677a51e56f5d3c3e8636db761ed143c3dd2"}, ] +keyring = [ + {file = "keyring-21.3.0-py3-none-any.whl", hash = "sha256:e7a17caf40c40b6bb8c4772224a487e4a63013560ed0c521065aeba7ecd42182"}, + {file = "keyring-21.3.0.tar.gz", hash = "sha256:22df6abfed49912fc560806030051067fba9f0069cffa79da72899aeea4ccbd5"}, +] libtmux = [ {file = "libtmux-0.8.2.tar.gz", hash = "sha256:2acd86617203bc966b125d016526fb40503411a2281b55d9d970a487dc6e065a"}, ] @@ -1286,6 +1602,10 @@ mccabe = [ {file = "mccabe-0.6.1-py2.py3-none-any.whl", hash = "sha256:ab8a6258860da4b6677da4bd2fe5dc2c659cff31b3ee4f7f5d64e79735b80d42"}, {file = "mccabe-0.6.1.tar.gz", hash = "sha256:dd8d182285a0fe56bace7f45b5e7d1a6ebcbf524e8f3bd87eb0f125271b8831f"}, ] +mock = [ + {file = "mock-3.0.5-py2.py3-none-any.whl", hash = "sha256:d157e52d4e5b938c550f39eb2fd15610db062441a9c2747d3dbfa9298211d0f8"}, + {file = "mock-3.0.5.tar.gz", hash = "sha256:83657d894c90d5681d62155c82bda9c1187827525880eda8ff5df4ec813437c3"}, +] more-itertools = [ {file = "more-itertools-5.0.0.tar.gz", hash = "sha256:38a936c0a6d98a38bcc2d03fdaaedaba9f412879461dd2ceff8d37564d6522e4"}, {file = "more_itertools-5.0.0-py2-none-any.whl", hash = "sha256:c0a5785b1109a6bd7fac76d6837fd1feca158e54e521ccd2ae8bfe393cc9d4fc"}, @@ -1300,15 +1620,13 @@ packaging = [ pathlib2 = [ {file = "pathlib2-2.3.4-py2.py3-none-any.whl", hash = "sha256:2156525d6576d21c4dcaddfa427fae887ef89a7a9de5cbfe0728b3aafa78427e"}, {file = "pathlib2-2.3.4.tar.gz", hash = "sha256:446014523bb9be5c28128c4d2a10ad6bb60769e78bd85658fe44a450674e0ef8"}, + {file = "pathlib2-2.3.5-py2.py3-none-any.whl", hash = "sha256:0ec8205a157c80d7acc301c0b18fbd5d44fe655968f5d947b6ecef5290fc35db"}, + {file = "pathlib2-2.3.5.tar.gz", hash = "sha256:6cd9a47b597b37cc57de1c05e56fb1a1c9cc9fab04fe78c29acd090418529868"}, ] pathspec = [ {file = "pathspec-0.8.0-py2.py3-none-any.whl", hash = "sha256:7d91249d21749788d07a2d0f94147accd8f845507400749ea19c1ec9054a12b0"}, {file = "pathspec-0.8.0.tar.gz", hash = "sha256:da45173eb3a6f2a5a487efba21f050af2b41948be6ab52b6a1e3ff22bb8b7061"}, ] -pbr = [ - {file = "pbr-5.4.5-py2.py3-none-any.whl", hash = "sha256:579170e23f8e0c2f24b0de612f71f648eccb79fb1322c814ae6b3c07b5ba23e8"}, - {file = "pbr-5.4.5.tar.gz", hash = "sha256:07f558fece33b05caf857474a366dfcc00562bca13dd8b47b2b3e22d9f9bf55c"}, -] pillow = [ {file = "Pillow-6.2.2-cp27-cp27m-macosx_10_6_intel.whl", hash = "sha256:834dd023b7f987d6b700ad93dc818098d7eb046bd445e9992b3093c6f9d7a95f"}, {file = "Pillow-6.2.2-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:d3a98444a00b4643b22b0685dbf9e0ddcaf4ebfd4ea23f84f228adf5a0765bb2"}, @@ -1340,29 +1658,32 @@ pillow = [ {file = "Pillow-6.2.2-pp273-pypy_73-win32.whl", hash = "sha256:aa1b0297e352007ec781a33f026afbb062a9a9895bb103c8f49af434b1666880"}, {file = "Pillow-6.2.2-pp373-pypy36_pp73-win32.whl", hash = "sha256:82859575005408af81b3e9171ae326ff56a69af5439d3fc20e8cb76cd51c8246"}, {file = "Pillow-6.2.2.tar.gz", hash = "sha256:db9ff0c251ed066d367f53b64827cc9e18ccea001b986d08c265e53625dab950"}, - {file = "Pillow-7.1.2-cp35-cp35m-macosx_10_10_intel.whl", hash = "sha256:ae2b270f9a0b8822b98655cb3a59cdb1bd54a34807c6c56b76dd2e786c3b7db3"}, - {file = "Pillow-7.1.2-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:d23e2aa9b969cf9c26edfb4b56307792b8b374202810bd949effd1c6e11ebd6d"}, - {file = "Pillow-7.1.2-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:b532bcc2f008e96fd9241177ec580829dee817b090532f43e54074ecffdcd97f"}, - {file = "Pillow-7.1.2-cp35-cp35m-win32.whl", hash = "sha256:12e4bad6bddd8546a2f9771485c7e3d2b546b458ae8ff79621214119ac244523"}, - {file = "Pillow-7.1.2-cp35-cp35m-win_amd64.whl", hash = "sha256:9744350687459234867cbebfe9df8f35ef9e1538f3e729adbd8fde0761adb705"}, - {file = "Pillow-7.1.2-cp36-cp36m-macosx_10_10_x86_64.whl", hash = "sha256:f54be399340aa602066adb63a86a6a5d4f395adfdd9da2b9a0162ea808c7b276"}, - {file = "Pillow-7.1.2-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:1f694e28c169655c50bb89a3fa07f3b854d71eb47f50783621de813979ba87f3"}, - {file = "Pillow-7.1.2-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:f784aad988f12c80aacfa5b381ec21fd3f38f851720f652b9f33facc5101cf4d"}, - {file = "Pillow-7.1.2-cp36-cp36m-win32.whl", hash = "sha256:b37bb3bd35edf53125b0ff257822afa6962649995cbdfde2791ddb62b239f891"}, - {file = "Pillow-7.1.2-cp36-cp36m-win_amd64.whl", hash = "sha256:b67a6c47ed963c709ed24566daa3f95a18f07d3831334da570c71da53d97d088"}, - {file = "Pillow-7.1.2-cp37-cp37m-macosx_10_10_x86_64.whl", hash = "sha256:eaa83729eab9c60884f362ada982d3a06beaa6cc8b084cf9f76cae7739481dfa"}, - {file = "Pillow-7.1.2-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:f46e0e024346e1474083c729d50de909974237c72daca05393ee32389dabe457"}, - {file = "Pillow-7.1.2-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:0e2a3bceb0fd4e0cb17192ae506d5f082b309ffe5fc370a5667959c9b2f85fa3"}, - {file = "Pillow-7.1.2-cp37-cp37m-win32.whl", hash = "sha256:ccc9ad2460eb5bee5642eaf75a0438d7f8887d484490d5117b98edd7f33118b7"}, - {file = "Pillow-7.1.2-cp37-cp37m-win_amd64.whl", hash = "sha256:b943e71c2065ade6fef223358e56c167fc6ce31c50bc7a02dd5c17ee4338e8ac"}, - {file = "Pillow-7.1.2-cp38-cp38-macosx_10_10_x86_64.whl", hash = "sha256:04766c4930c174b46fd72d450674612ab44cca977ebbcc2dde722c6933290107"}, - {file = "Pillow-7.1.2-cp38-cp38-manylinux1_i686.whl", hash = "sha256:f455efb7a98557412dc6f8e463c1faf1f1911ec2432059fa3e582b6000fc90e2"}, - {file = "Pillow-7.1.2-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:ee94fce8d003ac9fd206496f2707efe9eadcb278d94c271f129ab36aa7181344"}, - {file = "Pillow-7.1.2-cp38-cp38-win32.whl", hash = "sha256:4b02b9c27fad2054932e89f39703646d0c543f21d3cc5b8e05434215121c28cd"}, - {file = "Pillow-7.1.2-cp38-cp38-win_amd64.whl", hash = "sha256:3d25dd8d688f7318dca6d8cd4f962a360ee40346c15893ae3b95c061cdbc4079"}, - {file = "Pillow-7.1.2-pp373-pypy36_pp73-win32.whl", hash = "sha256:0f01e63c34f0e1e2580cc0b24e86a5ccbbfa8830909a52ee17624c4193224cd9"}, - {file = "Pillow-7.1.2-py3.8-macosx-10.9-x86_64.egg", hash = "sha256:70e3e0d99a0dcda66283a185f80697a9b08806963c6149c8e6c5f452b2aa59c0"}, - {file = "Pillow-7.1.2.tar.gz", hash = "sha256:a0b49960110bc6ff5fead46013bcb8825d101026d466f3a4de3476defe0fb0dd"}, + {file = "Pillow-7.2.0-cp35-cp35m-macosx_10_10_intel.whl", hash = "sha256:1ca594126d3c4def54babee699c055a913efb01e106c309fa6b04405d474d5ae"}, + {file = "Pillow-7.2.0-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:c92302a33138409e8f1ad16731568c55c9053eee71bb05b6b744067e1b62380f"}, + {file = "Pillow-7.2.0-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:8dad18b69f710bf3a001d2bf3afab7c432785d94fcf819c16b5207b1cfd17d38"}, + {file = "Pillow-7.2.0-cp35-cp35m-manylinux2014_aarch64.whl", hash = "sha256:431b15cffbf949e89df2f7b48528be18b78bfa5177cb3036284a5508159492b5"}, + {file = "Pillow-7.2.0-cp35-cp35m-win32.whl", hash = "sha256:09d7f9e64289cb40c2c8d7ad674b2ed6105f55dc3b09aa8e4918e20a0311e7ad"}, + {file = "Pillow-7.2.0-cp35-cp35m-win_amd64.whl", hash = "sha256:0295442429645fa16d05bd567ef5cff178482439c9aad0411d3f0ce9b88b3a6f"}, + {file = "Pillow-7.2.0-cp36-cp36m-macosx_10_10_x86_64.whl", hash = "sha256:ec29604081f10f16a7aea809ad42e27764188fc258b02259a03a8ff7ded3808d"}, + {file = "Pillow-7.2.0-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:612cfda94e9c8346f239bf1a4b082fdd5c8143cf82d685ba2dba76e7adeeb233"}, + {file = "Pillow-7.2.0-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:0a80dd307a5d8440b0a08bd7b81617e04d870e40a3e46a32d9c246e54705e86f"}, + {file = "Pillow-7.2.0-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:06aba4169e78c439d528fdeb34762c3b61a70813527a2c57f0540541e9f433a8"}, + {file = "Pillow-7.2.0-cp36-cp36m-win32.whl", hash = "sha256:f7e30c27477dffc3e85c2463b3e649f751789e0f6c8456099eea7ddd53be4a8a"}, + {file = "Pillow-7.2.0-cp36-cp36m-win_amd64.whl", hash = "sha256:ffe538682dc19cc542ae7c3e504fdf54ca7f86fb8a135e59dd6bc8627eae6cce"}, + {file = "Pillow-7.2.0-cp37-cp37m-macosx_10_10_x86_64.whl", hash = "sha256:94cf49723928eb6070a892cb39d6c156f7b5a2db4e8971cb958f7b6b104fb4c4"}, + {file = "Pillow-7.2.0-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:6edb5446f44d901e8683ffb25ebdfc26988ee813da3bf91e12252b57ac163727"}, + {file = "Pillow-7.2.0-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:52125833b070791fcb5710fabc640fc1df07d087fc0c0f02d3661f76c23c5b8b"}, + {file = "Pillow-7.2.0-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:9ad7f865eebde135d526bb3163d0b23ffff365cf87e767c649550964ad72785d"}, + {file = "Pillow-7.2.0-cp37-cp37m-win32.whl", hash = "sha256:c79f9c5fb846285f943aafeafda3358992d64f0ef58566e23484132ecd8d7d63"}, + {file = "Pillow-7.2.0-cp37-cp37m-win_amd64.whl", hash = "sha256:d350f0f2c2421e65fbc62690f26b59b0bcda1b614beb318c81e38647e0f673a1"}, + {file = "Pillow-7.2.0-cp38-cp38-macosx_10_10_x86_64.whl", hash = "sha256:6d7741e65835716ceea0fd13a7d0192961212fd59e741a46bbed7a473c634ed6"}, + {file = "Pillow-7.2.0-cp38-cp38-manylinux1_i686.whl", hash = "sha256:edf31f1150778abd4322444c393ab9c7bd2af271dd4dafb4208fb613b1f3cdc9"}, + {file = "Pillow-7.2.0-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:d08b23fdb388c0715990cbc06866db554e1822c4bdcf6d4166cf30ac82df8c41"}, + {file = "Pillow-7.2.0-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:5e51ee2b8114def244384eda1c82b10e307ad9778dac5c83fb0943775a653cd8"}, + {file = "Pillow-7.2.0-cp38-cp38-win32.whl", hash = "sha256:725aa6cfc66ce2857d585f06e9519a1cc0ef6d13f186ff3447ab6dff0a09bc7f"}, + {file = "Pillow-7.2.0-cp38-cp38-win_amd64.whl", hash = "sha256:a060cf8aa332052df2158e5a119303965be92c3da6f2d93b6878f0ebca80b2f6"}, + {file = "Pillow-7.2.0-pp36-pypy36_pp73-win32.whl", hash = "sha256:25930fadde8019f374400f7986e8404c8b781ce519da27792cbe46eabec00c4d"}, + {file = "Pillow-7.2.0.tar.gz", hash = "sha256:97f9e7953a77d5a70f49b9a48da7776dc51e9b738151b22dacf101641594a626"}, ] pkginfo = [ {file = "pkginfo-1.5.0.1-py2.py3-none-any.whl", hash = "sha256:a6d9e40ca61ad3ebd0b72fbadd4fba16e4c0e4df0428c041e01e06eb6ee71f32"}, @@ -1380,6 +1701,10 @@ pycodestyle = [ {file = "pycodestyle-2.6.0-py2.py3-none-any.whl", hash = "sha256:2295e7b2f6b5bd100585ebcb1f616591b652db8a741695b3d8f5d28bdc934367"}, {file = "pycodestyle-2.6.0.tar.gz", hash = "sha256:c58a7d2815e0e8d7972bf1803331fb0152f867bd89adf8a01dfd55085434192e"}, ] +pycparser = [ + {file = "pycparser-2.20-py2.py3-none-any.whl", hash = "sha256:7582ad22678f0fcd81102833f60ef8d0e57288b6b5fb00323d101be910e35705"}, + {file = "pycparser-2.20.tar.gz", hash = "sha256:2d475327684562c3a96cc71adf7dc8c4f0565175cf86b6d7a404ff4c771f15f0"}, +] pyflakes = [ {file = "pyflakes-2.2.0-py2.py3-none-any.whl", hash = "sha256:0d94e0e05a19e57a99444b6ddcf9a6eb2e5c68d3ca1e98e90707af8152c90a92"}, {file = "pyflakes-2.2.0.tar.gz", hash = "sha256:35b2d75ee967ea93b55750aa9edbbf72813e06a66ba54438df2cfac9e3c27fc8"}, @@ -1387,6 +1712,8 @@ pyflakes = [ pygments = [ {file = "Pygments-2.5.2-py2.py3-none-any.whl", hash = "sha256:2a3fe295e54a20164a9df49c75fa58526d3be48e14aceba6d6b1e8ac0bfd6f1b"}, {file = "Pygments-2.5.2.tar.gz", hash = "sha256:98c8aa5a9f778fcd1026a17361ddaf7330d1b7c62ae97c3bb0ae73e0b9b6b0fe"}, + {file = "Pygments-2.6.1-py3-none-any.whl", hash = "sha256:ff7a40b4860b727ab48fad6360eb351cc1b33cbf9b15a0f689ca5353e9463324"}, + {file = "Pygments-2.6.1.tar.gz", hash = "sha256:647344a061c249a3b74e230c739f434d7ea4d8b1d5f3721bc0f3558049b38f44"}, ] pyparsing = [ {file = "pyparsing-2.4.7-py2.py3-none-any.whl", hash = "sha256:ef9d7589ef3c200abe66653d3f1ab1033c3c419ae9b9bdb1240a85b024efc88b"}, @@ -1395,8 +1722,8 @@ pyparsing = [ pytest = [ {file = "pytest-4.6.11-py2.py3-none-any.whl", hash = "sha256:a00a7d79cbbdfa9d21e7d0298392a8dd4123316bfac545075e6f8f24c94d8c97"}, {file = "pytest-4.6.11.tar.gz", hash = "sha256:50fa82392f2120cc3ec2ca0a75ee615be4c479e66669789771f1758332be4353"}, - {file = "pytest-5.4.3-py3-none-any.whl", hash = "sha256:5c0db86b698e8f170ba4582a492248919255fcd4c79b1ee64ace34301fb589a1"}, - {file = "pytest-5.4.3.tar.gz", hash = "sha256:7979331bfcba207414f5e1263b5a0f8f521d0f457318836a7355531ed1a4c7d8"}, + {file = "pytest-6.0.1-py3-none-any.whl", hash = "sha256:8b6007800c53fdacd5a5c192203f4e531eb2a1540ad9c752e052ec0f7143dbad"}, + {file = "pytest-6.0.1.tar.gz", hash = "sha256:85228d75db9f45e06e57ef9bf4429267f81ac7c0d742cc9ed63d09886a9fe6f4"}, ] pytest-cov = [ {file = "pytest-cov-2.9.0.tar.gz", hash = "sha256:b6a814b8ed6247bd81ff47f038511b57fe1ce7f4cc25b9106f1a4b106f1d9322"}, @@ -1404,6 +1731,12 @@ pytest-cov = [ {file = "pytest-cov-2.10.0.tar.gz", hash = "sha256:1a629dc9f48e53512fcbfda6b07de490c374b0c83c55ff7a1720b3fccff0ac87"}, {file = "pytest_cov-2.10.0-py2.py3-none-any.whl", hash = "sha256:6e6d18092dce6fad667cd7020deed816f858ad3b49d5b5e2b1cc1c97a4dba65c"}, ] +pytest-mock = [ + {file = "pytest-mock-2.0.0.tar.gz", hash = "sha256:b35eb281e93aafed138db25c8772b95d3756108b601947f89af503f8c629413f"}, + {file = "pytest_mock-2.0.0-py2.py3-none-any.whl", hash = "sha256:cb67402d87d5f53c579263d37971a164743dc33c159dfb4fb4a86f37c5552307"}, + {file = "pytest-mock-3.2.0.tar.gz", hash = "sha256:7122d55505d5ed5a6f3df940ad174b3f606ecae5e9bc379569cdcbd4cd9d2b83"}, + {file = "pytest_mock-3.2.0-py3-none-any.whl", hash = "sha256:5564c7cd2569b603f8451ec77928083054d8896046830ca763ed68f4112d17c7"}, +] pytest-rerunfailures = [ {file = "pytest-rerunfailures-8.0.tar.gz", hash = "sha256:17c1236b9f8463f74a5df6c807f301c53c2ea1ab81b7509b7e23fab3b7cbe812"}, {file = "pytest_rerunfailures-8.0-py2.py3-none-any.whl", hash = "sha256:4997cda1b82f74cc0c280f6a5a0470d36deb318e3d8bd6da71efc32a3e0c9ae4"}, @@ -1414,6 +1747,10 @@ pytz = [ {file = "pytz-2020.1-py2.py3-none-any.whl", hash = "sha256:a494d53b6d39c3c6e44c3bec237336e14305e4f29bbf800b599253057fbb79ed"}, {file = "pytz-2020.1.tar.gz", hash = "sha256:c35965d010ce31b23eeb663ed3cc8c906275d6be1a34393a1d73a41febf4a048"}, ] +pywin32-ctypes = [ + {file = "pywin32-ctypes-0.2.0.tar.gz", hash = "sha256:24ffc3b341d457d48e8922352130cf2644024a4ff09762a2261fd34c36ee5942"}, + {file = "pywin32_ctypes-0.2.0-py2.py3-none-any.whl", hash = "sha256:9dc2d991b3479cc2df15930958b674a48a227d5361d413827a4cfd0b5876fc98"}, +] pyyaml = [ {file = "PyYAML-5.3.1-cp27-cp27m-win32.whl", hash = "sha256:74809a57b329d6cc0fdccee6318f44b9b8649961fa73144a98735b0aaf029f1f"}, {file = "PyYAML-5.3.1-cp27-cp27m-win_amd64.whl", hash = "sha256:240097ff019d7c70a4922b6869d8a86407758333f02203e0fc6ff79c5dcede76"}, @@ -1431,28 +1768,32 @@ readme-renderer = [ {file = "readme_renderer-26.0-py2.py3-none-any.whl", hash = "sha256:cc4957a803106e820d05d14f71033092537a22daa4f406dfbdd61177e0936376"}, {file = "readme_renderer-26.0.tar.gz", hash = "sha256:cbe9db71defedd2428a1589cdc545f9bd98e59297449f69d721ef8f1cfced68d"}, ] +recommonmark = [ + {file = "recommonmark-0.6.0-py2.py3-none-any.whl", hash = "sha256:2ec4207a574289355d5b6ae4ae4abb29043346ca12cdd5f07d374dc5987d2852"}, + {file = "recommonmark-0.6.0.tar.gz", hash = "sha256:29cd4faeb6c5268c633634f2d69aef9431e0f4d347f90659fd0aab20e541efeb"}, +] regex = [ - {file = "regex-2020.6.8-cp27-cp27m-win32.whl", hash = "sha256:fbff901c54c22425a5b809b914a3bfaf4b9570eee0e5ce8186ac71eb2025191c"}, - {file = "regex-2020.6.8-cp27-cp27m-win_amd64.whl", hash = "sha256:112e34adf95e45158c597feea65d06a8124898bdeac975c9087fe71b572bd938"}, - {file = "regex-2020.6.8-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:92d8a043a4241a710c1cf7593f5577fbb832cf6c3a00ff3fc1ff2052aff5dd89"}, - {file = "regex-2020.6.8-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:bae83f2a56ab30d5353b47f9b2a33e4aac4de9401fb582b55c42b132a8ac3868"}, - {file = "regex-2020.6.8-cp36-cp36m-manylinux2010_i686.whl", hash = "sha256:b2ba0f78b3ef375114856cbdaa30559914d081c416b431f2437f83ce4f8b7f2f"}, - {file = "regex-2020.6.8-cp36-cp36m-manylinux2010_x86_64.whl", hash = "sha256:95fa7726d073c87141f7bbfb04c284901f8328e2d430eeb71b8ffdd5742a5ded"}, - {file = "regex-2020.6.8-cp36-cp36m-win32.whl", hash = "sha256:e3cdc9423808f7e1bb9c2e0bdb1c9dc37b0607b30d646ff6faf0d4e41ee8fee3"}, - {file = "regex-2020.6.8-cp36-cp36m-win_amd64.whl", hash = "sha256:c78e66a922de1c95a208e4ec02e2e5cf0bb83a36ceececc10a72841e53fbf2bd"}, - {file = "regex-2020.6.8-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:08997a37b221a3e27d68ffb601e45abfb0093d39ee770e4257bd2f5115e8cb0a"}, - {file = "regex-2020.6.8-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:2f6f211633ee8d3f7706953e9d3edc7ce63a1d6aad0be5dcee1ece127eea13ae"}, - {file = "regex-2020.6.8-cp37-cp37m-manylinux2010_i686.whl", hash = "sha256:55b4c25cbb3b29f8d5e63aeed27b49fa0f8476b0d4e1b3171d85db891938cc3a"}, - {file = "regex-2020.6.8-cp37-cp37m-manylinux2010_x86_64.whl", hash = "sha256:89cda1a5d3e33ec9e231ece7307afc101b5217523d55ef4dc7fb2abd6de71ba3"}, - {file = "regex-2020.6.8-cp37-cp37m-win32.whl", hash = "sha256:690f858d9a94d903cf5cada62ce069b5d93b313d7d05456dbcd99420856562d9"}, - {file = "regex-2020.6.8-cp37-cp37m-win_amd64.whl", hash = "sha256:1700419d8a18c26ff396b3b06ace315b5f2a6e780dad387e4c48717a12a22c29"}, - {file = "regex-2020.6.8-cp38-cp38-manylinux1_i686.whl", hash = "sha256:654cb773b2792e50151f0e22be0f2b6e1c3a04c5328ff1d9d59c0398d37ef610"}, - {file = "regex-2020.6.8-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:52e1b4bef02f4040b2fd547357a170fc1146e60ab310cdbdd098db86e929b387"}, - {file = "regex-2020.6.8-cp38-cp38-manylinux2010_i686.whl", hash = "sha256:cf59bbf282b627130f5ba68b7fa3abdb96372b24b66bdf72a4920e8153fc7910"}, - {file = "regex-2020.6.8-cp38-cp38-manylinux2010_x86_64.whl", hash = "sha256:5aaa5928b039ae440d775acea11d01e42ff26e1561c0ffcd3d805750973c6baf"}, - {file = "regex-2020.6.8-cp38-cp38-win32.whl", hash = "sha256:97712e0d0af05febd8ab63d2ef0ab2d0cd9deddf4476f7aa153f76feef4b2754"}, - {file = "regex-2020.6.8-cp38-cp38-win_amd64.whl", hash = "sha256:6ad8663c17db4c5ef438141f99e291c4d4edfeaacc0ce28b5bba2b0bf273d9b5"}, - {file = "regex-2020.6.8.tar.gz", hash = "sha256:e9b64e609d37438f7d6e68c2546d2cb8062f3adb27e6336bc129b51be20773ac"}, + {file = "regex-2020.7.14-cp27-cp27m-win32.whl", hash = "sha256:e46d13f38cfcbb79bfdb2964b0fe12561fe633caf964a77a5f8d4e45fe5d2ef7"}, + {file = "regex-2020.7.14-cp27-cp27m-win_amd64.whl", hash = "sha256:6961548bba529cac7c07af2fd4d527c5b91bb8fe18995fed6044ac22b3d14644"}, + {file = "regex-2020.7.14-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:c50a724d136ec10d920661f1442e4a8b010a4fe5aebd65e0c2241ea41dbe93dc"}, + {file = "regex-2020.7.14-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:8a51f2c6d1f884e98846a0a9021ff6861bdb98457879f412fdc2b42d14494067"}, + {file = "regex-2020.7.14-cp36-cp36m-manylinux2010_i686.whl", hash = "sha256:9c568495e35599625f7b999774e29e8d6b01a6fb684d77dee1f56d41b11b40cd"}, + {file = "regex-2020.7.14-cp36-cp36m-manylinux2010_x86_64.whl", hash = "sha256:51178c738d559a2d1071ce0b0f56e57eb315bcf8f7d4cf127674b533e3101f88"}, + {file = "regex-2020.7.14-cp36-cp36m-win32.whl", hash = "sha256:9eddaafb3c48e0900690c1727fba226c4804b8e6127ea409689c3bb492d06de4"}, + {file = "regex-2020.7.14-cp36-cp36m-win_amd64.whl", hash = "sha256:14a53646369157baa0499513f96091eb70382eb50b2c82393d17d7ec81b7b85f"}, + {file = "regex-2020.7.14-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:1269fef3167bb52631ad4fa7dd27bf635d5a0790b8e6222065d42e91bede4162"}, + {file = "regex-2020.7.14-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:d0a5095d52b90ff38592bbdc2644f17c6d495762edf47d876049cfd2968fbccf"}, + {file = "regex-2020.7.14-cp37-cp37m-manylinux2010_i686.whl", hash = "sha256:4c037fd14c5f4e308b8370b447b469ca10e69427966527edcab07f52d88388f7"}, + {file = "regex-2020.7.14-cp37-cp37m-manylinux2010_x86_64.whl", hash = "sha256:bc3d98f621898b4a9bc7fecc00513eec8f40b5b83913d74ccb445f037d58cd89"}, + {file = "regex-2020.7.14-cp37-cp37m-win32.whl", hash = "sha256:46bac5ca10fb748d6c55843a931855e2727a7a22584f302dd9bb1506e69f83f6"}, + {file = "regex-2020.7.14-cp37-cp37m-win_amd64.whl", hash = "sha256:0dc64ee3f33cd7899f79a8d788abfbec168410be356ed9bd30bbd3f0a23a7204"}, + {file = "regex-2020.7.14-cp38-cp38-manylinux1_i686.whl", hash = "sha256:5ea81ea3dbd6767873c611687141ec7b06ed8bab43f68fad5b7be184a920dc99"}, + {file = "regex-2020.7.14-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:bbb332d45b32df41200380fff14712cb6093b61bd142272a10b16778c418e98e"}, + {file = "regex-2020.7.14-cp38-cp38-manylinux2010_i686.whl", hash = "sha256:c11d6033115dc4887c456565303f540c44197f4fc1a2bfb192224a301534888e"}, + {file = "regex-2020.7.14-cp38-cp38-manylinux2010_x86_64.whl", hash = "sha256:75aaa27aa521a182824d89e5ab0a1d16ca207318a6b65042b046053cfc8ed07a"}, + {file = "regex-2020.7.14-cp38-cp38-win32.whl", hash = "sha256:d6cff2276e502b86a25fd10c2a96973fdb45c7a977dca2138d661417f3728341"}, + {file = "regex-2020.7.14-cp38-cp38-win_amd64.whl", hash = "sha256:7a2dd66d2d4df34fa82c9dc85657c5e019b87932019947faece7983f2089a840"}, + {file = "regex-2020.7.14.tar.gz", hash = "sha256:3a3af27a8d23143c49a3420efe5b3f8cf1a48c6fc8bc6856b03f638abc1833bb"}, ] requests = [ {file = "requests-2.24.0-py2.py3-none-any.whl", hash = "sha256:fe75cc94a9443b9246fc7049224f75604b113c36acb93f87b80ed42c44cbb898"}, @@ -1462,8 +1803,9 @@ requests-toolbelt = [ {file = "requests-toolbelt-0.9.1.tar.gz", hash = "sha256:968089d4584ad4ad7c171454f0a5c6dac23971e9472521ea3b6d49d610aa6fc0"}, {file = "requests_toolbelt-0.9.1-py2.py3-none-any.whl", hash = "sha256:380606e1d10dc85c3bd47bf5a6095f815ec007be7a8b69c878507068df059e6f"}, ] -restructuredtext-lint = [ - {file = "restructuredtext_lint-1.3.1.tar.gz", hash = "sha256:470e53b64817211a42805c3a104d2216f6f5834b22fe7adb637d1de4d6501fb8"}, +rfc3986 = [ + {file = "rfc3986-1.4.0-py2.py3-none-any.whl", hash = "sha256:af9147e9aceda37c91a05f4deb128d4b4b49d6b199775fd2d2927768abdc8f50"}, + {file = "rfc3986-1.4.0.tar.gz", hash = "sha256:112398da31a3344dc25dbf477d8df6cb34f9278a94fee2625d89e4514be8bb9d"}, ] scandir = [ {file = "scandir-1.10.0-cp27-cp27m-win32.whl", hash = "sha256:92c85ac42f41ffdc35b6da57ed991575bdbe69db895507af88b9f499b701c188"}, @@ -1478,6 +1820,10 @@ scandir = [ {file = "scandir-1.10.0-cp37-cp37m-win_amd64.whl", hash = "sha256:b24086f2375c4a094a6b51e78b4cf7ca16c721dcee2eddd7aa6494b42d6d519d"}, {file = "scandir-1.10.0.tar.gz", hash = "sha256:4d4631f6062e658e9007ab3149a9b914f3548cb38bfb021c64f39a025ce578ae"}, ] +secretstorage = [ + {file = "SecretStorage-3.1.2-py3-none-any.whl", hash = "sha256:b5ec909dde94d4ae2fa26af7c089036997030f0cf0a5cb372b4cccabd81c143b"}, + {file = "SecretStorage-3.1.2.tar.gz", hash = "sha256:15da8a989b65498e29be338b3b279965f1b8f09b9668bd8010da183024c8bff6"}, +] six = [ {file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"}, {file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"}, @@ -1489,8 +1835,8 @@ snowballstemmer = [ sphinx = [ {file = "Sphinx-1.8.5-py2.py3-none-any.whl", hash = "sha256:9f3e17c64b34afc653d7c5ec95766e03043cc6d80b0de224f59b6b6e19d37c3c"}, {file = "Sphinx-1.8.5.tar.gz", hash = "sha256:c7658aab75c920288a8cf6f09f244c6cfdae30d82d803ac1634d9f223a80ca08"}, - {file = "Sphinx-3.1.1-py3-none-any.whl", hash = "sha256:97c9e3bcce2f61d9f5edf131299ee9d1219630598d9f9a8791459a4d9e815be5"}, - {file = "Sphinx-3.1.1.tar.gz", hash = "sha256:74fbead182a611ce1444f50218a1c5fc70b6cc547f64948f5182fb30a2a20258"}, + {file = "Sphinx-3.2.0-py3-none-any.whl", hash = "sha256:f7db5b76c42c8b5ef31853c2de7178ef378b985d7793829ec071e120dac1d0ca"}, + {file = "Sphinx-3.2.0.tar.gz", hash = "sha256:cf2d5bc3c6c930ab0a1fbef3ad8a82994b1bf4ae923f8098a05c7e5516f07177"}, ] sphinx-issues = [ {file = "sphinx-issues-1.2.0.tar.gz", hash = "sha256:845294736c7ac4c09c706f13431f709e1164037cbb00f6bf623ae16eccf509f3"}, @@ -1524,21 +1870,19 @@ sphinxcontrib-websupport = [ {file = "sphinxcontrib-websupport-1.1.2.tar.gz", hash = "sha256:1501befb0fdf1d1c29a800fdbf4ef5dc5369377300ddbdd16d2cd40e54c6eefc"}, {file = "sphinxcontrib_websupport-1.1.2-py2.py3-none-any.whl", hash = "sha256:e02f717baf02d0b6c3dd62cf81232ffca4c9d5c331e03766982e3ff9f1d2bc3f"}, ] -stevedore = [ - {file = "stevedore-1.32.0-py2.py3-none-any.whl", hash = "sha256:a4e7dc759fb0f2e3e2f7d8ffe2358c19d45b9b8297f393ef1256858d82f69c9b"}, - {file = "stevedore-1.32.0.tar.gz", hash = "sha256:18afaf1d623af5950cc0f7e75e70f917784c73b652a34a12d90b309451b5500b"}, -] toml = [ {file = "toml-0.10.1-py2.py3-none-any.whl", hash = "sha256:bda89d5935c2eac546d648028b9901107a595863cb36bae0c73ac804a9b4ce88"}, {file = "toml-0.10.1.tar.gz", hash = "sha256:926b612be1e5ce0634a2ca03470f95169cf16f939018233a670519cb4ac58b0f"}, ] tqdm = [ - {file = "tqdm-4.46.1-py2.py3-none-any.whl", hash = "sha256:07c06493f1403c1380b630ae3dcbe5ae62abcf369a93bbc052502279f189ab8c"}, - {file = "tqdm-4.46.1.tar.gz", hash = "sha256:cd140979c2bebd2311dfb14781d8f19bd5a9debb92dcab9f6ef899c987fcf71f"}, + {file = "tqdm-4.48.2-py2.py3-none-any.whl", hash = "sha256:1a336d2b829be50e46b84668691e0a2719f26c97c62846298dd5ae2937e4d5cf"}, + {file = "tqdm-4.48.2.tar.gz", hash = "sha256:564d632ea2b9cb52979f7956e093e831c28d441c11751682f84c86fc46e4fd21"}, ] twine = [ {file = "twine-1.15.0-py2.py3-none-any.whl", hash = "sha256:630fadd6e342e725930be6c696537e3f9ccc54331742b16245dab292a17d0460"}, {file = "twine-1.15.0.tar.gz", hash = "sha256:a3d22aab467b4682a22de4a422632e79d07eebd07ff2a7079effb13f8a693787"}, + {file = "twine-3.2.0-py3-none-any.whl", hash = "sha256:ba9ff477b8d6de0c89dd450e70b2185da190514e91c42cc62f96850025c10472"}, + {file = "twine-3.2.0.tar.gz", hash = "sha256:34352fd52ec3b9d29837e6072d5a2a7c6fe4290e97bba46bb8d478b5c598f7ab"}, ] typed-ast = [ {file = "typed_ast-1.4.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:73d785a950fc82dd2a25897d525d003f6378d1cb23ab305578394694202a58c3"}, @@ -1564,13 +1908,12 @@ typed-ast = [ {file = "typed_ast-1.4.1.tar.gz", hash = "sha256:8c8aaad94455178e3187ab22c8b01a3837f8ee50e09cf31f1ba129eb293ec30b"}, ] typing = [ - {file = "typing-3.7.4.1-py2-none-any.whl", hash = "sha256:c8cabb5ab8945cd2f54917be357d134db9cc1eb039e59d1606dc1e60cb1d9d36"}, - {file = "typing-3.7.4.1-py3-none-any.whl", hash = "sha256:f38d83c5a7a7086543a0f649564d661859c5146a85775ab90c0d2f93ffaa9714"}, - {file = "typing-3.7.4.1.tar.gz", hash = "sha256:91dfe6f3f706ee8cc32d38edbbf304e9b7583fb37108fef38229617f8b3eba23"}, + {file = "typing-3.7.4.3-py2-none-any.whl", hash = "sha256:283d868f5071ab9ad873e5e52268d611e851c870a2ba354193026f2dfb29d8b5"}, + {file = "typing-3.7.4.3.tar.gz", hash = "sha256:1187fb9c82fd670d10aa07bbb6cfcfe4bdda42d6fab8d5134f04e8c4d0b71cc9"}, ] urllib3 = [ - {file = "urllib3-1.25.9-py2.py3-none-any.whl", hash = "sha256:88206b0eb87e6d677d424843ac5209e3fb9d0190d0ee169599165ec25e9d9115"}, - {file = "urllib3-1.25.9.tar.gz", hash = "sha256:3018294ebefce6572a474f0604c2021e33b3fd8006ecd11d62107a5d2a963527"}, + {file = "urllib3-1.25.10-py2.py3-none-any.whl", hash = "sha256:e7983572181f5e1522d9c98453462384ee92a0be7fac5f1413a1e35c56cc0461"}, + {file = "urllib3-1.25.10.tar.gz", hash = "sha256:91056c15fa70756691db97756772bb1eb9678fa585d9184f24534b100dc60f4a"}, ] wcwidth = [ {file = "wcwidth-0.2.5-py2.py3-none-any.whl", hash = "sha256:beb4802a9cebb9144e99086eff703a642a13d6a0052920003a230f3294bbe784"}, @@ -1583,4 +1926,6 @@ webencodings = [ zipp = [ {file = "zipp-1.2.0-py2.py3-none-any.whl", hash = "sha256:e0d9e63797e483a30d27e09fffd308c59a700d365ec34e93cc100844168bf921"}, {file = "zipp-1.2.0.tar.gz", hash = "sha256:c70410551488251b0fee67b460fb9a536af8d6f9f008ad10ac51f615b6a521b1"}, + {file = "zipp-3.1.0-py3-none-any.whl", hash = "sha256:aa36550ff0c0b7ef7fa639055d797116ee891440eac1a56f378e2d3179e0320b"}, + {file = "zipp-3.1.0.tar.gz", hash = "sha256:c599e4d75c98f6798c509911d08a22e6c021d074469042177c8c86fb92eefd96"}, ] diff --git a/pyproject.toml b/pyproject.toml index 604f7895c78..15c588f801d 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -11,40 +11,62 @@ authors = ["Tony Narlock "] [tool.poetry.dependencies] python = "~2.7 || ^3.5" click = ">=7<8" -kaptan = "*" +kaptan = ">=0.5.10" libtmux = "<0.9" +colorama = ">=0.3.9" [tool.poetry.dev-dependencies] -aafigure = "*" -alagitpull = "~=0.1.0" -black = {version="==19.10b0", python="^3.6"} -doc8 = "*" -docutils = "*" -flake8 = "*" -isort = [ - {version="<5", python="<3.6"}, - {version=">=5.0.0", python=">=3.6"} +### Docs ### +sphinx = [ + {version="<2", python="<3"}, + {version="*", python=">=3"} ] +recommonmark = {version = "^0.6.0"} +alagitpull = {version = "~0.1.0"} +sphinx-issues = {version = "^1.2.0"} +aafigure = ">=0.6" pillow = [ {version="<7", python="<3"}, {version="*", python=">=3"} ] + +### Testing ### pytest = [ {version="<4.7.0", python="<3"}, {version="*", python=">=3"} ] pathlib2 = {version="<2.3.5", python="<3"} # Untangle pytest peer-dependency pytest-rerunfailures = "*" -sphinx = [ - {version="<2", python="<3"}, +pytest-mock = [ + {version="<3.0.0", python="<3"}, {version="*", python=">=3"} ] -sphinx-issues = "*" -twine = "*" + +### Coverage ### codecov = "*" -colorama = "*" coverage = "*" pytest-cov = [ {version="<2.10.0", python="<3"}, {version="*", python=">=3"} ] + +### Format ### +black = {version="==19.10b0", python="^3.6"} +isort = [ + {version="<5", python="<3.6"}, + {version="*", python=">=3.6"} +] + +### Lint ### +flake8 = "*" + +### Deploy ### +twine = "*" + +[tool.poetry.extras] +docs = ["sphinx", "recommonmark", "sphinx-issues", "alagitpull", "aafigure", "pillow"] +test = ["pytest", "pathlib2", "pytest-rerunfailures", "pytest-mock"] +coverage = ["codecov", "coverage", "pytest-cov"] +format = ["black", "isort"] +lint = ["flake8"] +deploy = ["twine"] From a28d0e1773322684823f10acd4cad6873e3838cb Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:34:53 -0500 Subject: [PATCH 04/31] build(Makefile): Update to latest and greatest --- Makefile | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/Makefile b/Makefile index 659df240ba8..890440d7770 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,6 @@ PY_FILES= find . -type f -not -path '*/\.*' | grep -i '.*[.]py$$' 2> /dev/null +DOC_FILES= find . -type f -not -path '*/\.*' | grep -i '.*[.]rst\$\|.*[.]md\$\|.*[.]css\$\|.*[.]py\$\|mkdocs\.yml\|CHANGES\|TODO\|.*conf\.py' 2> /dev/null +SHELL := /bin/bash entr_warn: @echo "----------------------------------------------------------" @@ -12,7 +14,7 @@ isort: poetry run isort `${PY_FILES}` black: - poetry run black `${PY_FILES}` --skip-string-normalization + poetry run black `${PY_FILES}` test: poetry run py.test $(test) @@ -21,13 +23,19 @@ watch_test: if command -v entr > /dev/null; then ${PY_FILES} | entr -c $(MAKE) test; else $(MAKE) test entr_warn; fi build_docs: - cd doc && $(MAKE) html + $(MAKE) -C docs html watch_docs: - cd doc && $(MAKE) watch_docs + if command -v entr > /dev/null; then ${DOC_FILES} | entr -c $(MAKE) build_docs; else $(MAKE) build_docs entr_warn; fi + +serve_docs: + $(MAKE) -C docs serve + +dev_docs: + $(MAKE) -j watch_docs serve_docs flake8: - poetry run flake8 tmuxp tests + poetry run flake8 watch_flake8: if command -v entr > /dev/null; then ${PY_FILES} | entr -c $(MAKE) flake8; else $(MAKE) flake8 entr_warn; fi From 80b69035c9dfb8aa6b48a4c78c888f3a42eb27e9 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:35:27 -0500 Subject: [PATCH 05/31] build(MANIFEST): Include pyproject.toml --- MANIFEST.in | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/MANIFEST.in b/MANIFEST.in index 06fe340bece..078513d84cf 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,4 +1,4 @@ -include README.rst LICENSE CHANGES .tmuxp.yaml +include README.rst LICENSE CHANGES pyproject.toml .tmuxp.yaml include requirements/*.txt recursive-include doc *.rst recursive-include tests *.py *.yaml *.json *.sh From 49307b1d2e49a560787458b27c9d0bf25ed5e08a Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:37:26 -0500 Subject: [PATCH 06/31] build(codecov): Ignore loud codecov messages --- .codecov.yml | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 .codecov.yml diff --git a/.codecov.yml b/.codecov.yml new file mode 100644 index 00000000000..bf9b9abef60 --- /dev/null +++ b/.codecov.yml @@ -0,0 +1,15 @@ +codecov: + notify: + require_ci_to_pass: no + +coverage: + precision: 2 + round: down + range: "70...100" + status: + project: + default: + target: auto + threshold: 1% + base: auto + patch: off From 54052185e6b3697d82f91319b29569427f227b3c Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:38:33 -0500 Subject: [PATCH 07/31] build(docs): run through poetry by default --- doc/Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/Makefile b/doc/Makefile index cf76db1b3d3..659b7d3820d 100644 --- a/doc/Makefile +++ b/doc/Makefile @@ -6,7 +6,7 @@ HTTP_PORT = 8031 # You can set these variables from the command line. SPHINXOPTS = -SPHINXBUILD = sphinx-build +SPHINXBUILD = poetry run sphinx-build PAPER = BUILDDIR = _build From e19d8098835eae9182360f59075cf910bc8a9bf1 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:39:46 -0500 Subject: [PATCH 08/31] build(docs): Update Makefile to latest and greatest --- doc/Makefile | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/doc/Makefile b/doc/Makefile index 659b7d3820d..6f47067bbc4 100644 --- a/doc/Makefile +++ b/doc/Makefile @@ -1,6 +1,7 @@ # Makefile for Sphinx documentation # -WATCH_FILES= find .. -type f -not -path '*/\.*' | grep -i '.*[.]rst\|CHANGES\|TODO\|.*conf\.py\|.*[.]py$$' 2> /dev/null +WATCH_FILES= find .. -type f -not -path '*/\.*' | grep -i '.*[.]rst\$\|.*[.].md\|.*[.]py\$\|CHANGES\|TODO\|.*conf\.py' 2> /dev/null +SHELL := /bin/bash PYVERSION=$(shell python -c "import sys;v=sys.version_info[0];sys.stdout.write(str(v))") HTTP_PORT = 8031 @@ -165,13 +166,16 @@ watch: serve: @echo '==============================================================' @echo - @echo 'docs server running at http://0.0.0.0:${HTTP_PORT}/_build/html' + @echo 'docs server running at http://localhost:${HTTP_PORT}/' @echo @echo '==============================================================' @if test ${PYVERSION} -eq 2; then $(MAKE) serve_py2; else make serve_py3; fi serve_py2: - python -m SimpleHTTPServer ${HTTP_PORT} + pushd _build/html; python2 -m SimpleHTTPServer ${HTTP_PORT}; popd serve_py3: - python -m http.server ${HTTP_PORT} + python -m http.server ${HTTP_PORT} --directory _build/html + +dev: + $(MAKE) -j watch serve From b5563769fb0581d0e31f8f01534bcc1bc192be80 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:43:27 -0500 Subject: [PATCH 09/31] build(docs): Add manifest and icons --- doc/_static/img/icons/icon-128x128.png | Bin 0 -> 1681 bytes doc/_static/img/icons/icon-144x144.png | Bin 0 -> 1847 bytes doc/_static/img/icons/icon-152x152.png | Bin 0 -> 1885 bytes doc/_static/img/icons/icon-192x192.png | Bin 0 -> 2462 bytes doc/_static/img/icons/icon-384x384.png | Bin 0 -> 4795 bytes doc/_static/img/icons/icon-512x512.png | Bin 0 -> 7521 bytes doc/_static/img/icons/icon-72x72.png | Bin 0 -> 1084 bytes doc/_static/img/icons/icon-96x96.png | Bin 0 -> 1316 bytes doc/manifest.json | 53 +++++++++++++++++++++++++ 9 files changed, 53 insertions(+) create mode 100644 doc/_static/img/icons/icon-128x128.png create mode 100644 doc/_static/img/icons/icon-144x144.png create mode 100644 doc/_static/img/icons/icon-152x152.png create mode 100644 doc/_static/img/icons/icon-192x192.png create mode 100644 doc/_static/img/icons/icon-384x384.png create mode 100644 doc/_static/img/icons/icon-512x512.png create mode 100644 doc/_static/img/icons/icon-72x72.png create mode 100644 doc/_static/img/icons/icon-96x96.png create mode 100644 doc/manifest.json diff --git a/doc/_static/img/icons/icon-128x128.png b/doc/_static/img/icons/icon-128x128.png new file mode 100644 index 0000000000000000000000000000000000000000..5c1868fbe87c520e6868e1a027dcf8bf003c09da GIT binary patch literal 1681 zcmchV`#aMM9LK+t%h2RWZp%A2`4DexCRH_2cLHd_M0)l#K;M2r2{s00e1iYI{KZFN66H z@+JIl>H!4(Egi4`Abj+fL8FYQ9RT1*AWbi#L+L9FN8e-iQUWaTC$aQ6FtWq*p6By3 z-(!r6CX?|_vS2|r$Xbi#noZ(84MBUiDpH;$V#HCJ(O$(U?WE-#3DsdyH#fB3q)7>y zWUUB#m?J@NEMO3Z)~rGXn%8|toA$GII0X|cRKi*ajaG*I#$lhX^3Kn$l%C1!ugSj| zwwI2O(YIIj9SnmgIYJkiM~Hrt&l#5uTIt!))twmytm|e&DkZLrik8EW&ujJG($xw^ zMV5BuE|lw4MOO4;%NM5RHJG2OKS@7LqRZtUmz)X@eW7dg7Gz*vPi{$u8-`iC>^n)O zB(lLdIb9scqr2NKQ<_cH^ZuhvoB$rH>G=qsMmY4`W&!0yUB~$`#{88Th5a&L_*&@L zSdh{^BOAaI<^pE#VhjWKN`y)6fff&6&}jE@%W7jdfMuNUO0Psd-}8Z2L1C$^PGx7F1+QZ@>Chwb)OL)Oh5RCVNl!mW&SOGD8pHBe9lAPSW7;pYlJ zRG}p?cR8^jc?OU!OmgAr5j^-@x*u@z0KZ>iyvCf{l6WT9?pvi&!@?_j9{?W!#J!D9 zBhm$y(t>TBn;$Gm#Uyc0A1&!JaxOWN>SO=`3b`nQk^8K7a*S;or^W5g7S8J42U>(` z-1x?j=j%EHJ={iJ6EID{BJ%|AXu{5BT8iArfeGLPz@r$T=cAbX3O`WF{cqdAg~l=m zz}0{!AMlRkQ5=9$5N|HhhGC8)=~=y#?u1QHPg}kD!aO6Yy^|F0hW)9cvnJbjDO~)m zv&$DzXNN!`pc63ngADiW2)t8IQ0LRj%WLc5p0f;6Ki(}YB|NX#>*HBDbsbFWS)TyQzHE%4 zdoEh8*nUl}>sFqJM#z&^dZKAe{$qtye(cwId{`}u5(&3V{0z}&6K#@CAz>#RCUMM3 zg>kieFojx)c(fHWHNmi3$E0o*j!oXi4KX&S_Mv(=W_N?Sp5@jqnmV5#wuh3R5fpb} znLkSFTt_M?1dVFN)PhRYep;Oq5-ZvL-RtGgAMB+{)k=En$W*7d*qec{;P)Q%t&QXJ zapT`Jmb9VvH6kC0f88nds$S9t(OcAqXT~0cJ4L7`H!s>@Fm$x7PAA-Gy!xNRgZTy% zwEVNN{SR+a2Salj8+Wn^i{$gAKA|Ze&SmjEf@_51%%ev9QD7k-5D}5o?@WXV@!uY> zGsH$2$-58OJ-Y0Nx(@0l-Db|V4-KeEiOkK3D%8Wk3F{-V^*a+W67go_p#j(-0Q@d( zh3C5MsrD@e(qoYOA>%y7=}oGva*IsL;6g$P{8oQ;Q#*^Qo3(QaE_Cekt_rV5p)4t> z&5fu**6ZvahAfz+iOQqux$C`Gu4Sx{g#%-qx67_AXCa2pY?;aJ7PW3)1;B&Lq2ydz zOU{=xDx5dicb342Db*y+2?!z VzC#B13N!xIR-~DYX|0KC%)dW5xKRKA literal 0 HcmV?d00001 diff --git a/doc/_static/img/icons/icon-144x144.png b/doc/_static/img/icons/icon-144x144.png new file mode 100644 index 0000000000000000000000000000000000000000..9ddcefd721ab5c476fb061a07b9b7230fdc069c3 GIT binary patch literal 1847 zcmd6oYdq5n7{~u3l#W!cXTnN8a<66-YRl#_B)3SIN=4;T%q(Uur@7QPZpmcQq_Yvu zWR}h4pg2MVb+K2F2g?Hhpn!Hjxo>&q z4{ev-nnJtr7hAUDrh`u;0PNiRL!f>EaSZ@uMQGG1PyEo_&}_K!S@rfW%*MCh?UbB` z1r+M%Fkes|b z*!R3A?E=XEk2enRfG-fM8|AgTAwrRydBND$50&ux$a0E zXc{y;(`Xf(5#L+akN0_3bnEUOYVP$A@zNTXO_5QEsuq_`BfjAv9x!DOY3e5qAJ?fg zPY6B9h4IrYk6s~#mUoQxW$scfK^xyFni0q$bZuU@Biv^(qk$jQloyPgO~Y00S?)^6 z&=-(qHDlN2h#qjQ(MIsYM@M?B#i5<%)<6Nl;`No&LX${Bkq9AJHZ<2BNd&ePm*`4( zvB;<91?;Lgv4sf$qVr6YC)vy(h2m4v4&hfGlkfo6C}9ZNylNroB9srdB;U2%od9?` zCM}0g0imF+ybS_?wj%(kpCDRVLVTr*CxDvGtO`MOZR8)%2J@IuP0B(VThd*xfXLa# ztBb>b9~sbWZVe5PQ4AAR!v^iyb9r*LSe6tWg}9n89!m^JflrIWCMOz3=Qo3UR!Yq6 z0wi?IZ{c!{lF}{qfI;#>GEz3dQQE98F=E&!f4KjXOTKURZbZ&B;+G$E{v+ZAI+{YV zIJ~}H-vCl~M;=ic4biP{)8=Sli?gkI;dtWajE49z!;P#k3pK^`W1?^ zK{6B3g0XI$MUlQ^t+&3I)-tfI`nmh$*SFvG1N#$_y~)?D5BNtN2pD)@fWYx*&UgOK z$dNUxA$X1^Ufpw_K=~5}c6F~hl@u>L=7P9%?PuE2|Mo-$7keCb^}at>+ycp@O;0?#19n~LuI^j-D!+rxr{9eAGdd07Wd|Yr}od* zHGyYRLm2@~ALAE+_qw6t5bCE)c#4aV}37hS`yu6HdTl#_#X{fu!jx>Bm#QT;m zvGmT4mfvEUH8)!9J=&`^j~(yez}L&JjoX*yYBQ9bN~#(hY4=s!eK3_}PfzFQpdOh% zaIi&{8Cah^`{8aynkVO?SXAUkAcj=s(5d2-d5-(sD^Hd%jpU{TQ}y_A&Ut*3*ILpO zYgtM5J`>`6;3Emc%h6R}3c$T&_*!rce*c^dc6zO;v3z2v9aSw#bQ0&D3 zS%ISWG6*XwNJy-R=pQ>jI-$^k|S78}I1{?etw01BQKFvLX?p{uQ z#BGPeQuHFKJ@SxPT&wY|^h04|sFK7%VT5K!C0R79)j5jVbliXr4;)Oj6+F8=>*ytM zhxcgIe?1Ss)aA!H?DerQYFS5#N;ipeL(*^`Gf*_Iy+qc_mLc>yfdUmsW@$1^HS;R)ytRTbM$hH19)!2t7 seq$AUKH(M8X`LdY{lI8x(aTR5&b*N%o97_I-1>w7+SUbCX>%dzU$R;utN;K2 literal 0 HcmV?d00001 diff --git a/doc/_static/img/icons/icon-152x152.png b/doc/_static/img/icons/icon-152x152.png new file mode 100644 index 0000000000000000000000000000000000000000..2950bed9694a8638179113f8ae9cbc76c387db69 GIT binary patch literal 1885 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 literal 0 HcmV?d00001 diff --git a/doc/_static/img/icons/icon-384x384.png b/doc/_static/img/icons/icon-384x384.png new file mode 100644 index 0000000000000000000000000000000000000000..cb5df94ab591e32ff8dbc6027e6e5c2eec02d621 GIT binary patch literal 4795 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 literal 0 HcmV?d00001 diff --git a/doc/_static/img/icons/icon-72x72.png b/doc/_static/img/icons/icon-72x72.png new file mode 100644 index 0000000000000000000000000000000000000000..656a708cdbc4c86116a26ec9b0da5cf8a278f32c GIT binary patch literal 1084 zcmeAS@N?(olHy`uVBq!ia0vp^9w5xY1|&n@ZgvM!oCO|{#S9GGLLkg|>2BR01_tJL zo-U3d6}R5rIiD?)D#89?XT^(?TdXy2FZz7$%sDmRY;9f9O`h6uE-d`4jy<+F|1Y>T zKlA0$kd`%^le$)9@E7A$NV5C1=$8coj{rH2qJt%IMv@zP5|~T;G~s z46I95JDG=k`1(fo`S^O+wQ(R&~bsjsq@_8$%`-NUwq9QC427p@AFGGKK}81 z1(Vtm2gXTnz8_n6`gf(*<|CD^j{>G^?z>a*+u6#|vHyvJ0XIWJR%CJPd{teYQO(n)Ks_Dwz`IG zRdvF8=8JCYuQDn!+cG>c5@0sOk0!9}vS9tYvfgfWkmP>*H}kW4&fbZ6yHi6wgKcuj zDy_@bM!mH!E#K^&63weEP*?r+Tv3rqc!jxjxWtJwW=g72)tV&^4513^AFUU?z9(s8 zOs3B@t)oJv8jaT`9x7-pYhrjIdq2CviKC_A;S2?imn=U+=Tr-qfBd%7zTn|v`@)BZ z*`73~#@Or^uv3tF{ou>G`KKP2_cQppFdmpfKP%XQy#X_ZyO z&INY`n7{5QnRNART;Y}H?(Nsg{+Tn3FKd4tMNUzu$^Ns71w`|-_7CFYs{d*r)-8WzS-C4Ur*f3_iTJ=yfx#Q@6QVT-2Zf{Wz6#n&Sj|Qvs(Z5-K%|@m#>yC z-(Mr7vBIc&m*1gv)BPS8x1YP?zcgs+>6UJtn4&_f&odUQrJ0dBLP4$QBI`_;{qQ42*c8BF$j$65{izWN6>J-&kbCyQwTTP3|>+KYkD!v+7x5>B1{{NO2 cQ_Sj_Srs!|_I24F1{Mblp00i_>zopr08fDCW&i*H literal 0 HcmV?d00001 diff --git a/doc/_static/img/icons/icon-96x96.png b/doc/_static/img/icons/icon-96x96.png new file mode 100644 index 0000000000000000000000000000000000000000..57fe0708713fe2444d169778ef26af8cdb064e67 GIT binary patch literal 1316 zcmeAS@N?(olHy`uVBq!ia0vp^2_VeD1|%QND7OGooCO|{#S9GGLLkg|>2BR01_qXE zo-U3d6}R5rx$PelD#G@`v(}_hEN9P>Iko3zO6Dm?cnaq&s(2_r!Oq0DMo>83XYoU` z4pYOGh8l}PFRRU3(W@IZS?a*HS;sCN5ua-HH0h}khe)r}5>_q~<1=S&p5DseGwH=_ zq3?5Q)PHU&YiQqlJ%9aS?&kHIc2>9d%dguWZc^U9(@lG}zvsG_6VxU?^}QSN`_Id( zOSk^uedL~Jm-W`d=-a#2i%+jtxxM&$FY%i4U2tU`~l z&sk-8$31lIa?j1j(yb267s#Kp*Xy|6xfNgY=NR3eHrxK|0dCt@6AI(3Uos~%{X5KA zaNU{j`qy$jpH=J67Z-^-bnp7P>gO!8d&a^O?uDnnFZfgO-*la`yU2lr&>z924(^Yi zRWl}NJH2|Vzxc{c<1cHOW~|Nm*-Ht4pKezy@p<*)XW*+(x8mL9 z|35lDTh@kg{WqTMxqau`R=mC=vA5`1SG$_SsUI`*m(|z)U;Xi^@N_jX`#19=E}5$T zQWvw|VX^Pm$Lo_X_OJ)En#qL<&-u#Zb%~qdU6;|9k7u+!(q2sdDLi2wQ~BGJm^~l4 zCRMP$G+^Xgdp>sgk2g$5>mUAEQ+VZH#r)UB+;U7F$6mDGs@$cMByuu-vB!gH`#4wq zRn-hKc&6Jhah9l*Nyj=C%eq?OhcUbYwfW~Oa+u^|mUTQ}W>dXyF!%8Vj`&F)38$JF z+@u;z{G<}3$O|3}UH^C;Tpzm|ziNn)<$F2n)UwH&_Iy;a6?qpI8xdE`DAd{Fqb7W* zP(@XEV?@!0w40I!8kPc6PBPkO%CxgFuk!o7>Q?o#Rs8jSVC}EI$wl70=iR@jq^z~N zzV>vzhiAQ)o!jQE-Xc#qJ3g`aeDJ+&&KLWbvxBYfQ>&b9fpW<1`A%EEZrZVJUdh>G z|GovEJp8rOxqV*m_V&Y9Ze3D3JZIaru&m51A5;6tJ@>991nf9C=^@)>lfKK}rnu_c z<(~chXPbTAy_w$6?(SY%c|Grv%{#gGH+D`gOHDmFXN^u!;q{w0r_A2mUiOq@=H%oF z*G`(Igl%)I3)cC`)T+8YNAZN2?n%Yo$@k{-+}g&Kdu{)a**3*BY;@s&*1>8NDv){h{oPLjqQ`h5+c_Q*^TX$Yx zoBj5CF1K>tvzZ}58e#J+GoJmt5*!g1{*3?0`PH5Q`(<*R6JJR0&-|CH<2+$yVNTuK z6>|5(Rr2iO(!+L~-Tw9gU#N4x> Date: Mon, 10 Aug 2020 18:48:46 -0500 Subject: [PATCH 10/31] build(setup.py): Fix quotes --- setup.py | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/setup.py b/setup.py index 8aae9cadd62..83b8ad9d945 100644 --- a/setup.py +++ b/setup.py @@ -44,19 +44,19 @@ keywords=about['__title__'], entry_points=dict(console_scripts=['tmuxp=tmuxp:cli.cli']), classifiers=[ - 'Development Status :: 5 - Production/Stable', + "Development Status :: 5 - Production/Stable", "License :: OSI Approved :: MIT License", "Operating System :: POSIX", "Operating System :: MacOS :: MacOS X", - 'Environment :: Web Environment', - 'Intended Audience :: Developers', - 'Programming Language :: Python', - 'Programming Language :: Python :: 2.7', - 'Programming Language :: Python :: 3.5', - 'Programming Language :: Python :: 3.6', - 'Programming Language :: Python :: 3.7', - 'Programming Language :: Python :: 3.8', - 'Programming Language :: Python :: Implementation :: PyPy', + "Environment :: Web Environment", + "Intended Audience :: Developers", + "Programming Language :: Python", + "Programming Language :: Python :: 2.7", + "Programming Language :: Python :: 3.5", + "Programming Language :: Python :: 3.6", + "Programming Language :: Python :: 3.7", + "Programming Language :: Python :: 3.8", + "Programming Language :: Python :: Implementation :: PyPy", "Topic :: Utilities", "Topic :: System :: Shells", ], From 578e277de1cb81285e3351ba383b524d1cd345e6 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:50:00 -0500 Subject: [PATCH 11/31] build(pyproject): Add classifiers --- pyproject.toml | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/pyproject.toml b/pyproject.toml index 15c588f801d..bdd3ddcfa90 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -7,6 +7,23 @@ version = "1.5.5" description = "tmux session manager." license = "MIT" authors = ["Tony Narlock "] +classifiers = [ + "Development Status :: 5 - Production/Stable", + "License :: OSI Approved :: MIT License", + "Operating System :: POSIX", + "Operating System :: MacOS :: MacOS X", + "Environment :: Web Environment", + "Intended Audience :: Developers", + "Programming Language :: Python", + "Programming Language :: Python :: 2.7", + "Programming Language :: Python :: 3.5", + "Programming Language :: Python :: 3.6", + "Programming Language :: Python :: 3.7", + "Programming Language :: Python :: 3.8", + "Programming Language :: Python :: Implementation :: PyPy", + "Topic :: Utilities", + "Topic :: System :: Shells" +] [tool.poetry.dependencies] python = "~2.7 || ^3.5" From 828308efa4212870449ad95e385842ee8fba9c52 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:54:36 -0500 Subject: [PATCH 12/31] build(pyproject): Add more metadata --- pyproject.toml | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index bdd3ddcfa90..b259bcd60c5 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ skip-string-normalization = true [tool.poetry] name = "tmuxp" version = "1.5.5" -description = "tmux session manager." +description = "tmux session manager" license = "MIT" authors = ["Tony Narlock "] classifiers = [ @@ -24,6 +24,14 @@ classifiers = [ "Topic :: Utilities", "Topic :: System :: Shells" ] +keywords = ["tmux", "session manager", "terminal", "ncurses"] +homepage = "http://github.com/tmux-python/tmuxp/" +readme = "README.rst" + +[tool.poetry.urls] +"Bug Tracker" = "https://github.com/tmux-python/tmuxp/issues" +Documentation = "https://tmuxp.git-pull.com" +Repository = "https://github.com/tmux-python/tmuxp" [tool.poetry.dependencies] python = "~2.7 || ^3.5" From a32d8ae0dfaff9f1d21a26a63ddcfbe93705c5cf Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 18:55:15 -0500 Subject: [PATCH 13/31] build(pyproject): Add scripts for tmuxp --- pyproject.toml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/pyproject.toml b/pyproject.toml index b259bcd60c5..fbddb8d07f9 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -33,6 +33,9 @@ readme = "README.rst" Documentation = "https://tmuxp.git-pull.com" Repository = "https://github.com/tmux-python/tmuxp" +[tool.poetry.scripts] +tmuxp = 'tmuxp:cli.cli' + [tool.poetry.dependencies] python = "~2.7 || ^3.5" click = ">=7<8" From e2865f915ad4db6f6aac212903f25197b1c4e892 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:01:58 -0500 Subject: [PATCH 14/31] refactor(docs): Move doc/ -> docs/ --- .tmuxp.json | 4 ++-- .tmuxp.yaml | 2 +- MANIFEST.in | 2 +- {doc => docs}/Makefile | 0 {doc => docs}/_ext/__init__.py | 0 {doc => docs}/_ext/aafig.py | 0 {doc => docs}/_static/favicon.ico | Bin {doc => docs}/_static/img/books/amazon-logo.png | Bin {doc => docs}/_static/img/books/ibooks-logo.png | Bin {doc => docs}/_static/img/icons/icon-128x128.png | Bin {doc => docs}/_static/img/icons/icon-144x144.png | Bin {doc => docs}/_static/img/icons/icon-152x152.png | Bin {doc => docs}/_static/img/icons/icon-192x192.png | Bin {doc => docs}/_static/img/icons/icon-384x384.png | Bin {doc => docs}/_static/img/icons/icon-512x512.png | Bin {doc => docs}/_static/img/icons/icon-72x72.png | Bin {doc => docs}/_static/img/icons/icon-96x96.png | Bin {doc => docs}/_static/img/tmuxp.svg | 0 {doc => docs}/_static/tao-tmux-screenshot.png | Bin {doc => docs}/_static/tmuxp-demo.gif | Bin {doc => docs}/_static/tmuxp-dev-screenshot.png | Bin {doc => docs}/_templates/book.html | 0 {doc => docs}/about.rst | 0 {doc => docs}/about_tmux.rst | 0 {doc => docs}/api.rst | 0 {doc => docs}/cli.rst | 0 {doc => docs}/conf.py | 0 {doc => docs}/developing.rst | 0 {doc => docs}/examples.rst | 0 {doc => docs}/glossary.rst | 0 {doc => docs}/history.rst | 0 {doc => docs}/index.rst | 0 {doc => docs}/manifest.json | 0 {doc => docs}/quickstart.rst | 0 {doc => docs}/requirements.txt | 0 35 files changed, 4 insertions(+), 4 deletions(-) rename {doc => docs}/Makefile (100%) rename {doc => docs}/_ext/__init__.py (100%) rename {doc => docs}/_ext/aafig.py (100%) rename {doc => docs}/_static/favicon.ico (100%) rename {doc => docs}/_static/img/books/amazon-logo.png (100%) rename {doc => docs}/_static/img/books/ibooks-logo.png (100%) rename {doc => docs}/_static/img/icons/icon-128x128.png (100%) rename {doc => docs}/_static/img/icons/icon-144x144.png (100%) rename {doc => docs}/_static/img/icons/icon-152x152.png (100%) rename {doc => docs}/_static/img/icons/icon-192x192.png (100%) rename {doc => docs}/_static/img/icons/icon-384x384.png (100%) rename {doc => docs}/_static/img/icons/icon-512x512.png (100%) rename {doc => docs}/_static/img/icons/icon-72x72.png (100%) rename {doc => docs}/_static/img/icons/icon-96x96.png (100%) rename {doc => docs}/_static/img/tmuxp.svg (100%) rename {doc => docs}/_static/tao-tmux-screenshot.png (100%) rename {doc => docs}/_static/tmuxp-demo.gif (100%) rename {doc => docs}/_static/tmuxp-dev-screenshot.png (100%) rename {doc => docs}/_templates/book.html (100%) rename {doc => docs}/about.rst (100%) rename {doc => docs}/about_tmux.rst (100%) rename {doc => docs}/api.rst (100%) rename {doc => docs}/cli.rst (100%) rename {doc => docs}/conf.py (100%) rename {doc => docs}/developing.rst (100%) rename {doc => docs}/examples.rst (100%) rename {doc => docs}/glossary.rst (100%) rename {doc => docs}/history.rst (100%) rename {doc => docs}/index.rst (100%) rename {doc => docs}/manifest.json (100%) rename {doc => docs}/quickstart.rst (100%) rename {doc => docs}/requirements.txt (100%) diff --git a/.tmuxp.json b/.tmuxp.json index 636804fce80..17256e7bcf6 100644 --- a/.tmuxp.json +++ b/.tmuxp.json @@ -27,7 +27,7 @@ "options": { "main-pane-height": 35 }, - "start_directory": "doc/", + "start_directory": "docs/", "panes": [ { "focus": true @@ -38,4 +38,4 @@ ] } ] -} \ No newline at end of file +} diff --git a/.tmuxp.yaml b/.tmuxp.yaml index d498e1d60a9..28ce7652faf 100644 --- a/.tmuxp.yaml +++ b/.tmuxp.yaml @@ -17,7 +17,7 @@ windows: layout: main-horizontal options: main-pane-height: 35 - start_directory: doc/ + start_directory: docs/ panes: - focus: true - pane diff --git a/MANIFEST.in b/MANIFEST.in index 078513d84cf..abc5eab53a1 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,5 +1,5 @@ include README.rst LICENSE CHANGES pyproject.toml .tmuxp.yaml include requirements/*.txt -recursive-include doc *.rst +recursive-include docs *.rst recursive-include tests *.py *.yaml *.json *.sh recursive-include examples *.yaml *.json diff --git a/doc/Makefile b/docs/Makefile similarity index 100% rename from doc/Makefile rename to docs/Makefile diff --git a/doc/_ext/__init__.py b/docs/_ext/__init__.py similarity index 100% rename from doc/_ext/__init__.py rename to docs/_ext/__init__.py diff --git a/doc/_ext/aafig.py b/docs/_ext/aafig.py similarity index 100% rename from doc/_ext/aafig.py rename to docs/_ext/aafig.py diff --git a/doc/_static/favicon.ico b/docs/_static/favicon.ico similarity index 100% rename from doc/_static/favicon.ico rename to docs/_static/favicon.ico diff --git a/doc/_static/img/books/amazon-logo.png b/docs/_static/img/books/amazon-logo.png similarity index 100% rename from doc/_static/img/books/amazon-logo.png rename to docs/_static/img/books/amazon-logo.png diff --git a/doc/_static/img/books/ibooks-logo.png b/docs/_static/img/books/ibooks-logo.png similarity index 100% rename from doc/_static/img/books/ibooks-logo.png rename to docs/_static/img/books/ibooks-logo.png diff --git a/doc/_static/img/icons/icon-128x128.png b/docs/_static/img/icons/icon-128x128.png similarity index 100% rename from doc/_static/img/icons/icon-128x128.png rename to docs/_static/img/icons/icon-128x128.png diff --git a/doc/_static/img/icons/icon-144x144.png b/docs/_static/img/icons/icon-144x144.png similarity index 100% rename from doc/_static/img/icons/icon-144x144.png rename to docs/_static/img/icons/icon-144x144.png diff --git a/doc/_static/img/icons/icon-152x152.png b/docs/_static/img/icons/icon-152x152.png similarity index 100% rename from doc/_static/img/icons/icon-152x152.png rename to docs/_static/img/icons/icon-152x152.png diff --git a/doc/_static/img/icons/icon-192x192.png b/docs/_static/img/icons/icon-192x192.png similarity index 100% rename from doc/_static/img/icons/icon-192x192.png rename to docs/_static/img/icons/icon-192x192.png diff --git a/doc/_static/img/icons/icon-384x384.png b/docs/_static/img/icons/icon-384x384.png similarity index 100% rename from doc/_static/img/icons/icon-384x384.png rename to docs/_static/img/icons/icon-384x384.png diff --git a/doc/_static/img/icons/icon-512x512.png b/docs/_static/img/icons/icon-512x512.png similarity index 100% rename from doc/_static/img/icons/icon-512x512.png rename to docs/_static/img/icons/icon-512x512.png diff --git a/doc/_static/img/icons/icon-72x72.png b/docs/_static/img/icons/icon-72x72.png similarity index 100% rename from doc/_static/img/icons/icon-72x72.png rename to docs/_static/img/icons/icon-72x72.png diff --git a/doc/_static/img/icons/icon-96x96.png b/docs/_static/img/icons/icon-96x96.png similarity index 100% rename from doc/_static/img/icons/icon-96x96.png rename to docs/_static/img/icons/icon-96x96.png diff --git a/doc/_static/img/tmuxp.svg b/docs/_static/img/tmuxp.svg similarity index 100% rename from doc/_static/img/tmuxp.svg rename to docs/_static/img/tmuxp.svg diff --git a/doc/_static/tao-tmux-screenshot.png b/docs/_static/tao-tmux-screenshot.png similarity index 100% rename from doc/_static/tao-tmux-screenshot.png rename to docs/_static/tao-tmux-screenshot.png diff --git a/doc/_static/tmuxp-demo.gif b/docs/_static/tmuxp-demo.gif similarity index 100% rename from doc/_static/tmuxp-demo.gif rename to docs/_static/tmuxp-demo.gif diff --git a/doc/_static/tmuxp-dev-screenshot.png b/docs/_static/tmuxp-dev-screenshot.png similarity index 100% rename from doc/_static/tmuxp-dev-screenshot.png rename to docs/_static/tmuxp-dev-screenshot.png diff --git a/doc/_templates/book.html b/docs/_templates/book.html similarity index 100% rename from doc/_templates/book.html rename to docs/_templates/book.html diff --git a/doc/about.rst b/docs/about.rst similarity index 100% rename from doc/about.rst rename to docs/about.rst diff --git a/doc/about_tmux.rst b/docs/about_tmux.rst similarity index 100% rename from doc/about_tmux.rst rename to docs/about_tmux.rst diff --git a/doc/api.rst b/docs/api.rst similarity index 100% rename from doc/api.rst rename to docs/api.rst diff --git a/doc/cli.rst b/docs/cli.rst similarity index 100% rename from doc/cli.rst rename to docs/cli.rst diff --git a/doc/conf.py b/docs/conf.py similarity index 100% rename from doc/conf.py rename to docs/conf.py diff --git a/doc/developing.rst b/docs/developing.rst similarity index 100% rename from doc/developing.rst rename to docs/developing.rst diff --git a/doc/examples.rst b/docs/examples.rst similarity index 100% rename from doc/examples.rst rename to docs/examples.rst diff --git a/doc/glossary.rst b/docs/glossary.rst similarity index 100% rename from doc/glossary.rst rename to docs/glossary.rst diff --git a/doc/history.rst b/docs/history.rst similarity index 100% rename from doc/history.rst rename to docs/history.rst diff --git a/doc/index.rst b/docs/index.rst similarity index 100% rename from doc/index.rst rename to docs/index.rst diff --git a/doc/manifest.json b/docs/manifest.json similarity index 100% rename from doc/manifest.json rename to docs/manifest.json diff --git a/doc/quickstart.rst b/docs/quickstart.rst similarity index 100% rename from doc/quickstart.rst rename to docs/quickstart.rst diff --git a/doc/requirements.txt b/docs/requirements.txt similarity index 100% rename from doc/requirements.txt rename to docs/requirements.txt From 0e403ac398023c5484cc2bae228dd5565fe1f11b Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:09:54 -0500 Subject: [PATCH 15/31] build(conf): Update to latest and greatest --- docs/conf.py | 28 ++++++++++++++++++++++++++-- 1 file changed, 26 insertions(+), 2 deletions(-) diff --git a/docs/conf.py b/docs/conf.py index 1b1425485fc..3ad371f5108 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -5,6 +5,7 @@ from os.path import dirname, relpath import alagitpull +from recommonmark.transform import AutoStructify import tmuxp @@ -30,16 +31,33 @@ 'aafig', 'alagitpull', 'sphinx_issues', + 'recommonmark', ] issues_github_path = about['__github__'].replace('https://github.com/', '') templates_path = ['_templates'] -source_suffix = '.rst' +source_suffix = {'.rst': 'restructuredtext', '.md': 'markdown'} master_doc = 'index' +# app setup hook +def setup(app): + app.add_config_value( + 'recommonmark_config', + { + #'url_resolver': lambda url: github_doc_root + url, + 'enable_auto_toc_tree': True, + 'auto_toc_tree_section': 'Contents', + 'auto_code_block': True, + 'enable_eval_rst': True, + }, + True, + ) + app.add_transform(AutoStructify) + + project = about['__title__'] copyright = about['__copyright__'] @@ -51,8 +69,8 @@ pygments_style = 'sphinx' html_theme_path = [alagitpull.get_path()] -html_favicon = '_static/favicon.ico' html_theme = 'alagitpull' +html_extra_path = ['manifest.json'] html_static_path = ['_static'] html_sidebars = { '**': [ @@ -73,6 +91,12 @@ 'github_banner': True, 'projects': alagitpull.projects, 'project_name': about['__title__'], + 'project_title': about['__title__'], + 'project_description': about['__description__'], + 'project_url': about['__docs__'], + 'show_meta_manifest_tag': True, + 'show_meta_og_tags': True, + 'show_meta_app_icon_tags': True, } alagitpull_internal_hosts = ['tmuxp.git-pull.com', '0.0.0.0'] From 4c50f75f87cf8c48d925f0b29a97742dd8310b6b Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:12:28 -0500 Subject: [PATCH 16/31] build(docs): Add layout --- docs/_templates/layout.html | 45 +++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 docs/_templates/layout.html diff --git a/docs/_templates/layout.html b/docs/_templates/layout.html new file mode 100644 index 00000000000..19a94fe4703 --- /dev/null +++ b/docs/_templates/layout.html @@ -0,0 +1,45 @@ +{% extends "!layout.html" %} +{%- block extrahead %} + {{ super() }} + {%- if theme_show_meta_manifest_tag == true %} + + {% endif -%} + {%- if theme_show_meta_og_tags == true %} + + + + + + + + + + + + + + + + {% endif -%} + {%- if theme_show_meta_app_icon_tags == true %} + + + + + + + + + + + + + + + + + + + + {% endif -%} +{% endblock %} From e00366829c42d213faaadbba7edbb7f038bde7ff Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:13:14 -0500 Subject: [PATCH 17/31] build(publish-docs): Add doc builder gh action --- .github/workflows/publish-docs.yml | 97 ++++++++++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100644 .github/workflows/publish-docs.yml diff --git a/.github/workflows/publish-docs.yml b/.github/workflows/publish-docs.yml new file mode 100644 index 00000000000..572b9b8827a --- /dev/null +++ b/.github/workflows/publish-docs.yml @@ -0,0 +1,97 @@ +name: Publish Docs + +on: [push] + +jobs: + build: + + runs-on: ubuntu-latest + strategy: + matrix: + python-version: [ '3.x' ] + steps: + - uses: actions/checkout@v1 + - name: Configure git + run: | + git config --global user.name 'travis-ci' + git config --global user.email 'travis@nowhere.edu' + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v1 + with: + python-version: ${{ matrix.python-version }} + + - name: Get full Python version + id: full-python-version + shell: bash + run: echo ::set-output name=version::$(python -c "import sys; print('-'.join(str(v) for v in sys.version_info))") + + - name: Install poetry + run: | + curl -O -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py + python get-poetry.py -y + echo "::set-env name=PATH::$HOME/.poetry/bin:$PATH" + rm get-poetry.py + + - name: Get poetry cache paths from config + run: | + echo ::set-env name=poetry_cache_dir::$(poetry config --list | sed -n 's/.*cache-dir = //p' | sed -e 's/^"//' -e 's/"$//') + echo ::set-env name=poetry_virtualenvs_path::$(poetry config --list | sed -n 's/.*virtualenvs.path = .* # //p' | sed -e 's/^"//' -e 's/"$//') + + - name: Configure poetry + shell: bash + run: poetry config virtualenvs.in-project true + + - name: Set up cache + uses: actions/cache@v2 + id: cache + with: + path: | + .venv + {{ env.poetry_cache_dir }} + {{ env.poetry_virtualenvs_path }} + key: venv-${{ runner.os }}-${{ steps.full-python-version.outputs.version }}-${{ hashFiles('**/poetry.lock') }} + + - name: Ensure cache is healthy + if: steps.cache.outputs.cache-hit == 'true' + shell: bash + run: poetry run pip --version >/dev/null 2>&1 || rm -rf .venv + + - name: Upgrade pip + shell: bash + run: poetry run python -m pip install pip -U + + - name: Install dependencies [w/ docs] + run: poetry install --extras "docs lint" + + - name: Build documentation + run: | + pushd docs; make SPHINXBUILD='poetry run sphinx-build' html; popd + + - name: Push documentation to S3 + uses: jakejarvis/s3-sync-action@master + with: + args: --acl public-read --follow-symlinks --delete + env: + AWS_S3_BUCKET: ${{ secrets.AWS_S3_BUCKET }} + AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} + AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + AWS_REGION: 'us-west-1' # optional: defaults to us-east-1 + SOURCE_DIR: 'docs/_build/html' # optional: defaults to entire repository + + - name: Generate list of changed files for CloudFront to invalidate + run: | + pushd docs/_build/html; FILES=$(find . -name \* -print | grep html | cut -c2- | sort | uniq | tr '\n' ' '); popd + for file in $FILES; do + echo $file + # add bare directory to list of updated paths when we see index.html + [[ "$file" == *"/index.html" ]] && echo $file | sed -e 's/\/index.html$/\//' + done | sort | uniq | tr '\n' ' ' > .updated_files + + - name: Invalidate on CloudFront + uses: chetan/invalidate-cloudfront-action@master + env: + DISTRIBUTION: ${{ secrets.AWS_CLOUDFRONT_DISTRIBUTION }} + AWS_REGION: 'us-east-1' + AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} + AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + PATHS_FROM: .updated_files From 498093a11b0f4b938a34ce32e34b1bb76dff4b15 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:16:38 -0500 Subject: [PATCH 18/31] docs: Include buttons on docs page --- docs/index.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/index.rst b/docs/index.rst index 3708aa125a9..a79d62409a6 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -8,7 +8,7 @@ tmux session manager ==================== .. include:: ../README.rst - :start-line: 4 + :start-line: 2 :end-before: .. image .. image:: _static/tmuxp-demo.gif From ccea1ba94bcf6c9c2520fd8544aad1e1d0f909dc Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:16:50 -0500 Subject: [PATCH 19/31] docs(README): Link to docs CI task --- README.rst | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/README.rst b/README.rst index bc3ae5c1364..56125f35dab 100644 --- a/README.rst +++ b/README.rst @@ -197,6 +197,10 @@ tests .. code-block:: bash :alt: Python Package :target: http://badge.fury.io/py/tmuxp +.. |docs| image:: https://github.com/tmux-python/tmuxp/workflows/Publish%20Docs/badge.svg + :alt: Docs + :target: https://github.com/tmux-python/tmuxp/actions?query=workflow%3A"Publish+Docs" + .. |build-status| image:: https://img.shields.io/travis/tmux-python/tmuxp.svg :alt: Build Status :target: https://travis-ci.org/tmux-python/tmuxp @@ -207,8 +211,3 @@ tests .. code-block:: bash .. |license| image:: https://img.shields.io/github/license/tmux-python/tmuxp.svg :alt: License - -.. |docs| image:: https://readthedocs.org/projects/tmuxp/badge/?version=latest - :alt: Documentation Status - :scale: 100% - :target: https://readthedocs.org/projects/tmuxp/ From c92cc348f96216d2cebe67e5d22c5d1ab23913b8 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:23:33 -0500 Subject: [PATCH 20/31] build(doc index): Update includes, headers --- docs/index.rst | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/docs/index.rst b/docs/index.rst index a79d62409a6..fc6d6779547 100644 --- a/docs/index.rst +++ b/docs/index.rst @@ -14,14 +14,13 @@ tmux session manager .. image:: _static/tmuxp-demo.gif :width: 100% - Freeze a tmux session --------------------- .. include:: ../README.rst :start-after: --------------------- -Explore: - +Table of Contents +----------------- .. toctree:: :maxdepth: 2 From 304f910495ee062d5219d63c17fc9064fbe79535 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:24:21 -0500 Subject: [PATCH 21/31] build(README): Remove table --- README.rst | 46 +++++++++++----------------------------------- 1 file changed, 11 insertions(+), 35 deletions(-) diff --git a/README.rst b/README.rst index 56125f35dab..8af3b9de190 100644 --- a/README.rst +++ b/README.rst @@ -153,41 +153,17 @@ See donation options at https://git-pull.com/support.html. Project details --------------- - -============== ========================================================== -tmux support 1.8, 1.9a, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6, 2.7. 2.8 -python support 2.7, >= 3.5, pypy, pypy3 -config support yaml, json, python dict -Source https://github.com/tmux-python/tmuxp -Docs http://tmuxp.git-pull.com -API http://tmuxp.git-pull.com/en/latest/api.html -Changelog http://tmuxp.git-pull.com/en/latest/history.html -Issues https://github.com/tmux-python/tmuxp/issues -Travis http://travis-ci.org/tmux-python/tmuxp -Test Coverage https://codecov.io/gh/tmux-python/tmuxp -pypi https://pypi.python.org/pypi/tmuxp -Open Hub https://www.openhub.net/p/tmuxp -License `MIT`_. -git repo .. code-block:: bash - - $ git clone https://github.com/tmux-python/tmuxp.git -install stable .. code-block:: bash - - $ pip install --user tmuxp -install dev .. code-block:: bash - - $ git clone https://github.com/tmux-python/tmuxp.git tmuxp - $ cd ./tmuxp - $ virtualenv .venv - $ source .venv/bin/activate - $ pip install -e . - - See the `developing and testing`_ page in the docs for - more. -tests .. code-block:: bash - - $ make test -============== ========================================================== +- tmux support: 1.8, 1.9a, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6 +- python support: 2.7, >= 3.3, pypy, pypy3 +- Source: https://github.com/tmux-python/tmuxp +- Docs: https://tmuxp.git-pull.com +- API: https://tmuxp.git-pull.com/api.html +- Changelog: https://tmuxp.git-pull.com/history.html +- Issues: https://github.com/tmux-python/tmuxp/issues +- Test Coverage: https://codecov.io/gh/tmux-python/tmuxp +- pypi: https://pypi.python.org/pypi/tmuxp +- Open Hub: https://www.openhub.net/p/tmuxp-python +- License: `MIT`_. .. _MIT: http://opensource.org/licenses/MIT .. _developing and testing: http://tmuxp.git-pull.com/en/latest/developing.html From 91ad602c5075d5e7f746e3f5191abe4dad027fb3 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:25:11 -0500 Subject: [PATCH 22/31] docs: Update /en/latest reference to new path / --- README.rst | 30 +++++++++++++++--------------- docs/conf.py | 2 +- docs/quickstart.rst | 2 +- tmuxp/cli.py | 6 +++--- 4 files changed, 20 insertions(+), 20 deletions(-) diff --git a/README.rst b/README.rst index 8af3b9de190..55391e4da3f 100644 --- a/README.rst +++ b/README.rst @@ -118,26 +118,26 @@ Want to learn more about tmux itself? `Read The Tao of Tmux online`_. .. _Documentation: http://tmuxp.git-pull.com .. _Source: https://github.com/tmux-python/tmuxp .. _中文: http://tmuxp-zh.rtfd.org/ -.. _before_script: http://tmuxp.git-pull.com/en/latest/examples.html#bootstrap-project-before-launch -.. _virtualenv: https://virtualenv.git-pull.com/en/latest/ -.. _Read The Tao of tmux online: http://tmuxp.git-pull.com/en/latest/about_tmux.html +.. _before_script: http://tmuxp.git-pull.com/examples.html#bootstrap-project-before-launch +.. _virtualenv: https://virtualenv.git-pull.com/ +.. _Read The Tao of tmux online: http://tmuxp.git-pull.com/about_tmux.html .. _author's tmuxp configs: https://github.com/tony/tmuxp-config -.. _python library: https://tmuxp.git-pull.com/en/latest/api.html -.. _python API quickstart: https://tmuxp.git-pull.com/en/latest/quickstart_python.html +.. _python library: https://tmuxp.git-pull.com/api.html +.. _python API quickstart: https://tmuxp.git-pull.com/quickstart_python.html .. _tmux(1): http://tmux.sourceforge.net/ .. _tmuxinator: https://github.com/aziz/tmuxinator .. _teamocil: https://github.com/remiprev/teamocil -.. _Examples: http://tmuxp.git-pull.com/en/latest/examples.html -.. _freezing tmux: http://tmuxp.git-pull.com/en/latest/cli.html#freeze-sessions +.. _Examples: http://tmuxp.git-pull.com/examples.html +.. _freezing tmux: http://tmuxp.git-pull.com/cli.html#freeze-sessions .. _bootstrap_env.py: https://github.com/tmux-python/tmuxp/blob/master/bootstrap_env.py -.. _travis.yml: http://tmuxp.git-pull.com/en/latest/developing.html#travis-ci -.. _testing: http://tmuxp.git-pull.com/en/latest/developing.html#test-runner -.. _python objects: http://tmuxp.git-pull.com/en/latest/api.html#api +.. _travis.yml: http://tmuxp.git-pull.com/developing.html#travis-ci +.. _testing: http://tmuxp.git-pull.com/developing.html#test-runner +.. _python objects: http://tmuxp.git-pull.com/api.html#api .. _tmuxp.yaml: https://github.com/tmux-python/tmuxp/blob/master/.tmuxp.yaml -.. _simple: http://tmuxp.git-pull.com/en/latest/examples.html#short-hand-inline -.. _very elaborate: http://tmuxp.git-pull.com/en/latest/examples.html#super-advanced-dev-environment -.. _Quickstart: http://tmuxp.git-pull.com/en/latest/quickstart.html -.. _Commands: http://tmuxp.git-pull.com/en/latest/cli.html +.. _simple: http://tmuxp.git-pull.com/examples.html#short-hand-inline +.. _very elaborate: http://tmuxp.git-pull.com/examples.html#super-advanced-dev-environment +.. _Quickstart: http://tmuxp.git-pull.com/quickstart.html +.. _Commands: http://tmuxp.git-pull.com/cli.html .. _libtmux: https://github.com/tmux-python/libtmux .. _on the web: https://leanpub.com/the-tao-of-tmux/read @@ -166,7 +166,7 @@ Project details - License: `MIT`_. .. _MIT: http://opensource.org/licenses/MIT -.. _developing and testing: http://tmuxp.git-pull.com/en/latest/developing.html +.. _developing and testing: http://tmuxp.git-pull.com/developing.html .. _Amazon Kindle: http://amzn.to/2gPfRhC .. |pypi| image:: https://img.shields.io/pypi/v/tmuxp.svg diff --git a/docs/conf.py b/docs/conf.py index 3ad371f5108..f28e06db0cc 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -138,7 +138,7 @@ def setup(app): intersphinx_mapping = { 'python': ('https://docs.python.org/', None), - 'libtmux': ('https://libtmux.readthedocs.io/en/latest', None), + 'libtmux': ('https://libtmux.readthedocs.io', None), 'click': ('http://click.pocoo.org/5', None), } diff --git a/docs/quickstart.rst b/docs/quickstart.rst index 380c8edae1c..b10753f43d3 100644 --- a/docs/quickstart.rst +++ b/docs/quickstart.rst @@ -98,7 +98,7 @@ python abstraction layer :meth:`libtmux.Pane.send_keys` ``$ tmux send-keys`` ======================================== ================================= -.. _Import: http://tmuxp.readthedocs.io/en/latest/cli.html#import +.. _Import: http://tmuxp.readthedocs.io/cli.html#import .. _tmuxinator: https://github.com/aziz/tmuxinator .. _teamocil: https://github.com/remiprev/teamocil .. _Abstraction Layer: http://en.wikipedia.org/wiki/Abstraction_layer diff --git a/tmuxp/cli.py b/tmuxp/cli.py index f724a765afa..18772d1a9d8 100644 --- a/tmuxp/cli.py +++ b/tmuxp/cli.py @@ -606,7 +606,7 @@ def cli(log_level): Pass the "--help" argument to any command to see detailed help. See detailed documentation and examples at: - http://tmuxp.readthedocs.io/en/latest/""" + http://tmuxp.readthedocs.io/""" try: has_minimum_version() except TmuxCommandNotFound: @@ -735,7 +735,7 @@ def command_freeze(session_name, socket_name, socket_path): else: print( 'tmuxp has examples in JSON and YAML format at ' - '\n' + '\n' 'View tmuxp docs at .' ) sys.exit() @@ -866,7 +866,7 @@ def import_config(configfile, importfunc): else: click.echo( 'tmuxp has examples in JSON and YAML format at ' - '\n' + '\n' 'View tmuxp docs at ' ) sys.exit() From 798f9921318a0d98b09fe8329835198818a99aa1 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:25:40 -0500 Subject: [PATCH 23/31] build(docs): Use new libtmux site --- docs/conf.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/conf.py b/docs/conf.py index f28e06db0cc..65f4b5b9fc7 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -138,7 +138,7 @@ def setup(app): intersphinx_mapping = { 'python': ('https://docs.python.org/', None), - 'libtmux': ('https://libtmux.readthedocs.io', None), + 'libtmux': ('https://libtmux.git-pull.com/', None), 'click': ('http://click.pocoo.org/5', None), } From 877fd7e1d88fc90ec0dda4ae4e6070ad217ee19c Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:39:57 -0500 Subject: [PATCH 24/31] docs(CHANGES): Update for this PRs changes --- CHANGES | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/CHANGES b/CHANGES index 768523c601c..babc6a3afab 100644 --- a/CHANGES +++ b/CHANGES @@ -4,6 +4,14 @@ Changelog Here you can find the recent changes to tmuxp +current +------- +- :issue:`623` Move docs from RTD to self-serve site +- :issue:`623` Modernize Makefiles +- :issue:`623` New development docs +- :issue:`623` Update pyproject.toml to experiment with poetry packaging +- :issue:`619` isort 5 + tmuxp 1.5.5 (2020-07-26) ------------------------ - :issue:`616` (via: :issue:`599`) New command: ``tmuxp ls`` From e1acb04750e8f16315214658d84016fa399c9269 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 19:40:18 -0500 Subject: [PATCH 25/31] docs: Update tmuxp doc links to mention tmuxp.git-pull.com --- docs/quickstart.rst | 2 +- tmuxp/cli.py | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/docs/quickstart.rst b/docs/quickstart.rst index b10753f43d3..aebac4812fb 100644 --- a/docs/quickstart.rst +++ b/docs/quickstart.rst @@ -98,7 +98,7 @@ python abstraction layer :meth:`libtmux.Pane.send_keys` ``$ tmux send-keys`` ======================================== ================================= -.. _Import: http://tmuxp.readthedocs.io/cli.html#import +.. _Import: http://tmuxp.git-pull.com/cli.html#import .. _tmuxinator: https://github.com/aziz/tmuxinator .. _teamocil: https://github.com/remiprev/teamocil .. _Abstraction Layer: http://en.wikipedia.org/wiki/Abstraction_layer diff --git a/tmuxp/cli.py b/tmuxp/cli.py index 18772d1a9d8..35374493568 100644 --- a/tmuxp/cli.py +++ b/tmuxp/cli.py @@ -606,7 +606,7 @@ def cli(log_level): Pass the "--help" argument to any command to see detailed help. See detailed documentation and examples at: - http://tmuxp.readthedocs.io/""" + http://tmuxp.git-pull.com/""" try: has_minimum_version() except TmuxCommandNotFound: @@ -735,8 +735,8 @@ def command_freeze(session_name, socket_name, socket_path): else: print( 'tmuxp has examples in JSON and YAML format at ' - '\n' - 'View tmuxp docs at .' + '\n' + 'View tmuxp docs at .' ) sys.exit() @@ -866,8 +866,8 @@ def import_config(configfile, importfunc): else: click.echo( 'tmuxp has examples in JSON and YAML format at ' - '\n' - 'View tmuxp docs at ' + '\n' + 'View tmuxp docs at ' ) sys.exit() From 94f799e42d604321d56209fc868dd97ff86a9d85 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Mon, 10 Aug 2020 20:59:42 -0500 Subject: [PATCH 26/31] docs: Fix metadata --- docs/_templates/layout.html | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/_templates/layout.html b/docs/_templates/layout.html index 19a94fe4703..2943238cf7b 100644 --- a/docs/_templates/layout.html +++ b/docs/_templates/layout.html @@ -33,10 +33,10 @@ - + - + From 0d4654e4ff8ed4adc167b5e44a254687dbbcec4c Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Tue, 11 Aug 2020 05:23:01 -0500 Subject: [PATCH 27/31] build: Fix .gitignore --- .gitignore | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index d103c98ef88..cfc23d45dd6 100644 --- a/.gitignore +++ b/.gitignore @@ -45,7 +45,7 @@ htmlcov/ .cache nosetests.xml coverage.xml -*,cover +*.cover .hypothesis/ .pytest_cache/ From e5ec2d8fa3f468ea9c6375b1b2a73fe16810cda6 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Sun, 16 Aug 2020 10:13:20 -0500 Subject: [PATCH 28/31] build: Update poetry lockfile --- poetry.lock | 87 +++++++++++++++++++++++++++-------------------------- 1 file changed, 44 insertions(+), 43 deletions(-) diff --git a/poetry.lock b/poetry.lock index 8ce732469b8..69ba5a51927 100644 --- a/poetry.lock +++ b/poetry.lock @@ -132,7 +132,7 @@ marker = "sys_platform == \"linux\"" name = "cffi" optional = false python-versions = "*" -version = "1.14.1" +version = "1.14.2" [package.dependencies] pycparser = "*" @@ -205,7 +205,7 @@ testing = ["pytest (>=3.5,<3.7.3 || >3.7.3)", "pytest-checkdocs (>=1.2)", "pytes [[package]] category = "dev" description = "Backports and enhancements for the contextlib module" -marker = "python_version < \"3\"" +marker = "python_version < \"3.4\"" name = "contextlib2" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" @@ -414,7 +414,7 @@ marker = "python_version >= \"3.6\"" name = "isort" optional = false python-versions = ">=3.6,<4.0" -version = "5.3.2" +version = "5.4.2" [package.extras] colors = ["colorama (>=0.4.3,<0.5.0)"] @@ -486,7 +486,7 @@ description = "scripting library / orm for tmux" name = "libtmux" optional = false python-versions = "*" -version = "0.8.2" +version = "0.8.3" [[package]] category = "dev" @@ -795,7 +795,7 @@ marker = "python_version >= \"3\"" name = "pytest-cov" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" -version = "2.10.0" +version = "2.10.1" [package.dependencies] coverage = ">=4.4" @@ -1043,7 +1043,7 @@ description = "Python documentation generator" name = "sphinx" optional = false python-versions = ">=3.5" -version = "3.2.0" +version = "3.2.1" [package.dependencies] Jinja2 = ">=2.3" @@ -1293,7 +1293,7 @@ version = "0.5.1" [[package]] category = "dev" description = "Backport of pathlib-compatible object wrapper for zip files" -marker = "python_version >= \"3\" and python_version < \"3.8\" or python_version < \"3\"" +marker = "python_version < \"3.8\" or python_version >= \"3\" and python_version < \"3.8\"" name = "zipp" optional = false python-versions = ">=2.7" @@ -1311,7 +1311,7 @@ testing = ["pathlib2", "unittest2", "jaraco.itertools", "func-timeout"] [[package]] category = "dev" description = "Backport of pathlib-compatible object wrapper for zip files" -marker = "python_version >= \"3\" and python_version < \"3.8\"" +marker = "python_version >= \"3\" and python_version < \"3.8\" or python_version < \"3.8\"" name = "zipp" optional = false python-versions = ">=3.6" @@ -1380,34 +1380,34 @@ certifi = [ {file = "certifi-2020.6.20.tar.gz", hash = "sha256:5930595817496dd21bb8dc35dad090f1c2cd0adfaf21204bf6732ca5d8ee34d3"}, ] cffi = [ - {file = "cffi-1.14.1-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:66dd45eb9530e3dde8f7c009f84568bc7cac489b93d04ac86e3111fb46e470c2"}, - {file = "cffi-1.14.1-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:4f53e4128c81ca3212ff4cf097c797ab44646a40b42ec02a891155cd7a2ba4d8"}, - {file = "cffi-1.14.1-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:833401b15de1bb92791d7b6fb353d4af60dc688eaa521bd97203dcd2d124a7c1"}, - {file = "cffi-1.14.1-cp27-cp27m-win32.whl", hash = "sha256:26f33e8f6a70c255767e3c3f957ccafc7f1f706b966e110b855bfe944511f1f9"}, - {file = "cffi-1.14.1-cp27-cp27m-win_amd64.whl", hash = "sha256:b87dfa9f10a470eee7f24234a37d1d5f51e5f5fa9eeffda7c282e2b8f5162eb1"}, - {file = "cffi-1.14.1-cp27-cp27mu-manylinux1_i686.whl", hash = "sha256:effd2ba52cee4ceff1a77f20d2a9f9bf8d50353c854a282b8760ac15b9833168"}, - {file = "cffi-1.14.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bac0d6f7728a9cc3c1e06d4fcbac12aaa70e9379b3025b27ec1226f0e2d404cf"}, - {file = "cffi-1.14.1-cp35-cp35m-macosx_10_9_x86_64.whl", hash = "sha256:d6033b4ffa34ef70f0b8086fd4c3df4bf801fee485a8a7d4519399818351aa8e"}, - {file = "cffi-1.14.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:8416ed88ddc057bab0526d4e4e9f3660f614ac2394b5e019a628cdfff3733849"}, - {file = "cffi-1.14.1-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:892daa86384994fdf4856cb43c93f40cbe80f7f95bb5da94971b39c7f54b3a9c"}, - {file = "cffi-1.14.1-cp35-cp35m-win32.whl", hash = "sha256:c991112622baee0ae4d55c008380c32ecfd0ad417bcd0417ba432e6ba7328caa"}, - {file = "cffi-1.14.1-cp35-cp35m-win_amd64.whl", hash = "sha256:fcf32bf76dc25e30ed793145a57426064520890d7c02866eb93d3e4abe516948"}, - {file = "cffi-1.14.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:f960375e9823ae6a07072ff7f8a85954e5a6434f97869f50d0e41649a1c8144f"}, - {file = "cffi-1.14.1-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:a6d28e7f14ecf3b2ad67c4f106841218c8ab12a0683b1528534a6c87d2307af3"}, - {file = "cffi-1.14.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:cda422d54ee7905bfc53ee6915ab68fe7b230cacf581110df4272ee10462aadc"}, - {file = "cffi-1.14.1-cp36-cp36m-win32.whl", hash = "sha256:4a03416915b82b81af5502459a8a9dd62a3c299b295dcdf470877cb948d655f2"}, - {file = "cffi-1.14.1-cp36-cp36m-win_amd64.whl", hash = "sha256:4ce1e995aeecf7cc32380bc11598bfdfa017d592259d5da00fc7ded11e61d022"}, - {file = "cffi-1.14.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:e23cb7f1d8e0f93addf0cae3c5b6f00324cccb4a7949ee558d7b6ca973ab8ae9"}, - {file = "cffi-1.14.1-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:ddff0b2bd7edcc8c82d1adde6dbbf5e60d57ce985402541cd2985c27f7bec2a0"}, - {file = "cffi-1.14.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:f90c2267101010de42f7273c94a1f026e56cbc043f9330acd8a80e64300aba33"}, - {file = "cffi-1.14.1-cp37-cp37m-win32.whl", hash = "sha256:3cd2c044517f38d1b577f05927fb9729d3396f1d44d0c659a445599e79519792"}, - {file = "cffi-1.14.1-cp37-cp37m-win_amd64.whl", hash = "sha256:4fa72a52a906425416f41738728268072d5acfd48cbe7796af07a923236bcf96"}, - {file = "cffi-1.14.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:267adcf6e68d77ba154334a3e4fc921b8e63cbb38ca00d33d40655d4228502bc"}, - {file = "cffi-1.14.1-cp38-cp38-manylinux1_i686.whl", hash = "sha256:d3148b6ba3923c5850ea197a91a42683f946dba7e8eb82dfa211ab7e708de939"}, - {file = "cffi-1.14.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:98be759efdb5e5fa161e46d404f4e0ce388e72fbf7d9baf010aff16689e22abe"}, - {file = "cffi-1.14.1-cp38-cp38-win32.whl", hash = "sha256:6923d077d9ae9e8bacbdb1c07ae78405a9306c8fd1af13bfa06ca891095eb995"}, - {file = "cffi-1.14.1-cp38-cp38-win_amd64.whl", hash = "sha256:b1d6ebc891607e71fd9da71688fcf332a6630b7f5b7f5549e6e631821c0e5d90"}, - {file = "cffi-1.14.1.tar.gz", hash = "sha256:b2a2b0d276a136146e012154baefaea2758ef1f56ae9f4e01c612b0831e0bd2f"}, + {file = "cffi-1.14.2-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:da9d3c506f43e220336433dffe643fbfa40096d408cb9b7f2477892f369d5f82"}, + {file = "cffi-1.14.2-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:23e44937d7695c27c66a54d793dd4b45889a81b35c0751ba91040fe825ec59c4"}, + {file = "cffi-1.14.2-cp27-cp27m-manylinux1_x86_64.whl", hash = "sha256:0da50dcbccd7cb7e6c741ab7912b2eff48e85af217d72b57f80ebc616257125e"}, + {file = "cffi-1.14.2-cp27-cp27m-win32.whl", hash = "sha256:76ada88d62eb24de7051c5157a1a78fd853cca9b91c0713c2e973e4196271d0c"}, + {file = "cffi-1.14.2-cp27-cp27m-win_amd64.whl", hash = "sha256:15a5f59a4808f82d8ec7364cbace851df591c2d43bc76bcbe5c4543a7ddd1bf1"}, + {file = "cffi-1.14.2-cp27-cp27mu-manylinux1_i686.whl", hash = "sha256:e4082d832e36e7f9b2278bc774886ca8207346b99f278e54c9de4834f17232f7"}, + {file = "cffi-1.14.2-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:57214fa5430399dffd54f4be37b56fe22cedb2b98862550d43cc085fb698dc2c"}, + {file = "cffi-1.14.2-cp35-cp35m-macosx_10_9_x86_64.whl", hash = "sha256:6843db0343e12e3f52cc58430ad559d850a53684f5b352540ca3f1bc56df0731"}, + {file = "cffi-1.14.2-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:577791f948d34d569acb2d1add5831731c59d5a0c50a6d9f629ae1cefd9ca4a0"}, + {file = "cffi-1.14.2-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:8662aabfeab00cea149a3d1c2999b0731e70c6b5bac596d95d13f643e76d3d4e"}, + {file = "cffi-1.14.2-cp35-cp35m-win32.whl", hash = "sha256:837398c2ec00228679513802e3744d1e8e3cb1204aa6ad408b6aff081e99a487"}, + {file = "cffi-1.14.2-cp35-cp35m-win_amd64.whl", hash = "sha256:bf44a9a0141a082e89c90e8d785b212a872db793a0080c20f6ae6e2a0ebf82ad"}, + {file = "cffi-1.14.2-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:29c4688ace466a365b85a51dcc5e3c853c1d283f293dfcc12f7a77e498f160d2"}, + {file = "cffi-1.14.2-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:99cc66b33c418cd579c0f03b77b94263c305c389cb0c6972dac420f24b3bf123"}, + {file = "cffi-1.14.2-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:65867d63f0fd1b500fa343d7798fa64e9e681b594e0a07dc934c13e76ee28fb1"}, + {file = "cffi-1.14.2-cp36-cp36m-win32.whl", hash = "sha256:f5033952def24172e60493b68717792e3aebb387a8d186c43c020d9363ee7281"}, + {file = "cffi-1.14.2-cp36-cp36m-win_amd64.whl", hash = "sha256:7057613efefd36cacabbdbcef010e0a9c20a88fc07eb3e616019ea1692fa5df4"}, + {file = "cffi-1.14.2-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:6539314d84c4d36f28d73adc1b45e9f4ee2a89cdc7e5d2b0a6dbacba31906798"}, + {file = "cffi-1.14.2-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:672b539db20fef6b03d6f7a14b5825d57c98e4026401fce838849f8de73fe4d4"}, + {file = "cffi-1.14.2-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:95e9094162fa712f18b4f60896e34b621df99147c2cee216cfa8f022294e8e9f"}, + {file = "cffi-1.14.2-cp37-cp37m-win32.whl", hash = "sha256:b9aa9d8818c2e917fa2c105ad538e222a5bce59777133840b93134022a7ce650"}, + {file = "cffi-1.14.2-cp37-cp37m-win_amd64.whl", hash = "sha256:e4b9b7af398c32e408c00eb4e0d33ced2f9121fd9fb978e6c1b57edd014a7d15"}, + {file = "cffi-1.14.2-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:e613514a82539fc48291d01933951a13ae93b6b444a88782480be32245ed4afa"}, + {file = "cffi-1.14.2-cp38-cp38-manylinux1_i686.whl", hash = "sha256:9b219511d8b64d3fa14261963933be34028ea0e57455baf6781fe399c2c3206c"}, + {file = "cffi-1.14.2-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:c0b48b98d79cf795b0916c57bebbc6d16bb43b9fc9b8c9f57f4cf05881904c75"}, + {file = "cffi-1.14.2-cp38-cp38-win32.whl", hash = "sha256:15419020b0e812b40d96ec9d369b2bc8109cc3295eac6e013d3261343580cc7e"}, + {file = "cffi-1.14.2-cp38-cp38-win_amd64.whl", hash = "sha256:12a453e03124069b6896107ee133ae3ab04c624bb10683e1ed1c1663df17c13c"}, + {file = "cffi-1.14.2.tar.gz", hash = "sha256:ae8f34d50af2c2154035984b8b5fc5d9ed63f32fe615646ab435b05b132ca91b"}, ] chardet = [ {file = "chardet-3.0.4-py2.py3-none-any.whl", hash = "sha256:fc323ffcaeaed0e0a02bf4d117757b98aed530d9ed4531e3e15460124c106691"}, @@ -1542,8 +1542,8 @@ iniconfig = [ isort = [ {file = "isort-4.3.21-py2.py3-none-any.whl", hash = "sha256:6e811fcb295968434526407adb8796944f1988c5b65e8139058f2014cbe100fd"}, {file = "isort-4.3.21.tar.gz", hash = "sha256:54da7e92468955c4fceacd0c86bd0ec997b0e1ee80d97f67c35a78b719dccab1"}, - {file = "isort-5.3.2-py3-none-any.whl", hash = "sha256:5196bd2f5b23dc91215734b1c96c6d28390061d69860a948094c12635d6d64e6"}, - {file = "isort-5.3.2.tar.gz", hash = "sha256:ba83762132a8661d3525f87a86549712fb7d8da79eeb452e01f327ada9e87920"}, + {file = "isort-5.4.2-py3-none-any.whl", hash = "sha256:60a1b97e33f61243d12647aaaa3e6cc6778f5eb9f42997650f1cc975b6008750"}, + {file = "isort-5.4.2.tar.gz", hash = "sha256:d488ba1c5a2db721669cc180180d5acf84ebdc5af7827f7aaeaa75f73cf0e2b8"}, ] jeepney = [ {file = "jeepney-0.4.3-py3-none-any.whl", hash = "sha256:d6c6b49683446d2407d2fe3acb7a368a77ff063f9182fe427da15d622adc24cf"}, @@ -1561,7 +1561,8 @@ keyring = [ {file = "keyring-21.3.0.tar.gz", hash = "sha256:22df6abfed49912fc560806030051067fba9f0069cffa79da72899aeea4ccbd5"}, ] libtmux = [ - {file = "libtmux-0.8.2.tar.gz", hash = "sha256:2acd86617203bc966b125d016526fb40503411a2281b55d9d970a487dc6e065a"}, + {file = "libtmux-0.8.3-py2.py3-none-any.whl", hash = "sha256:b628121f6db98e34837f78e06aa4388c1a0c53518b2336f437b023bd95798c09"}, + {file = "libtmux-0.8.3.tar.gz", hash = "sha256:a4c7379604ccdc684aa865723211184709f9a2b45511772989b5f26ad156650e"}, ] markupsafe = [ {file = "MarkupSafe-1.1.1-cp27-cp27m-macosx_10_6_intel.whl", hash = "sha256:09027a7803a62ca78792ad89403b1b7a73a01c8cb65909cd876f7fcebd79b161"}, @@ -1728,8 +1729,8 @@ pytest = [ pytest-cov = [ {file = "pytest-cov-2.9.0.tar.gz", hash = "sha256:b6a814b8ed6247bd81ff47f038511b57fe1ce7f4cc25b9106f1a4b106f1d9322"}, {file = "pytest_cov-2.9.0-py2.py3-none-any.whl", hash = "sha256:c87dfd8465d865655a8213859f1b4749b43448b5fae465cb981e16d52a811424"}, - {file = "pytest-cov-2.10.0.tar.gz", hash = "sha256:1a629dc9f48e53512fcbfda6b07de490c374b0c83c55ff7a1720b3fccff0ac87"}, - {file = "pytest_cov-2.10.0-py2.py3-none-any.whl", hash = "sha256:6e6d18092dce6fad667cd7020deed816f858ad3b49d5b5e2b1cc1c97a4dba65c"}, + {file = "pytest-cov-2.10.1.tar.gz", hash = "sha256:47bd0ce14056fdd79f93e1713f88fad7bdcc583dcd7783da86ef2f085a0bb88e"}, + {file = "pytest_cov-2.10.1-py2.py3-none-any.whl", hash = "sha256:45ec2d5182f89a81fc3eb29e3d1ed3113b9e9a873bcddb2a71faaab066110191"}, ] pytest-mock = [ {file = "pytest-mock-2.0.0.tar.gz", hash = "sha256:b35eb281e93aafed138db25c8772b95d3756108b601947f89af503f8c629413f"}, @@ -1835,8 +1836,8 @@ snowballstemmer = [ sphinx = [ {file = "Sphinx-1.8.5-py2.py3-none-any.whl", hash = "sha256:9f3e17c64b34afc653d7c5ec95766e03043cc6d80b0de224f59b6b6e19d37c3c"}, {file = "Sphinx-1.8.5.tar.gz", hash = "sha256:c7658aab75c920288a8cf6f09f244c6cfdae30d82d803ac1634d9f223a80ca08"}, - {file = "Sphinx-3.2.0-py3-none-any.whl", hash = "sha256:f7db5b76c42c8b5ef31853c2de7178ef378b985d7793829ec071e120dac1d0ca"}, - {file = "Sphinx-3.2.0.tar.gz", hash = "sha256:cf2d5bc3c6c930ab0a1fbef3ad8a82994b1bf4ae923f8098a05c7e5516f07177"}, + {file = "Sphinx-3.2.1-py3-none-any.whl", hash = "sha256:ce6fd7ff5b215af39e2fcd44d4a321f6694b4530b6f2b2109b64d120773faea0"}, + {file = "Sphinx-3.2.1.tar.gz", hash = "sha256:321d6d9b16fa381a5306e5a0b76cd48ffbc588e6340059a729c6fdd66087e0e8"}, ] sphinx-issues = [ {file = "sphinx-issues-1.2.0.tar.gz", hash = "sha256:845294736c7ac4c09c706f13431f709e1164037cbb00f6bf623ae16eccf509f3"}, From b73ca90a16db69aa64e385e309af78930afea0e2 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Sun, 16 Aug 2020 10:14:16 -0500 Subject: [PATCH 29/31] ci: Remove travis --- .travis.yml | 65 ----------------------------------------------------- 1 file changed, 65 deletions(-) delete mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index b535b4f8125..00000000000 --- a/.travis.yml +++ /dev/null @@ -1,65 +0,0 @@ -language: python -sudo: false -dist: bionic # 18.04 -python: - - 2.7 - - 3.7 - - pypy3 -if: (type = push AND branch IN (master)) OR (type = pull_request) -env: - global: - - RETRY_TIMEOUT_SECONDS=15 - matrix: - - TMUX_VERSION=master - - TMUX_VERSION=3.0a - - TMUX_VERSION=2.9 - - TMUX_VERSION=2.8 - - TMUX_VERSION=2.8 - - TMUX_VERSION=2.7 - - TMUX_VERSION=2.6 - - TMUX_VERSION=2.5 - - TMUX_VERSION=2.4 - - TMUX_VERSION=2.3 - - TMUX_VERSION=2.2 - - TMUX_VERSION=2.1 - - TMUX_VERSION=2.0 - - TMUX_VERSION=1.9a - - TMUX_VERSION=1.8 -matrix: - finish_fast: true - allow_failures: - - env: TMUX_VERSION=master - - python: pypy3 -cache: - - pip - - apt - - directories: - - ~/source - - ~/build -before_install: - - pip install poetry - - poetry --version - - poetry version -install: - - poetry install -v -before_script: - - mkdir -p ~/source - - mkdir -p ~/build/tmux-$TMUX_VERSION - - if [[ ! -d ~/source/tmux-$TMUX_VERSION ]]; then git clone https://github.com/tmux/tmux.git ~/source/tmux-$TMUX_VERSION; fi - - cd ~/source/tmux-$TMUX_VERSION - - git checkout $TMUX_VERSION - - export PATH=$HOME/build/tmux-$TMUX_VERSION/bin:$PATH - - if [[ $TMUX_VERSION == "master" || ! $(tmux -V | grep $TMUX_VERSION) ]]; then sh autogen.sh; fi - - if [[ $TMUX_VERSION == "master" || ! $(tmux -V | grep $TMUX_VERSION) ]]; then ./configure --prefix=$HOME/build/tmux-$TMUX_VERSION && make && make install; fi - - cd $TRAVIS_BUILD_DIR - - tmux -V -script: - - poetry run py.test --cov - - make flake8 -addons: - apt: - packages: - - libevent-dev - - libncurses-dev -after_success: - - codecov From 54e20a3ac415482ce341e60efab06a6424dfd682 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Sun, 16 Aug 2020 10:13:52 -0500 Subject: [PATCH 30/31] build: Add gh action for testing (ported via libtmux) --- .github/workflows/tests.yml | 100 ++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 .github/workflows/tests.yml diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml new file mode 100644 index 00000000000..b077c871e27 --- /dev/null +++ b/.github/workflows/tests.yml @@ -0,0 +1,100 @@ +name: tests + +on: [push, pull_request] + +jobs: + build: + # Don't run twice for internal PRs from our own repo + if: github.event_name == 'push' || github.event.pull_request.head.repo.full_name != github.repository + + runs-on: ubuntu-latest + strategy: + matrix: + python-version: [ '2.7', '3.x' ] + tmux-version: [ '2.6', '2.7', '2.8', '3.0', 'master' ] + steps: + - uses: actions/checkout@v1 + + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v1 + with: + python-version: ${{ matrix.python-version }} + + - name: Get full Python version + id: full-python-version + shell: bash + run: echo ::set-output name=version::$(python -c "import sys; print('-'.join(str(v) for v in sys.version_info))") + + - name: Install poetry + run: | + curl -O -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py + python get-poetry.py -y + echo "::set-env name=PATH::$HOME/.poetry/bin:$PATH" + rm get-poetry.py + + - name: Get poetry cache paths from config + run: | + echo ::set-env name=poetry_cache_dir::$(poetry config --list | sed -n 's/.*cache-dir = //p' | sed -e 's/^"//' -e 's/"$//') + echo ::set-env name=poetry_virtualenvs_path::$(poetry config --list | sed -n 's/.*virtualenvs.path = .* # //p' | sed -e 's/^"//' -e 's/"$//') + + - name: Configure poetry + shell: bash + run: poetry config virtualenvs.in-project true + + - name: Set up poetry cache + uses: actions/cache@v2 + id: cache + with: + path: | + .venv + {{ env.poetry_cache_dir }} + {{ env.poetry_virtualenvs_path }} + key: venv-${{ runner.os }}-${{ steps.full-python-version.outputs.version }}-${{ hashFiles('**/poetry.lock') }} + + - name: Ensure cache is healthy + if: steps.cache.outputs.cache-hit == 'true' + shell: bash + run: poetry run pip --version >/dev/null 2>&1 || rm -rf .venv + + - name: Setup tmux build cache for tmux ${{ matrix.tmux-version }} + id: tmux-build-cache + uses: actions/cache@v1 + with: + path: ~/tmux-builds/tmux-${{ matrix.tmux-version }} + key: tmux-${{ matrix.tmux-version }} + + - name: Build tmux ${{ matrix.tmux-version }} + if: steps.tmux-build-cache.outputs.cache-hit != 'true' + run: | + sudo apt install libevent-dev libncurses5-dev libtinfo-dev libutempter-dev bison + mkdir ~/tmux-builds + mkdir ~/tmux-src + git clone https://github.com/tmux/tmux.git ~/tmux-src/tmux-${{ matrix.tmux-version }} + cd ~/tmux-src/tmux-${{ matrix.tmux-version }} + git checkout ${{ matrix.tmux-version }} + sh autogen.sh + ./configure --prefix=$HOME/tmux-builds/tmux-${{ matrix.tmux-version }} && make && make install + export PATH=$HOME/tmux-builds/tmux-${{ matrix.tmux-version }}/bin:$PATH + cd ~ + tmux -V + + - name: Upgrade pip + shell: bash + run: poetry run python -m pip install pip -U + + - name: Install python dependencies + run: | + poetry install -E "test coverage lint" + - name: Lint with flake8 + run: | + poetry run flake8 + - name: Test with pytest + continue-on-error: ${{ matrix.tmux-version == 'master' }} + run: | + export PATH=$HOME/tmux-builds/tmux-${{ matrix.tmux-version }}/bin:$PATH + ls $HOME/tmux-builds/tmux-${{ matrix.tmux-version }}/bin + tmux -V + poetry run py.test --cov=./ --cov-report=xml + - uses: codecov/codecov-action@v1 + with: + token: ${{ secrets.CODECOV_TOKEN }} From 06454a35100f4de699d943e8294aa95db29238b5 Mon Sep 17 00:00:00 2001 From: Tony Narlock Date: Sun, 16 Aug 2020 10:40:13 -0500 Subject: [PATCH 31/31] docs(CHANGES): Update --- CHANGES | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGES b/CHANGES index babc6a3afab..d91236054ba 100644 --- a/CHANGES +++ b/CHANGES @@ -9,6 +9,8 @@ current - :issue:`623` Move docs from RTD to self-serve site - :issue:`623` Modernize Makefiles - :issue:`623` New development docs +- :issue:`623` Move doc -> docs +- :issue:`623` Move tests to GitHub Actions - :issue:`623` Update pyproject.toml to experiment with poetry packaging - :issue:`619` isort 5