From c379059ff4d18c6c26bf463d6f0304af3ab4eede Mon Sep 17 00:00:00 2001
From: Magnus Walbeck <mw@mwalbeck.org>
Date: Mon, 10 Aug 2020 23:09:55 +0200
Subject: [PATCH] Rename project and remove logo

---
 .gitignore                        |   4 +-
 .vscode/extensions.json           |  15 +
 .vscode/settings.json             |   3 +
 README.md                         |  52 ++-
 logo/logo.ase                     | Bin 1053 -> 0 bytes
 logo/logo.png                     | Bin 2514 -> 0 bytes
 {podfox => podweasel}/__init__.py |  19 +-
 poetry.lock                       | 517 ++++++++++++++++++++++++++++++
 poetry.toml                       |   2 +
 pyproject.toml                    |  22 ++
 requirements.txt                  |   5 -
 setup.py                          |  25 --
 12 files changed, 589 insertions(+), 75 deletions(-)
 create mode 100644 .vscode/extensions.json
 create mode 100644 .vscode/settings.json
 delete mode 100644 logo/logo.ase
 delete mode 100644 logo/logo.png
 rename {podfox => podweasel}/__init__.py (97%)
 create mode 100644 poetry.lock
 create mode 100644 poetry.toml
 create mode 100644 pyproject.toml
 delete mode 100644 requirements.txt
 delete mode 100644 setup.py

