Elixir - Alias

Afin de faciliter la réutilisation des logiciels, Elixir fournit trois directives - alias, require et import. Il fournit également une macro appelée utilisation qui est résumée ci-dessous -

# Alias the module so it can be called as Bar instead of Foo.Bar
alias Foo.Bar, as: Bar

# Ensure the module is compiled and available (usually for macros)
require Foo

# Import functions from Foo so they can be called without the `Foo.` prefix
import Foo

# Invokes the custom code defined in Foo as an extension point
use Foo

Voyons maintenant en détail chaque directive.

alias

La directive alias vous permet de configurer des alias pour tout nom de module donné. Par exemple, si vous souhaitez donner un alias'Str' dans le module String, vous pouvez simplement écrire -

alias String, as: Str
IO.puts(Str.length("Hello"))

Le programme ci-dessus génère le résultat suivant -

5

Un alias est donné au String module comme Str. Maintenant, lorsque nous appelons une fonction en utilisant le littéral Str, elle fait en fait référence auStringmodule. Ceci est très utile lorsque nous utilisons des noms de modules très longs et que nous voulons les remplacer par des plus courts dans la portée actuelle.

NOTE - Alias MUST commencez par une majuscule.

Les alias ne sont valides que dans le lexical scope ils sont appelés. Par exemple, si vous avez 2 modules dans un fichier et créez un alias dans l'un des modules, cet alias ne sera pas accessible dans le second module.

Si vous donnez le nom d'un module intégré, comme String ou Tuple, comme alias à un autre module, pour accéder au module intégré, vous devrez le préfixer avec "Elixir.". Par exemple,

alias List, as: String
#Now when we use String we are actually using List.
#To use the string module: 
IO.puts(Elixir.String.length("Hello"))

Lorsque le programme ci-dessus est exécuté, il génère le résultat suivant -

5

exiger

Elixir fournit des macros comme mécanisme de méta-programmation (écriture de code qui génère du code).

Les macros sont des morceaux de code qui sont exécutés et développés au moment de la compilation. Cela signifie que pour utiliser une macro, nous devons garantir que son module et son implémentation sont disponibles lors de la compilation. Ceci est fait avec lerequire directif.

Integer.is_odd(3)

Lorsque le programme ci-dessus est exécuté, il générera le résultat suivant -

** (CompileError) iex:1: you must require Integer before invoking the macro Integer.is_odd/1

Dans Elixir, Integer.is_odd est défini comme un macro. Cette macro peut être utilisée comme garde. Cela signifie que, pour invoquerInteger.is_odd, nous aurons besoin du module Integer.

Utilisez le require Integer fonction et exécutez le programme comme indiqué ci-dessous.

require Integer
Integer.is_odd(3)

Cette fois, le programme s'exécutera et produira la sortie comme: true.

En général, un module n'est pas requis avant l'utilisation, sauf si nous voulons utiliser les macros disponibles dans ce module. Une tentative d'appeler une macro qui n'a pas été chargée générera une erreur. Notez que comme la directive alias, require a également une portée lexicale . Nous parlerons plus en détail des macros dans un chapitre ultérieur.

importer

Nous utilisons le importdirective pour accéder facilement aux fonctions ou aux macros à partir d'autres modules sans utiliser le nom complet. Par exemple, si nous voulons utiliser leduplicate fonction du module List plusieurs fois, nous pouvons simplement l'importer.

import List, only: [duplicate: 2]

Dans ce cas, nous importons uniquement la fonction duplicate (avec l'argument de longueur de liste 2) depuis List. Bien que:only est facultative, son utilisation est recommandée afin d'éviter d'importer toutes les fonctions d'un module donné dans l'espace de noms. :except pourrait également être donné en option pour tout importer dans un module sauf une liste de fonctions.

le import directive prend également en charge :macros et :functions à donner à :only. Par exemple, pour importer toutes les macros, un utilisateur peut écrire -

import Integer, only: :macros

Notez que l'importation est aussi Lexically scopedtout comme les directives require et alias. Notez également que'import'ing a module also 'require's it.

utilisation

Bien que ce ne soit pas une directive, use est une macro étroitement liée à requirequi vous permet d'utiliser un module dans le contexte actuel. La macro use est fréquemment utilisée par les développeurs pour intégrer des fonctionnalités externes dans la portée lexicale actuelle, souvent des modules. Comprenons la directive use à travers un exemple -

defmodule Example do 
   use Feature, option: :value 
end

Use est une macro qui transforme ce qui précède en -

defmodule Example do
   require Feature
   Feature.__using__(option: :value)
end

le use Module requiert d'abord le module, puis appelle le __using__macro sur le module. Elixir a d'excellentes capacités de métaprogrammation et il a des macros pour générer du code au moment de la compilation. La macro _ _using__ est appelée dans l'instance ci-dessus et le code est injecté dans notre contexte local. Le contexte local est l'endroit où la macro use a été appelée au moment de la compilation.