diff options
| author | Ekaterina Vaartis <vaartis@cock.li> | 2019-04-18 15:32:18 +0300 | 
|---|---|---|
| committer | Ekaterina Vaartis <vaartis@cock.li> | 2019-04-20 11:17:17 +0300 | 
| commit | af5494f942636bc6d2baa2638502974ed8cb7846 (patch) | |
| tree | d68934bf68f2194eec3cf32c2c90c1ff16b2ead8 /lib/mix | |
| parent | 21b39c54a36c265fee89a9c2f2312ad925f82263 (diff) | |
| download | pleroma-af5494f942636bc6d2baa2638502974ed8cb7846.tar.gz pleroma-af5494f942636bc6d2baa2638502974ed8cb7846.zip | |
Separate emoji pack file lists in a different file
The file should be in the same directory as the manifest file
Diffstat (limited to 'lib/mix')
| -rw-r--r-- | lib/mix/tasks/pleroma/emoji.ex | 26 | 
1 files changed, 22 insertions, 4 deletions
| diff --git a/lib/mix/tasks/pleroma/emoji.ex b/lib/mix/tasks/pleroma/emoji.ex index 902bddc65..526b09b11 100644 --- a/lib/mix/tasks/pleroma/emoji.ex +++ b/lib/mix/tasks/pleroma/emoji.ex @@ -55,8 +55,9 @@ defmodule Mix.Tasks.Pleroma.Emoji do      {options, pack_names, []} = parse_global_opts(args) -    manifest = -      fetch_manifest(if options[:manifest], do: options[:manifest], else: @default_manifest) +    manifest_url = if options[:manifest], do: options[:manifest], else: @default_manifest + +    manifest = fetch_manifest(manifest_url)      for pack_name <- pack_names do        if Map.has_key?(manifest, pack_name) do @@ -77,6 +78,23 @@ defmodule Mix.Tasks.Pleroma.Emoji do          binary_archive = Tesla.get!(src_url).body +        # The url specified in files should be in the same directory +        files_url = Path.join(Path.dirname(manifest_url), pack["files"]) + +        IO.puts( +          IO.ANSI.format([ +            "Fetching the file list for ", +            :bright, +            pack_name, +            :normal, +            " from ", +            :underline, +            files_url +          ]) +        ) + +        files = Tesla.get!(files_url).body |> Poison.decode!() +          IO.puts(IO.ANSI.format(["Unpacking ", :bright, pack_name]))          static_path = Path.join(:code.priv_dir(:pleroma), "static") @@ -91,7 +109,7 @@ defmodule Mix.Tasks.Pleroma.Emoji do          files_to_unzip =            Enum.map( -            pack["files"], +            files,              fn {_, f} -> to_charlist(f) end            ) @@ -105,7 +123,7 @@ defmodule Mix.Tasks.Pleroma.Emoji do          emoji_txt_str =            Enum.map( -            pack["files"], +            files,              fn {shortcode, path} ->                "#{shortcode}, /instance/static/emoji/#{pack_name}/#{path}"              end | 
