2 Commits

Author SHA1 Message Date
cb2942f8b9 Merge fd6b58022d into 1f41f4b35a 2024-11-21 17:34:45 +01:00
fd6b58022d Review comments 2024-11-21 17:34:32 +01:00
2 changed files with 11 additions and 8 deletions

View File

@@ -1,4 +1,5 @@
import datetime
import time
import click
@@ -14,17 +15,19 @@ from . import days
default="-",
help="Problem input file",
)
@click.option("-t", "--time", is_flag=True, help="Print elapsed time afterwards")
@click.option("-t", "--time", "timing", is_flag=True, help="Print elapsed time afterwards")
@click.argument("day", required=True)
def main(day: int, time: bool, data: str) -> None:
def main(day: int, timing: bool, data: str) -> None:
runner_class = days.get_runner(day)
start = datetime.datetime.now()
start = time.perf_counter_ns()
part1, part2 = runner_class.run_both(data)
if time:
click.echo(f"Elapsed: {datetime.datetime.now() - start}", err=True)
if timing:
elapsed = time.perf_counter_ns() - start
delta = datetime.timedelta(microseconds=elapsed / 1000)
click.echo(f"Elapsed: {delta}", err=True)
click.echo(part1)
click.echo(part2)

View File

@@ -1,12 +1,12 @@
import importlib
from abc import ABC, abstractmethod
from typing import Any, Tuple, cast
from typing import Any, cast
class Runner(ABC):
@classmethod
@abstractmethod
def run_both(cls, data: str) -> Tuple[Any, Any]:
def run_both(cls, data: str) -> tuple[Any, Any]:
pass
@classmethod
@@ -22,7 +22,7 @@ class Runner(ABC):
class SeparateRunner(Runner):
@classmethod
def run_both(cls, data: str) -> Tuple[Any, Any]:
def run_both(cls, data: str) -> tuple[Any, Any]:
return (cls.part1(data), cls.part2(data))