Mix.Generator (Mix v1.19.0-dev)
View SourceConveniences for working with paths and generating content.
Summary
Functions
Copies source
to target
.
Evaluates and copy templates at source
to target
.
Creates a directory if one does not exist yet.
Creates a file with the given contents.
Embeds a template given by contents
into the current module.
Embeds a text given by contents
into the current module.
Prompts the user to overwrite the file if it exists.
Prompts the user to overwrite the file if it exists.
Functions
Copies source
to target
.
If target
already exists and the contents are not the same,
it asks for user confirmation.
Options
:force
- forces copying without a shell prompt:quiet
- does not log command output
Examples
iex> Mix.Generator.copy_file("source/gitignore", ".gitignore")
* creating .gitignore
true
Evaluates and copy templates at source
to target
.
The template in source
is evaluated with the given assigns
.
If target
already exists and the contents are not the same,
it asks for user confirmation.
Options
:force
- forces copying without a shell prompt:quiet
- does not log command output:format_elixir
(since v1.18.0) - iftrue
, apply formatter to the generated file
Examples
iex> assigns = [project_path: "/Users/joe/newproject"]
iex> Mix.Generator.copy_template("source/gitignore", ".gitignore", assigns)
* creating .gitignore
true
Creates a directory if one does not exist yet.
This function does nothing if the given directory already exists; in this case, it still logs the directory creation.
Options
:quiet
- does not log command output
Examples
iex> Mix.Generator.create_directory("path/to/dir")
* creating path/to/dir
true
Creates a file with the given contents.
If the file already exists and the contents are not the same, it asks for user confirmation.
Options
:force
- forces creation without a shell prompt:quiet
- does not log command output
Examples
iex> Mix.Generator.create_file(".gitignore", "_build\ndeps\n")
* creating .gitignore
true
Embeds a template given by contents
into the current module.
It will define a private function with the name
followed by
_template
that expects assigns as arguments.
This function must be invoked passing a keyword list.
Each key in the keyword list can be accessed in the
template using the @
macro.
For more information, check EEx.SmartEngine
.
Examples
defmodule Mix.Tasks.MyTask do
require Mix.Generator
Mix.Generator.embed_template(:log, "Log: <%= @log %>")
end
Embeds a text given by contents
into the current module.
It will define a private function with the name
followed by
_text
that expects no arguments.
Examples
defmodule Mix.Tasks.MyTask do
require Mix.Generator
Mix.Generator.embed_text(:error, "There was an error!")
end
Prompts the user to overwrite the file if it exists.
Returns false
if the file exists and the user forbade
to override it. Returns true
otherwise.
Prompts the user to overwrite the file if it exists.
The contents are compared to avoid asking the user to
override if the contents did not change. Returns false
if the file exists and the content is the same or the
user forbade to override it. Returns true
otherwise.