defmodule Mix.Tasks.Ecto.Create do use Mix.Task import Mix.Ecto @shortdoc "Creates the repository storage" @switches [ quiet: :boolean, repo: [:string, :keep], no_compile: :boolean, no_deps_check: :boolean ] @aliases [ r: :repo, q: :quiet ] @moduledoc """ Create the storage for the given repository. The repositories to create are the ones specified under the `:ecto_repos` option in the current app configuration. However, if the `-r` option is given, it replaces the `:ecto_repos` config. Since Ecto tasks can only be executed once, if you need to create multiple repositories, set `:ecto_repos` accordingly or pass the `-r` flag multiple times. ## Examples $ mix ecto.create $ mix ecto.create -r Custom.Repo ## Command line options * `-r`, `--repo` - the repo to create * `--quiet` - do not log output * `--no-compile` - do not compile before creating * `--no-deps-check` - do not compile before creating """ @impl true def run(args) do repos = parse_repo(args) {opts, _} = OptionParser.parse!(args, strict: @switches, aliases: @aliases) Enum.each(repos, fn repo -> ensure_repo(repo, args) ensure_implements( repo.__adapter__(), Ecto.Adapter.Storage, "create storage for #{inspect(repo)}" ) case repo.__adapter__().storage_up(repo.config()) do :ok -> unless opts[:quiet] do Mix.shell().info("The database for #{inspect(repo)} has been created") end {:error, :already_up} -> unless opts[:quiet] do Mix.shell().info("The database for #{inspect(repo)} has already been created") end {:error, term} when is_binary(term) -> Mix.raise("The database for #{inspect(repo)} couldn't be created: #{term}") {:error, term} -> Mix.raise("The database for #{inspect(repo)} couldn't be created: #{inspect(term)}") end end) end end