Elixir Language
Módulos
Buscar..
Observaciones
Nombres de módulos
En Elixir, los nombres de módulos como IO o String son solo átomos debajo del capó y se convierten a la forma :"Elixir.ModuleName" en el momento de la compilación.
iex(1)> is_atom(IO)
true
iex(2)> IO == :"Elixir.IO"
true
Listar las funciones o macros de un módulo.
La función __info__/1 toma uno de los siguientes átomos:
-
:functions- Devuelve una lista de palabras clave de funciones públicas junto con sus aridades -
:macros- Devuelve una lista de palabras clave de macros públicas junto con sus aridades
Para enumerar las funciones del módulo Kernel :
iex> Kernel.__info__ :functions
[!=: 2, !==: 2, *: 2, +: 1, +: 2, ++: 2, -: 1, -: 2, --: 2, /: 2, <: 2, <=: 2,
==: 2, ===: 2, =~: 2, >: 2, >=: 2, abs: 1, apply: 2, apply: 3, binary_part: 3,
bit_size: 1, byte_size: 1, div: 2, elem: 2, exit: 1, function_exported?: 3,
get_and_update_in: 3, get_in: 2, hd: 1, inspect: 1, inspect: 2, is_atom: 1,
is_binary: 1, is_bitstring: 1, is_boolean: 1, is_float: 1, is_function: 1,
is_function: 2, is_integer: 1, is_list: 1, is_map: 1, is_number: 1, is_pid: 1,
is_port: 1, is_reference: 1, is_tuple: 1, length: 1, macro_exported?: 3,
make_ref: 0, ...]
Reemplace el Kernel con cualquier módulo de su elección.
Utilizando modulos
Los módulos tienen cuatro palabras clave asociadas para usarlos en otros módulos: alias , import , use y require .
alias registrará un módulo con un nombre diferente (generalmente más corto):
defmodule MyModule do
# Will make this module available as `CoolFunctions`
alias MyOtherModule.CoolFunctions
# Or you can specify the name to use
alias MyOtherModule.CoolFunctions, as: CoolFuncs
end
import hará que todas las funciones en el módulo estén disponibles sin nombre delante de ellas:
defmodule MyModule do
import Enum
def do_things(some_list) do
# No need for the `Enum.` prefix
join(some_list, " ")
end
end
use permite a un módulo inyectar código en el módulo actual; esto generalmente se realiza como parte de un marco que crea sus propias funciones para que su módulo confirme algún comportamiento.
require cargar macros desde el módulo para que puedan ser utilizadas.
Delegar funciones a otro módulo.
Utilice defdelegate para definir funciones que delegan funciones del mismo nombre definidas en otro módulo:
defmodule Math do
defdelegate pi, to: :math
end
iex> Math.pi
3.141592653589793