| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 1 | #ifndef Py_LIMITED_API | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 2 | #ifndef Py_SYMTABLE_H | 
 | 3 | #define Py_SYMTABLE_H | 
| Neal Norwitz | 090b3dd | 2006-02-28 22:36:46 +0000 | [diff] [blame] | 4 |  | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 5 | #ifdef __cplusplus | 
 | 6 | extern "C" { | 
 | 7 | #endif | 
 | 8 |  | 
| Nick Coghlan | 650f0d0 | 2007-04-15 12:05:43 +0000 | [diff] [blame] | 9 | /* XXX(ncoghlan): This is a weird mix of public names and interpreter internal | 
 | 10 |  *                names. | 
 | 11 |  */ | 
 | 12 |  | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 13 | typedef enum _block_type { FunctionBlock, ClassBlock, ModuleBlock } | 
| Neal Norwitz | 62c2fac | 2005-10-24 00:30:44 +0000 | [diff] [blame] | 14 |     _Py_block_ty; | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 15 |  | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 16 | struct _symtable_entry; | 
 | 17 |  | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 18 | struct symtable { | 
| Victor Stinner | 00676d1 | 2010-12-27 01:49:31 +0000 | [diff] [blame] | 19 |     const char *st_filename;        /* name of file being compiled, | 
 | 20 |                                        decoded from the filesystem encoding */ | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 21 |     struct _symtable_entry *st_cur; /* current symbol table entry */ | 
 | 22 |     struct _symtable_entry *st_top; /* symbol table entry for module */ | 
 | 23 |     PyObject *st_blocks;            /* dict: map AST node addresses | 
 | 24 |                                      *       to symbol table entries */ | 
 | 25 |     PyObject *st_stack;             /* list: stack of namespace info */ | 
 | 26 |     PyObject *st_global;            /* borrowed ref to st_top->st_symbols */ | 
 | 27 |     int st_nblocks;                 /* number of blocks used */ | 
 | 28 |     PyObject *st_private;           /* name of current class or NULL */ | 
 | 29 |     PyFutureFeatures *st_future;    /* module's future features */ | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 30 | }; | 
 | 31 |  | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 32 | typedef struct _symtable_entry { | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 33 |     PyObject_HEAD | 
 | 34 |     PyObject *ste_id;        /* int: key in ste_table->st_blocks */ | 
 | 35 |     PyObject *ste_symbols;   /* dict: variable names to flags */ | 
 | 36 |     PyObject *ste_name;      /* string: name of current block */ | 
 | 37 |     PyObject *ste_varnames;  /* list of variable names */ | 
 | 38 |     PyObject *ste_children;  /* list of child blocks */ | 
 | 39 |     _Py_block_ty ste_type;   /* module, class, or function */ | 
 | 40 |     int ste_unoptimized;     /* false if namespace is optimized */ | 
 | 41 |     int ste_nested;      /* true if block is nested */ | 
 | 42 |     unsigned ste_free : 1;        /* true if block has free variables */ | 
 | 43 |     unsigned ste_child_free : 1;  /* true if a child block has free vars, | 
 | 44 |                                      including free refs to globals */ | 
 | 45 |     unsigned ste_generator : 1;   /* true if namespace is a generator */ | 
 | 46 |     unsigned ste_varargs : 1;     /* true if block has varargs */ | 
 | 47 |     unsigned ste_varkeywords : 1; /* true if block has varkeywords */ | 
 | 48 |     unsigned ste_returns_value : 1;  /* true if namespace uses return with | 
 | 49 |                                         an argument */ | 
 | 50 |     int ste_lineno;          /* first line of block */ | 
| Benjamin Peterson | d4efd9e | 2010-09-20 23:02:10 +0000 | [diff] [blame] | 51 |     int ste_col_offset;      /* offset of first line of block */ | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 52 |     int ste_opt_lineno;      /* lineno of last exec or import * */ | 
| Benjamin Peterson | d4efd9e | 2010-09-20 23:02:10 +0000 | [diff] [blame] | 53 |     int ste_opt_col_offset;  /* offset of last exec or import * */ | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 54 |     int ste_tmpname;         /* counter for listcomp temp vars */ | 
 | 55 |     struct symtable *ste_table; | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 56 | } PySTEntryObject; | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 57 |  | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 58 | PyAPI_DATA(PyTypeObject) PySTEntry_Type; | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 59 |  | 
| Christian Heimes | 90aa764 | 2007-12-19 02:45:37 +0000 | [diff] [blame] | 60 | #define PySTEntry_Check(op) (Py_TYPE(op) == &PySTEntry_Type) | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 61 |  | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 62 | PyAPI_FUNC(int) PyST_GetScope(PySTEntryObject *, PyObject *); | 
| Jeremy Hylton | cb17ae8 | 2001-02-09 22:22:18 +0000 | [diff] [blame] | 63 |  | 
| Victor Stinner | 00676d1 | 2010-12-27 01:49:31 +0000 | [diff] [blame] | 64 | PyAPI_FUNC(struct symtable *) PySymtable_Build( | 
 | 65 |     mod_ty mod, | 
 | 66 |     const char *filename,       /* decoded from the filesystem encoding */ | 
 | 67 |     PyFutureFeatures *future); | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 68 | PyAPI_FUNC(PySTEntryObject *) PySymtable_Lookup(struct symtable *, void *); | 
 | 69 |  | 
| Mark Hammond | 91a681d | 2002-08-12 07:21:58 +0000 | [diff] [blame] | 70 | PyAPI_FUNC(void) PySymtable_Free(struct symtable *); | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 71 |  | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 72 | /* Flags for def-use information */ | 
 | 73 |  | 
 | 74 | #define DEF_GLOBAL 1           /* global stmt */ | 
 | 75 | #define DEF_LOCAL 2            /* assignment in code block */ | 
 | 76 | #define DEF_PARAM 2<<1         /* formal parameter */ | 
| Jeremy Hylton | 81e9502 | 2007-02-27 06:50:52 +0000 | [diff] [blame] | 77 | #define DEF_NONLOCAL 2<<2      /* nonlocal stmt */ | 
 | 78 | #define USE 2<<3               /* name is used */ | 
| Benjamin Peterson | 78565b2 | 2009-06-28 19:19:51 +0000 | [diff] [blame] | 79 | #define DEF_FREE 2<<4          /* name used but not defined in nested block */ | 
 | 80 | #define DEF_FREE_CLASS 2<<5    /* free variable from class's method */ | 
 | 81 | #define DEF_IMPORT 2<<6        /* assignment occurred via import */ | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 82 |  | 
| Jeremy Hylton | 99858b5 | 2001-02-28 23:03:39 +0000 | [diff] [blame] | 83 | #define DEF_BOUND (DEF_LOCAL | DEF_PARAM | DEF_IMPORT) | 
 | 84 |  | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 85 | /* GLOBAL_EXPLICIT and GLOBAL_IMPLICIT are used internally by the symbol | 
| Antoine Pitrou | f95a1b3 | 2010-05-09 15:52:27 +0000 | [diff] [blame] | 86 |    table.  GLOBAL is returned from PyST_GetScope() for either of them. | 
| Jeremy Hylton | 81e9502 | 2007-02-27 06:50:52 +0000 | [diff] [blame] | 87 |    It is stored in ste_symbols at bits 12-15. | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 88 | */ | 
| Nick Coghlan | 650f0d0 | 2007-04-15 12:05:43 +0000 | [diff] [blame] | 89 | #define SCOPE_OFFSET 11 | 
| Jeremy Hylton | 81e9502 | 2007-02-27 06:50:52 +0000 | [diff] [blame] | 90 | #define SCOPE_MASK (DEF_GLOBAL | DEF_LOCAL | DEF_PARAM | DEF_NONLOCAL) | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 91 |  | 
 | 92 | #define LOCAL 1 | 
 | 93 | #define GLOBAL_EXPLICIT 2 | 
 | 94 | #define GLOBAL_IMPLICIT 3 | 
 | 95 | #define FREE 4 | 
 | 96 | #define CELL 5 | 
 | 97 |  | 
| Georg Brandl | 7cae87c | 2006-09-06 06:51:57 +0000 | [diff] [blame] | 98 | /* The following two names are used for the ste_unoptimized bit field */ | 
| Jeremy Hylton | 29906ee | 2001-02-27 04:23:34 +0000 | [diff] [blame] | 99 | #define OPT_IMPORT_STAR 1 | 
| Georg Brandl | 7cae87c | 2006-09-06 06:51:57 +0000 | [diff] [blame] | 100 | #define OPT_TOPLEVEL 2  /* top-level names, including eval and exec */ | 
| Jeremy Hylton | 3e0055f | 2005-10-20 19:59:25 +0000 | [diff] [blame] | 101 |  | 
 | 102 | #define GENERATOR 1 | 
 | 103 | #define GENERATOR_EXPRESSION 2 | 
| Jeremy Hylton | 29906ee | 2001-02-27 04:23:34 +0000 | [diff] [blame] | 104 |  | 
| Jeremy Hylton | 4b38da6 | 2001-02-02 18:19:15 +0000 | [diff] [blame] | 105 | #ifdef __cplusplus | 
 | 106 | } | 
 | 107 | #endif | 
 | 108 | #endif /* !Py_SYMTABLE_H */ | 
| Martin v. Löwis | 4d0d471 | 2010-12-03 20:14:31 +0000 | [diff] [blame] | 109 | #endif /* Py_LIMITED_API */ |