diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2002-03-01 10:38:44 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2002-03-01 10:38:44 (GMT) |
commit | dbd55b3737e122b4cc06473f7b48aa9c8f114551 (patch) | |
tree | fa8122d34b6f241e911c75e46452fe128647a3fe /Modules/grpmodule.c | |
parent | 99866336094bd432860d32dd368f5934683939e7 (diff) | |
download | cpython-dbd55b3737e122b4cc06473f7b48aa9c8f114551.zip cpython-dbd55b3737e122b4cc06473f7b48aa9c8f114551.tar.gz cpython-dbd55b3737e122b4cc06473f7b48aa9c8f114551.tar.bz2 |
Patch #523268, #522027: return enhanced tuples.
Diffstat (limited to 'Modules/grpmodule.c')
-rw-r--r-- | Modules/grpmodule.c | 59 |
1 files changed, 51 insertions, 8 deletions
diff --git a/Modules/grpmodule.c b/Modules/grpmodule.c index a4b8ca3..daad574 100644 --- a/Modules/grpmodule.c +++ b/Modules/grpmodule.c @@ -2,17 +2,47 @@ /* UNIX group file access module */ #include "Python.h" +#include "structseq.h" #include <sys/types.h> #include <grp.h> +static PyStructSequence_Field struct_group_type_fields[] = { + {"gr_name", "group name"}, + {"gr_passwd", "password"}, + {"gr_gid", "group id"}, + {"gr_mem", "group memebers"}, + {0} +}; + +static char struct_group__doc__[] = +"grp.struct_group: Results from getgr*() routines.\n\n\ +This object may be accessed either as a tuple of\n\ + (gr_name,gr_passwd,gr_gid,gr_mem)\n\ +or via the object attributes as named in the above tuple.\n"; + +static PyStructSequence_Desc struct_group_type_desc = { + "grp.struct_group", + struct_group__doc__, + struct_group_type_fields, + 4, +}; + + +static PyTypeObject StructGrpType; static PyObject * mkgrent(struct group *p) { - PyObject *v, *w; + int setIndex = 0; + PyObject *v = PyStructSequence_New(&StructGrpType), *w; char **member; + + if (v == NULL) + return NULL; + if ((w = PyList_New(0)) == NULL) { + Py_DECREF(v); return NULL; } for (member = p->gr_mem; *member != NULL; member++) { @@ -20,16 +50,25 @@ mkgrent(struct group *p) if (x == NULL || PyList_Append(w, x) != 0) { Py_XDECREF(x); Py_DECREF(w); + Py_DECREF(v); return NULL; } Py_DECREF(x); } - v = Py_BuildValue("(sslO)", - p->gr_name, - p->gr_passwd, - (long)p->gr_gid, - w); - Py_DECREF(w); + +#define SET(i,val) PyStructSequence_SET_ITEM(v, i, val) + SET(setIndex++, PyString_FromString(p->gr_name)); + SET(setIndex++, PyString_FromString(p->gr_passwd)); + SET(setIndex++, PyInt_FromLong((long) p->gr_gid)); + SET(setIndex++, w); +#undef SET + + if (PyErr_Occurred()) { + Py_DECREF(v); + Py_DECREF(w); + return NULL; + } + return v; } @@ -120,5 +159,9 @@ complete membership information.)"; DL_EXPORT(void) initgrp(void) { - Py_InitModule3("grp", grp_methods, grp__doc__); + PyObject *m, *d; + m = Py_InitModule3("grp", grp_methods, grp__doc__); + d = PyModule_GetDict(m); + PyStructSequence_InitType(&StructGrpType, &struct_group_type_desc); + PyDict_SetItemString(d, "struct_group", (PyObject *) &StructGrpType); } |