1 Commits

Author SHA1 Message Date
ddc141007d Merge b7244ad400 into 1f41f4b35a 2024-11-19 21:58:34 +01:00
2 changed files with 8 additions and 11 deletions

View File

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

View File

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