feat: fetch input if not exists when solve
This commit is contained in:
parent
42b6917614
commit
f770a143eb
1 changed files with 25 additions and 7 deletions
|
@ -1,5 +1,6 @@
|
||||||
defmodule Mix.Tasks.AdventOfCode.Solve do
|
defmodule Mix.Tasks.AdventOfCode.Solve do
|
||||||
use Mix.Task
|
use Mix.Task
|
||||||
|
import Mix.AdventOfCode
|
||||||
|
|
||||||
@shortdoc "Runs solution code with problem input"
|
@shortdoc "Runs solution code with problem input"
|
||||||
|
|
||||||
|
@ -60,14 +61,31 @@ defmodule Mix.Tasks.AdventOfCode.Solve do
|
||||||
end
|
end
|
||||||
|
|
||||||
defp stream_for_input(selector, opts) do
|
defp stream_for_input(selector, opts) do
|
||||||
input = Keyword.get(opts, :input, selector)
|
case Keyword.fetch(opts, :input) do
|
||||||
|
{:ok, "-"} ->
|
||||||
if input == "-" do
|
|
||||||
{:indeterminate, IO.stream()}
|
{:indeterminate, IO.stream()}
|
||||||
else
|
|
||||||
file = Path.join("priv/inputs", "#{input}.input")
|
{:ok, name} ->
|
||||||
|
Path.join("priv/inputs", "#{name}.input")
|
||||||
|
|> get_size_and_stream()
|
||||||
|
|
||||||
|
:error ->
|
||||||
|
[day | _] = String.split(selector, ".")
|
||||||
|
|
||||||
|
file = day_input_path(day)
|
||||||
|
|
||||||
|
unless File.exists?(file) or
|
||||||
|
not Mix.shell().yes?("Input missing. Fetch input for day #{day}?") do
|
||||||
|
Mix.Task.run("advent_of_code.fetch_input", [day])
|
||||||
|
end
|
||||||
|
|
||||||
|
day_input_path(day)
|
||||||
|
|> get_size_and_stream()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def get_size_and_stream(file) do
|
||||||
stream = File.stream!(file)
|
stream = File.stream!(file)
|
||||||
{Enum.count(stream), stream}
|
{Enum.count(stream), stream}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
Loading…
Reference in a new issue