/src/cpython3/Objects/stringlib/find.h
Line | Count | Source (jump to first uncovered line) |
1 | | /* stringlib: find/index implementation */ |
2 | | |
3 | | #ifndef STRINGLIB_FASTSEARCH_H |
4 | | #error must include "stringlib/fastsearch.h" before including this module |
5 | | #endif |
6 | | |
7 | | Py_LOCAL_INLINE(Py_ssize_t) |
8 | | STRINGLIB(find)(const STRINGLIB_CHAR* str, Py_ssize_t str_len, |
9 | | const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, |
10 | | Py_ssize_t offset) |
11 | 300M | { |
12 | 300M | Py_ssize_t pos; |
13 | | |
14 | 300M | assert(str_len >= 0); |
15 | 300M | if (sub_len == 0) |
16 | 0 | return offset; |
17 | | |
18 | 300M | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); |
19 | | |
20 | 300M | if (pos >= 0) |
21 | 43.8k | pos += offset; |
22 | | |
23 | 300M | return pos; |
24 | 300M | } unicodeobject.c:asciilib_find Line | Count | Source | 11 | 10.3k | { | 12 | 10.3k | Py_ssize_t pos; | 13 | | | 14 | 10.3k | assert(str_len >= 0); | 15 | 10.3k | if (sub_len == 0) | 16 | 0 | return offset; | 17 | | | 18 | 10.3k | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); | 19 | | | 20 | 10.3k | if (pos >= 0) | 21 | 10.3k | pos += offset; | 22 | | | 23 | 10.3k | return pos; | 24 | 10.3k | } |
unicodeobject.c:ucs1lib_find Line | Count | Source | 11 | 300M | { | 12 | 300M | Py_ssize_t pos; | 13 | | | 14 | 300M | assert(str_len >= 0); | 15 | 300M | if (sub_len == 0) | 16 | 0 | return offset; | 17 | | | 18 | 300M | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); | 19 | | | 20 | 300M | if (pos >= 0) | 21 | 5.04k | pos += offset; | 22 | | | 23 | 300M | return pos; | 24 | 300M | } |
unicodeobject.c:ucs2lib_find Line | Count | Source | 11 | 16.2k | { | 12 | 16.2k | Py_ssize_t pos; | 13 | | | 14 | 16.2k | assert(str_len >= 0); | 15 | 16.2k | if (sub_len == 0) | 16 | 0 | return offset; | 17 | | | 18 | 16.2k | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); | 19 | | | 20 | 16.2k | if (pos >= 0) | 21 | 16.2k | pos += offset; | 22 | | | 23 | 16.2k | return pos; | 24 | 16.2k | } |
unicodeobject.c:ucs4lib_find Line | Count | Source | 11 | 10.6k | { | 12 | 10.6k | Py_ssize_t pos; | 13 | | | 14 | 10.6k | assert(str_len >= 0); | 15 | 10.6k | if (sub_len == 0) | 16 | 0 | return offset; | 17 | | | 18 | 10.6k | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); | 19 | | | 20 | 10.6k | if (pos >= 0) | 21 | 10.6k | pos += offset; | 22 | | | 23 | 10.6k | return pos; | 24 | 10.6k | } |
bytes_methods.c:stringlib_find Line | Count | Source | 11 | 3.39k | { | 12 | 3.39k | Py_ssize_t pos; | 13 | | | 14 | 3.39k | assert(str_len >= 0); | 15 | 3.39k | if (sub_len == 0) | 16 | 0 | return offset; | 17 | | | 18 | 3.39k | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_SEARCH); | 19 | | | 20 | 3.39k | if (pos >= 0) | 21 | 1.47k | pos += offset; | 22 | | | 23 | 3.39k | return pos; | 24 | 3.39k | } |
Unexecuted instantiation: bytearrayobject.c:stringlib_find Unexecuted instantiation: bytesobject.c:stringlib_find |
25 | | |
26 | | Py_LOCAL_INLINE(Py_ssize_t) |
27 | | STRINGLIB(rfind)(const STRINGLIB_CHAR* str, Py_ssize_t str_len, |
28 | | const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, |
29 | | Py_ssize_t offset) |
30 | 0 | { |
31 | 0 | Py_ssize_t pos; |
32 | |
|
33 | 0 | assert(str_len >= 0); |
34 | 0 | if (sub_len == 0) |
35 | 0 | return str_len + offset; |
36 | | |
37 | 0 | pos = FASTSEARCH(str, str_len, sub, sub_len, -1, FAST_RSEARCH); |
38 | |
|
39 | 0 | if (pos >= 0) |
40 | 0 | pos += offset; |
41 | |
|
42 | 0 | return pos; |
43 | 0 | } Unexecuted instantiation: unicodeobject.c:asciilib_rfind Unexecuted instantiation: unicodeobject.c:ucs1lib_rfind Unexecuted instantiation: unicodeobject.c:ucs2lib_rfind Unexecuted instantiation: unicodeobject.c:ucs4lib_rfind Unexecuted instantiation: bytes_methods.c:stringlib_rfind Unexecuted instantiation: bytearrayobject.c:stringlib_rfind Unexecuted instantiation: bytesobject.c:stringlib_rfind |
44 | | |
45 | | Py_LOCAL_INLINE(Py_ssize_t) |
46 | | STRINGLIB(find_slice)(const STRINGLIB_CHAR* str, Py_ssize_t str_len, |
47 | | const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, |
48 | | Py_ssize_t start, Py_ssize_t end) |
49 | 0 | { |
50 | 0 | return STRINGLIB(find)(str + start, end - start, sub, sub_len, start); |
51 | 0 | } Unexecuted instantiation: unicodeobject.c:asciilib_find_slice Unexecuted instantiation: unicodeobject.c:ucs1lib_find_slice Unexecuted instantiation: unicodeobject.c:ucs2lib_find_slice Unexecuted instantiation: unicodeobject.c:ucs4lib_find_slice Unexecuted instantiation: bytes_methods.c:stringlib_find_slice Unexecuted instantiation: bytearrayobject.c:stringlib_find_slice Unexecuted instantiation: bytesobject.c:stringlib_find_slice |
52 | | |
53 | | Py_LOCAL_INLINE(Py_ssize_t) |
54 | | STRINGLIB(rfind_slice)(const STRINGLIB_CHAR* str, Py_ssize_t str_len, |
55 | | const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, |
56 | | Py_ssize_t start, Py_ssize_t end) |
57 | 0 | { |
58 | 0 | return STRINGLIB(rfind)(str + start, end - start, sub, sub_len, start); |
59 | 0 | } Unexecuted instantiation: unicodeobject.c:asciilib_rfind_slice Unexecuted instantiation: unicodeobject.c:ucs1lib_rfind_slice Unexecuted instantiation: unicodeobject.c:ucs2lib_rfind_slice Unexecuted instantiation: unicodeobject.c:ucs4lib_rfind_slice Unexecuted instantiation: bytes_methods.c:stringlib_rfind_slice Unexecuted instantiation: bytearrayobject.c:stringlib_rfind_slice Unexecuted instantiation: bytesobject.c:stringlib_rfind_slice |
60 | | |
61 | | #ifdef STRINGLIB_WANT_CONTAINS_OBJ |
62 | | |
63 | | Py_LOCAL_INLINE(int) |
64 | | STRINGLIB(contains_obj)(PyObject* str, PyObject* sub) |
65 | | { |
66 | | return STRINGLIB(find)( |
67 | | STRINGLIB_STR(str), STRINGLIB_LEN(str), |
68 | | STRINGLIB_STR(sub), STRINGLIB_LEN(sub), 0 |
69 | | ) != -1; |
70 | | } |
71 | | |
72 | | #endif /* STRINGLIB_WANT_CONTAINS_OBJ */ |