CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Audiobooks by Valerio Di Stefano: Single Download - Complete Download [TAR] [WIM] [ZIP] [RAR] - Alphabetical Download  [TAR] [WIM] [ZIP] [RAR] - Download Instructions

Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Perl 6 - Wikipédia

Perl 6

Un article de Wikipédia, l'encyclopédie libre.

Vous avez de nouveaux messages (diff ?).
Langage de programmation
Image:Programming-republic-of-perl.gif Perl 6
Apparu en Spécification : 2001-2006, mise en œuvre alpha par pugs prévue nouvel an 2007
Auteur Larry Wall
Développeurs The Perl Foundation
Paradigmes Objet, impératif, fonctionnel
Typage Fort, dynamique
Influencé par Perl, Haskell, APL, Ruby, Python, SmallTalk, Self
Implémentations Pugs, Parrot
Système d'exploitation Multi-plate-forme
Site Web http://dev.perl.org/perl6

Perl 6 est une refonte totale du langage de programmation Perl. Cette refonte garde l'esprit du langage qui laisse une grande liberté au programmeur et lui permet une expression concise. Perl 6 reste un langage générique et permet toujours de programmer des unilignes mais propose un bien meilleur support pour l'écriture de programmes importants. Le système de documentation a été amélioré et mieux intégré au langage pour permettre la programmation lettrée.

Perl 6 n'a pas pour objectif premier d'avoir une compatibilité ascendante avec Perl 5, bien qu'il y aura un mode de compatibilité et la possibilité d'appeler les modules existants de CPAN. La spécification du langage est pratiquement terminée. Ces derniers mois, avec la disponibilité de l'interpréteur expérimental pugs, cette spécification a eu lieu en parallèle avec l'écriture de jeux de tests et de bibliothèques logicielles, ce qui a permis son affinement. Une version alpha raisonnablement complète devrait être mise en œuvre par pugs pour le nouvel an 2007. Le langage permet toujours d'écrire des programmes très concis, notamment avec le support d'hyperopérateurs similaires aux opérateurs de manipulation de tableaux dynamiques du langage APL. C'est un des aspects de la syntaxe concrète qui permet de paralléliser l'exécution de portions de programmes.

Le langage est complexe mais il est toujours possible de programmer dans un sous-ensemble restreint du langage. Il inclut beaucoup de fonctionnalités qui, pour d'autres langages, appartiennent généralement à des bibliothèques logicielles. Ainsi le système d'expressions rationnelles a été entièrement refondu et constitue aussi un moteur d'analyse syntaxique puissant et rapide grâce à un contrôle très fin du retour sur trace. Il est complètement intégré au système objet. Le système objet, mimimaliste en Perl 5, supporte maintenant le dispatch multiple, les rôles et la réflexion. La programmation orientée prototype et la programmation orientée objet sont toutes deux possibles car le programmeur peut modifier le comportement par défaut des métaclasses et du mécanisme de dispatch vers les méthodes et multiméthodes. Les rôles sont un système de composition de code similaire aux mixin mais de granularité inférieure à la classe.

Les concepteurs de Perl 6 ont apporté un soin tout particulier à la syntaxe du langage qui avait était notablement alourdie en Perl 5 avec l'ajout du support des références. Les principes directeurs dans la conception du langage sont : le principe de Huffman, la lisibilité, l'extensibilité. Chaque aspect du langage est hautement paramétrable via des constructions lexicales ou syntaxiques appelés adverbes ou modificateurs. Certains opérateurs sont des caractères Unicode mais souvent un alias plus verbeux en ASCII est disponible. L'interopérabilité avec les bibliothèques d'autres langages dynamiques de haut niveau est un but à terme grâce à la mise en œuvre de ces langages par le même moteur (Pugs ou Parrot).

