Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #43019
| References | <5161B4A1.80604@gmail.com> |
|---|---|
| Date | 2013-04-07 21:21 +0100 |
| Subject | Re: __doc__ string for getset members |
| From | Arnaud Delobelle <arnodel@gmail.com> |
| Newsgroups | comp.lang.python |
| Message-ID | <mailman.255.1365366070.3114.python-list@python.org> (permalink) |
On 7 April 2013 19:02, Nick Gnedin <ngnedin@gmail.com> wrote:
>
> Folks,
>
> I am writing an extension where I follow the guide on the web
> (http://docs.python.org/3.3/extending/newtypes.html#generic-attribute-management).
> I have an object declared,
>
> struct Object
> {
> PyObject_HEAD
> };
>
> and a member set through tp_getset mechanism,
>
> PyGetSetDef ObjectGetSet[] =
> {
> {"mem", (getter)MemGet, (setter)MemSet, "mem-doc-string", NULL},
> {NULL} /* Sentinel */
> };
>
> My question is - how do I access the doc string "mem-doc-string" supplied in
> the PyGetSetDef structure? If I type
>
> print(obj.mem.__doc__)
>
> then the __doc__ string for the result of a call to MemGet(...) is printed,
> not the doc string supplied in the PyGetSetDef structure.
>
That's not how Python works. You won't be able to get the docstring
of a descriptor this way. You need to do it from the class. The
behaviour you observe is normal and cannot be overriden.
--
Arnaud
Back to comp.lang.python | Previous | Next — Next in thread | Find similar | Unroll thread
Re: __doc__ string for getset members Arnaud Delobelle <arnodel@gmail.com> - 2013-04-07 21:21 +0100 Re: __doc__ string for getset members Steven D'Aprano <steve+comp.lang.python@pearwood.info> - 2013-04-07 21:35 +0000
csiph-web