summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Modules/pwdmodule.c36
1 files changed, 32 insertions, 4 deletions
diff --git a/Modules/pwdmodule.c b/Modules/pwdmodule.c
index b7e0c92..e37e5fd 100644
--- a/Modules/pwdmodule.c
+++ b/Modules/pwdmodule.c
@@ -36,6 +36,17 @@ PERFORMANCE OF THIS SOFTWARE.
#include <sys/types.h>
#include <pwd.h>
+static char pwd__doc__ [] = "\
+This module provides access to the Unix password database.\n\
+It is available on all Unix versions.\n\
+\n\
+Password database entries are reported as 7-tuples containing the following\n\
+items from the password database (see `<pwd.h>'), in order:\n\
+pw_name, pw_passwd, pw_uid, pw_gid, pw_gecos, pw_dir, pw_shell.\n\
+The uid and gid items are integers, all others are strings. An\n\
+exception is raised if the entry asked for cannot be found.";
+
+
static PyObject *
mkpwent(p)
struct passwd *p;
@@ -58,6 +69,11 @@ mkpwent(p)
p->pw_shell);
}
+static char pwd_getpwuid__doc__[] = "\
+getpwuid(uid) -> entry\n\
+Return the password database entry for the given numeric user ID.\n\
+See pwd.__doc__ for more on password database entries.";
+
static PyObject *
pwd_getpwuid(self, args)
PyObject *self;
@@ -74,6 +90,11 @@ pwd_getpwuid(self, args)
return mkpwent(p);
}
+static char pwd_getpwnam__doc__[] = "\
+getpwnam(name) -> entry\n\
+Return the password database entry for the given user name.\n\
+See pwd.__doc__ for more on password database entries.";
+
static PyObject *
pwd_getpwnam(self, args)
PyObject *self;
@@ -91,6 +112,12 @@ pwd_getpwnam(self, args)
}
#ifdef HAVE_GETPWENT
+static char pwd_getpwall__doc__[] = "\
+getpwall() -> list_of_entries\n\
+Return a list of all available password database entries, \
+in arbitrary order.\n\
+See pwd.__doc__ for more on password database entries.";
+
static PyObject *
pwd_getpwall(self, args)
PyObject *self;
@@ -117,10 +144,10 @@ pwd_getpwall(self, args)
#endif
static PyMethodDef pwd_methods[] = {
- {"getpwuid", pwd_getpwuid},
- {"getpwnam", pwd_getpwnam},
+ {"getpwuid", pwd_getpwuid, 0, pwd_getpwuid__doc__},
+ {"getpwnam", pwd_getpwnam, 0, pwd_getpwnam__doc__},
#ifdef HAVE_GETPWENT
- {"getpwall", pwd_getpwall},
+ {"getpwall", pwd_getpwall, 0, pwd_getpwall__doc__},
#endif
{NULL, NULL} /* sentinel */
};
@@ -128,5 +155,6 @@ static PyMethodDef pwd_methods[] = {
void
initpwd()
{
- Py_InitModule("pwd", pwd_methods);
+ Py_InitModule4("pwd", pwd_methods, pwd__doc__,
+ (PyObject *)NULL, PYTHON_API_VERSION);
}