diff options
author | Anton Samokhvalov <pg83@yandex.ru> | 2022-02-10 16:45:17 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:17 +0300 |
commit | d3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch) | |
tree | dd4bd3ca0f36b817e96812825ffaf10d645803f2 /contrib/tools/cython/Cython/Includes/cpython/string.pxd | |
parent | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff) | |
download | ydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz |
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'contrib/tools/cython/Cython/Includes/cpython/string.pxd')
-rw-r--r-- | contrib/tools/cython/Cython/Includes/cpython/string.pxd | 394 |
1 files changed, 197 insertions, 197 deletions
diff --git a/contrib/tools/cython/Cython/Includes/cpython/string.pxd b/contrib/tools/cython/Cython/Includes/cpython/string.pxd index 19fcfd3452..8af78f3dde 100644 --- a/contrib/tools/cython/Cython/Includes/cpython/string.pxd +++ b/contrib/tools/cython/Cython/Includes/cpython/string.pxd @@ -1,198 +1,198 @@ from .object cimport PyObject - -cdef extern from "Python.h": - ctypedef struct va_list - - ############################################################################ - # 7.3.1 String Objects - ############################################################################ - - # These functions raise TypeError when expecting a string - # parameter and are called with a non-string parameter. - # PyStringObject - # This subtype of PyObject represents a Python string object. - # PyTypeObject PyString_Type - # This instance of PyTypeObject represents the Python string type; - # it is the same object as str and types.StringType in the Python - # layer. - - bint PyString_Check(object o) - # Return true if the object o is a string object or an instance of - # a subtype of the string type. - - bint PyString_CheckExact(object o) - # Return true if the object o is a string object, but not an instance of a subtype of the string type. - - object PyString_FromString(char *v) - # Return value: New reference. - # Return a new string object with the value v on success, and NULL - # on failure. The parameter v must not be NULL; it will not be - # checked. - - object PyString_FromStringAndSize(char *v, Py_ssize_t len) - # Return value: New reference. - # Return a new string object with the value v and length len on - # success, and NULL on failure. If v is NULL, the contents of the - # string are uninitialized. - - object PyString_FromFormat(char *format, ...) - # Return value: New reference. - # Take a C printf()-style format string and a variable number of - # arguments, calculate the size of the resulting Python string and - # return a string with the values formatted into it. The variable - # arguments must be C types and must correspond exactly to the - # format characters in the format string. The following format - # characters are allowed: - # Format Characters Type Comment - # %% n/a The literal % character. - # %c int A single character, represented as an C int. - # %d int Exactly equivalent to printf("%d"). - # %u unsigned int Exactly equivalent to printf("%u"). - # %ld long Exactly equivalent to printf("%ld"). - # %lu unsigned long Exactly equivalent to printf("%lu"). - # %zd Py_ssize_t Exactly equivalent to printf("%zd"). - # %zu size_t Exactly equivalent to printf("%zu"). - # %i int Exactly equivalent to printf("%i"). - # %x int Exactly equivalent to printf("%x"). - # %s char* A null-terminated C character array. - - # %p void* The hex representation of a C pointer. - # Mostly equivalent to printf("%p") except that it is guaranteed to - # start with the literal 0x regardless of what the platform's printf - # yields. - # An unrecognized format character causes all the rest of the - # format string to be copied as-is to the result string, and any - # extra arguments discarded. - - object PyString_FromFormatV(char *format, va_list vargs) - # Return value: New reference. - # Identical to PyString_FromFormat() except that it takes exactly two arguments. - - Py_ssize_t PyString_Size(object string) except -1 - # Return the length of the string in string object string. - - Py_ssize_t PyString_GET_SIZE(object string) - # Macro form of PyString_Size() but without error checking. - - char* PyString_AsString(object string) except NULL - # Return a NUL-terminated representation of the contents of - # string. The pointer refers to the internal buffer of string, not - # a copy. The data must not be modified in any way, unless the - # string was just created using PyString_FromStringAndSize(NULL, - # size). It must not be deallocated. If string is a Unicode - # object, this function computes the default encoding of string - # and operates on that. If string is not a string object at all, - # PyString_AsString() returns NULL and raises TypeError. - - char* PyString_AS_STRING(object string) - # Macro form of PyString_AsString() but without error - # checking. Only string objects are supported; no Unicode objects - # should be passed. - - int PyString_AsStringAndSize(object obj, char **buffer, Py_ssize_t *length) except -1 - # Return a NULL-terminated representation of the contents of the - # object obj through the output variables buffer and length. - # - # The function accepts both string and Unicode objects as - # input. For Unicode objects it returns the default encoded - # version of the object. If length is NULL, the resulting buffer - # may not contain NUL characters; if it does, the function returns - # -1 and a TypeError is raised. - - # The buffer refers to an internal string buffer of obj, not a - # copy. The data must not be modified in any way, unless the - # string was just created using PyString_FromStringAndSize(NULL, - # size). It must not be deallocated. If string is a Unicode - # object, this function computes the default encoding of string - # and operates on that. If string is not a string object at all, - # PyString_AsStringAndSize() returns -1 and raises TypeError. - - void PyString_Concat(PyObject **string, object newpart) - # Create a new string object in *string containing the contents of - # newpart appended to string; the caller will own the new - # reference. The reference to the old value of string will be - # stolen. If the new string cannot be created, the old reference - # to string will still be discarded and the value of *string will - # be set to NULL; the appropriate exception will be set. - - void PyString_ConcatAndDel(PyObject **string, object newpart) - # Create a new string object in *string containing the contents of - # newpart appended to string. This version decrements the - # reference count of newpart. - - int _PyString_Resize(PyObject **string, Py_ssize_t newsize) except -1 - # A way to resize a string object even though it is - # ``immutable''. Only use this to build up a brand new string - # object; don't use this if the string may already be known in - # other parts of the code. It is an error to call this function if - # the refcount on the input string object is not one. Pass the - # address of an existing string object as an lvalue (it may be - # written into), and the new size desired. On success, *string - # holds the resized string object and 0 is returned; the address - # in *string may differ from its input value. If the reallocation - # fails, the original string object at *string is deallocated, - # *string is set to NULL, a memory exception is set, and -1 is - # returned. - - object PyString_Format(object format, object args) - # Return value: New reference. Return a new string object from - # format and args. Analogous to format % args. The args argument - # must be a tuple. - - void PyString_InternInPlace(PyObject **string) - # Intern the argument *string in place. The argument must be the - # address of a pointer variable pointing to a Python string - # object. If there is an existing interned string that is the same - # as *string, it sets *string to it (decrementing the reference - # count of the old string object and incrementing the reference - # count of the interned string object), otherwise it leaves - # *string alone and interns it (incrementing its reference - # count). (Clarification: even though there is a lot of talk about - # reference counts, think of this function as - # reference-count-neutral; you own the object after the call if - # and only if you owned it before the call.) - - object PyString_InternFromString(char *v) - # Return value: New reference. - # A combination of PyString_FromString() and - # PyString_InternInPlace(), returning either a new string object - # that has been interned, or a new (``owned'') reference to an - # earlier interned string object with the same value. - - object PyString_Decode(char *s, Py_ssize_t size, char *encoding, char *errors) - # Return value: New reference. - # Create an object by decoding size bytes of the encoded buffer s - # using the codec registered for encoding. encoding and errors - # have the same meaning as the parameters of the same name in the - # unicode() built-in function. The codec to be used is looked up - # using the Python codec registry. Return NULL if an exception was - # raised by the codec. - - object PyString_AsDecodedObject(object str, char *encoding, char *errors) - # Return value: New reference. - # Decode a string object by passing it to the codec registered for - # encoding and return the result as Python object. encoding and - # errors have the same meaning as the parameters of the same name - # in the string encode() method. The codec to be used is looked up - # using the Python codec registry. Return NULL if an exception was - # raised by the codec. - - object PyString_Encode(char *s, Py_ssize_t size, char *encoding, char *errors) - # Return value: New reference. - # Encode the char buffer of the given size by passing it to the - # codec registered for encoding and return a Python - # object. encoding and errors have the same meaning as the - # parameters of the same name in the string encode() method. The - # codec to be used is looked up using the Python codec - # registry. Return NULL if an exception was raised by the codec. - - object PyString_AsEncodedObject(object str, char *encoding, char *errors) - # Return value: New reference. - # Encode a string object using the codec registered for encoding - # and return the result as Python object. encoding and errors have - # the same meaning as the parameters of the same name in the - # string encode() method. The codec to be used is looked up using - # the Python codec registry. Return NULL if an exception was - # raised by the codec. - - + +cdef extern from "Python.h": + ctypedef struct va_list + + ############################################################################ + # 7.3.1 String Objects + ############################################################################ + + # These functions raise TypeError when expecting a string + # parameter and are called with a non-string parameter. + # PyStringObject + # This subtype of PyObject represents a Python string object. + # PyTypeObject PyString_Type + # This instance of PyTypeObject represents the Python string type; + # it is the same object as str and types.StringType in the Python + # layer. + + bint PyString_Check(object o) + # Return true if the object o is a string object or an instance of + # a subtype of the string type. + + bint PyString_CheckExact(object o) + # Return true if the object o is a string object, but not an instance of a subtype of the string type. + + object PyString_FromString(char *v) + # Return value: New reference. + # Return a new string object with the value v on success, and NULL + # on failure. The parameter v must not be NULL; it will not be + # checked. + + object PyString_FromStringAndSize(char *v, Py_ssize_t len) + # Return value: New reference. + # Return a new string object with the value v and length len on + # success, and NULL on failure. If v is NULL, the contents of the + # string are uninitialized. + + object PyString_FromFormat(char *format, ...) + # Return value: New reference. + # Take a C printf()-style format string and a variable number of + # arguments, calculate the size of the resulting Python string and + # return a string with the values formatted into it. The variable + # arguments must be C types and must correspond exactly to the + # format characters in the format string. The following format + # characters are allowed: + # Format Characters Type Comment + # %% n/a The literal % character. + # %c int A single character, represented as an C int. + # %d int Exactly equivalent to printf("%d"). + # %u unsigned int Exactly equivalent to printf("%u"). + # %ld long Exactly equivalent to printf("%ld"). + # %lu unsigned long Exactly equivalent to printf("%lu"). + # %zd Py_ssize_t Exactly equivalent to printf("%zd"). + # %zu size_t Exactly equivalent to printf("%zu"). + # %i int Exactly equivalent to printf("%i"). + # %x int Exactly equivalent to printf("%x"). + # %s char* A null-terminated C character array. + + # %p void* The hex representation of a C pointer. + # Mostly equivalent to printf("%p") except that it is guaranteed to + # start with the literal 0x regardless of what the platform's printf + # yields. + # An unrecognized format character causes all the rest of the + # format string to be copied as-is to the result string, and any + # extra arguments discarded. + + object PyString_FromFormatV(char *format, va_list vargs) + # Return value: New reference. + # Identical to PyString_FromFormat() except that it takes exactly two arguments. + + Py_ssize_t PyString_Size(object string) except -1 + # Return the length of the string in string object string. + + Py_ssize_t PyString_GET_SIZE(object string) + # Macro form of PyString_Size() but without error checking. + + char* PyString_AsString(object string) except NULL + # Return a NUL-terminated representation of the contents of + # string. The pointer refers to the internal buffer of string, not + # a copy. The data must not be modified in any way, unless the + # string was just created using PyString_FromStringAndSize(NULL, + # size). It must not be deallocated. If string is a Unicode + # object, this function computes the default encoding of string + # and operates on that. If string is not a string object at all, + # PyString_AsString() returns NULL and raises TypeError. + + char* PyString_AS_STRING(object string) + # Macro form of PyString_AsString() but without error + # checking. Only string objects are supported; no Unicode objects + # should be passed. + + int PyString_AsStringAndSize(object obj, char **buffer, Py_ssize_t *length) except -1 + # Return a NULL-terminated representation of the contents of the + # object obj through the output variables buffer and length. + # + # The function accepts both string and Unicode objects as + # input. For Unicode objects it returns the default encoded + # version of the object. If length is NULL, the resulting buffer + # may not contain NUL characters; if it does, the function returns + # -1 and a TypeError is raised. + + # The buffer refers to an internal string buffer of obj, not a + # copy. The data must not be modified in any way, unless the + # string was just created using PyString_FromStringAndSize(NULL, + # size). It must not be deallocated. If string is a Unicode + # object, this function computes the default encoding of string + # and operates on that. If string is not a string object at all, + # PyString_AsStringAndSize() returns -1 and raises TypeError. + + void PyString_Concat(PyObject **string, object newpart) + # Create a new string object in *string containing the contents of + # newpart appended to string; the caller will own the new + # reference. The reference to the old value of string will be + # stolen. If the new string cannot be created, the old reference + # to string will still be discarded and the value of *string will + # be set to NULL; the appropriate exception will be set. + + void PyString_ConcatAndDel(PyObject **string, object newpart) + # Create a new string object in *string containing the contents of + # newpart appended to string. This version decrements the + # reference count of newpart. + + int _PyString_Resize(PyObject **string, Py_ssize_t newsize) except -1 + # A way to resize a string object even though it is + # ``immutable''. Only use this to build up a brand new string + # object; don't use this if the string may already be known in + # other parts of the code. It is an error to call this function if + # the refcount on the input string object is not one. Pass the + # address of an existing string object as an lvalue (it may be + # written into), and the new size desired. On success, *string + # holds the resized string object and 0 is returned; the address + # in *string may differ from its input value. If the reallocation + # fails, the original string object at *string is deallocated, + # *string is set to NULL, a memory exception is set, and -1 is + # returned. + + object PyString_Format(object format, object args) + # Return value: New reference. Return a new string object from + # format and args. Analogous to format % args. The args argument + # must be a tuple. + + void PyString_InternInPlace(PyObject **string) + # Intern the argument *string in place. The argument must be the + # address of a pointer variable pointing to a Python string + # object. If there is an existing interned string that is the same + # as *string, it sets *string to it (decrementing the reference + # count of the old string object and incrementing the reference + # count of the interned string object), otherwise it leaves + # *string alone and interns it (incrementing its reference + # count). (Clarification: even though there is a lot of talk about + # reference counts, think of this function as + # reference-count-neutral; you own the object after the call if + # and only if you owned it before the call.) + + object PyString_InternFromString(char *v) + # Return value: New reference. + # A combination of PyString_FromString() and + # PyString_InternInPlace(), returning either a new string object + # that has been interned, or a new (``owned'') reference to an + # earlier interned string object with the same value. + + object PyString_Decode(char *s, Py_ssize_t size, char *encoding, char *errors) + # Return value: New reference. + # Create an object by decoding size bytes of the encoded buffer s + # using the codec registered for encoding. encoding and errors + # have the same meaning as the parameters of the same name in the + # unicode() built-in function. The codec to be used is looked up + # using the Python codec registry. Return NULL if an exception was + # raised by the codec. + + object PyString_AsDecodedObject(object str, char *encoding, char *errors) + # Return value: New reference. + # Decode a string object by passing it to the codec registered for + # encoding and return the result as Python object. encoding and + # errors have the same meaning as the parameters of the same name + # in the string encode() method. The codec to be used is looked up + # using the Python codec registry. Return NULL if an exception was + # raised by the codec. + + object PyString_Encode(char *s, Py_ssize_t size, char *encoding, char *errors) + # Return value: New reference. + # Encode the char buffer of the given size by passing it to the + # codec registered for encoding and return a Python + # object. encoding and errors have the same meaning as the + # parameters of the same name in the string encode() method. The + # codec to be used is looked up using the Python codec + # registry. Return NULL if an exception was raised by the codec. + + object PyString_AsEncodedObject(object str, char *encoding, char *errors) + # Return value: New reference. + # Encode a string object using the codec registered for encoding + # and return the result as Python object. encoding and errors have + # the same meaning as the parameters of the same name in the + # string encode() method. The codec to be used is looked up using + # the Python codec registry. Return NULL if an exception was + # raised by the codec. + + |