Shows into the first time a module is visted.

This commit is contained in:
Felipe Sere
2016-05-10 22:49:04 +01:00
parent 149cc47195
commit 3d79284aab
3 changed files with 27 additions and 7 deletions

View File

@@ -20,6 +20,18 @@ defmodule Display do
defp name("Elixir." <> module), do: module
defp name(module), do: name(Atom.to_string(module))
def intro(module) do
show_intro(module.intro)
module
end
defp show_intro(""), do: nil
defp show_intro(message) do
message <> "\n"
|> Colours.green
|> IO.puts
end
def show_failure(failure, module, name) do
IO.puts(format(failure, module, name))
end

View File

@@ -1,15 +1,15 @@
defmodule Execute do
def run_module(module, callback \\ fn(_result, _koan) -> nil end) do
def run_module(module, callback \\ fn(_result, _module, _koan) -> nil end) do
Enum.reduce_while(module.all_koans, :passed, fn(koan, _) ->
module
|> run_koan(koan)
|> hook(koan, callback)
|> hook(module, koan, callback)
|> continue?
end)
end
defp hook(result,koan, callback) do
callback.(result, koan)
defp hook(result, module, koan, callback) do
callback.(result, module, koan)
result
end

View File

@@ -17,6 +17,7 @@ defmodule Runner do
]
def koan?(koan), do: Enum.member?(@modules, koan)
def modules, do: @modules
def modules_to_run, do: Options.initial_koan |> modules_to_run
@@ -31,16 +32,23 @@ defmodule Runner do
def run_module(module) do
module
|> Execute.run_module(&track/2)
|> Execute.run_module(&track/3)
|> display
end
defp track(:passed, koan), do: Tracker.completed(koan)
defp track(_, _), do: nil
defp track(:passed, module, koan), do: Tracker.completed(module, koan)
defp track(_, _, _), do: nil
defp display({:failed, error, module, name}) do
intro(module, Tracker.summarize)
Display.show_failure(error, module, name)
:failed
end
defp display(_), do: :passed
defp intro(module, %{visited_modules: modules}) do
if ! module in modules do
Display.intro(module)
end
end
end