9. Composants de plus haut niveau
*********************************

L'entrée de l'interpréteur Python peut provenir d'un certain nombre de
sources : d'un script passé en entrée standard ou en argument de
programme, tapée de manière interactive, à partir d'un fichier source
de module, etc. Ce chapitre donne la syntaxe utilisée dans ces
différents cas.


9.1. Programmes Python complets
===============================

Bien que les spécifications d'un langage n'ont pas à préciser comment
l'interpréteur du langage est invoqué, il est utile d'avoir des
notions sur ce qu'est un programme Python complet. Un programme Python
complet est exécuté dans un environnement dont l'initialisation est
minimale : tous les modules intégrés et standard sont disponibles mais
aucun n'a été initialisé, à l'exception de "sys" (divers services
système), "builtins" (fonctions natives, exceptions et "None") et
"__main__". Ce dernier est utilisé pour avoir des espaces de nommage
locaux et globaux pour l'exécution du programme complet.

La syntaxe d'un programme Python complet est celle d'un fichier
d'entrée, dont la description est donnée dans la section suivante.

L'interpréteur peut également être invoqué en mode interactif ; dans
ce cas, il ne lit et n'exécute pas un programme complet mais lit et
exécute une seule instruction (éventuellement composée) à la fois.
L'environnement initial est identique à celui d'un programme complet ;
chaque instruction est exécutée dans l'espace de nommage de
"__main__".

Un programme complet peut être transmis à l'interpréteur sous trois
formes : avec l'option "-c" *chaîne* en ligne de commande, avec un
fichier passé comme premier argument de ligne de commande ou comme
entrée standard. Si le fichier ou l'entrée standard est un
périphérique tty, l'interpréteur entre en mode interactif ; sinon, il
exécute le fichier comme un programme complet.


9.2. Fichier d'entrée
=====================

Toutes les entrées lues à partir de fichiers non interactifs sont de
la même forme :

   file_input ::= (NEWLINE | statement)*

Cette syntaxe est utilisée dans les situations suivantes :

* lors de l'analyse d'un programme Python complet (à partir d'un
  fichier ou d'une chaîne de caractères) ;

* lors de l'analyse d'un module ;

* lors de l'analyse d'une chaîne de caractères passée à la fonction
  "exec()".


9.3. Entrée interactive
=======================

L'entrée en mode interactif est analysée à l'aide de la grammaire
suivante :

   interactive_input ::= [stmt_list] NEWLINE | compound_stmt NEWLINE

Notez qu'une instruction composée (de niveau supérieur) doit être
suivie d'une ligne blanche en mode interactif ; c'est nécessaire pour
aider l'analyseur à détecter la fin de l'entrée.


9.4. Entrée d'expression
========================

"eval()" est utilisée pour évaluer les expressions entrées. Elle
ignore les espaces en tête. L'argument de "eval()", de type chaîne de
caractères, doit être de la forme suivante :

   eval_input ::= expression_list NEWLINE*
