2005-10-20 16:59:25 -03:00
|
|
|
#ifndef Py_ASDL_H
|
|
|
|
#define Py_ASDL_H
|
|
|
|
|
|
|
|
typedef PyObject * identifier;
|
|
|
|
typedef PyObject * string;
|
2011-08-09 18:08:39 -03:00
|
|
|
typedef PyObject * bytes;
|
2005-10-20 16:59:25 -03:00
|
|
|
typedef PyObject * object;
|
2012-12-06 18:41:04 -04:00
|
|
|
typedef PyObject * singleton;
|
2016-01-25 19:40:57 -04:00
|
|
|
typedef PyObject * constant;
|
2005-10-20 16:59:25 -03:00
|
|
|
|
|
|
|
/* It would be nice if the code generated by asdl_c.py was completely
|
|
|
|
independent of Python, but it is a goal the requires too much work
|
|
|
|
at this stage. So, for example, I'll represent identifiers as
|
|
|
|
interned Python strings.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* XXX A sequence should be typed so that its use can be typechecked. */
|
|
|
|
|
|
|
|
typedef struct {
|
2012-05-15 09:45:03 -03:00
|
|
|
Py_ssize_t size;
|
2005-10-20 16:59:25 -03:00
|
|
|
void *elements[1];
|
|
|
|
} asdl_seq;
|
|
|
|
|
2006-04-21 07:40:58 -03:00
|
|
|
typedef struct {
|
2012-05-15 09:45:03 -03:00
|
|
|
Py_ssize_t size;
|
2006-04-21 07:40:58 -03:00
|
|
|
int elements[1];
|
|
|
|
} asdl_int_seq;
|
|
|
|
|
2013-10-12 17:52:43 -03:00
|
|
|
asdl_seq *_Py_asdl_seq_new(Py_ssize_t size, PyArena *arena);
|
|
|
|
asdl_int_seq *_Py_asdl_int_seq_new(Py_ssize_t size, PyArena *arena);
|
2005-10-20 16:59:25 -03:00
|
|
|
|
|
|
|
#define asdl_seq_GET(S, I) (S)->elements[(I)]
|
2006-02-28 13:58:27 -04:00
|
|
|
#define asdl_seq_LEN(S) ((S) == NULL ? 0 : (S)->size)
|
|
|
|
#ifdef Py_DEBUG
|
2013-11-15 19:16:58 -04:00
|
|
|
#define asdl_seq_SET(S, I, V) \
|
|
|
|
do { \
|
|
|
|
Py_ssize_t _asdl_i = (I); \
|
|
|
|
assert((S) != NULL); \
|
2018-11-22 09:45:16 -04:00
|
|
|
assert(0 <= _asdl_i && _asdl_i < (S)->size); \
|
2005-10-20 16:59:25 -03:00
|
|
|
(S)->elements[_asdl_i] = (V); \
|
2013-11-15 19:16:58 -04:00
|
|
|
} while (0)
|
2005-10-20 16:59:25 -03:00
|
|
|
#else
|
|
|
|
#define asdl_seq_SET(S, I, V) (S)->elements[I] = (V)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* !Py_ASDL_H */
|