# Copyright (c) 2016 Andrew Nesbitt
# MIT License
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
# "Software"), to deal in the Software without restriction, including
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so, subject to
# the following conditions:
# The above copyright notice and this permission notice shall be
# included in all copies or substantial portions of the Software.
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
defmodule Hex.Encoder do
@moduledoc """
Provides map to json encoder
"""
@spec mixfile_json(map) :: charlist
def mixfile_json(dependencies) do
dependencies
|> libraries
|> Poison.encode!()
end
def mixfile_map(dependencies) do
dependencies
|> libraries
end
defp libraries(dependencies) do
dependencies |> Enum.reduce(%{}, &library/2)
end
defp library({name, version}, acc) when is_bitstring(version) do
Map.put(acc, name, version)
end
defp library({name, details}, acc) do
Map.put(acc, name, extract_version(details))
end
# defp library({_, _, [name, version, _]}, acc) do
# Map.put(acc, name, version)
# end
defp extract_version(details) do
item = Enum.into(details, %{})
Map.get(item, :tag) || Map.get(item, :branch) || "HEAD"
end
def lockfile_json(dependencies_full) do
dependencies_full
|> instruct()
|> Poison.encode!()
end
def lockfile_map(dependencies) do
dependencies
|> deps
end
defp instruct(deps) do
deps
|> Enum.map(fn {k, v} ->
create_library(k, elem(v, 2))
end)
end
defp create_library(name, [source_type, source_name, source_hash, dependencies]) do
%Hex.Library{
name: name,
source_name: source_name,
source_type: source_type,
source_hash: source_hash,
dependencies: simplify_lib_dependencies(dependencies)
}
end
defp create_library(name, [source_type, source_name, version, source_hash, type, dependencies]) do
%Hex.Library{
name: name,
source_name: source_name,
source_type: source_type,
version: version,
source_hash: source_hash,
type: type,
dependencies: simplify_lib_dependencies(dependencies)
}
end
defp create_library(name, [
source_type,
source_name,
version,
source_hash,
type,
dependencies,
repo,
repo_hash
]) do
%Hex.Library{
name: name,
source_name: source_name,
source_type: source_type,
version: version,
source_hash: source_hash,
type: type,
dependencies: simplify_lib_dependencies(dependencies),
repo: repo,
repo_hash: repo_hash
}
end
defp simplify_lib_dependencies(deps) do
deps
|> Enum.map(fn t ->
v = elem(t, 2)
%{
name: Enum.at(v, 0),
version: Enum.at(v, 1)
}
end)
end
defp deps(deps) do
deps
|> Enum.reduce(%{}, fn {source, lib, version}, acc ->
Map.put(acc, lib, %{source: source, version: version})
end)
end
end