« Caml » : différence entre les versions
mAucun résumé des modifications |
Aucun résumé des modifications |
||
Ligne 197 : | Ligne 197 : | ||
[[Catégorie:Théorie des types]] |
[[Catégorie:Théorie des types]] |
||
[[Catégorie:ML]] |
[[Catégorie:ML]] |
||
[[Catégorie:Invention française]] |
Version du 11 mars 2017 à 13:06
Caml (prononcé camel, signifie Categorical Abstract Machine Language) est un langage de programmation généraliste conçu pour la sécurité et la fiabilité des programmes. Il se prête à des styles de programmation fonctionnelle, impérative et orientée objet. C'est de plus un langage fortement typé.
Le style fonctionnel rapproche le langage Caml de l’écriture mathématique, notamment grâce à la récursivité et au filtrage par motif (pattern matching). Ce dernier, particularité de la famille ML, offre une syntaxe au cas par cas claire et lisible, et est aussi utilisé dans le rattrapage des exceptions, en particulier pour la gestion des erreurs. Le typage fort rend l’usage sûr mais moins souple pour le programmeur. Enfin, Caml pratique l’inférence de types pour déterminer automatiquement le type des variables et expressions et permet la généricité.
Descendant du langage ML, le Caml est développé depuis 1985 par les équipes Formel puis Cristal de l'Inria et l'a notamment été pendant cinq ans par le professeur Guy Cousineau (université Paris Diderot)[1]. Il existe deux variantes principales de Caml.
- Caml Light est une ancienne version, légère, principalement utilisée en milieu pédagogique[note 1]. Elle n’est plus développée et a été supplantée par OCaml.
- OCaml est la version la plus avancée et la branche de développement active du langage. Elle ajoute de nombreuses fonctionnalités, comme un système de modules beaucoup plus poussé et le support de la programmation orientée objet (reposant sur le duck typing) dont elle tire son nom.
Consortium
La conception et le développement du langage Caml ainsi que son environnement sont fédérés par un consortium dirigé par Inria.[réf. nécessaire]
Extensions
Il existe un grand nombre d'extensions de Caml, permettant au langage de couvrir beaucoup de concepts.
- PolyAML et Aspectual Caml : programmation par aspects[3],[4].
- OCamlDuce : manipulation robuste de XML et d’expressions régulières, via l’intégration du langage CDuce[5].
- MetaOcaml et sa réimplémentation BER MetaOCaml : métaprogrammation et macros[6],[7].
- OCaml-templates : génération de code à partir des types[8].
- FreshML : manipulation de données de syntaxe comportant des variables liées[9].
- des extensions de ML pour supporter le polymorphisme ad-hoc[10].
- O’Jacare : interfaçage entre OCaml et Java (basé sur camljava)[11].
- ocamllex et ocamlyacc : génération d’analyseurs lexicaux et syntaxiques (équivalents des traditionnels lex et yacc)[12].
Voir aussi
Articles connexes
Liens externes
- (fr) Site officiel
- (fr) Cours de programmation en Caml pour débutants
- (en) A brief history of Caml (as I remember it)
- (fr) Exercices de programmation en Caml, avec corrigés
- (fr) Exercices en Caml avec corrigés
Notes & références
Notes
- Caml Light est enseigné en France dans les classes préparatoires, dans l’option informatique de la filière MPSI / MP[2].
Références
- « CV de Guy Cousineau », sur aeres-evaluation.fr (consulté le )
- « note de service nº 2013-0020 du 4-11-2013 : Enseignement de l'option informatique en classes préparatoires scientifiques Mathématiques, physique et sciences de l'ingénieur (MPSI) et Mathématiques et physique (MP) — Langage de programmation », sur education.gouv.fr (consulté le )
- (en) Daniel S. Dantas, David Walker, Geoffrey Washburn et Stephanie Weirich, « PolyAML : A Polymorphic Aspect-oriented Functional Programming Language », Proceedings of the ACM SIGPLAN International Conference on Functional Programming (ICFP), vol. 40, no 9, , p. 306-319 (DOI 10.1145/1086365.1086404, lire en ligne [PDF])
- (en) Hidehiko Masuhara, Hideaki Tatsuzawa, Akinori Yonezawa et Stephanie Weirich, « Aspectual Caml : An Aspect-Oriented Functional Language », Proceedings of the ACM SIGPLAN International Conference on Functional Programming (ICFP), vol. 40, no 9, , p. 320-330 (DOI 10.1145/1086365.1086405, lire en ligne [PDF])
- (en) « CDuce: OCamlDuce », sur cduce.org (consulté le )
- (en) « MetaOCaml : A compiled, type-safe, multi-stage programming language », sur cs.rice.edu (consulté le )
- (en) « MetaOCaml : An OCaml dialect for multi-stage programming », sur okmij.org (consulté le )
- (en) « Ocaml-templates »(Archive.org • Wikiwix • Archive.is • Google • Que faire ?), sur pps.jussieu.fr (consulté le )
- (en) Mark R. Shinwell, Andrew M. Pitts et Murdoch J. Gabbay, « FreshML: Programming with Binders Made Simple », Proceedings of the ACM SIGPLAN International Conference on Functional Programming (ICFP), vol. 38, no 9, , p. 263-274 (DOI 10.1145/944705.944729, lire en ligne [PDF])
- (en) J. Furuse, « Generic Polymorphism in ML », Journées francophones des langages applicatifs (JFLA), , p. 75-96 (ISBN 2-7261-1180-7, lire en ligne [PDF])
- « O’Jacare : Une interface objet entre O’Caml et Java »(Archive.org • Wikiwix • Archive.is • Google • Que faire ?), sur pps.jussieu.fr (consulté le )
- (en) « The OCaml system, § 12. Lexer and parser generators (ocamllex, ocamlyacc) », sur caml.inria.fr (consulté le )