summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1992-12-08 13:38:24 (GMT)
committerGuido van Rossum <guido@python.org>1992-12-08 13:38:24 (GMT)
commit2a7178efe1353aed277c0714e92a0790c84f7b88 (patch)
tree46809ce0318b86aebb6fafa9dea5d24db920641f /Modules
parent6209b97df4872f2e3954f0b18d38d79d7f0eeafc (diff)
downloadcpython-2a7178efe1353aed277c0714e92a0790c84f7b88.zip
cpython-2a7178efe1353aed277c0714e92a0790c84f7b88.tar.gz
cpython-2a7178efe1353aed277c0714e92a0790c84f7b88.tar.bz2
socketmodule.c: added socket.fromfd(fd, family, type, [proto]);
converted socket() to use of getargs().
Diffstat (limited to 'Modules')
-rw-r--r--Modules/socketmodule.c40
1 files changed, 32 insertions, 8 deletions
diff --git a/Modules/socketmodule.c b/Modules/socketmodule.c
index bb451eb..c66d38c 100644
--- a/Modules/socketmodule.c
+++ b/Modules/socketmodule.c
@@ -933,15 +933,12 @@ socket_socket(self, args)
object *args;
{
sockobject *s;
- int family, type, proto, fd;
- if (args != NULL && is_tupleobject(args) && gettuplesize(args) == 3) {
- if (!getintintintarg(args, &family, &type, &proto))
- return NULL;
- }
- else {
- if (!getintintarg(args, &family, &type))
+ int fd, family, type, proto;
+ proto = 0;
+ if (!getargs(args, "(ii)", &family, &type)) {
+ err_clear();
+ if (!getargs(args, "(iii)", &family, &type, &proto))
return NULL;
- proto = 0;
}
BGN_SAVE
fd = socket(family, type, proto);
@@ -960,6 +957,32 @@ socket_socket(self, args)
}
+/* Create a socket object from a numeric file description.
+ Useful e.g. if stdin is a socket.
+ Additional arguments as for socket(). */
+
+/*ARGSUSED*/
+static object *
+socket_fromfd(self, args)
+ object *self;
+ object *args;
+{
+ sockobject *s;
+ int fd, family, type, proto;
+ proto = 0;
+ if (!getargs(args, "(iii)", &fd, &family, &type)) {
+ err_clear();
+ if (!getargs(args, "(iiii)", &fd, &family, &type, &proto))
+ return NULL;
+ }
+ s = newsockobject(fd, family, type, proto);
+ /* From now on, ignore SIGPIPE and let the error checking
+ do the work. */
+ (void) signal(SIGPIPE, SIG_IGN);
+ return (object *) s;
+}
+
+
/* List of functions exported by this module. */
static struct methodlist socket_methods[] = {
@@ -967,6 +990,7 @@ static struct methodlist socket_methods[] = {
{"gethostname", socket_gethostname},
{"getservbyname", socket_getservbyname},
{"socket", socket_socket},
+ {"fromfd", socket_fromfd},
{NULL, NULL} /* Sentinel */
};