doc: french doc "développez en Nit"
[nit.git] / doc / developpez / presentation / presentation.tex
1 \part{Présentation de Nit}
2
3 \chapter{Caractéristiques}
4 Nit est un langage de programmation orienté objet dont la syntaxe est proche de celle des langages de scripts. Le but de Nit est de proposer un langage de programmation robuste typage statique, où la structure n'est pas une torture.
5 \begin{description}
6 \item[Nit est compilé]Le code source de Nit est compilé pour être ensuite traduit en C.
7 \item[Nit est orienté objet]Comme la plupart des langages récents, Nit est orienté objet. Chaque fichier source contient la définition d'une ou plusieurs classes qui sont utilisées les unes avec les autres pour former une application. En Nit, TOUT est objet (Et oui même a = 0, c'est de l'objet).
8 \item[Nit supporte l'héritage multiple]Avec Nit il est possible de faire hériter une classe de plusieurs classes parentes, et bien d'autres choses plus intéressantes encore !
9 \item[Nit est fortement typé]Toutes les variables sont statiquement typées mais Nit utilise le typage adaptatif. C'est à dire qu'il devinera automatiquement et adaptera le type statique d'une variable en fonction de son utilisation dans le programme. Il n'est donc plus nécessaire de spécifier un type à chaque déclaration (mais cela reste possible). Le typage fort n'est plus une torture !
10 \item[Nit assure la gestion de la mémoire]L'allocation de la mémoire pour un objet est automatique à sa création et Nit récupère automatiquement la mémoire utilisée grâce à un ramasse miette qui restitue les zones de mémoires laissées libres suite à la destruction des objets.
11 \end{description}
12
13 \begin{quote}
14 \centering
15 \textsc{\textbf{Nit : A Fun Language for Serious Programming !}}
16 \end{quote}
17
18 \chapter{Historique}
19 Nit est le descendant direct de PRM développé en 2005 au LIRMM en France. Il s'agit d'un langage jouet servant à expérimenter des traits de langage et des techniques d'implémentation.
20
21 En 2008 nait Nit un langage plus généraliste développé conjointement par l'UQAM et le LIRMM. Il étend PRM en y ajoutant utilisabilité et robustesse.
22
23 Aujourd'hui, en 2011, le développement de Nit continu...
24
25
26 \chapter{Installation de Nit}
27 Le compilateur Nit est librement accessible grâce à Git :
28 \begin{description}
29 \item[Protocole GIT]\url{git://nitlanguage.org/nit.git}
30 \item[Protocole HTTP]\url{http://nitlanguage.org/nit.git}
31 \end{description}
32
33 La documentation de la librairie standard se trouve sur le site web de Nit : \url{http://nitlanguage.org/}
34
35 Pour télécharger le compilateur :
36 \begin{lstlisting}[language=bash]
37 $ git clone git://nitlanguage.org/nit.git
38 \end{lstlisting}
39 ou
40 \begin{lstlisting}[language=bash]
41 $ git clone http://nitlanguage.org/nit.git
42 \end{lstlisting}
43
44 Il faut maintenant compiler le compilateur :
45
46 \begin{lstlisting}[language=bash,firstnumber=last]
47 $ cd nit
48 $ make
49 \end{lstlisting}
50
51 Ça y est, le compilateur Nit est maintenant installé sur votre ordinateur !
52
53 \chapter{Compilation et exécution}
54 Un programme Nit est composé d'un ou plus généralement plusieurs fichiers source. N'importe quel éditeur de texte peut être utilisé pour éditer un fichier Nit.
55
56 Ces fichiers source possèdent l'extension \og .nit \fg. Ils peuvent contenir du code, une ou plusieurs classes et/ou modules.
57
58 Il est nécessaire de compiler le source pour pouvoir l'exécuter. Le compilateur \textbf{nitc} est utilisé pour compiler chaque fichier source en code exécutable par la machine. Lors de la compilation, les fichiers sources écrits en Nit seront transformés en C pour être exécutés.
59
60 Commençons par créer le classique Hello World dans le fichier hello\_world.nit :
61 \lstinputlisting[language=Nit]{./presentation/listings/hello_world_s.nit}
62
63 A présent il faut le compiler :
64 \begin{lstlisting}[language=bash]
65 $ bin/nitc hello_world.nit
66 \end{lstlisting}
67
68 Puis l'exécuter comme on le ferait en C :
69 \begin{lstlisting}[language=bash,firstnumber=last]
70 $ ./hello_world
71 \end{lstlisting}