Le typage explicite du contenu d'une variable est optionnel. Le typage des données est donc statique lorsqu'il est explicite ou inferré, dynamique sinon. Le programmeur dispose donc un continuum entre la programmation lâche typique des langages de script et la rectitude et les performances d'un langage à typage statique. Typiquement, un programme évoluera au cours du temps vers un typage plus "serré".

Sommaire

[modifier] Pourquoi Perl6 ?

Le langage Perl était au départ très modeste et a grossi en respectant la compatibilité ascendante. En 18 ans d'évolution, il a accumulé beaucoup de scories qui rendent son apprentissage difficile et complexifient inutilement l'interpréteur. Il fallait s'en débarasser. Les comportements par défaut du langage était conçus pour des programmes de quelques lignes. Même si le langage avait évolué (variables lexicales, orientation objet...) pour supporter de gros programmes, une grande partie des programmeurs n'avaient pas adapté leur style, ce qui a donné à Perl une réputation de langage sale.

L'interpréteur de Perl 5 n'utilise pas au mieux les architectures multiprocesseurs ou multicore dont la mémoire est lente par rapport au processeur. De plus, pour la programmation en grand, il est nécessaire d'avoir un système puissant de passage de paramètres. De même il était important de donner la possibilité au programmeur, mais non l'obligation, d'un typage statique des données. Ce typage constitue à la fois une documentation, une forme d'assertion exécutée à la compilation et une amélioration des performances par rapport au typage dynamique. Finalement, l'inférence de type sera possible à terme.

[modifier] Historique

Le processus de conception de Perl 6 a été annoncé pour la première fois le 19 Juillet 2000, par Larry Wall le 4° jour de la conférence annuelle OSCON dans son discours sur l'état de l'oignon 2000 ("State of the Onion 2000"). A cette date, les principaux objectifs étaient de débarrasser le langage de verrues historiques ("historical warts"); “les choses faciles doivent rester faciles, les choses difficiles doivent être plus faciles, et les choses impossibles ne devraient pas être difficile;” de nettoyer d'une manière général le design interne et les APIs. Le processus a commencé avec une série de demandes de changements ou « RFC ». Ce processus était ouvert à tous les contributeurs et ne laissait aucun aspect du langage à l’abri du changement.

Une fois le processus des RFC complété, Wall a revu et classé chaque demande. Il a alors commencé la rédaction des Apocalypses. Bien que le but initial était d’écrire un Apocalypse pour chaque chapitre de « Programmation en Perl », il est devenu évident à la rédaction de chacun des Apocalypses que les précédents apocalypses devenaient invalides de part les derniers changements. Pour cette raison, un ensemble de synopses ont été publiés, chacun relatifs au contenu d’un Apocalypse, mais mis à jour suivant les modifications apparues. Aujourd’hui, les spécifications de Perl 6 continuent presque entièrement à travers les Synopses.

Il y a 3 méthodes principales de communication utilisées dans le développement de Perl 6 actuellement. La première est le canal IRC #perl6 sur irc.freenode.net. La seconde est un ensemble de liste de diffusion sur les serveurs de la Fondation Perl du domaine perl.org. La troisième est le référentiel de code source Subversion utilisé par l’équipe du projet Pugs.

Au fil des ans, Perl 6 à connu plusieurs changements de direction. L’introduction de concepts provenant de Python et Ruby ont influé au début, mais lors de l’écriture de l’interpréteur pugs dans le langage Haskell, on a pu noter une large influence de la programmation fonctionnelle sur l’équipe de conception de Perl 6.

[modifier] Mises en œuvre

Pugs est une mise en œuvre encore expérimentale de Perl 6 en Haskell. Elle sera utilisée pour le bootstrap de Perl 6. Après cela, Perl 6 sera probablement auto-hébergé — il sera utilisé pour se compiler lui-même. Une grande partie de la mise en œuvre de Perl sera alors exposée, rendant possible, par exemple, l'expansion de l'analyseur de code.

Pugs peut exécuter du code Perl 6 directement, ainsi que compiler du Perl 6 vers du JavaScript, du Perl 5 ou du bytecode Parrot.

