improved argument reading

This commit is contained in:
klemek
2020-04-27 21:02:55 +02:00
parent 4bb9bbb23a
commit 03fa2540e3
3 changed files with 36 additions and 8 deletions
+3 -8
View File
@@ -4,6 +4,7 @@ import os
from . import img_factory
from . import meme_db
from . import meme_otron
from . import utils
from . import VERSION
if __name__ == "__main__":
@@ -12,7 +13,7 @@ if __name__ == "__main__":
# TODO better arguments reading (-h, -o, -v)
if len(sys.argv) <= 1 or sys.argv[1].lower().strip() == "help" or "-h" in sys.argv:
if len(sys.argv) <= 1 or utils.read_argument(sys.argv, "help", "--help", "-h"):
print(f"Meme-Otron v{VERSION}"
"python -m meme_otron -h\n"
"python -m meme_otron (meme_id) \"[text 1]\" \"[text 2]\" ... > file.jpg\n"
@@ -20,13 +21,7 @@ if __name__ == "__main__":
file=sys.stderr)
sys.exit(1)
else:
output_file = None
if "-o" in sys.argv:
i = sys.argv.index("-o")
if len(sys.argv) >= i:
output_file = sys.argv[i + 1]
del sys.argv[i + 1]
del sys.argv[i]
output_file = utils.read_argument(sys.argv, "-o", "--output", valued=True, delete=True)
img = meme_otron.compute(*sys.argv[1:])
if img is None:
proposal = meme_db.find_nearest(sys.argv[1])
+18
View File
@@ -143,3 +143,21 @@ def safe_index(src: Union[str, list], pattern, start: int = 0):
return src.index(pattern, start)
except ValueError:
return None
def read_argument(args: List[str], *names: str, valued: bool = False, delete: bool = False):
for i, arg in enumerate(args):
if arg.lower() in names:
if delete:
del args[i]
i -= 1
if not valued:
return True
else:
v = None
if i + 1 < len(args):
v = args[i + 1]
if delete:
del args[i + 1]
return v
return None
+15
View File
@@ -128,3 +128,18 @@ class Test(TestCase):
self.assertEqual([5, 9, 15], utils.place_line_breaks([5.2, 14.3, 15.2], [3, 5, 9, 15, 18]))
self.assertEqual([5, 9, 15, 18], utils.place_line_breaks([5.2, 14.3, 14.5, 15.2], [3, 5, 9, 15, 18]))
self.assertEqual([5, 9, 15, 18], utils.place_line_breaks([5.2, 14.3, 14.5, 15.2], [3, 5, 9, 15, 18, 20]))
def test_read_argument(self):
self.assertIsNone(utils.read_argument(["test", "-o", "test"], "--output"))
self.assertTrue(utils.read_argument(["test", "-O", "test"], "--output", "-o"))
self.assertIsNone(utils.read_argument(["test", "-o"], "-o", valued=True))
self.assertEqual("test1", utils.read_argument(["test", "-o", "test1", "-o", "test2"], "-o", valued=True))
args = ["test", "-o", "test1"]
self.assertTrue(utils.read_argument(args, "-o", delete=True))
self.assertEqual(["test", "test1"], args)
args = ["test", "-o", "test1"]
self.assertEqual("test1", utils.read_argument(args, "-o", valued=True, delete=True))
self.assertEqual(["test"], args)
args = ["test", "-o"]
self.assertIsNone(utils.read_argument(args, "-o", valued=True, delete=True))
self.assertEqual(["test"], args)