summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Modules/parsermodule.c132
1 files changed, 97 insertions, 35 deletions
diff --git a/Modules/parsermodule.c b/Modules/parsermodule.c
index 7f994d0..6e7d889 100644
--- a/Modules/parsermodule.c
+++ b/Modules/parsermodule.c
@@ -183,6 +183,8 @@ staticforward void parser_free Py_PROTO((PyAST_Object *ast));
staticforward int parser_compare Py_PROTO((PyAST_Object *left,
PyAST_Object *right));
+staticforward PyObject *parser_getattr Py_PROTO((PyObject *self, char *name));
+
/* static */
PyTypeObject PyAST_Type = {
@@ -194,7 +196,7 @@ PyTypeObject PyAST_Type = {
0, /* tp_itemsize */
(destructor)parser_free, /* tp_dealloc */
0, /* tp_print */
- 0, /* tp_getattr */
+ parser_getattr, /* tp_getattr */
0, /* tp_setattr */
(cmpfunc)parser_compare, /* tp_compare */
0, /* tp_repr */
@@ -321,25 +323,28 @@ parser_free(ast)
*/
static PyObject*
parser_ast2tuple(self, args)
- PyObject *self;
+ PyAST_Object *self;
PyObject *args;
{
- PyObject *ast;
PyObject *line_option = 0;
PyObject *res = 0;
+ int ok;
- if (PyArg_ParseTuple(args, "O!|O:ast2tuple", &PyAST_Type, &ast,
- &line_option)) {
+ if (self == NULL)
+ ok = PyArg_ParseTuple(
+ args, "O!|O:ast2tuple", &PyAST_Type, &self, &line_option);
+ else
+ ok = PyArg_ParseTuple(args, "|O:totuple", &line_option);
+ if (ok) {
int lineno = 0;
- if (line_option != 0) {
- lineno = PyObject_IsTrue(line_option);
- lineno = lineno ? 1 : 0;
+ if (line_option != NULL) {
+ lineno = PyObject_IsTrue(line_option) ? 1 : 0;
}
/*
* Convert AST into a tuple representation. Use Guido's function,
* since it's known to work already.
*/
- res = node2tuple(((PyAST_Object*)ast)->ast_node,
+ res = node2tuple(((PyAST_Object*)self)->ast_node,
PyTuple_New, PyTuple_SetItem, lineno);
}
return (res);
@@ -355,25 +360,28 @@ parser_ast2tuple(self, args)
*/
static PyObject*
parser_ast2list(self, args)
- PyObject *self;
+ PyAST_Object *self;
PyObject *args;
{
- PyObject *ast;
PyObject *line_option = 0;
PyObject *res = 0;
+ int ok;
- if (PyArg_ParseTuple(args, "O!|O:ast2list", &PyAST_Type, &ast,
- &line_option)) {
+ if (self == NULL)
+ ok = PyArg_ParseTuple(
+ args, "O!|O:ast2list", &PyAST_Type, &self, &line_option);
+ else
+ ok = PyArg_ParseTuple(args, "|O:tolist", &line_option);
+ if (ok) {
int lineno = 0;
if (line_option != 0) {
- lineno = PyObject_IsTrue(line_option);
- lineno = lineno ? 1 : 0;
+ lineno = PyObject_IsTrue(line_option) ? 1 : 0;
}
/*
* Convert AST into a tuple representation. Use Guido's function,
* since it's known to work already.
*/
- res = node2tuple(((PyAST_Object*)ast)->ast_node,
+ res = node2tuple(((PyAST_Object *)self)->ast_node,
PyList_New, PyList_SetItem, lineno);
}
return (res);
@@ -389,15 +397,21 @@ parser_ast2list(self, args)
*/
static PyObject*
parser_compileast(self, args)
- PyObject *self;
+ PyAST_Object *self;
PyObject *args;
{
- PyAST_Object* ast;
PyObject* res = 0;
char* str = "<ast>";
+ int ok;
- if (PyArg_ParseTuple(args, "O!|s", &PyAST_Type, &ast, &str))
- res = (PyObject*) PyNode_Compile(ast->ast_node, str);
+ if (self == NULL)
+ ok = PyArg_ParseTuple(
+ args, "O!|s:compileast", &PyAST_Type, &self, &str);
+ else
+ ok = PyArg_ParseTuple(args, "|s:compile", &str);
+
+ if (ok)
+ res = (PyObject *)PyNode_Compile(self->ast_node, str);
return (res);
@@ -413,17 +427,20 @@ parser_compileast(self, args)
*/
static PyObject*
parser_isexpr(self, args)
- PyObject *self;
+ PyAST_Object *self;
PyObject *args;
{
- PyAST_Object* ast;
PyObject* res = 0;
+ int ok;
- if (PyArg_ParseTuple(args, "O!:isexpr", &PyAST_Type, &ast)) {
- /*
- * Check to see if the AST represents an expression or not.
- */
- res = (ast->ast_type == PyAST_EXPR) ? Py_True : Py_False;
+ if (self == NULL)
+ ok = PyArg_ParseTuple(args, "O!:isexpr", &PyAST_Type, &self);
+ else
+ ok = PyArg_ParseTuple(args, ":isexpr");
+
+ if (ok) {
+ /* Check to see if the AST represents an expression or not. */
+ res = (self->ast_type == PyAST_EXPR) ? Py_True : Py_False;
Py_INCREF(res);
}
return (res);
@@ -433,17 +450,20 @@ parser_isexpr(self, args)
static PyObject*
parser_issuite(self, args)
- PyObject *self;
+ PyAST_Object *self;
PyObject *args;
{
- PyAST_Object* ast;
PyObject* res = 0;
+ int ok;
- if (PyArg_ParseTuple(args, "O!:issuite", &PyAST_Type, &ast)) {
- /*
- * Check to see if the AST represents an expression or not.
- */
- res = (ast->ast_type == PyAST_EXPR) ? Py_False : Py_True;
+ if (self == NULL)
+ ok = PyArg_ParseTuple(args, "O!:issuite", &PyAST_Type, &self);
+ else
+ ok = PyArg_ParseTuple(args, ":issuite");
+
+ if (ok) {
+ /* Check to see if the AST represents an expression or not. */
+ res = (self->ast_type == PyAST_EXPR) ? Py_False : Py_True;
Py_INCREF(res);
}
return (res);
@@ -451,6 +471,35 @@ parser_issuite(self, args)
} /* parser_issuite() */
+static PyMethodDef
+parser_methods[] = {
+ {"compile", parser_compileast, METH_VARARGS},
+ {"isexpr", parser_isexpr, METH_VARARGS},
+ {"issuite", parser_issuite, METH_VARARGS},
+ {"tolist", parser_ast2list, METH_VARARGS},
+ {"totuple", parser_ast2tuple, METH_VARARGS},
+
+ {NULL}
+};
+
+static PyObject*
+parser_method_list = NULL;
+
+
+static PyObject*
+parser_getattr(self, name)
+ PyObject *self;
+ char *name;
+{
+ if (strcmp(name, "__methods__") == 0) {
+ Py_INCREF(parser_method_list);
+ return (parser_method_list);
+ }
+ return (Py_FindMethod(parser_methods, self, name));
+
+} /* parser_getattr() */
+
+
/* err_string(char* message)
*
* Sets the error string for an exception of type ParserError.
@@ -2668,7 +2717,6 @@ initparser()
{
PyObject* module;
PyObject* dict;
- PyObject *temp;
PyAST_Type.ob_type = &PyType_Type;
module = Py_InitModule("parser", parser_functions);
@@ -2696,6 +2744,20 @@ initparser()
PyDict_SetItemString(dict, "__version__",
PyString_FromString(parser_version_string));
+ parser_method_list = PyList_New(0);
+ if (parser_method_list != NULL) {
+ PyMethodDef *mdef = parser_methods;
+
+ while (mdef->ml_name != NULL) {
+ PyObject *temp = PyString_FromString(mdef->ml_name);
+ if (temp != NULL) {
+ PyList_Append(parser_method_list, temp);
+ Py_DECREF(temp);
+ }
+ ++mdef;
+ }
+ }
+
/* register to support pickling */
module = PyImport_ImportModule("copy_reg");
if (module != NULL) {