index : pandoc | |
Hex package with a file-watcher and Mix task for using Pandoc to convert Markdown files to HTML. |
aboutsummaryrefslogtreecommitdiff |
diff options
-rw-r--r-- | lib/mix/tasks/pandoc.ex | 18 | ||||
-rw-r--r-- | lib/pandoc.ex | 6 | ||||
-rw-r--r-- | lib/pandoc/watcher.ex | 2 | ||||
-rw-r--r-- | mix.exs | 5 | ||||
-rw-r--r-- | mix.lock | 9 |
5 files changed, 26 insertions, 14 deletions
diff --git a/lib/mix/tasks/pandoc.ex b/lib/mix/tasks/pandoc.ex index 4da8bf1..94d7dd5 100644 --- a/lib/mix/tasks/pandoc.ex +++ b/lib/mix/tasks/pandoc.ex @@ -1,6 +1,8 @@ defmodule Mix.Tasks.Pandoc do use Mix.Task + @ext ".md" + @impl true def run(args) do switches = [runtime_config: :boolean] @@ -17,15 +19,17 @@ defmodule Mix.Tasks.Pandoc do install_and_run(remaining_args) end - defp install_and_run([profile | args] = _all) do - IO.puts("mix task args #{inspect(args)}") + defp install_and_run([profile | _args] = all) do + IO.puts("Converting markdown...") - "documents" - |> File.ls!() - |> Enum.each(fn path -> - all = [profile, path] + profile = String.to_atom(profile) + config = Application.get_env(:pandoc, profile) - case Pandoc.run(String.to_atom(profile), [path]) do + (config[:cd] || File.cwd!()) + |> Path.join("*#{@ext}") + |> Path.wildcard() + |> Enum.each(fn path -> + case Pandoc.run(profile, Path.basename(path)) do 0 -> :ok status -> Mix.raise("`mix pandoc #{Enum.join(all, " ")}` exited with #{status}") end diff --git a/lib/pandoc.ex b/lib/pandoc.ex index 57606da..882d772 100644 --- a/lib/pandoc.ex +++ b/lib/pandoc.ex @@ -23,7 +23,7 @@ defmodule Pandoc do end end - def run(profile, extra_args) do + def run(profile, path) do config = Application.get_env(:pandoc, profile) args = config[:args] || [] @@ -33,8 +33,6 @@ defmodule Pandoc do stderr_to_stdout: true ] - [path] = extra_args - args = List.update_at(args, -1, fn v -> Path.join( @@ -46,6 +44,6 @@ defmodule Pandoc do ) end) - "pandoc" |> System.cmd(args ++ extra_args, opts) |> elem(1) + "pandoc" |> System.cmd(args ++ [path], opts) |> elem(1) end end diff --git a/lib/pandoc/watcher.ex b/lib/pandoc/watcher.ex index c67ae26..304bb50 100644 --- a/lib/pandoc/watcher.ex +++ b/lib/pandoc/watcher.ex @@ -15,7 +15,7 @@ defmodule Pandoc.Watcher do def handle_info({:file_event, watcher_pid, {path, events}}, %{watcher_pid: watcher_pid} = state) do case {Path.extname(path), :closed in events} do - {@ext, true} -> Pandoc.run(state[:profile], [path]) + {@ext, true} -> Pandoc.run(state[:profile], path) _ -> nil end @@ -8,7 +8,7 @@ defmodule Pandoc.MixProject do elixir: "~> 1.14", deps: deps(), description: "Pandoc", - package: [] + package: [links: [], licenses: ["MIT"]] ] end @@ -23,7 +23,8 @@ defmodule Pandoc.MixProject do # Run "mix help deps" to learn about dependencies. defp deps do [ - {:file_system, "~> 1.0"} + {:file_system, "~> 1.0"}, + {:ex_doc, ">= 0.0.0", only: :dev, runtime: false} ] end end diff --git a/mix.lock b/mix.lock new file mode 100644 index 0000000..d2090ab --- /dev/null +++ b/mix.lock @@ -0,0 +1,9 @@ +%{ + "earmark_parser": {:hex, :earmark_parser, "1.4.41", "ab34711c9dc6212dda44fcd20ecb87ac3f3fce6f0ca2f28d4a00e4154f8cd599", [:mix], [], "hexpm", "a81a04c7e34b6617c2792e291b5a2e57ab316365c2644ddc553bb9ed863ebefa"}, + "ex_doc": {:hex, :ex_doc, "0.35.1", "de804c590d3df2d9d5b8aec77d758b00c814b356119b3d4455e4b8a8687aecaf", [:mix], [{:earmark_parser, "~> 1.4.39", [hex: :earmark_parser, repo: "hexpm", optional: false]}, {:makeup_c, ">= 0.1.0", [hex: :makeup_c, repo: "hexpm", optional: true]}, {:makeup_elixir, "~> 0.14 or ~> 1.0", [hex: :makeup_elixir, repo: "hexpm", optional: false]}, {:makeup_erlang, "~> 0.1 or ~> 1.0", [hex: :makeup_erlang, repo: "hexpm", optional: false]}, {:makeup_html, ">= 0.1.0", [hex: :makeup_html, repo: "hexpm", optional: true]}], "hexpm", "2121c6402c8d44b05622677b761371a759143b958c6c19f6558ff64d0aed40df"}, + "file_system": {:hex, :file_system, "1.0.1", "79e8ceaddb0416f8b8cd02a0127bdbababe7bf4a23d2a395b983c1f8b3f73edd", [:mix], [], "hexpm", "4414d1f38863ddf9120720cd976fce5bdde8e91d8283353f0e31850fa89feb9e"}, + "makeup": {:hex, :makeup, "1.2.1", "e90ac1c65589ef354378def3ba19d401e739ee7ee06fb47f94c687016e3713d1", [:mix], [{:nimble_parsec, "~> 1.4", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "d36484867b0bae0fea568d10131197a4c2e47056a6fbe84922bf6ba71c8d17ce"}, + "makeup_elixir": {:hex, :makeup_elixir, "1.0.0", "74bb8348c9b3a51d5c589bf5aebb0466a84b33274150e3b6ece1da45584afc82", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.2.3 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "49159b7d7d999e836bedaf09dcf35ca18b312230cf901b725a64f3f42e407983"}, + "makeup_erlang": {:hex, :makeup_erlang, "1.0.1", "c7f58c120b2b5aa5fd80d540a89fdf866ed42f1f3994e4fe189abebeab610839", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "8a89a1eeccc2d798d6ea15496a6e4870b75e014d1af514b1b71fa33134f57814"}, + "nimble_parsec": {:hex, :nimble_parsec, "1.4.0", "51f9b613ea62cfa97b25ccc2c1b4216e81df970acd8e16e8d1bdc58fef21370d", [:mix], [], "hexpm", "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"}, +} |