summaryrefslogtreecommitdiffstats
path: root/Objects/methodobject.c
diff options
context:
space:
mode:
authorLarry Hastings <larry@hastings.org>2014-01-24 14:17:25 (GMT)
committerLarry Hastings <larry@hastings.org>2014-01-24 14:17:25 (GMT)
commit5c66189e88034ba807b10422a8750b0c71c4b62b (patch)
tree541626d6d627396acaccab565e936d35c3b99173 /Objects/methodobject.c
parentb3c0f4067d992fc2c0d8578e308cc7167dc98f32 (diff)
downloadcpython-5c66189e88034ba807b10422a8750b0c71c4b62b.zip
cpython-5c66189e88034ba807b10422a8750b0c71c4b62b.tar.gz
cpython-5c66189e88034ba807b10422a8750b0c71c4b62b.tar.bz2
Issue #20189: Four additional builtin types (PyTypeObject,
PyMethodDescr_Type, _PyMethodWrapper_Type, and PyWrapperDescr_Type) have been modified to provide introspection information for builtins. Also: many additional Lib, test suite, and Argument Clinic fixes.
Diffstat (limited to 'Objects/methodobject.c')
-rw-r--r--Objects/methodobject.c67
1 files changed, 6 insertions, 61 deletions
diff --git a/Objects/methodobject.c b/Objects/methodobject.c
index 6179aee..227ad57 100644
--- a/Objects/methodobject.c
+++ b/Objects/methodobject.c
@@ -179,75 +179,20 @@ static PyMethodDef meth_methods[] = {
{NULL, NULL}
};
-/*
- * finds the docstring's introspection signature.
- * if present, returns a pointer pointing to the first '('.
- * otherwise returns NULL.
- */
-static const char *find_signature(PyCFunctionObject *m)
-{
- const char *trace = m->m_ml->ml_doc;
- const char *name = m->m_ml->ml_name;
- size_t length;
- if (!trace || !name)
- return NULL;
- length = strlen(name);
- if (strncmp(trace, name, length))
- return NULL;
- trace += length;
- if (*trace != '(')
- return NULL;
- return trace;
-}
-
-/*
- * skips to the end of the docstring's instrospection signature.
- */
-static const char *skip_signature(const char *trace)
-{
- while (*trace && *trace != '\n')
- trace++;
- return trace;
-}
-
-static const char *skip_eols(const char *trace)
-{
- while (*trace == '\n')
- trace++;
- return trace;
-}
-
static PyObject *
meth_get__text_signature__(PyCFunctionObject *m, void *closure)
{
- const char *start = find_signature(m);
- const char *trace;
-
- if (!start) {
- Py_INCREF(Py_None);
- return Py_None;
- }
-
- trace = skip_signature(start);
- return PyUnicode_FromStringAndSize(start, trace - start);
+ const char *name = m->m_ml->ml_name;
+ const char *doc = m->m_ml->ml_doc;
+ return _PyType_GetTextSignatureFromInternalDoc(name, doc);
}
static PyObject *
meth_get__doc__(PyCFunctionObject *m, void *closure)
{
- const char *doc = find_signature(m);
-
- if (doc)
- doc = skip_eols(skip_signature(doc));
- else
- doc = m->m_ml->ml_doc;
-
- if (!doc) {
- Py_INCREF(Py_None);
- return Py_None;
- }
-
- return PyUnicode_FromString(doc);
+ const char *name = m->m_ml->ml_name;
+ const char *doc = m->m_ml->ml_doc;
+ return _PyType_GetDocFromInternalDoc(name, doc);
}
static PyObject *