feat: solution generator
This commit is contained in:
parent
14ba910fa2
commit
375478d31b
3 changed files with 83 additions and 2 deletions
2021
|
@ -2,4 +2,12 @@ defmodule Mix.AdventOfCode do
|
||||||
@moduledoc """
|
@moduledoc """
|
||||||
Helpers for `AdventOfCode` mix tasks.
|
Helpers for `AdventOfCode` mix tasks.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
def day_module(day) do
|
||||||
|
Module.concat(AdventOfCode, Macro.camelize("Day#{day}"))
|
||||||
|
end
|
||||||
|
|
||||||
|
def part_module(day, part) do
|
||||||
|
Module.concat(day_module(day), Macro.camelize("Part#{part}"))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
defmodule Mix.Tasks.AdventOfCode.Gen.Solution do
|
defmodule Mix.Tasks.AdventOfCode.Gen.Solution do
|
||||||
use Mix.Task
|
use Mix.Task
|
||||||
import Mix.Generator
|
import Mix.Generator
|
||||||
|
import Mix.AdventOfCode
|
||||||
|
|
||||||
@shortdoc "Generate a new solution module"
|
@shortdoc "Generate a new solution module"
|
||||||
|
|
||||||
|
@ -15,7 +16,79 @@ defmodule Mix.Tasks.AdventOfCode.Gen.Solution do
|
||||||
$ mix advent_of_code.gen.solution 2
|
$ mix advent_of_code.gen.solution 2
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
@switches []
|
||||||
|
|
||||||
@impl Mix.Task
|
@impl Mix.Task
|
||||||
def run(_args) do
|
def run(args) do
|
||||||
|
case OptionParser.parse!(args, switches: @switches) do
|
||||||
|
{_, [day]} ->
|
||||||
|
day_module = day_module(day)
|
||||||
|
day_contents = day_template(mod: day_module) |> Code.format_string!()
|
||||||
|
day_path = Path.join("lib", Macro.underscore(day_module))
|
||||||
|
day_tests_path = Path.join("test", Macro.underscore(day_module))
|
||||||
|
day_file = "#{day_path}.ex"
|
||||||
|
|
||||||
|
create_directory(day_path)
|
||||||
|
create_directory(day_tests_path)
|
||||||
|
create_file(day_file, day_contents)
|
||||||
|
|
||||||
|
for part <- 1..2 do
|
||||||
|
part_module = part_module(day, part)
|
||||||
|
|
||||||
|
part_contents =
|
||||||
|
part_template(mod: part_module, day_mod: day_module) |> Code.format_string!()
|
||||||
|
|
||||||
|
part_file = Path.join("lib", "#{Macro.underscore(part_module)}.ex")
|
||||||
|
create_file(part_file, part_contents)
|
||||||
|
|
||||||
|
part_test_module = Module.concat(day_module, Macro.camelize("Part#{part}Test"))
|
||||||
|
|
||||||
|
part_test_contents =
|
||||||
|
part_test_template(mod: part_module, test_mod: part_test_module)
|
||||||
|
|> Code.format_string!()
|
||||||
|
|
||||||
|
part_test_file =
|
||||||
|
Path.join(day_tests_path, "#{Macro.underscore("part_#{part}_test")}.exs")
|
||||||
|
|
||||||
|
create_file(part_test_file, part_test_contents)
|
||||||
|
end
|
||||||
|
|
||||||
|
_ ->
|
||||||
|
Mix.raise("Unknown arguments.")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
embed_template(:day, ~S"""
|
||||||
|
defmodule <%= inspect(@mod) %> do
|
||||||
|
|
||||||
|
end
|
||||||
|
""")
|
||||||
|
|
||||||
|
embed_template(:part, ~S"""
|
||||||
|
defmodule <%= inspect(@mod) %> do
|
||||||
|
alias AdventOfCode.PuzzleSolver
|
||||||
|
use PuzzleSolver
|
||||||
|
|
||||||
|
import <%= inspect(@day_mod) %>, warn: false
|
||||||
|
|
||||||
|
@impl PuzzleSolver
|
||||||
|
def solve(_input_stream) do
|
||||||
|
:ok |> to_string()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
""")
|
||||||
|
|
||||||
|
embed_template(:part_test, ~S[
|
||||||
|
defmodule <%= inspect(@test_mod) %> do
|
||||||
|
use AdventOfCode.PuzzleCase, module: <%= inspect(@mod) %>
|
||||||
|
|
||||||
|
test "returns :ok" do
|
||||||
|
input = ~S"""
|
||||||
|
input
|
||||||
|
"""
|
||||||
|
|
||||||
|
assert_solution input, "ok"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
])
|
||||||
end
|
end
|
||||||
|
|
|
@ -15,7 +15,7 @@ defmodule AdventOfCode.MixProject do
|
||||||
# Run "mix help compile.app" to learn about applications.
|
# Run "mix help compile.app" to learn about applications.
|
||||||
def application do
|
def application do
|
||||||
[
|
[
|
||||||
extra_applications: [:logger]
|
extra_applications: [:logger, :eex]
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue