diff options
author | Guido van Rossum <guido@python.org> | 1997-04-11 19:56:06 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1997-04-11 19:56:06 (GMT) |
commit | 3dc35b0c66e2f0fc33346447041ad287bbf3d330 (patch) | |
tree | 6fa5efdd6ad0501e2e74e31d8fcfa5b06cf28349 | |
parent | 1d2e240954ab52f44a6228e95f4f7d0267144b93 (diff) | |
download | cpython-3dc35b0c66e2f0fc33346447041ad287bbf3d330.zip cpython-3dc35b0c66e2f0fc33346447041ad287bbf3d330.tar.gz cpython-3dc35b0c66e2f0fc33346447041ad287bbf3d330.tar.bz2 |
My own patch: support writable 'softspace' attribute.
-rw-r--r-- | Modules/cStringIO.c | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/Modules/cStringIO.c b/Modules/cStringIO.c index 107f889..104ab51 100644 --- a/Modules/cStringIO.c +++ b/Modules/cStringIO.c @@ -58,6 +58,9 @@ $Log$ + Revision 2.5 1997/04/11 19:56:06 guido + My own patch: support writable 'softspace' attribute. + Revision 2.4 1997/04/09 17:35:33 guido Unknown changes by Jim Fulton. @@ -154,7 +157,7 @@ static char cStringIO_module_documentation[] = typedef struct { PyObject_HEAD char *buf; - int pos, string_size, buf_size, closed; + int pos, string_size, buf_size, closed, softspace; } Oobject; staticforward PyTypeObject Otype; @@ -453,6 +456,7 @@ newOobject(int size) { self->pos=0; self->closed = 0; self->string_size = 0; + self->softspace = 0; UNLESS(self->buf=malloc(size*sizeof(char))) { @@ -474,9 +478,26 @@ O_dealloc(Oobject *self) { static PyObject * O_getattr(Oobject *self, char *name) { + if (strcmp(name, "softspace") == 0) { + return PyInt_FromLong(self->softspace); + } return Py_FindMethod(O_methods, (PyObject *)self, name); } +static int +O_setattr(Oobject *self, char *name, PyObject *value) { + long x; + if (strcmp(name, "softspace") != 0) { + PyErr_SetString(PyExc_AttributeError, name); + return -1; + } + x = PyInt_AsLong(value); + if (x == -1 && PyErr_Occurred()) + return -1; + self->softspace = x; + return 0; +} + static char Otype__doc__[] = "Simple type for output to strings." ; @@ -491,7 +512,7 @@ static PyTypeObject Otype = { (destructor)O_dealloc, /*tp_dealloc*/ (printfunc)0, /*tp_print*/ (getattrfunc)O_getattr, /*tp_getattr*/ - (setattrfunc)0, /*tp_setattr*/ + (setattrfunc)O_setattr, /*tp_setattr*/ (cmpfunc)0, /*tp_compare*/ (reprfunc)0, /*tp_repr*/ 0, /*tp_as_number*/ |