• Guido van Rossum's avatar
    - Finally fixed the bug in compile() and exec where a string ending · 4b499dd3
    Guido van Rossum yazdı
      with an indented code block but no newline would raise SyntaxError.
      This would have been a four-line change in parsetok.c...  Except
      codeop.py depends on this behavior, so a compilation flag had to be
      invented that causes the tokenizer to revert to the old behavior;
      this required extra changes to 2 .h files, 2 .c files, and 2 .py
      files.  (Fixes SF bug #501622.)
    4b499dd3
parsetok.h 1.15 KB

/* Parser-tokenizer link interface */

#ifndef Py_PARSETOK_H
#define Py_PARSETOK_H
#ifdef __cplusplus
extern "C" {
#endif

typedef struct {
    int error;
    const char *filename;
    int lineno;
    int offset;
    char *text;
    int token;
    int expected;
} perrdetail;

#if 0
#define PyPARSE_YIELD_IS_KEYWORD	0x0001
#endif

#define PyPARSE_DONT_IMPLY_DEDENT	0x0002

PyAPI_FUNC(node *) PyParser_ParseString(const char *, grammar *, int,
                                              perrdetail *);
PyAPI_FUNC(node *) PyParser_ParseFile (FILE *, const char *, grammar *, int,
                                             char *, char *, perrdetail *);

PyAPI_FUNC(node *) PyParser_ParseStringFlags(const char *, grammar *, int,
                                              perrdetail *, int);
PyAPI_FUNC(node *) PyParser_ParseFileFlags(FILE *, const char *, grammar *,
						 int, char *, char *,
						 perrdetail *, int);

PyAPI_FUNC(node *) PyParser_ParseStringFlagsFilename(const char *,
					      const char *,
					      grammar *, int,
                                              perrdetail *, int);
#ifdef __cplusplus
}
#endif
#endif /* !Py_PARSETOK_H */