Parrot est une machine virtuelle conçue pour mettre en œuvre les langages interprétés modernes, particulièrement Perl 6. Le compilateur Perl 6 auto-hébergé ciblera (et tourne sous) Parrot.

[modifier] Principaux changement depuis Perl 5

Perl 6 garde l'esprit de Perl 5. La plupart des changements apportés ont pour but de rendre le langage plus homogène, d'intégrer de nouvelles fonctionnalités et de mieux exploiter les architectures matérielles modernes. Les nouvelles fonctionnalités sont un puissant système de passage de paramètres, la curryfication, le support du typage statique (mais son utilisation reste optionnelle), l'évaluation paresseuse, le filtrage par motif, l'expression du parallélisme dans le code source pour utiliser au mieux les multiprocesseurs ou les processeurs multicores, et, optionnellement, l'inférence de types. Le but est, Selon Larry Wall, de rendre les choses simples plus simples et les choses compliquées plus facilement réalisables.

[modifier] Une spécification

En Perl 5, la référence est la mise en œuvre unique du langage. Si la documentation et la mise en œuvre divergent, sauf bogue avéré, c'est la documentation qui doit être amendée. Ce système n'est plus possible car il semble que Perl 6 aura au moins deux mises en œuvre. De plus, pour une mise en œuvre donnée, il pourra y avoir des générateurs de code réalisés par des tierces parties.

Perl 6 est spécifié par des documents appelés synopsis. Ils ont été précédés par des apocalypses (au sens de révélation) qui expliquaient et motivaient les premières décisions. Les apocalypses ont maintenant une valeur purement historique.

Durant 2006, Pugs, une première mise en œuvre écrite en Haskell était suffisamment avancée pour permettre d'écrire des jeux de tests, de valider, de corriger et d'affiner les spécifications.

[modifier] Un système typé

Le système statique de typage de Perl 5 comporte peu de types. Lors de la déclaration d'une variable, son sigil détermine si elle est de type scalaire, tableau ou hash (métonyme pour table associative). Un scalaire peut contenir un entier, un flottant ou une chaîne de caractères. Puisque le type du contenant ne détermine que partiellement le type du contenu, on parle de typage semi-dynamique.

En Perl 6, les sigils et le typage dynamique de Perl 5 ont été étendus par l'addition de types statiques. Cela consiste en la déclaration explicite du type du contenant. Par exemple :

my int $i = 0;
my num $n = 3.141;
my str $s = "Hello, world";

Cependant, tout comme en Perl 5, les programmeurs peuvent se passer de typage explicite :

my $i = "25" + 10;

Le typage statique est une forme de documentation et de tests intégrée au code source. Il améliore la maintenance, spécialement dans les grands projets logiciels. Mais le typage statique alourdit le code de scripts courts ou d'unilignes. Ce style concis sans déclaration explicite de type autre que par les sigils est une force du Perl lorsque utilisé pour l'écriture de code à usage unique.

Perl 6 introduces also secondary sigils called twigils.

[modifier] Liste formelle de paramètres de sous-routines

[modifier] Carence en Perl 5

Perl 5 définit les sous-routines sans liste formelle de paramètres.

Les arguments de sous-routines entrant dans une sous-routine devenaient des alias dans les éléments du tableau @_. Si @_ était modifié, les changements étaient reflétés dans les données originales :

# Code Perl 5
sub incr { $_[0]++ }
my $x = 1;
incr($x); # $x est maintenant 2
incr(3); # erreur de runtime : "Essai de modification d'une valeur en lecture seule"

Note: Le système de prototypes, ajout tardif au langage, est un moyen de vérification du nombre de paramètres et une faible vérification de type.

[modifier] Système complexe mais puissant en Perl 6

Perl 6 introduit un vrai formalisme de paramètres dans le langage qui va au dela des signatures de types. En Perl 6, une déclaration de sous-routine ressemble à :

