2021-12-09 15:59:26 -04:00
|
|
|
#ifndef Py_INTERNAL_BYTESOBJECT_H
|
|
|
|
#define Py_INTERNAL_BYTESOBJECT_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef Py_BUILD_CORE
|
|
|
|
# error "this header requires Py_BUILD_CORE define"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2022-03-02 09:15:26 -04:00
|
|
|
/* Substring Search.
|
|
|
|
|
2022-03-21 20:11:50 -03:00
|
|
|
Returns the index of the first occurrence of
|
2022-03-02 09:15:26 -04:00
|
|
|
a substring ("needle") in a larger text ("haystack").
|
|
|
|
If the needle is not found, return -1.
|
|
|
|
If the needle is found, add offset to the index.
|
|
|
|
*/
|
|
|
|
|
|
|
|
PyAPI_FUNC(Py_ssize_t)
|
|
|
|
_PyBytes_Find(const char *haystack, Py_ssize_t len_haystack,
|
|
|
|
const char *needle, Py_ssize_t len_needle,
|
|
|
|
Py_ssize_t offset);
|
|
|
|
|
|
|
|
/* Same as above, but search right-to-left */
|
|
|
|
PyAPI_FUNC(Py_ssize_t)
|
|
|
|
_PyBytes_ReverseFind(const char *haystack, Py_ssize_t len_haystack,
|
|
|
|
const char *needle, Py_ssize_t len_needle,
|
|
|
|
Py_ssize_t offset);
|
|
|
|
|
2022-03-28 05:43:45 -03:00
|
|
|
|
|
|
|
/** Helper function to implement the repeat and inplace repeat methods on a buffer
|
|
|
|
*
|
|
|
|
* len_dest is assumed to be an integer multiple of len_src.
|
|
|
|
* If src equals dest, then assume the operation is inplace.
|
|
|
|
*
|
|
|
|
* This method repeately doubles the number of bytes copied to reduce
|
|
|
|
* the number of invocations of memcpy.
|
|
|
|
*/
|
|
|
|
PyAPI_FUNC(void)
|
|
|
|
_PyBytes_Repeat(char* dest, Py_ssize_t len_dest,
|
|
|
|
const char* src, Py_ssize_t len_src);
|
|
|
|
|
2021-12-09 15:59:26 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* !Py_INTERNAL_BYTESOBJECT_H */
|