Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
dbd55b37
Commit
dbd55b37
authored
Mar 01, 2002
by
Martin v. Löwis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Patch #523268, #522027: return enhanced tuples.
parent
99866336
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
114 additions
and
23 deletions
+114
-23
Doc/lib/libgrp.tex
Doc/lib/libgrp.tex
+4
-3
Modules/grpmodule.c
Modules/grpmodule.c
+51
-8
Modules/pwdmodule.c
Modules/pwdmodule.c
+59
-12
No files found.
Doc/lib/libgrp.tex
View file @
dbd55b37
...
...
@@ -9,10 +9,11 @@
This module provides access to the
\UNIX
{}
group database.
It is available on all
\UNIX
{}
versions.
Group database entries are reported as 4-tuples containing the
following items from the group database (see
\code
{
<grp.h>
}
), in order:
Group database entries are reported as a tuple-like object, whose
attributes correspond to the members of the
\code
{
group
}
structure
(Attribute field below, see
\code
{
<pwd.h>
}
):
\begin{tableiii}
{
r|l|l
}{
textrm
}{
Index
}{
Field
}{
Meaning
}
\begin{tableiii}
{
r|l|l
}{
textrm
}{
Index
}{
Attribute
}{
Meaning
}
\lineiii
{
0
}{
gr
_
name
}{
the name of the group
}
\lineiii
{
1
}{
gr
_
passwd
}{
the (encrypted) group password; often empty
}
\lineiii
{
2
}{
gr
_
gid
}{
the numerical group ID
}
...
...
Modules/grpmodule.c
View file @
dbd55b37
...
...
@@ -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
);
}
Modules/pwdmodule.c
View file @
dbd55b37
...
...
@@ -2,10 +2,35 @@
/* UNIX password file access module */
#include "Python.h"
#include "structseq.h"
#include <sys/types.h>
#include <pwd.h>
static
PyStructSequence_Field
struct_pwd_type_fields
[]
=
{
{
"pw_name"
,
"user name"
},
{
"pw_passwd"
,
"password"
},
{
"pw_uid"
,
"user id"
},
{
"pw_gid"
,
"group id"
},
{
"pw_gecos"
,
"real name"
},
{
"pw_dir"
,
"home directory"
},
{
"pw_shell"
,
"shell program"
},
{
0
}
};
static
char
struct_passwd__doc__
[]
=
"pwd.struct_passwd: Results from getpw*() routines.
\n\n
\
This object may be accessed either as a tuple of
\n
\
(pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)
\n
\
or via the object attributes as named in the above tuple.
\n
"
;
static
PyStructSequence_Desc
struct_pwd_type_desc
=
{
"pwd.struct_passwd"
,
struct_passwd__doc__
,
struct_pwd_type_fields
,
7
,
};
static
char
pwd__doc__
[]
=
"\
This module provides access to the Unix password database.
\n
\
It is available on all Unix versions.
\n
\
...
...
@@ -17,22 +42,40 @@ 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
PyTypeObject
StructPwdType
;
static
PyObject
*
mkpwent
(
struct
passwd
*
p
)
{
return
Py_BuildValue
(
"(ssllsss)"
,
p
->
pw_name
,
p
->
pw_passwd
,
(
long
)
p
->
pw_uid
,
(
long
)
p
->
pw_gid
,
p
->
pw_gecos
,
p
->
pw_dir
,
p
->
pw_shell
);
int
setIndex
=
0
;
PyObject
*
v
=
PyStructSequence_New
(
&
StructPwdType
);
if
(
v
==
NULL
)
return
NULL
;
#define SETI(i,val) PyStructSequence_SET_ITEM(v, i, PyInt_FromLong((long) val))
#define SETS(i,val) PyStructSequence_SET_ITEM(v, i, PyString_FromString(val))
SETS
(
setIndex
++
,
p
->
pw_name
);
SETS
(
setIndex
++
,
p
->
pw_passwd
);
SETI
(
setIndex
++
,
p
->
pw_uid
);
SETI
(
setIndex
++
,
p
->
pw_gid
);
SETS
(
setIndex
++
,
p
->
pw_gecos
);
SETS
(
setIndex
++
,
p
->
pw_dir
);
SETS
(
setIndex
++
,
p
->
pw_shell
);
#undef SETS
#undef SETI
if
(
PyErr_Occurred
())
{
Py_XDECREF
(
v
);
return
NULL
;
}
return
v
;
}
static
char
pwd_getpwuid__doc__
[]
=
"\
getpwuid(uid) ->
entry
\n
\
getpwuid(uid) ->
(pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)
\n
\
Return the password database entry for the given numeric user ID.
\n
\
See pwd.__doc__ for more on password database entries."
;
...
...
@@ -51,7 +94,7 @@ pwd_getpwuid(PyObject *self, PyObject *args)
}
static
char
pwd_getpwnam__doc__
[]
=
"\
getpwnam(name) ->
entry
\n
\
getpwnam(name) ->
(pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)
\n
\
Return the password database entry for the given user name.
\n
\
See pwd.__doc__ for more on password database entries."
;
...
...
@@ -112,6 +155,10 @@ static PyMethodDef pwd_methods[] = {
DL_EXPORT
(
void
)
initpwd
(
void
)
{
Py_InitModule4
(
"pwd"
,
pwd_methods
,
pwd__doc__
,
PyObject
*
m
,
*
d
;
m
=
Py_InitModule4
(
"pwd"
,
pwd_methods
,
pwd__doc__
,
(
PyObject
*
)
NULL
,
PYTHON_API_VERSION
);
d
=
PyModule_GetDict
(
m
);
PyStructSequence_InitType
(
&
StructPwdType
,
&
struct_pwd_type_desc
);
PyDict_SetItemString
(
d
,
"struct_pwent"
,
(
PyObject
*
)
&
StructPwdType
);
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment