1991-02-19 08:39:46 -04:00
|
|
|
|
1990-10-14 09:07:46 -03:00
|
|
|
/* Method object interface */
|
|
|
|
|
2000-07-08 21:20:36 -03:00
|
|
|
#ifndef Py_METHODOBJECT_H
|
|
|
|
#define Py_METHODOBJECT_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2004-10-28 13:32:00 -03:00
|
|
|
/* This is about the type 'builtin_function_or_method',
|
|
|
|
not Python methods in user-defined classes. See classobject.h
|
|
|
|
for the latter. */
|
|
|
|
|
2002-08-12 04:21:58 -03:00
|
|
|
PyAPI_DATA(PyTypeObject) PyCFunction_Type;
|
1990-10-14 09:07:46 -03:00
|
|
|
|
2007-12-18 22:45:37 -04:00
|
|
|
#define PyCFunction_Check(op) (Py_TYPE(op) == &PyCFunction_Type)
|
1990-10-14 09:07:46 -03:00
|
|
|
|
2000-07-09 00:09:57 -03:00
|
|
|
typedef PyObject *(*PyCFunction)(PyObject *, PyObject *);
|
2017-12-15 07:11:11 -04:00
|
|
|
typedef PyObject *(*_PyCFunctionFast) (PyObject *, PyObject *const *, Py_ssize_t);
|
2000-07-09 00:09:57 -03:00
|
|
|
typedef PyObject *(*PyCFunctionWithKeywords)(PyObject *, PyObject *,
|
2012-04-05 00:42:48 -03:00
|
|
|
PyObject *);
|
2017-07-03 15:20:15 -03:00
|
|
|
typedef PyObject *(*_PyCFunctionFastWithKeywords) (PyObject *,
|
2017-12-15 07:11:11 -04:00
|
|
|
PyObject *const *, Py_ssize_t,
|
2017-07-03 15:20:15 -03:00
|
|
|
PyObject *);
|
2001-08-12 18:52:24 -03:00
|
|
|
typedef PyObject *(*PyNoArgsFunction)(PyObject *);
|
1990-10-14 09:07:46 -03:00
|
|
|
|
2002-08-12 04:21:58 -03:00
|
|
|
PyAPI_FUNC(PyCFunction) PyCFunction_GetFunction(PyObject *);
|
|
|
|
PyAPI_FUNC(PyObject *) PyCFunction_GetSelf(PyObject *);
|
|
|
|
PyAPI_FUNC(int) PyCFunction_GetFlags(PyObject *);
|
1990-12-20 11:06:42 -04:00
|
|
|
|
1998-07-10 12:21:55 -03:00
|
|
|
/* Macros for direct access to these values. Type checks are *not*
|
|
|
|
done, so use with care. */
|
2010-12-03 16:14:31 -04:00
|
|
|
#ifndef Py_LIMITED_API
|
1998-07-10 12:21:55 -03:00
|
|
|
#define PyCFunction_GET_FUNCTION(func) \
|
|
|
|
(((PyCFunctionObject *)func) -> m_ml -> ml_meth)
|
|
|
|
#define PyCFunction_GET_SELF(func) \
|
2011-12-23 07:40:16 -04:00
|
|
|
(((PyCFunctionObject *)func) -> m_ml -> ml_flags & METH_STATIC ? \
|
|
|
|
NULL : ((PyCFunctionObject *)func) -> m_self)
|
1998-07-10 12:21:55 -03:00
|
|
|
#define PyCFunction_GET_FLAGS(func) \
|
2012-04-05 00:42:48 -03:00
|
|
|
(((PyCFunctionObject *)func) -> m_ml -> ml_flags)
|
2010-12-03 16:14:31 -04:00
|
|
|
#endif
|
2002-08-12 04:21:58 -03:00
|
|
|
PyAPI_FUNC(PyObject *) PyCFunction_Call(PyObject *, PyObject *, PyObject *);
|
1998-07-10 12:21:55 -03:00
|
|
|
|
2016-08-19 11:11:43 -03:00
|
|
|
#ifndef Py_LIMITED_API
|
2016-08-22 18:15:44 -03:00
|
|
|
PyAPI_FUNC(PyObject *) _PyCFunction_FastCallDict(PyObject *func,
|
2017-12-15 07:11:11 -04:00
|
|
|
PyObject *const *args,
|
2016-08-24 19:04:09 -03:00
|
|
|
Py_ssize_t nargs,
|
2016-08-19 11:11:43 -03:00
|
|
|
PyObject *kwargs);
|
|
|
|
#endif
|
|
|
|
|
1995-01-12 07:45:45 -04:00
|
|
|
struct PyMethodDef {
|
2012-04-05 00:42:48 -03:00
|
|
|
const char *ml_name; /* The name of the built-in function/method */
|
|
|
|
PyCFunction ml_meth; /* The C function that implements it */
|
|
|
|
int ml_flags; /* Combination of METH_xxx flags, which mostly
|
|
|
|
describe the args expected by the C func */
|
|
|
|
const char *ml_doc; /* The __doc__ attribute, or NULL */
|
1990-12-20 11:06:42 -04:00
|
|
|
};
|
1995-01-12 07:45:45 -04:00
|
|
|
typedef struct PyMethodDef PyMethodDef;
|
1990-12-20 11:06:42 -04:00
|
|
|
|
2012-12-26 16:52:04 -04:00
|
|
|
#define PyCFunction_New(ML, SELF) PyCFunction_NewEx((ML), (SELF), NULL)
|
2015-04-03 13:42:32 -03:00
|
|
|
PyAPI_FUNC(PyObject *) PyCFunction_NewEx(PyMethodDef *, PyObject *,
|
2012-04-05 00:42:48 -03:00
|
|
|
PyObject *);
|
1993-07-28 06:05:47 -03:00
|
|
|
|
1995-01-04 15:06:22 -04:00
|
|
|
/* Flag passed to newmethodobject */
|
2007-09-01 10:59:50 -03:00
|
|
|
/* #define METH_OLDARGS 0x0000 -- unsupported now */
|
1995-01-04 15:06:22 -04:00
|
|
|
#define METH_VARARGS 0x0001
|
1995-07-26 14:58:29 -03:00
|
|
|
#define METH_KEYWORDS 0x0002
|
2002-03-28 01:33:33 -04:00
|
|
|
/* METH_NOARGS and METH_O must not be combined with the flags above. */
|
2001-08-12 18:52:24 -03:00
|
|
|
#define METH_NOARGS 0x0004
|
|
|
|
#define METH_O 0x0008
|
1995-01-04 15:06:22 -04:00
|
|
|
|
2002-03-28 01:33:33 -04:00
|
|
|
/* METH_CLASS and METH_STATIC are a little different; these control
|
|
|
|
the construction of methods for a class. These cannot be used for
|
|
|
|
functions in modules. */
|
|
|
|
#define METH_CLASS 0x0010
|
|
|
|
#define METH_STATIC 0x0020
|
|
|
|
|
2006-08-17 02:42:55 -03:00
|
|
|
/* METH_COEXIST allows a method to be entered even though a slot has
|
2003-12-13 07:26:12 -04:00
|
|
|
already filled the entry. When defined, the flag allows a separate
|
2015-04-03 13:42:32 -03:00
|
|
|
method, "__contains__" for example, to coexist with a defined
|
2003-12-13 07:26:12 -04:00
|
|
|
slot like sq_contains. */
|
|
|
|
|
|
|
|
#define METH_COEXIST 0x0040
|
|
|
|
|
2016-09-12 10:55:21 -03:00
|
|
|
#ifndef Py_LIMITED_API
|
2016-09-09 21:40:22 -03:00
|
|
|
#define METH_FASTCALL 0x0080
|
2017-11-02 19:54:57 -03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* This bit is preserved for Stackless Python */
|
|
|
|
#ifdef STACKLESS
|
|
|
|
#define METH_STACKLESS 0x0100
|
|
|
|
#else
|
|
|
|
#define METH_STACKLESS 0x0000
|
|
|
|
#endif
|
2016-09-09 21:40:22 -03:00
|
|
|
|
2017-11-02 19:54:57 -03:00
|
|
|
#ifndef Py_LIMITED_API
|
1998-07-10 12:21:55 -03:00
|
|
|
typedef struct {
|
2000-07-08 21:20:36 -03:00
|
|
|
PyObject_HEAD
|
2004-10-28 13:32:00 -03:00
|
|
|
PyMethodDef *m_ml; /* Description of the C function to call */
|
|
|
|
PyObject *m_self; /* Passed as 'self' arg to the C func, can be NULL */
|
|
|
|
PyObject *m_module; /* The __module__ attribute, can be anything */
|
2014-08-06 20:31:40 -03:00
|
|
|
PyObject *m_weakreflist; /* List of weak references */
|
2019-05-29 15:31:52 -03:00
|
|
|
vectorcallfunc vectorcall;
|
1998-07-10 12:21:55 -03:00
|
|
|
} PyCFunctionObject;
|
2017-01-18 05:38:09 -04:00
|
|
|
|
|
|
|
PyAPI_FUNC(PyObject *) _PyMethodDef_RawFastCallDict(
|
|
|
|
PyMethodDef *method,
|
|
|
|
PyObject *self,
|
2017-12-15 07:11:11 -04:00
|
|
|
PyObject *const *args,
|
2017-01-18 05:38:09 -04:00
|
|
|
Py_ssize_t nargs,
|
|
|
|
PyObject *kwargs);
|
2017-02-02 18:43:03 -04:00
|
|
|
|
|
|
|
PyAPI_FUNC(PyObject *) _PyMethodDef_RawFastCallKeywords(
|
|
|
|
PyMethodDef *method,
|
|
|
|
PyObject *self,
|
2017-12-15 07:11:11 -04:00
|
|
|
PyObject *const *args,
|
2017-02-02 18:43:03 -04:00
|
|
|
Py_ssize_t nargs,
|
|
|
|
PyObject *kwnames);
|
2010-12-03 16:14:31 -04:00
|
|
|
#endif
|
1998-07-10 12:21:55 -03:00
|
|
|
|
Merged revisions 60481,60485,60489-60492,60494-60496,60498-60499,60501-60503,60505-60506,60508-60509,60523-60524,60532,60543,60545,60547-60548,60552,60554,60556-60559,60561-60562,60569,60571-60572,60574,60576-60583,60585-60586,60589,60591,60594-60595,60597-60598,60600-60601,60606-60612,60615,60617,60619-60621,60623-60625,60627-60629,60631,60633,60635,60647,60650,60652,60654,60656,60658-60659,60664-60666,60668-60670,60672,60676,60678,60680-60683,60685-60686,60688,60690,60692-60694,60697-60700,60705-60706,60708,60711,60714,60720,60724-60730,60732,60736,60742,60744,60746,60748,60750-60751,60753,60756-60757,60759-60761,60763-60764,60766,60769-60770,60774-60784,60787-60845 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r60790 | raymond.hettinger | 2008-02-14 10:32:45 +0100 (Thu, 14 Feb 2008) | 4 lines
Add diagnostic message to help figure-out why SocketServer tests occasionally crash
when trying to remove a pid that in not in the activechildren list.
........
r60791 | raymond.hettinger | 2008-02-14 11:46:57 +0100 (Thu, 14 Feb 2008) | 1 line
Add fixed-point examples to the decimal FAQ
........
r60792 | raymond.hettinger | 2008-02-14 12:01:10 +0100 (Thu, 14 Feb 2008) | 1 line
Improve rst markup
........
r60794 | raymond.hettinger | 2008-02-14 12:57:25 +0100 (Thu, 14 Feb 2008) | 1 line
Show how to remove exponents.
........
r60795 | raymond.hettinger | 2008-02-14 13:05:42 +0100 (Thu, 14 Feb 2008) | 1 line
Fix markup.
........
r60797 | christian.heimes | 2008-02-14 13:47:33 +0100 (Thu, 14 Feb 2008) | 1 line
Implemented Martin's suggestion to clear the free lists during the garbage collection of the highest generation.
........
r60798 | raymond.hettinger | 2008-02-14 13:49:37 +0100 (Thu, 14 Feb 2008) | 1 line
Simplify moneyfmt() recipe.
........
r60810 | raymond.hettinger | 2008-02-14 20:02:39 +0100 (Thu, 14 Feb 2008) | 1 line
Fix markup
........
r60811 | raymond.hettinger | 2008-02-14 20:30:30 +0100 (Thu, 14 Feb 2008) | 1 line
No need to register subclass of ABCs.
........
r60814 | thomas.heller | 2008-02-14 22:00:28 +0100 (Thu, 14 Feb 2008) | 1 line
Try to correct a markup error that does hide the following paragraph.
........
r60822 | christian.heimes | 2008-02-14 23:40:11 +0100 (Thu, 14 Feb 2008) | 1 line
Use a static and interned string for __subclasscheck__ and __instancecheck__ as suggested by Thomas Heller in #2115
........
r60827 | christian.heimes | 2008-02-15 07:57:08 +0100 (Fri, 15 Feb 2008) | 1 line
Fixed repr() and str() of complex numbers. Complex suffered from the same problem as floats but I forgot to test and fix them.
........
r60830 | christian.heimes | 2008-02-15 09:20:11 +0100 (Fri, 15 Feb 2008) | 2 lines
Bug #2111: mmap segfaults when trying to write a block opened with PROT_READ
Thanks to Thomas Herve for the fix.
........
r60835 | eric.smith | 2008-02-15 13:14:32 +0100 (Fri, 15 Feb 2008) | 1 line
In PyNumber_ToBase, changed from an assert to returning an error when PyObject_Index() returns something other than an int or long. It should never be possible to trigger this, as PyObject_Index checks to make sure it returns an int or long.
........
r60837 | skip.montanaro | 2008-02-15 20:03:59 +0100 (Fri, 15 Feb 2008) | 8 lines
Two new functions:
* place_summary_first copies the regrtest summary to the front of the file
making it easier to scan quickly for problems.
* count_failures gets the actual count of the number of failing tests, not
just a 1 (some failures) or 0 (no failures).
........
r60840 | raymond.hettinger | 2008-02-15 22:21:25 +0100 (Fri, 15 Feb 2008) | 1 line
Update example to match the current syntax.
........
r60841 | amaury.forgeotdarc | 2008-02-15 22:22:45 +0100 (Fri, 15 Feb 2008) | 8 lines
Issue #2115: __slot__ attributes setting was 10x slower.
Also correct a possible crash using ABCs.
This change is exactly the same as an optimisation
done 5 years ago, but on slot *access*:
http://svn.python.org/view?view=rev&rev=28297
........
r60842 | amaury.forgeotdarc | 2008-02-15 22:27:44 +0100 (Fri, 15 Feb 2008) | 2 lines
Temporarily let these tests pass
........
r60843 | kurt.kaiser | 2008-02-15 22:56:36 +0100 (Fri, 15 Feb 2008) | 2 lines
ScriptBinding event handlers weren't returning 'break'. Patch 2050, Tal Einat.
........
r60844 | kurt.kaiser | 2008-02-15 23:25:09 +0100 (Fri, 15 Feb 2008) | 4 lines
Configured selection highlighting colors were ignored; updating highlighting
in the config dialog would cause non-Python files to be colored as if they
were Python source; improve use of ColorDelagator. Patch 1334. Tal Einat.
........
r60845 | amaury.forgeotdarc | 2008-02-15 23:44:20 +0100 (Fri, 15 Feb 2008) | 9 lines
Re-enable tests, they were failing since gc.collect() clears the various freelists.
They still remain fragile.
For example, a call to assertEqual currently does not make any allocation
(which surprised me at first).
But this can change when gc.collect also deletes the numerous "zombie frames"
attached to each function.
........
2008-02-16 03:38:31 -04:00
|
|
|
PyAPI_FUNC(int) PyCFunction_ClearFreeList(void);
|
|
|
|
|
2012-06-22 15:55:41 -03:00
|
|
|
#ifndef Py_LIMITED_API
|
|
|
|
PyAPI_FUNC(void) _PyCFunction_DebugMallocStats(FILE *out);
|
|
|
|
PyAPI_FUNC(void) _PyMethod_DebugMallocStats(FILE *out);
|
|
|
|
#endif
|
|
|
|
|
1993-07-28 06:05:47 -03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* !Py_METHODOBJECT_H */
|