/* stringlib: find/index implementation */ #ifndef STRINGLIB_FIND_H #define STRINGLIB_FIND_H #ifndef STRINGLIB_FASTSEARCH_H #error must include "stringlib/fastsearch.h" before including this module #endif Py_LOCAL_INLINE(Py_ssize_t) stringlib_find(const STRINGLIB_CHAR* str, Py_ssize_t str_len, const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, Py_ssize_t offset) { Py_ssize_t pos; if (sub_len == 0) { if (str_len < 0) return -1; return offset; } pos = fastsearch(str, str_len, sub, sub_len, FAST_SEARCH); if (pos >= 0) pos += offset; return pos; } Py_LOCAL_INLINE(Py_ssize_t) stringlib_rfind(const STRINGLIB_CHAR* str, Py_ssize_t str_len, const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, Py_ssize_t offset) { /* XXX - create reversefastsearch helper! */ if (sub_len == 0) { if (str_len < 0) return -1; return str_len + offset; } else { Py_ssize_t j, pos = -1; for (j = str_len - sub_len; j >= 0; --j) if (STRINGLIB_CMP(str+j, sub, sub_len) == 0) { pos = j + offset; break; } return pos; } } Py_LOCAL_INLINE(Py_ssize_t) stringlib_find_slice(const STRINGLIB_CHAR* str, Py_ssize_t str_len, const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, Py_ssize_t start, Py_ssize_t end) { if (start < 0) start += str_len; if (start < 0) start = 0; if (end > str_len) end = str_len; if (end < 0) end += str_len; if (end < 0) end = 0; return stringlib_find( str + start, end - start, sub, sub_len, start ); } Py_LOCAL_INLINE(Py_ssize_t) stringlib_rfind_slice(const STRINGLIB_CHAR* str, Py_ssize_t str_len, const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, Py_ssize_t start, Py_ssize_t end) { if (start < 0) start += str_len; if (start < 0) start = 0; if (end > str_len) end = str_len; if (end < 0) end += str_len; if (end < 0) end = 0; return stringlib_rfind(str + start, end - start, sub, sub_len, start); } #ifdef STRINGLIB_STR Py_LOCAL_INLINE(int) stringlib_contains_obj(PyObject* str, PyObject* sub) { return stringlib_find( STRINGLIB_STR(str), STRINGLIB_LEN(str), STRINGLIB_STR(sub), STRINGLIB_LEN(sub), 0 ) != -1; } #endif /* STRINGLIB_STR */ #endif /* STRINGLIB_FIND_H */ /* Local variables: c-basic-offset: 4 indent-tabs-mode: nil End: */