#changed all email address to go through python.org
[python/dscho.git] / Doc / ref / ref8.tex
bloba9e688a8405dad153e2dea9cb8a42932861a651d
1 \chapter{Top-level components}
3 The Python interpreter can get its input from a number of sources:
4 from a script passed to it as standard input or as program argument,
5 typed in interactively, from a module source file, etc. This chapter
6 gives the syntax used in these cases.
7 \index{interpreter}
9 \section{Complete Python programs}
10 \index{program}
12 While a language specification need not prescribe how the language
13 interpreter is invoked, it is useful to have a notion of a complete
14 Python program. A complete Python program is executed in a minimally
15 initialized environment: all built-in and standard modules are
16 available, but none have been initialized, except for \verb@sys@
17 (various system services), \verb@__builtin__@ (built-in functions,
18 exceptions and \verb@None@) and \verb@__main__@. The latter is used
19 to provide the local and global name space for execution of the
20 complete program.
21 \bimodindex{sys}
22 \bimodindex{__main__}
23 \bimodindex{__builtin__}
25 The syntax for a complete Python program is that for file input,
26 described in the next section.
28 The interpreter may also be invoked in interactive mode; in this case,
29 it does not read and execute a complete program but reads and executes
30 one statement (possibly compound) at a time. The initial environment
31 is identical to that of a complete program; each statement is executed
32 in the name space of \verb@__main__@.
33 \index{interactive mode}
34 \bimodindex{__main__}
36 Under {\UNIX}, a complete program can be passed to the interpreter in
37 three forms: with the {\bf -c} {\it string} command line option, as a
38 file passed as the first command line argument, or as standard input.
39 If the file or standard input is a tty device, the interpreter enters
40 interactive mode; otherwise, it executes the file as a complete
41 program.
42 \index{UNIX}
43 \index{command line}
44 \index{standard input}
46 \section{File input}
48 All input read from non-interactive files has the same form:
50 \begin{verbatim}
51 file_input: (NEWLINE | statement)*
52 \end{verbatim}
54 This syntax is used in the following situations:
56 \begin{itemize}
58 \item when parsing a complete Python program (from a file or from a string);
60 \item when parsing a module;
62 \item when parsing a string passed to the \verb@exec@ statement;
64 \end{itemize}
66 \section{Interactive input}
68 Input in interactive mode is parsed using the following grammar:
70 \begin{verbatim}
71 interactive_input: [stmt_list] NEWLINE | compound_stmt NEWLINE
72 \end{verbatim}
74 Note that a (top-level) compound statement must be followed by a blank
75 line in interactive mode; this is needed to help the parser detect the
76 end of the input.
78 \section{Expression input}
79 \index{input}
81 There are two forms of expression input. Both ignore leading
82 whitespace.
84 The string argument to \verb@eval()@ must have the following form:
85 \bifuncindex{eval}
87 \begin{verbatim}
88 eval_input: condition_list NEWLINE*
89 \end{verbatim}
91 The input line read by \verb@input()@ must have the following form:
92 \bifuncindex{input}
94 \begin{verbatim}
95 input_input: condition_list NEWLINE
96 \end{verbatim}
98 Note: to read `raw' input line without interpretation, you can use the
99 built-in function \verb@raw_input()@ or the \verb@readline()@ method
100 of file objects.
101 \obindex{file}
102 \index{input!raw}
103 \index{raw input}
104 \bifuncindex{raw_index}
105 \ttindex{readline}