diff --git a/.gitignore b/.gitignore
index 7c39684..1d17dae 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,3 +1 @@
-*.swp
-.vscode
-.virtualenv
\ No newline at end of file
+.venv
diff --git a/.vscode/extensions.json b/.vscode/extensions.json
new file mode 100644
index 0000000..d1a329d
--- /dev/null
+++ b/.vscode/extensions.json
@@ -0,0 +1,15 @@
+{
+	// See https://go.microsoft.com/fwlink/?LinkId=827846 to learn about workspace recommendations.
+	// Extension identifier format: ${publisher}.${name}. Example: vscode.csharp
+
+	// List of extensions which should be recommended for users of this workspace.
+	"recommendations": [
+		"bungcip.better-toml",
+		"ms-python.python",
+		"coenraads.bracket-pair-colorizer-2"
+	],
+	// List of extensions recommended by VS Code that should not be recommended for users of this workspace.
+	"unwantedRecommendations": [
+		
+	]
+}
diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 0000000..2edab25
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,3 @@
+{
+    "python.pythonPath": "./.venv/bin/python"
+}
diff --git a/README.md b/README.md
index e64d90a..923bd85 100644
--- a/README.md
+++ b/README.md
@@ -1,23 +1,10 @@
-# podfox - podcatching for the terminal.
-![podfox logo](https://raw.githubusercontent.com/brtmr/podfox/62a0a3e745185deee2ee92e1250034d65d863c21/logo/logo.png)
-
+# podweasel - podcatching for the terminal.
 
 A program for managing & catching podcasts from the terminal. 
 
-Work in Progress and unfinished. Use at your own risk.
-
-## Requirements
-requires feedparser, requests, colorama and tqdm
-
-```
-git clone https://github.com/mwalbeck/podfox.git
-cd podfox
-python3 setup.py install
-```
-
 ## Configuration
 
-podfox main configuration file is called `.podfox.json` and should be located in your home directory.
+podweasel main configuration file is called `.podweasel.json` and should be located in your home directory.
 Here is mine: 
 ```
 {
@@ -43,7 +30,7 @@ Here is mine:
 
 ## Directory Structure
 
-In podfox, every podcast is identified with its own `shortname`, which is restricted to lowercase-letters, numbers, and dashes. If the `shortname` is not specifically given during import, it will be derived from the title of the feed. The following shows a directory tree for such a setup, including two podcasts, each with its own feed.json file for bookkeeping.
+In podweasel, every podcast is identified with its own `shortname`, which is restricted to lowercase-letters, numbers, and dashes. If the `shortname` is not specifically given during import, it will be derived from the title of the feed. The following shows a directory tree for such a setup, including two podcasts, each with its own feed.json file for bookkeeping.
  
 ```
 + podcast-directory
@@ -62,36 +49,36 @@ In podfox, every podcast is identified with its own `shortname`, which is restri
 ```
 ## Usage:
 ```
-    podfox.py import <feed-url> [<shortname>]
-    podfox.py update [<shortname>]
-    podfox.py feeds
-    podfox.py episodes <shortname>
-    podfox.py download [<shortname> --how-many=<n>]
+    podweasel.py import <feed-url> [<shortname>]
+    podweasel.py update [<shortname>]
+    podweasel.py feeds
+    podweasel.py episodes <shortname>
+    podweasel.py download [<shortname> --how-many=<n>]
 ```
 ### Import 
 
 To import a new feed use: 
-`podfox.py import <feed-url> [<shortname>]`
+`podweasel.py import <feed-url> [<shortname>]`
 For example, to import the haskell cast feed:
 
-`podfox import http://www.haskellcast.com/feed.xml`
+`podweasel import http://www.haskellcast.com/feed.xml`
 To import the techsnap podcast, and to store the episodes to a specific folder `ts`, use 
 
 
-`podfox import http://feeds.feedburner.com/techsnapmp3 ts`
+`podweasel import http://feeds.feedburner.com/techsnapmp3 ts`
 
 
 ### Update
-`podfox update` will update all feeds (This does not include downloading any new episodes)
+`podweasel update` will update all feeds (This does not include downloading any new episodes)
 
-`podfox update <shortname>` will only update the feed associated with the given `shortname`
+`podweasel update <shortname>` will only update the feed associated with the given `shortname`
 
 ### Feeds 
 
-`podfox feeds` will give an overview over the imported pocasts, and their `shortname`s.
+`podweasel feeds` will give an overview over the imported pocasts, and their `shortname`s.
 In the example: 
 ```
-$ podfox feeds
+$ podweasel feeds
 title                                     |  shortname           
 ================================================================
 TechSNAP MP3                              |  ts                  
@@ -100,10 +87,10 @@ The Haskell Cast                          |  the-haskell-cast
 
 ### Episodes
 
-`podfox episodes <shortname>` will produce a list of episodes available for this podcast, and wether they have been downloaded yet.
+`podweasel episodes <shortname>` will produce a list of episodes available for this podcast, and wether they have been downloaded yet.
 
 ```
-$ podfox episodes ts
+$ podweasel episodes ts
 A Rip in NTP | TechSNAP 237               |  Not Downloaded      
 National Security Breaking Agency | Tech  |  Not Downloaded      
 Catching the Angler | TechSNAP 235        |  Not Downloaded      
@@ -118,7 +105,6 @@ Extortion Startups | TechSNAP 229         |  Not Downloaded
 
 ### Downloading
 
-`podfox download` will download `maxnum` not yet downloaded episodes for every feed (if possible.)
-
-`podfox download ts --how-many=3` will download the 3 newest techsnap podcasts that have not yet been downloaded. (Skipping newer, but already downloaded ones). If the `--how-many` parameter is omitted, the `maxnum` parameter from the configuration file is used instead.
+`podweasel download` will download `maxnum` not yet downloaded episodes for every feed (if possible.)
 
+`podweasel download ts --how-many=3` will download the 3 newest techsnap podcasts that have not yet been downloaded. (Skipping newer, but already downloaded ones). If the `--how-many` parameter is omitted, the `maxnum` parameter from the configuration file is used instead.
diff --git a/logo/logo.ase b/logo/logo.ase
deleted file mode 100644
index 80a613ab30dc554d145fa2654ceeef5b1815cd78..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1053
zcmcJNTTByK9ET5zF+RG!sL`P!;)TEhik0HnXs`on)o7y9R;z+sx|?b(!FERQ9*xyZ
zh$sq}7|SX|3!>nKplm`SxCDrmZRH|WsTgfqV=b**?D!*INPPDs^UZlW-}gT=vqK4a
z`A-O0M8b)Pgb+e9@Qg3f`1ZH#E>9$6_+#i#Yd0)2L_e%yzd8j%!bMBK)eDw`nTc^A
zza<HD=pw<cE196DsRSJHE(I^W*$8SL#e(7@Ex0!4PjJ)P2rzzmA}E#Sg0VY~f=cZx
zFuha&)oo6&wPzF*um~x&+yjpnoCI?;8Zd3kCNOW+Y4B!zJlM509kg@xAYZ%&JiRwo
z&|sF(u^S#64ntr9<f9$os75k+5sOk}q7i|pLmIjeg(BpPwFm+#kN`jAFhdI`gs?#s
zHf9pxVt+0qkjZ4-F5{m4qPRs92$>`zWKi%30`}il20nqI%-z){Z;G9Mc$aJ?y^nc)
z^!c%=Y}Oy1vgaojE~^QNIy_;z$}Uw~SIzToV?);{Z+N4`^7_O^w&(jPqjR&={hc5B
z#SJUygClO^4o^&Gnv&0PTMY%hG1~ZtS~h>C#ds|t<|H-ZG92RW+)wS>U2<K_SeWY8
zZq6x}ZMW*Z`MMNdaV{Z{o$zj<GMRPC<hE{e@7%&jqv_z@<N#A`q7FICDvo|EXX$~v
z*@G!Ab<$lwHS{22f3T%v##5@UqtZsDrQ?(o)2Kem8a|lqo<jReeKuomgMIf*c2-{o
zmp?Se^2H~fZK`cy-oGk%;-&OOpNje~e$YqL7nY`0%N-LH(O0>DgP-HhCPrJ?Vn^#$
zTH~r}*76Oh61DTcgbmRe$N9fpHyPEV_PWSDrcp`x-&SQ7JrKyw&pXfC+0KEy;5M5%
zZ++ESujHXU{B}EA%bh9d^pyG(MJ`p({3_`%t&l4MH8Q<RXW(0gA|wYM_zTn7+UmuM
zz_eojE$QP6y^b%gKt;2T^~r*UVKsjvt?@|t+jjR<ql$k)6*@YK{ikx@wcW8%&4wKo
z#;F_W-yGx&<&3l5T-VngRzp=jsbGAPjeHa5vq{)SO{e+)6#kj-mNYn-{_zWpzjr#4
Jl4WI|z5@A>p$Py0

diff --git a/logo/logo.png b/logo/logo.png
deleted file mode 100644
index f1b0424af55c08a8b5610f42021cebccea8911ea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2514
zcma)8Sx{346n!jVF+gcM0z;*!b#Sz3P+QS}3V}>nT9HjifP~5vEtv+?AhJewoj9nq
zBnn206$()ViGkpd1fjq<6v~pt3MK@L+0Xzc1OiF=Qp=RKI=+wh^XARH=bn4cx$oSe
zgI_qVabE)ffMaM#a1;Po+yb8%I~(u~K^)=@0QOfyg9BquUwbirkB}JW-YXqG60$j?
z1}6-NV#A-sC}SFtv3E<h`rUHAVvP!;ZD^)EM4yeekGsp?Qi+V6ZKhL_+^*r!0ZCh5
zcslniWy=!jak~8x`B(OSa$)f}CENE@tE*@iAfHa>AOL`Qb-jf%>LPG<eFzZjyb0K7
z_W|&}wfz~pBI^L_K+E-A93g_8XSlBor+Pc#Gqdr%1G>di*E|!oTuZAbeowvWuS#Bj
zSp*ged~>0axu_tmt4f!3V_8CLe?&gW^`_qzr>F7G$WjIB{;4z!Ql}V>P$kMDs7(Y}
z-F&{-DC6bgrNsqHdZsvzJ?g*Vt;NkK&An?n_=jSX4)5{HjYI0D2hgKBmfVNPadE@>
zi?`9oB;<Hx+voTn1~1iWzyF0#^@LJ#F)9cl!1LR1r23ZS45pAQ6T%&aqB9r2_NF*p
zfAg>_c+6Zl^Y}B9vqZ%>)7Q23WTUG`>vPITyO3fXJxVC7(Howf(qK2$Z}-ydq@ryj
z-n@a;yvkeo%{)^x>E-nF(@x)ZOcT1iLBZ-A!fKa(&A}qPVrXzIVx0zC5P~PoK-dd0
z+!5f^A`WP<Bzez=|K9xSzAM7mZPv~<e8!^wTgCWP+V6AU9X)zf9VWZZX+Ngt#`5sX
z<5T&gPbK*yQ~CJ6X@9KAZ!=HbBfVXxu70^Z!5|U6`(Y`VwEBVy&gj6%UI>G;MN5{A
zG2}?Rp|n6SJR3PGs;*KN^*rjoT&Et(DJ&d|OtLxFC_2&=@8ZFLw%P8<nOMd6oOX1i
zy<c#Gu38S&y6O{Nfx7u-p8$PcD4{Wwx>~)dxSECA6oN01XYz2+DhI`?(B-%hngur8
z)WI=sk4{LA=a3VSzT}x>6V*Om5QNiwkI7-b%s=Nc;_AU&n(wP?(hbm9_|7;QoB?+*
zEi}x-4GcATfuT^bc2i+x$`%wsP+Rt@_;z7BDkAsi>e`bKx+FJP?Eg^&dUGj{tb5ey
zi;2i=ut?nn?xSR7<Ex@zwIJLEqJk>XwyDf{xI-U4FAAAO%8NnzvS4Nibxopvu_9Id
z>1V@w$xr&MSqMtZ<sdS~7`!tk!=$V*y~|k%w`J9qDJ_Et0ySQLvzs5|>eSmJAFA5?
z|BPA<%#8a>VnYo>bhA54VtlO8<}4b^o2s}t6}kuqci4=G2$NM*TnLk4$tIU_77XrI
z1hJ&Pe_pvW09>uID-blE2398QhjH%XNLQX%c7yXO#upz7I(?-nr%|sH=`CsaSFHX)
zb<a_-<U`>qm<@3^$QuI$Cn&WeKDYlTeE&PxN;Xs7ji}5WHQJ4ZrNz~;rhUDWQ%z(I
zw~L;-LrR=`H`~_Xjszu`jxH{4as_Be-P-;25B6L#?uBBVhf&?zu0FY046~U?$$s~w
zMYUx<3W`$-Cb{`eXWwJ<#qc}8c3<#Pg__nu(x|i|jU)E~McyxH(XDl>0f}d5ev?Ar
z=_9`}ib_mlf5r1Rb&!YzuG@l_L(K#Jj80|(5p?!J;Hm^vCeWN?YSpdXIN<5Ol}<3|
z2nMb|1mW(1Jd>p-Sl;xpDufN!o{2F?tWuf!od5<xkbpc_c_Z)iSy}~w=`p6!j?g@@
zk|w>mJ2c+R7hB6k-NIidi<j1%Kcojkf<xVcMIa$6bZ}5yIru_-V4ayZy&BHMER_}u
z>st3fA^&nhT78TBVvnWO`5O=%7M~U$of$Z>Kmq-UGwS=0qH~dk4i`5z{P}wyR}MCc
xc^(U1&!D*jFxtW$+Pa}0G!DW7fWYVs-t{oGJy&|X6#Q2MLeU3<@1l~6{sdv{oudE%

diff --git a/podfox/__init__.py b/podweasel/__init__.py
similarity index 97%
rename from podfox/__init__.py
rename to podweasel/__init__.py
index 264fff2..763cb48 100755
--- a/podfox/__init__.py
+++ b/podweasel/__init__.py
@@ -1,17 +1,17 @@
 #!/usr/bin/env python3
-"""podfox - podcatcher for the terminal
+"""podweasel - podcatcher for the terminal
 
 
 Usage:
-    podfox.py import <feed-url> [<shortname>] [-c=<path>]
-    podfox.py update [<shortname>] [-c=<path>]
-    podfox.py feeds [-c=<path>]
-    podfox.py episodes <shortname> [-c=<path>]
-    podfox.py download [<shortname> --how-many=<n>] [-c=<path>]
-    podfox.py rename <shortname> <newname> [-c=<path>]
+    podweasel.py import <feed-url> [<shortname>] [-c=<path>]
+    podweasel.py update [<shortname>] [-c=<path>]
+    podweasel.py feeds [-c=<path>]
+    podweasel.py episodes <shortname> [-c=<path>]
+    podweasel.py download [<shortname> --how-many=<n>] [-c=<path>]
+    podweasel.py rename <shortname> <newname> [-c=<path>]
 
 Options:
-    -c --config=<path>    Specify an alternate config file [default: ~/.podfox.json]
+    -c --config=<path>    Specify an alternate config file [default: ~/.podweasel.json]
     -h --help     Show this help
 """
 # (C) 2015 Bastian Reitemeier
@@ -393,7 +393,7 @@ def download_single(folder, url, filename):
 
 def available_feeds():
     '''
-    podfox will save each feed to its own folder. Each folder should
+    podweasel will save each feed to its own folder. Each folder should
     contain a json configuration file describing which elements
     have been downloaded already, and how many will be kept.
     '''
@@ -531,5 +531,6 @@ def main():
     if arguments['rename']:
         rename(arguments['<shortname>'], arguments['<newname>'])
 
+
 if __name__ == "__main__":
     main()
diff --git a/poetry.lock b/poetry.lock
new file mode 100644
index 0000000..9fcbefe
--- /dev/null
+++ b/poetry.lock
@@ -0,0 +1,517 @@
+[[package]]
+category = "dev"
+description = "A small Python module for determining appropriate platform-specific dirs, e.g. a \"user data dir\"."
+name = "appdirs"
+optional = false
+python-versions = "*"
+version = "1.4.4"
+
+[[package]]
+category = "dev"
+description = "Atomic file writes."
+marker = "sys_platform == \"win32\""
+name = "atomicwrites"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "1.4.0"
+
+[[package]]
+category = "dev"
+description = "Classes Without Boilerplate"
+name = "attrs"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "19.3.0"
+
+[package.extras]
+azure-pipelines = ["coverage", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "zope.interface", "pytest-azurepipelines"]
+dev = ["coverage", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "zope.interface", "sphinx", "pre-commit"]
+docs = ["sphinx", "zope.interface"]
+tests = ["coverage", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "zope.interface"]
+
+[[package]]
+category = "dev"
+description = "The uncompromising code formatter."
+name = "black"
+optional = false
+python-versions = ">=3.6"
+version = "19.10b0"
+
+[package.dependencies]
+appdirs = "*"
+attrs = ">=18.1.0"
+click = ">=6.5"
+pathspec = ">=0.6,<1"
+regex = "*"
+toml = ">=0.9.4"
+typed-ast = ">=1.4.0"
+
+[package.extras]
+d = ["aiohttp (>=3.3.2)", "aiohttp-cors"]
+
+[[package]]
+category = "main"
+description = "Python package for providing Mozilla's CA Bundle."
+name = "certifi"
+optional = false
+python-versions = "*"
+version = "2020.6.20"
+
+[[package]]
+category = "main"
+description = "Universal encoding detector for Python 2 and 3"
+name = "chardet"
+optional = false
+python-versions = "*"
+version = "3.0.4"
+
+[[package]]
+category = "dev"
+description = "Composable command line interface toolkit"
+name = "click"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*"
+version = "7.1.2"
+
+[[package]]
+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 = "main"
+description = "Pythonic argument parser, that will make you smile"
+name = "docopt"
+optional = false
+python-versions = "*"
+version = "0.6.2"
+
+[[package]]
+category = "main"
+description = "Universal feed parser, handles RSS 0.9x, RSS 1.0, RSS 2.0, CDF, Atom 0.3, and Atom 1.0 feeds"
+name = "feedparser"
+optional = false
+python-versions = "*"
+version = "5.2.1"
+
+[[package]]
+category = "dev"
+description = "the modular source code checker: pep8 pyflakes and co"
+name = "flake8"
+optional = false
+python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,>=2.7"
+version = "3.8.3"
+
+[package.dependencies]
+mccabe = ">=0.6.0,<0.7.0"
+pycodestyle = ">=2.6.0a1,<2.7.0"
+pyflakes = ">=2.2.0,<2.3.0"
+
+[package.dependencies.importlib-metadata]
+python = "<3.8"
+version = "*"
+
+[[package]]
+category = "main"
+description = "Internationalized Domain Names in Applications (IDNA)"
+name = "idna"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "2.10"
+
+[[package]]
+category = "dev"
+description = "Read metadata from Python packages"
+marker = "python_version < \"3.8\""
+name = "importlib-metadata"
+optional = false
+python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7"
+version = "1.7.0"
+
+[package.dependencies]
+zipp = ">=0.5"
+
+[package.extras]
+docs = ["sphinx", "rst.linker"]
+testing = ["packaging", "pep517", "importlib-resources (>=1.3)"]
+
+[[package]]
+category = "dev"
+description = "McCabe checker, plugin for flake8"
+name = "mccabe"
+optional = false
+python-versions = "*"
+version = "0.6.1"
+
+[[package]]
+category = "dev"
+description = "More routines for operating on iterables, beyond itertools"
+name = "more-itertools"
+optional = false
+python-versions = ">=3.5"
+version = "8.4.0"
+
+[[package]]
+category = "dev"
+description = "Core utilities for Python packages"
+name = "packaging"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "20.4"
+
+[package.dependencies]
+pyparsing = ">=2.0.2"
+six = "*"
+
+[[package]]
+category = "dev"
+description = "Utility library for gitignore style pattern matching of file paths."
+name = "pathspec"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*"
+version = "0.8.0"
+
+[[package]]
+category = "dev"
+description = "plugin and hook calling mechanisms for python"
+name = "pluggy"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "0.13.1"
+
+[package.dependencies]
+[package.dependencies.importlib-metadata]
+python = "<3.8"
+version = ">=0.12"
+
+[package.extras]
+dev = ["pre-commit", "tox"]
+
+[[package]]
+category = "dev"
+description = "library with cross-python path, ini-parsing, io, code, log facilities"
+name = "py"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "1.9.0"
+
+[[package]]
+category = "dev"
+description = "Python style guide checker"
+name = "pycodestyle"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "2.6.0"
+
+[[package]]
+category = "dev"
+description = "passive checker of Python programs"
+name = "pyflakes"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*"
+version = "2.2.0"
+
+[[package]]
+category = "dev"
+description = "Python parsing module"
+name = "pyparsing"
+optional = false
+python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*"
+version = "2.4.7"
+
+[[package]]
+category = "dev"
+description = "pytest: simple powerful testing with Python"
+name = "pytest"
+optional = false
+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 = "*"
+
+[package.dependencies.importlib-metadata]
+python = "<3.8"
+version = ">=0.12"
+
+[package.extras]
+checkqa-mypy = ["mypy (v0.761)"]
+testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "requests", "xmlschema"]
+
+[[package]]
+category = "dev"
+description = "Alternative regular expression module, to replace re."
+name = "regex"
+optional = false
+python-versions = "*"
+version = "2020.7.14"
+
+[[package]]
+category = "main"
+description = "Python HTTP for Humans."
+name = "requests"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*"
+version = "2.24.0"
+
+[package.dependencies]
+certifi = ">=2017.4.17"
+chardet = ">=3.0.2,<4"
+idna = ">=2.5,<3"
+urllib3 = ">=1.21.1,<1.25.0 || >1.25.0,<1.25.1 || >1.25.1,<1.26"
+
+[package.extras]
+security = ["pyOpenSSL (>=0.14)", "cryptography (>=1.3.4)"]
+socks = ["PySocks (>=1.5.6,<1.5.7 || >1.5.7)", "win-inet-pton"]
+
+[[package]]
+category = "dev"
+description = "Python 2 and 3 compatibility utilities"
+name = "six"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*"
+version = "1.15.0"
+
+[[package]]
+category = "dev"
+description = "Python Library for Tom's Obvious, Minimal Language"
+name = "toml"
+optional = false
+python-versions = "*"
+version = "0.10.1"
+
+[[package]]
+category = "main"
+description = "Fast, Extensible Progress Meter"
+name = "tqdm"
+optional = false
+python-versions = ">=2.6, !=3.0.*, !=3.1.*"
+version = "4.48.2"
+
+[package.extras]
+dev = ["py-make (>=0.1.0)", "twine", "argopt", "pydoc-markdown"]
+
+[[package]]
+category = "dev"
+description = "a fork of Python 2 and 3 ast modules with type comment support"
+name = "typed-ast"
+optional = false
+python-versions = "*"
+version = "1.4.1"
+
+[[package]]
+category = "main"
+description = "HTTP library with thread-safe connection pooling, file post, and more."
+name = "urllib3"
+optional = false
+python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, <4"
+version = "1.25.10"
+
+[package.extras]
+brotli = ["brotlipy (>=0.6.0)"]
+secure = ["certifi", "cryptography (>=1.3.4)", "idna (>=2.0.0)", "pyOpenSSL (>=0.14)", "ipaddress"]
+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"
+name = "wcwidth"
+optional = false
+python-versions = "*"
+version = "0.2.5"
+
+[[package]]
+category = "dev"
+description = "Backport of pathlib-compatible object wrapper for zip files"
+marker = "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"]
+
+[metadata]
+content-hash = "b7bdc0271e75f0cd26a2b56cea4c0d2a6b6cf655e9a8c961445f2d256ee23bdf"
+lock-version = "1.0"
+python-versions = "^3.6"
+
+[metadata.files]
+appdirs = [
+    {file = "appdirs-1.4.4-py2.py3-none-any.whl", hash = "sha256:a841dacd6b99318a741b166adb07e19ee71a274450e68237b4650ca1055ab128"},
+    {file = "appdirs-1.4.4.tar.gz", hash = "sha256:7d5d0167b2b1ba821647616af46a749d1c653740dd0d2415100fe26e27afdf41"},
+]
+atomicwrites = [
+    {file = "atomicwrites-1.4.0-py2.py3-none-any.whl", hash = "sha256:6d1784dea7c0c8d4a5172b6c620f40b6e4cbfdf96d783691f2e1302a7b88e197"},
+    {file = "atomicwrites-1.4.0.tar.gz", hash = "sha256:ae70396ad1a434f9c7046fd2dd196fc04b12f9e91ffb859164193be8b6168a7a"},
+]
+attrs = [
+    {file = "attrs-19.3.0-py2.py3-none-any.whl", hash = "sha256:08a96c641c3a74e44eb59afb61a24f2cb9f4d7188748e76ba4bb5edfa3cb7d1c"},
+    {file = "attrs-19.3.0.tar.gz", hash = "sha256:f7b7ce16570fe9965acd6d30101a28f62fb4a7f9e926b3bbc9b61f8b04247e72"},
+]
+black = [
+    {file = "black-19.10b0-py36-none-any.whl", hash = "sha256:1b30e59be925fafc1ee4565e5e08abef6b03fe455102883820fe5ee2e4734e0b"},
+    {file = "black-19.10b0.tar.gz", hash = "sha256:c2edb73a08e9e0e6f65a0e6af18b059b8b1cdd5bef997d7a0b181df93dc81539"},
+]
+certifi = [
+    {file = "certifi-2020.6.20-py2.py3-none-any.whl", hash = "sha256:8fc0819f1f30ba15bdb34cceffb9ef04d99f420f68eb75d901e9560b8749fc41"},
+    {file = "certifi-2020.6.20.tar.gz", hash = "sha256:5930595817496dd21bb8dc35dad090f1c2cd0adfaf21204bf6732ca5d8ee34d3"},
+]
+chardet = [
+    {file = "chardet-3.0.4-py2.py3-none-any.whl", hash = "sha256:fc323ffcaeaed0e0a02bf4d117757b98aed530d9ed4531e3e15460124c106691"},
+    {file = "chardet-3.0.4.tar.gz", hash = "sha256:84ab92ed1c4d4f16916e05906b6b75a6c0fb5db821cc65e70cbd64a3e2a5eaae"},
+]
+click = [
+    {file = "click-7.1.2-py2.py3-none-any.whl", hash = "sha256:dacca89f4bfadd5de3d7489b7c8a566eee0d3676333fbb50030263894c38c0dc"},
+    {file = "click-7.1.2.tar.gz", hash = "sha256:d2b5255c7c6349bc1bd1e59e08cd12acbbd63ce649f2588755783aa94dfb6b1a"},
+]
+colorama = [
+    {file = "colorama-0.4.3-py2.py3-none-any.whl", hash = "sha256:7d73d2a99753107a36ac6b455ee49046802e59d9d076ef8e47b61499fa29afff"},
+    {file = "colorama-0.4.3.tar.gz", hash = "sha256:e96da0d330793e2cb9485e9ddfd918d456036c7149416295932478192f4436a1"},
+]
+docopt = [
+    {file = "docopt-0.6.2.tar.gz", hash = "sha256:49b3a825280bd66b3aa83585ef59c4a8c82f2c8a522dbe754a8bc8d08c85c491"},
+]
+feedparser = [
+    {file = "feedparser-5.2.1.tar.bz2", hash = "sha256:ce875495c90ebd74b179855449040003a1beb40cd13d5f037a0654251e260b02"},
+    {file = "feedparser-5.2.1.tar.gz", hash = "sha256:bd030652c2d08532c034c27fcd7c85868e7fa3cb2b17f230a44a6bbc92519bf9"},
+    {file = "feedparser-5.2.1.zip", hash = "sha256:cd2485472e41471632ed3029d44033ee420ad0b57111db95c240c9160a85831c"},
+]
+flake8 = [
+    {file = "flake8-3.8.3-py2.py3-none-any.whl", hash = "sha256:15e351d19611c887e482fb960eae4d44845013cc142d42896e9862f775d8cf5c"},
+    {file = "flake8-3.8.3.tar.gz", hash = "sha256:f04b9fcbac03b0a3e58c0ab3a0ecc462e023a9faf046d57794184028123aa208"},
+]
+idna = [
+    {file = "idna-2.10-py2.py3-none-any.whl", hash = "sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"},
+    {file = "idna-2.10.tar.gz", hash = "sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6"},
+]
+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"},
+]
+mccabe = [
+    {file = "mccabe-0.6.1-py2.py3-none-any.whl", hash = "sha256:ab8a6258860da4b6677da4bd2fe5dc2c659cff31b3ee4f7f5d64e79735b80d42"},
+    {file = "mccabe-0.6.1.tar.gz", hash = "sha256:dd8d182285a0fe56bace7f45b5e7d1a6ebcbf524e8f3bd87eb0f125271b8831f"},
+]
+more-itertools = [
+    {file = "more-itertools-8.4.0.tar.gz", hash = "sha256:68c70cc7167bdf5c7c9d8f6954a7837089c6a36bf565383919bb595efb8a17e5"},
+    {file = "more_itertools-8.4.0-py3-none-any.whl", hash = "sha256:b78134b2063dd214000685165d81c154522c3ee0a1c0d4d113c80361c234c5a2"},
+]
+packaging = [
+    {file = "packaging-20.4-py2.py3-none-any.whl", hash = "sha256:998416ba6962ae7fbd6596850b80e17859a5753ba17c32284f67bfff33784181"},
+    {file = "packaging-20.4.tar.gz", hash = "sha256:4357f74f47b9c12db93624a82154e9b120fa8293699949152b22065d556079f8"},
+]
+pathspec = [
+    {file = "pathspec-0.8.0-py2.py3-none-any.whl", hash = "sha256:7d91249d21749788d07a2d0f94147accd8f845507400749ea19c1ec9054a12b0"},
+    {file = "pathspec-0.8.0.tar.gz", hash = "sha256:da45173eb3a6f2a5a487efba21f050af2b41948be6ab52b6a1e3ff22bb8b7061"},
+]
+pluggy = [
+    {file = "pluggy-0.13.1-py2.py3-none-any.whl", hash = "sha256:966c145cd83c96502c3c3868f50408687b38434af77734af1e9ca461a4081d2d"},
+    {file = "pluggy-0.13.1.tar.gz", hash = "sha256:15b2acde666561e1298d71b523007ed7364de07029219b604cf808bfa1c765b0"},
+]
+py = [
+    {file = "py-1.9.0-py2.py3-none-any.whl", hash = "sha256:366389d1db726cd2fcfc79732e75410e5fe4d31db13692115529d34069a043c2"},
+    {file = "py-1.9.0.tar.gz", hash = "sha256:9ca6883ce56b4e8da7e79ac18787889fa5206c79dcc67fb065376cd2fe03f342"},
+]
+pycodestyle = [
+    {file = "pycodestyle-2.6.0-py2.py3-none-any.whl", hash = "sha256:2295e7b2f6b5bd100585ebcb1f616591b652db8a741695b3d8f5d28bdc934367"},
+    {file = "pycodestyle-2.6.0.tar.gz", hash = "sha256:c58a7d2815e0e8d7972bf1803331fb0152f867bd89adf8a01dfd55085434192e"},
+]
+pyflakes = [
+    {file = "pyflakes-2.2.0-py2.py3-none-any.whl", hash = "sha256:0d94e0e05a19e57a99444b6ddcf9a6eb2e5c68d3ca1e98e90707af8152c90a92"},
+    {file = "pyflakes-2.2.0.tar.gz", hash = "sha256:35b2d75ee967ea93b55750aa9edbbf72813e06a66ba54438df2cfac9e3c27fc8"},
+]
+pyparsing = [
+    {file = "pyparsing-2.4.7-py2.py3-none-any.whl", hash = "sha256:ef9d7589ef3c200abe66653d3f1ab1033c3c419ae9b9bdb1240a85b024efc88b"},
+    {file = "pyparsing-2.4.7.tar.gz", hash = "sha256:c203ec8783bf771a155b207279b9bccb8dea02d8f0c9e5f8ead507bc3246ecc1"},
+]
+pytest = [
+    {file = "pytest-5.4.3-py3-none-any.whl", hash = "sha256:5c0db86b698e8f170ba4582a492248919255fcd4c79b1ee64ace34301fb589a1"},
+    {file = "pytest-5.4.3.tar.gz", hash = "sha256:7979331bfcba207414f5e1263b5a0f8f521d0f457318836a7355531ed1a4c7d8"},
+]
+regex = [
+    {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"},
+    {file = "requests-2.24.0.tar.gz", hash = "sha256:b3559a131db72c33ee969480840fff4bb6dd111de7dd27c8ee1f820f4f00231b"},
+]
+six = [
+    {file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"},
+    {file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"},
+]
+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.48.2-py2.py3-none-any.whl", hash = "sha256:1a336d2b829be50e46b84668691e0a2719f26c97c62846298dd5ae2937e4d5cf"},
+    {file = "tqdm-4.48.2.tar.gz", hash = "sha256:564d632ea2b9cb52979f7956e093e831c28d441c11751682f84c86fc46e4fd21"},
+]
+typed-ast = [
+    {file = "typed_ast-1.4.1-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:73d785a950fc82dd2a25897d525d003f6378d1cb23ab305578394694202a58c3"},
+    {file = "typed_ast-1.4.1-cp35-cp35m-manylinux1_x86_64.whl", hash = "sha256:aaee9905aee35ba5905cfb3c62f3e83b3bec7b39413f0a7f19be4e547ea01ebb"},
+    {file = "typed_ast-1.4.1-cp35-cp35m-win32.whl", hash = "sha256:0c2c07682d61a629b68433afb159376e24e5b2fd4641d35424e462169c0a7919"},
+    {file = "typed_ast-1.4.1-cp35-cp35m-win_amd64.whl", hash = "sha256:4083861b0aa07990b619bd7ddc365eb7fa4b817e99cf5f8d9cf21a42780f6e01"},
+    {file = "typed_ast-1.4.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:269151951236b0f9a6f04015a9004084a5ab0d5f19b57de779f908621e7d8b75"},
+    {file = "typed_ast-1.4.1-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:24995c843eb0ad11a4527b026b4dde3da70e1f2d8806c99b7b4a7cf491612652"},
+    {file = "typed_ast-1.4.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:fe460b922ec15dd205595c9b5b99e2f056fd98ae8f9f56b888e7a17dc2b757e7"},
+    {file = "typed_ast-1.4.1-cp36-cp36m-win32.whl", hash = "sha256:4e3e5da80ccbebfff202a67bf900d081906c358ccc3d5e3c8aea42fdfdfd51c1"},
+    {file = "typed_ast-1.4.1-cp36-cp36m-win_amd64.whl", hash = "sha256:249862707802d40f7f29f6e1aad8d84b5aa9e44552d2cc17384b209f091276aa"},
+    {file = "typed_ast-1.4.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:8ce678dbaf790dbdb3eba24056d5364fb45944f33553dd5869b7580cdbb83614"},
+    {file = "typed_ast-1.4.1-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:c9e348e02e4d2b4a8b2eedb48210430658df6951fa484e59de33ff773fbd4b41"},
+    {file = "typed_ast-1.4.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:bcd3b13b56ea479b3650b82cabd6b5343a625b0ced5429e4ccad28a8973f301b"},
+    {file = "typed_ast-1.4.1-cp37-cp37m-win32.whl", hash = "sha256:d5d33e9e7af3b34a40dc05f498939f0ebf187f07c385fd58d591c533ad8562fe"},
+    {file = "typed_ast-1.4.1-cp37-cp37m-win_amd64.whl", hash = "sha256:0666aa36131496aed8f7be0410ff974562ab7eeac11ef351def9ea6fa28f6355"},
+    {file = "typed_ast-1.4.1-cp38-cp38-macosx_10_15_x86_64.whl", hash = "sha256:d205b1b46085271b4e15f670058ce182bd1199e56b317bf2ec004b6a44f911f6"},
+    {file = "typed_ast-1.4.1-cp38-cp38-manylinux1_i686.whl", hash = "sha256:6daac9731f172c2a22ade6ed0c00197ee7cc1221aa84cfdf9c31defeb059a907"},
+    {file = "typed_ast-1.4.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:498b0f36cc7054c1fead3d7fc59d2150f4d5c6c56ba7fb150c013fbc683a8d2d"},
+    {file = "typed_ast-1.4.1-cp38-cp38-win32.whl", hash = "sha256:715ff2f2df46121071622063fc7543d9b1fd19ebfc4f5c8895af64a77a8c852c"},
+    {file = "typed_ast-1.4.1-cp38-cp38-win_amd64.whl", hash = "sha256:fc0fea399acb12edbf8a628ba8d2312f583bdbdb3335635db062fa98cf71fca4"},
+    {file = "typed_ast-1.4.1-cp39-cp39-macosx_10_15_x86_64.whl", hash = "sha256:d43943ef777f9a1c42bf4e552ba23ac77a6351de620aa9acf64ad54933ad4d34"},
+    {file = "typed_ast-1.4.1.tar.gz", hash = "sha256:8c8aaad94455178e3187ab22c8b01a3837f8ee50e09cf31f1ba129eb293ec30b"},
+]
+urllib3 = [
+    {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"},
+    {file = "wcwidth-0.2.5.tar.gz", hash = "sha256:c4d647b99872929fdb7bdcaa4fbe7f01413ed3d98077df798530e5b04f116c83"},
+]
+zipp = [
+    {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/poetry.toml b/poetry.toml
new file mode 100644
index 0000000..ab1033b
--- /dev/null
+++ b/poetry.toml
@@ -0,0 +1,2 @@
+[virtualenvs]
+in-project = true
diff --git a/pyproject.toml b/pyproject.toml
new file mode 100644
index 0000000..d80ea20
--- /dev/null
+++ b/pyproject.toml
@@ -0,0 +1,22 @@
+[tool.poetry]
+name = "podweasel"
+version = "0.1.0"
+description = ""
+authors = ["Magnus Walbeck <mw@mwalbeck.org>"]
+
+[tool.poetry.dependencies]
+python = "^3.6"
+requests = "^2.24.0"
+tqdm = "^4.48.2"
+feedparser = "^5.2.1"
+docopt = "^0.6.2"
+colorama = "^0.4.3"
+
+[tool.poetry.dev-dependencies]
+pytest = "^5.2"
+black = "^19.10b0"
+flake8 = "^3.8.3"
+
+[build-system]
+requires = ["poetry>=0.12"]
+build-backend = "poetry.masonry.api"
diff --git a/requirements.txt b/requirements.txt
deleted file mode 100644
index d36ccb2..0000000
--- a/requirements.txt
+++ /dev/null
@@ -1,5 +0,0 @@
-colorama>=0.3.7,<=0.3.9
-docopt==0.6.2
-feedparser==5.2.1
-requests>=2.11.1,<=2.18.1
-tqdm==4.14.0
\ No newline at end of file
diff --git a/setup.py b/setup.py
deleted file mode 100644
index 7b82ed9..0000000
--- a/setup.py
+++ /dev/null
@@ -1,25 +0,0 @@
-from setuptools import setup
-
-with open('requirements.txt') as f:
-    required = f.read().splitlines()
-
-setup(name='podfox',
-    version='0.1.3',
-    description='Podcatcher for the terminal',
-    url='https://github.com/mwalbeck/podfox',
-    license='GPLv3',
-    packages=['podfox'],
-    zip_safe=False,
-    entry_points={
-        'console_scripts': [
-            'podfox = podfox.__init__:main'
-        ]
-    },
-    install_requires=[
-        'colorama>=0.3.7,<=0.3.9',
-        'docopt==0.6.2',
-        'feedparser==5.2.1',
-        'requests>=2.11.1,<=2.18.1',
-        'tqdm==4.14.0',
-        ],
-    )