| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- defmodule Toy.MixProject do
- use Mix.Project
- def project do
- [
- app: :toy,
- version: from_file(),
- elixir: "~> 1.7",
- elixirc_paths: elixirc_paths(Mix.env()),
- compilers: [:phoenix, :gettext] ++ Mix.compilers(),
- start_permanent: Mix.env() == :prod,
- aliases: aliases(),
- deps: deps()
- ]
- end
- # Configuration for the OTP application.
- #
- # Type `mix help compile.app` for more information.
- def application do
- [
- mod: {Toy.Application, []},
- extra_applications: [:logger, :runtime_tools]
- ]
- end
- # Specifies which paths to compile per environment.
- defp elixirc_paths(:test), do: ["lib", "config", "test/support"]
- defp elixirc_paths(_), do: ["lib", "config"]
- # Specifies your project dependencies.
- #
- # Type `mix help deps` for examples and options.
- defp deps do
- [
- {:phoenix, "~> 1.5.9"},
- {:phoenix_ecto, "~> 4.1"},
- {:ecto_sql, "~> 3.4"},
- {:postgrex, ">= 0.0.0"},
- {:phoenix_live_view, "~> 0.15.1"},
- {:floki, ">= 0.30.0", only: :test},
- {:phoenix_html, "~> 2.11"},
- {:phoenix_live_reload, "~> 1.2", only: :dev},
- {:phoenix_live_dashboard, "~> 0.4"},
- {:telemetry_metrics, "~> 0.4"},
- {:telemetry_poller, "~> 0.4"},
- {:gettext, "~> 0.11"},
- {:jason, "~> 1.0"},
- {:plug_cowboy, "~> 2.0"}
- ]
- end
- # Aliases are shortcuts or tasks specific to the current project.
- # For example, to install project dependencies and perform other setup tasks, run:
- #
- # $ mix setup
- #
- # See the documentation for `Mix` for more info on aliases.
- defp aliases do
- [
- setup: ["deps.get", "ecto.setup", "cmd npm install --prefix assets"],
- "ecto.setup": ["ecto.create", "ecto.migrate", "run priv/repo/seeds.exs"],
- "ecto.reset": ["ecto.drop", "ecto.setup"],
- test: ["ecto.create --quiet", "ecto.migrate --quiet", "test"],
- version: ["run -e \"Mix.Project.config[:version] |> IO.puts\""]
- ]
- end
- defp from_file(file \\ "VERSION") do
- with {:ok, described} <- File.read(file),
- {:ok, version} <- described |> String.trim() |> to_semver_string() do
- version
- end
- end
- defp to_semver_string(described) when is_binary(described) do
- with {:ok, _} <- described |> Version.parse(), do: {:ok, described}
- end
- end
|