8
/* Error codes passed around between file input, tokenizer, parser and
9
interpreter. This is necessary so we can turn them into Python
10
exceptions at a higher level. Note that some errors have a
11
slightly different meaning when passed from the tokenizer to the
12
parser than when passed from the parser to the interpreter; e.g.
13
the parser only returns E_EOF when it hits EOF immediately, and it
14
never returns E_OK. */
16
#define E_OK 10 /* No error */
17
#define E_EOF 11 /* End Of File */
18
#define E_INTR 12 /* Interrupted */
19
#define E_TOKEN 13 /* Bad token */
20
#define E_SYNTAX 14 /* Syntax error */
21
#define E_NOMEM 15 /* Ran out of memory */
22
#define E_DONE 16 /* Parsing complete */
23
#define E_ERROR 17 /* Execution error */
24
#define E_TABSPACE 18 /* Inconsistent mixing of tabs and spaces */
25
#define E_OVERFLOW 19 /* Node had too many children */
26
#define E_TOODEEP 20 /* Too many indentation levels */
27
#define E_DEDENT 21 /* No matching outer block for dedent */
28
#define E_DECODE 22 /* Error in decoding into Unicode */
29
#define E_EOFS 23 /* EOF in triple-quoted string */
30
#define E_EOLS 24 /* EOL in single-quoted string */
31
#define E_LINECONT 25 /* Unexpected characters after a line continuation */
36
#endif /* !Py_ERRCODE_H */