« Caml » : différence entre les versions

Un article de Wikipédia, l'encyclopédie libre.
Contenu supprimé Contenu ajouté
Maëlan (discuter | contributions)
Bob08 (discuter | contributions)
m infobox
 
(17 versions intermédiaires par 12 utilisateurs non affichées)
Ligne 1 : Ligne 1 :
{{Infobox Logiciel}}
'''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 [[Programmation fonctionnelle|fonctionnelle]], [[Programmation impérative|impérative]] et [[Programmation orientée objet|orientée objet]]. C'est de plus un langage [[typage fort|fortement typé]].
'''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 [[Programmation fonctionnelle|fonctionnelle]], [[Programmation impérative|impérative]] et [[Programmation orientée objet|orientée objet]]. C'est de plus un langage [[typage fort|fortement typé]].


Le style fonctionnel rapproche le langage Caml de l’écriture mathématique, notamment grâce à la [[algorithme récursif|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 [[Système de gestion d'exceptions|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é]].
Le style fonctionnel rapproche le langage Caml de l’écriture mathématique, notamment grâce à la [[algorithme récursif|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 [[Système de gestion d'exceptions|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 [[ML (langage)|langage ML]], le Caml est développé depuis 1985 par les équipes Formel puis Cristal de l'[[Institut national de recherche en informatique et en automatique|Inria]] et l'a notamment été pendant cinq ans par le professeur [[Guy Cousineau]]<ref>[http://www.aeres-evaluation.fr/content/download/15025/248183/file/Cousineau%20Guy-CV.pdf Guy Cousineau - AERES - CV], consulté sur www.aeres-evaluation.fr le {{Date|15|février|2011}}.</ref> ([[université Paris Diderot]]). Il existe deux variantes principales de Caml.
Descendant du [[ML (langage)|langage ML]], le Caml est développé depuis 1985 par les équipes Formel puis Cristal de l'[[Institut national de recherche en informatique et en automatique|Inria]] et l'a notamment été pendant cinq ans par le professeur [[Guy Cousineau]] ([[université Paris-Diderot]])<ref name="CV-Cousineau"/>. La variante active de Caml est '''[[OCaml]]'''. Par rapport à l'ancienne variante '''[[Caml Light]]''', aujourd'hui obsolète, elle ajoute de nombreuses fonctionnalités, comme un système de [[Module (programmation)|modules]] beaucoup plus poussé et le support de la programmation orientée objet (reposant sur le ''[[duck typing]]'') dont elle tire son nom.

* '''[[Caml Light]]''' est une ancienne version, légère, principalement utilisée en milieu pédagogique<ref group=N>Caml Light est enseigné en France dans les [[Classe préparatoire aux grandes écoles|classes préparatoires]], dans l’option informatique de la filière [[Classes préparatoires mathématiques, physique et sciences de l'ingénieur|MPSI]] / [[Classes préparatoires mathématiques, physique|MP]].</ref>{{,}}<ref>[http://www.enseignementsup-recherche.gouv.fr/pid20536/bulletin-officiel.html?cid_bo=71588&cbo=1 note de service nº 2013-0020 du 4-11-2013]</ref>. 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 [[Module (programmation)|modules]] beaucoup plus poussé et le support de la programmation orienté objet (reposant sur le ''[[duck typing]]'') dont elle tire son nom.


== Consortium ==
== 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]].
La conception et le développement du langage Caml ainsi que son environnement sont fédérés par un [[consortium]] dirigé par [[Inria]]<ref>{{Lien web |langue=fr |titre=Une histoire de Caml |url=https://caml.inria.fr/about/history.fr.html |site=caml.inria.fr |date=28/01/2005}}</ref>.


== Extensions ==
== Extensions ==
Ligne 17 : Ligne 15 :
Il existe un grand nombre d'extensions de Caml, permettant au langage de couvrir beaucoup de concepts.
Il existe un grand nombre d'extensions de Caml, permettant au langage de couvrir beaucoup de concepts.


* '''PolyAML''' et '''Aspectual Caml''' : [[Programmation orientée aspect|programmation par aspects]]<ref group="ext" name="PolyAML"/>{{,}}<ref group="ext" name="Aspectual-Caml"/>.
*'''Aspectual Caml''' : [[Programmation orientée aspect|programmation par aspects]]<ref name="PolyAML"/>{{,}}<ref name="Aspectual-Caml"/>.
* '''OCamlDuce''' : manipulation robuste de [[XML]] et d’[[expression régulière|expressions régulières]], ''via'' l’intégration du langage [[CDuce]]<ref name="OCamlDuce"/>.
* {{fr}} {{c'est-à-dire|[http://www.lri.fr/~signoles/mvc.fr.html MVC] en OCaml}}.
* '''MetaOcaml''' et sa réimplémentation '''BER MetaOCaml''' : [[métaprogrammation]] et [[macro-définition|macros]]<ref name="MetaOCaml"/>{{,}}<ref name="BER-MetaOCaml"/>.
* '''OCamlDuce''' : manipulation robuste de [[XML]] et d’[[expression régulière|expressions régulières]], ''via'' l’intégration du langage [[CDuce]]<ref group="ext" name="OCamlDuce"/>.
* '''OCaml-templates''' : génération de code à partir des types<ref name="OCaml-templates"/>.
* '''MetaOcaml''' et sa réimplémentation '''BER MetaOCaml''' : [[métaprogrammation]] et [[macro-définition|macros]]<ref group="ext" name="MetaOCaml"/>{{,}}<ref group="ext" name="BER-MetaOCaml"/>.
* '''OCaml-templates''' : génération de code à partir des types<ref group="ext" name="OCaml-templates"/>.
* '''FreshML''' : manipulation de données de syntaxe comportant des [[variable liée|variables liées]]<ref name="FreshML"/>.
* '''FreshML''' : manipulation de données de syntaxe comportant des [[variable liée|variables liées]]<ref group="ext" name="FreshML"/>.
* des extensions de ML pour supporter le [[polymorphisme ad-hoc]]<ref name="Furuse"/>.
* '''O’Jacare''' : interfaçage entre OCaml et [[Java (langage)|Java]] (basé sur camljava)<ref name="O’Jacare"/>.
* des extensions de ML pour supporter le [[polymorphisme ad-hoc]]<ref group="ext" name="Furuse"/>.
* '''ocamllex''' et '''ocamlyacc''' : génération d’[[analyse lexicale|analyseurs lexicaux]] et [[analyse syntaxique|syntaxiques]] (équivalents des traditionnels [[lex (logiciel)|lex]] et [[yacc (logiciel)|yacc]])<ref name="lexyacc"/>.
* '''O’Jacare''' : interfaçage entre OCaml et [[Java (langage)|Java]] (basé sur camljava)<ref group="ext" name="O’Jacare/>.
* '''ocamllex''' et '''ocamlyacc''' : génération d’[[analyse lexicale|analyseurs lexicaux]] et [[analyse syntaxique|syntaxiques]] (équivalents des traditionnels [[lex (logiciel)|lex]] et [[yacc (logiciel)|yacc]])<ref group="ext" name="lexyacc"/>.


== Voir aussi ==
== Voir aussi ==
Ligne 32 : Ligne 29 :


=== Liens externes ===
=== Liens externes ===
* {{fr}} {{officiel|http://caml.inria.fr/}}
* {{Site officiel|fr|http://caml.inria.fr/}}

* {{fr}} [http://www.france-ioi.org/algo/chapters.php Cours de programmation en Caml pour débutants]
* {{fr}} [http://www.france-ioi.org/algo/chapters.php Cours de programmation en Caml pour débutants]
* {{en}} [http://www.pps.jussieu.fr/~cousinea/Caml/caml_history.html A brief history of Caml (as I remember it)]
* {{en}} [http://www.pps.jussieu.fr/~cousinea/Caml/caml_history.html A brief history of Caml (as I remember it)]
Ligne 39 : Ligne 35 :
* {{fr}} [http://pauillac.inria.fr/~quercia/cdrom/cours/index.html#tp-caml Exercices en Caml avec corrigés]
* {{fr}} [http://pauillac.inria.fr/~quercia/cdrom/cours/index.html#tp-caml Exercices en Caml avec corrigés]


=== Notes & références ===
=== Notes et références ===


== Notes ==
== Notes ==
{{Références|groupe=N}}
{{Références|groupe=note}}


== Références ==
== Références ==
{{Références}}
{{Références|références=
<ref name="CV-Cousineau">{{lien web
{{Références|groupe=ext|références=
|url=http://www.aeres-evaluation.fr/content/download/15025/248183/file/Cousineau%20Guy-CV.pdf
|titre={{abréviation|CV|curriculum vitæ|la}} de Guy Cousineau
|site=aeres-evaluation.fr
|consulté le=15 février 2011
}}</ref>
<ref name="PolyAML">{{Article
<ref name="PolyAML">{{Article
|langue=en
|langue=en
Ligne 99 : Ligne 100 :
|titre={{langue|en|CDuce: OCamlDuce}}
|titre={{langue|en|CDuce: OCamlDuce}}
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{subst:aujourd'hui}}
|consulté le=19 août 2016
}}</ref>
}}</ref>
<ref name="MetaOCaml">{{Lien web
<ref name="MetaOCaml">{{Lien web
Ligne 108 : Ligne 109 :
|sous-titre={{langue|en|A compiled, type-safe, multi-stage programming language}}
|sous-titre={{langue|en|A compiled, type-safe, multi-stage programming language}}
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{subst:aujourd'hui}}
|consulté le=19 août 2016
}}</ref>
}}</ref>
<ref name="BER-MetaOCaml">{{Lien web
<ref name="BER-MetaOCaml">{{Lien web
Ligne 117 : Ligne 118 :
|sous-titre={{langue|en|An OCaml dialect for multi-stage programming}}
|sous-titre={{langue|en|An OCaml dialect for multi-stage programming}}
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{subst:aujourd'hui}}
|consulté le=19 août 2016
}}</ref>
}}</ref>
<ref name="OCaml-templates">{{Lien brisé
<ref name="OCaml-templates">{{Lien brisé
Ligne 126 : Ligne 127 :
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{date-|2015-06-14}}
|consulté le={{date-|2015-06-14}}
|brisé le={{subst:aujourd'hui}}
|brisé le=19 août 2016
}}</ref>
}}</ref>
<ref name="FreshML">{{Article
<ref name="FreshML">{{Article
Ligne 170 : Ligne 171 :
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{date-|2013-12-04}}
|consulté le={{date-|2013-12-04}}
|brisé le={{subst:aujourd'hui}}
|brisé le=19 août 2016
}}</ref>
}}</ref>
<ref name="lexyacc">{{Lien web
<ref name="lexyacc">{{Lien web
Ligne 178 : Ligne 179 :
|titre={{langue|en|The OCaml system, § 12. Lexer and parser generators (ocamllex, ocamlyacc)}}
|titre={{langue|en|The OCaml system, § 12. Lexer and parser generators (ocamllex, ocamlyacc)}}
<!-- |date=???-->
<!-- |date=???-->
|consulté le={{subst:aujourd'hui}}
|consulté le=19 août 2016
}}</ref>
}}</ref>
}}
}}


{{Portail|programmation informatique}}
{{Portail|programmation informatique}}

[[Catégorie:Théorie des types]]
[[Catégorie:Théorie des types]]
[[Catégorie:ML]]
[[Catégorie:ML]]
[[Catégorie:Invention française]]

Dernière version du 2 mars 2024 à 15:29

Caml

Informations
Développé par InriaVoir et modifier les données sur Wikidata
Première version Voir et modifier les données sur Wikidata
Dernière version 4.07 ()[1]Voir et modifier les données sur Wikidata
Type Dialecte (en)Voir et modifier les données sur Wikidata
Site web caml.inria.frVoir et modifier les données sur Wikidata

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)[2]. La variante active de Caml est OCaml. Par rapport à l'ancienne variante Caml Light, aujourd'hui obsolète, 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[modifier | modifier le code]

La conception et le développement du langage Caml ainsi que son environnement sont fédérés par un consortium dirigé par Inria[3].

Extensions[modifier | modifier le code]

Il existe un grand nombre d'extensions de Caml, permettant au langage de couvrir beaucoup de concepts.

Voir aussi[modifier | modifier le code]

Articles connexes[modifier | modifier le code]

Liens externes[modifier | modifier le code]

Notes et références[modifier | modifier le code]

Notes[modifier | modifier le code]

Références[modifier | modifier le code]

  1. « http://caml.inria.fr/pub/distrib/ocaml-4.07/ »
  2. « CV de Guy Cousineau », sur aeres-evaluation.fr (consulté le )
  3. « Une histoire de Caml », sur caml.inria.fr,
  4. (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])
  5. (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])
  6. (en) « CDuce: OCamlDuce », sur cduce.org (consulté le )
  7. (en) « MetaOCaml : A compiled, type-safe, multi-stage programming language », sur cs.rice.edu (consulté le )
  8. (en) « MetaOCaml : An OCaml dialect for multi-stage programming », sur okmij.org (consulté le )
  9. (en) « Ocaml-templates »(Archive.orgWikiwixArchive.isGoogleQue faire ?), sur pps.jussieu.fr (consulté le )
  10. (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])
  11. (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])
  12. « O’Jacare : Une interface objet entre O’Caml et Java »(Archive.orgWikiwixArchive.isGoogleQue faire ?), sur pps.jussieu.fr (consulté le )
  13. (en) « The OCaml system, § 12. Lexer and parser generators (ocamllex, ocamlyacc) », sur caml.inria.fr (consulté le )