diff options
author | rinpatch <rinpatch@sdf.org> | 2019-06-21 06:41:13 +0300 |
---|---|---|
committer | rinpatch <rinpatch@sdf.org> | 2019-06-21 06:41:13 +0300 |
commit | d55358f3705c34510f5ec1d9cef7ab3b0f11ed2f (patch) | |
tree | 2a6018046d37201c6d0236a0ea23ffabbeb86d5c /lib/mix/pleroma.ex | |
parent | 4bec121798218f8abf8d2915fa7c26ccb23a4f4a (diff) | |
parent | 2437f5128407bbcdfc152ea3f008d7eecc1728f2 (diff) | |
download | pleroma-d55358f3705c34510f5ec1d9cef7ab3b0f11ed2f.tar.gz pleroma-d55358f3705c34510f5ec1d9cef7ab3b0f11ed2f.zip |
Merge branch 'develop' into release-docs
Diffstat (limited to 'lib/mix/pleroma.ex')
-rw-r--r-- | lib/mix/pleroma.ex | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/lib/mix/pleroma.ex b/lib/mix/pleroma.ex new file mode 100644 index 000000000..548c8a0a4 --- /dev/null +++ b/lib/mix/pleroma.ex @@ -0,0 +1,63 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2018 Pleroma Authors <https://pleroma.social/> +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Mix.Pleroma do + @doc "Common functions to be reused in mix tasks" + def start_pleroma do + Application.put_env(:phoenix, :serve_endpoints, false, persistent: true) + {:ok, _} = Application.ensure_all_started(:pleroma) + end + + def get_option(options, opt, prompt, defval \\ nil, defname \\ nil) do + Keyword.get(options, opt) || shell_prompt(prompt, defval, defname) + end + + def shell_prompt(prompt, defval \\ nil, defname \\ nil) do + prompt_message = "#{prompt} [#{defname || defval}] " + + input = + if mix_shell?(), + do: Mix.shell().prompt(prompt_message), + else: :io.get_line(prompt_message) + + case input do + "\n" -> + case defval do + nil -> + shell_prompt(prompt, defval, defname) + + defval -> + defval + end + + input -> + String.trim(input) + end + end + + def shell_yes?(message) do + if mix_shell?(), + do: Mix.shell().yes?("Continue?"), + else: shell_prompt(message, "Continue?") in ~w(Yn Y y) + end + + def shell_info(message) do + if mix_shell?(), + do: Mix.shell().info(message), + else: IO.puts(message) + end + + def shell_error(message) do + if mix_shell?(), + do: Mix.shell().error(message), + else: IO.puts(:stderr, message) + end + + @doc "Performs a safe check whether `Mix.shell/0` is available (does not raise if Mix is not loaded)" + def mix_shell?, do: :erlang.function_exported(Mix, :shell, 0) + + def escape_sh_path(path) do + ~S(') <> String.replace(path, ~S('), ~S(\')) <> ~S(') + end +end |