sub faire_quelquechose(Str $chose, Int $autre) { ... }

Comme en Perl 5, les paramètres formels (exemple, les pseudo-variables dans la liste de paramètres) sont aliasés en leurs paramètres actuels (valeurs d'entrées), mais par défaut, les alias sont marqués is readonly (signifiant qu'ils sont en lecture seule et donc constants) non modifiables :

sub incr(Num $x) {
  $x++; # compile-time error
}

Si un paramètre formel est suivi par is copy ou is rw, cependant, il peut être modifié. Dans le cas is copy, Perl 6 copie les paramètres actuels plutôt que des les aliaser ; ainsi ils peuvent être modifiés, mais les changements restent locaux à la sous-routine. Dans le cas is rw (rw signifie lecture-écriture, read-write en anglais), l'alias n'est pas marqué readonly. Ce changement détecte aussi lors de la compilateur des erreurs telles que :

sub incr(Num $x is rw) { $x++ }
incr(3); # erreur au moment de la compilation
sub incr_copy(Num $x is copy) { $x++ }
incr_copy(3);  # Pas de problème

De nouvelles fonctionnalités de Perl 6 dans les listes de paramètres rendent le passage de paramètres beaucoup plus puissant qu'en Perl 5 :

  • = après un paramètre permet d'assigner des valeurs par défaut.
  • ? après un paramètre indique des arguments optionnels.
  • : avant un paramètre indique un argument nommé (passé comme élément d'hash).
  • where peut fournir une condition que le paramètre doit respecter.

Par exemple :

sub my_split(Rule $pat? = rx/\s+/, Str $expr? = $_, Int $lim? where $^lim >= 0) { ... }

Perl 6 supporte aussi la curryfication.

[modifier] Invariance du sigil

En Perl 5, le sigil — le caractère non alphanumérique qui précède un nom de variable — pouvait changer selon son contexte d'utilisation (scalaire ou tableau) :

# Perl 5 code
my @array = (0, 1, 2, 3);
my $element = $array[1]; # $element est égal à 1

En Perl 6, l'abondance des contextes possibles nécessite un mécanisme différent des sigils. Le sigil ne désigne plus le contexte d'accès. Perl 6 propose des opérateurs spécialisés pour ce faire. Le sigil d'une variable est donc invariant. Il est plus pédagogique d'avoir deux mécanismes syntaxiques pour deux fonctions grammaticales différentes (le typage faible de la variable et son contexte d'accès). De plus, cette séparation ouvre la voie à l'ajout futur d'autres sigils pour désigner d'autres types faibles. Avec l'alphabet ASCII, il n'y avait pas place pour d'autre sigils, mais ce n'est plus un problème avec Unicode. Ce serait une forme limitée mais compacte de notation hongroise.


my @array = (0, 1, 2, 3);
my $element = @array[1]; # $element est égal à 1

[modifier] Orientation objet

Perl 5 supportait l'orientation objet via un mécanisme propre à Perl et nommé bénédiction. N'importe quelle référence pouvait être bénie comme étant un objet d'une classe particulière, comme :

# Perl 5 code
my $object = bless $reference, 'Class';

Un objet béni pouvait alors avoir des méthodes invoquées en utilisant la « syntaxe flèche » :

# Perl 5 code
$objet->méthode();

L'invocation identifie la sous-routine appropriée de nom méthode, et l'appelle avec $objet comme premier argument.

Bien que très puissant — virtuellement n'importe quel autre modèle objet d'un autre langage pouvait être simulé en utilisant cette simple fonctionnalité — il rendait le cas le plus commun d'orientation objet, comme une structure C associée à du code, inutilement difficile. De plus, Perl ne pouvant faire d'hypothèse sur le modèle objet utilisé, l'invocation de méthode ne pouvait pas être très bien optimisée.

Dans l'esprit de rendre les choses simples plus simples, et les choses compliquées faciles, Perl 6 garde le principe de bénédiction pour créer une instance pour les programmeurs qui désirent des fonctionnalités communes. Cela fournit un modèle objet plus robuste pour les cas communs. Par exemple, une classe pour encapsuler un point cartésien peut être écrite comme :

class Point is rw {
  has $.x;
  has $.y;
}

et utilisée :

my Point $point .= new;
$point.x = 1.2;
$point.y = -3.7;

Le point remplace la flèche (propre à Perl 5) comme opérateur d'accès au membre d'une instance. C'est la syntaxe propre à de nombreux langages dont C++, Java, Python, et Ruby.

Notez que les méthodes « x » et « y » ne sont pas déclarées explicitement. Elles sont appelées des auto-accesseurs. Le modificateur « is rw » dans la définition de la classe permet à tous ses attributs publics d'être écrits par défaut, en utilisant les auto-accesseurs.[1]

Les données membres d'une instance sont appelés « attributs » Elles peuvent être déclarées ainsi :

has $.a; # mode d'accès par défaut (généralement en lecture seule)
has $.b is rw; # accès en lecture et en écriture
has $!c; # membre privé; pas d'accesseur public
has $d; # comme $!d

[modifier] Expressions rationnelles

Les expression rationnelles de Perl ont connu tellement de succès qu'elles ont été mises en œuvre par une bibliothèque appelée PCRE (Perl Compatible Regular Expressions). Via PCRE, les expression rationnelles ont été incluses sans améliorations dans beaucoup d'autres langages. Pourtant, comme le fait remarquer Larry Wall, ce sont les expressions rationnelles qui contribué à donner à Perl une réputation de langage peu lisible. Elle sont trop compactes et trop malines, les mêmes caractères sont utilisés pour des usages divers. Il y a peu de support pour les captures nommées, peu de support pour les grammaires, et une intégration pauvre avec les langages réels. [2]

Perl 6 fournit un sur-ensemble des fonctionnalités de Perl 5 concernant les expressions rationnelles. Elles sont désormais appelées regex. Le mécanisme des regex fournit une puissance comparable aux analyseurs syntaxiques. Ces regex agissent comme des fermetures par rapport à leur champ lexical. Les regex sont introduites avec un des mots-clefs rule, regex, token. La définition d'une regex est similaire à une définition de sous-routine et peut admettre des paramètres. Le choix du mot-clef permet de contrôler si les espaces sont significatifs ou non dans la regex, et de spécifier s'il peut y a retour sur trace ou non. Comme en Perl 5, on peut aussi définir des regex anonymes ou les utiliser directement dans les opérateurs m (matching) ou s (chercher et remplacer).

Seules six fonctionnalités n'ont pas été changées depuis les regex du Perl 5 :

  • Littéraux : les caractères de mots tels que « A » et souligné seront reconnus littéralement.
  • Capture : (...)
  • Alternatives : |
  • Séquences d'échappement par barre oblique inverse (backslash) : \
  • Les quantificateurs de répétition : *, +, et ?
  • Suffixe de reconnaissance minimale : *?, +?, ??

Quelques-uns des ajouts les plus efficaces sont :

  • La possibilité de référencer des règles en utilisant <rulename> pour construire des grammaires entières.
  • Des opérateurs de commission permettent au programmeur de contrôler les retours sur trace pendant la reconnaissance.

Les changements suivants ont grandement augmenté la lisibilité des regexes :

  • Simplification des groupes non-capturant : [...] qui sont les mêmes que ceux du Perl 5's : (?:...)
  • des codes assertions simplifiés : <?{...}>
  • Perl 5's /x est maintenant le défaut.

Exemples :

rx { a [ b | c ] ( d | e ) f : g }
rx { ?( ab* ) <{ $1.size % 2 == 0 }> }

La dernière ligne est identique à :

rx { ( ab[bb]* ) }

[modifier] Simplification syntaxique

Les parenthèses obligatoires au contrôle de flot en Perl 5 sont maintenant optionnelles comme les autres parenthèses :

if is_true() {
   for @array {
       ...
   }
}

Les trois points ci-dessus (...) sont syntaxiquement valides en Perl 6 et constituent l'opérateur « yadda-yadda ». « ... » peut être utilisé comme une marque substitutive pour du code qui doit être inséré par la suite. Si un programme essaye d' exécuter « ... », cependant, une exception est levée. Cet opérateur est utile pour les méthodes abstraites, ou bien pour marquer les places où le programmeur essaye d'insérer du code plus tard.

[modifier] Comparaisons chaînées

Les nouveaux programmeurs attendent souvent que les comparaisons chaînées comme le suivant fonctionnent :

if 1 <= $dé1 == $dé2 <= 6 { say "Doubles!" }

En Perl 6, ce code fonctionne maintenant naturellement, dans l'esprit du DWIM (Do What I Mean), et s'exécute comme :

if 1 <= $dé1 and $dé1 == $dé2 and $dé2 <= 6 { say "Doubles!" }


[modifier] Évaluation paresseuse

Perl 6 propose l'évaluation paresseuse de listes qui est une fonctionnalité de certains langages de programmation fonctionnelle tels que Haskell. L'Évaluation paresseuse simplifie des tâches communes en Perl6 comme les opérations d'entrées/sorties, la transformation de listes et le passage de paramètres à une routine :

my int @integers = 0..Inf; # entiers de 0 à l'infini

Le code ci-dessus ne crashera pas en essayant d'assigner une liste de taille infinie à la table @integers.

À cause de cette fonctionnalité, l'idiome Perl pour lire la liste d'arguments sur l'entrée standard :

# Perl 5 code
while (<>) {
  print;
}

est remplacé par :

for =<> {
  print;
}

Le préfixe opérateur = transforme un handle ou un nom de fichier en un itérateur. L'évaluation paresseuse de Perl 6 du for signifie que la boucle Perl 6 for ci-dessus ne doit pas être sujette à aucune conversion spéciale pour fonctionner comme attendu.

[modifier] Jonctions

Perl 6 introduit le concept de jonctions. Nous choisissons ce terme pour le distinguer des jointures, concept propre aux bases de données relationnelles. Les jonctions sont des valeurs scalaires composites. Les jonctions ont été initialement appelées superpositions, par analogie au concept de physique quantique de superpositions quantiques — des courbes qui peuvent simultanément occuper plusieurs états jusqu'à ce que leur observation les effondre. Un module Perl 5 réalisé en l'an 2000 par Damian Conway appelé Quantum::Superpositions fournissait une preuve de concept initiale. D'abord une curiosité programmatique, les jonctions sont un concept important de Perl 6.

Dans leur forme la plus simple, les jonctions sont créées par combinaison d'un ensemble de valeurs avec l'opérateur de jonction :

my $even_digit = 0|2|4|6|8; # any(0, 2, 4, 6, 8)
my $odd_digits = 1&3&5&7&9; # all(1, 3, 5, 7, 9)
my $not_zero = none(0);

Ces valeurs peuvent être utilisées arithmétiquement :

my $jonction = 1|2|3;
$jonction += 4; # jonction maintenant égale à 5|6|7
$jonction += (1&2); #  jonction maintenant égale(6|7|8)&(7|8|9)

ou dans des comparaisons :

if $grade eq any('A'..'D') { say "pass" }

ou même pour l'accès à un tableau :

if %person{any('first_name','nickname')} eq "Joe" { say "What do you know, Joe?" }

Les jonctions peuvent aussi être utilisées pour étendre le système de types :

class RGB_Color is Tuple[int,3] & Color { ... }
sub get_tint (RGB_Color|CMYK_Color $color, num $opacity where 0 <= $^opacity <= 1) { ... }
sub store_record (Record&Storable $rec) { ... }

Les jonctions ne sont pas ordonnées ; 1|2|3 et 3|2|1 représentent les mêmes valeurs. Cette absence d'ordre signifie que le compilateur Perl 6 peut choisir d'évaluer les expressions jonctives en parallèle. En fait, plusieurs dans la communauté Perl 6 croient que les jonctions peuvent surpasser l'explicite multithreading comme manière ordinaire d'accomplir le parallélisme en Perl 6. Par exemple, le code

for all(@array) { ...}

pourrait indiquer au compilateur que la boucle for doit être exécutée en parallèle plutôt qu'en série.

[modifier] Macros

Dans les langages de bas niveau, le concept de macros a été synonyme de substitutions textuelles du code source à cause de la large utilisation d'un préprocesseur ignorant la syntaxe du langage. Le langage C utilise la construction #define. Perl 5 utilise des systèmes de filtres sources à cet effet. Ils sont notoirement peu fiables, car leur empilement a des effet aléatoires. En effet chaque filtre suppose que le code qu'il filtre est du code Perl 5 alors qu'il reçoit du code modifié par ces prédécesseurs. Lisp est privilégié, car il propose un système de macros qui manipulent directement l'arbre syntaxique correspondant au source du programme. C'est facile car sa syntaxe concrète est identique à sa syntaxe abstraite.

Perl 6 proposera les deux type de macro: substitutions textuelles et manipulation de l'AST. Une définition de macro Perl 6 ressemblera à une définition de sous-routine ou méthode, et peut travailler sur des chaînes non analysées, un arbre de syntaxe abstrait AST représentant du code pré-analysé, ou encore une combinaison des deux. Une définition de macro pourrait ressembler à :

macro hello($what) {
   q:code { say "Hello { {{{$what}}} }" };
}

Dans cet exemple particulier, la macro n'est pas plus complexe qu'une substitution textuelle en C, mais parce que l'analyse du paramètre de la macro se produit avant que la macro n'opère sur le code appelé, les messages de diagnostic seront beaucoup plus informatifs. Cependant, parce que le corps de la macro est compilé à chaque lancement du programme, diverses techniques d' optimisation peuvent être employées.

[modifier] Hello world

En Perl 6 comme en Perl 5, on peut écrire

  print "Hello world\n";

En Perl 6, on préfèrera écrire le hello world ainsi :

say "Hello world";

say est semblable au say de REXX, au writeln de Pascal et au puts de Ruby et C.

[modifier] JAPH

Comme en Perl 5, les JAPHs (programmes qui impriment "Just another Perl hacker,") sont de bons moyens d'expérimenter avec Perl 6. Ici un exemple de curryfication :

sub japh (Str $lang) { say "just another $lang hacker"; }
my &perl6Japh := &japh.assuming("Perl6");
perl6Japh();

[modifier] Voir aussi

  • Pugs, la mise en œuvre en Haskell.
  • Parrot, la mise en œuvre en C.
  • Perl, Perl avant Perl 6.
  • The Perl Foundation, la fondation en charge de la promotion et du dèveloppement de Perl.

[modifier] Liens externes


Portail de l'informatique – Accédez aux articles de Wikipédia concernant l’informatique.
Portail des logiciels libres – Accédez aux articles de Wikipédia concernant les logiciels libres.
Static Wikipedia 2008 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Static Wikipedia 2007 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Static Wikipedia 2006 (no images)

aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -

Sub-domains

CDRoms - Magnatune - Librivox - Liber Liber - Encyclopaedia Britannica - Project Gutenberg - Wikipedia 2008 - Wikipedia 2007 - Wikipedia 2006 -

Other Domains

https://www.classicistranieri.it - https://www.ebooksgratis.com - https://www.gutenbergaustralia.com - https://www.englishwikipedia.com - https://www.wikipediazim.com - https://www.wikisourcezim.com - https://www.projectgutenberg.net - https://www.projectgutenberg.es - https://www.radioascolto.com - https://www.debitoformtivo.it - https://www.wikipediaforschools.org - https://www.projectgutenbergzim.com