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