diff options
| author | Antoine Pitrou <solipsis@pitrou.net> | 2010-01-13 08:07:53 +0000 | 
|---|---|---|
| committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-01-13 08:07:53 +0000 | 
| commit | f2c5484f9ee9c964454b2d4a176170042e3beea5 (patch) | |
| tree | 56796a9587d43c252560bddc60ad864cbad0fa7a /Objects/stringlib/count.h | |
| parent | 5efea0430caf2c6e066ae2f32e4c28f65d42d69a (diff) | |
| download | cpython-git-f2c5484f9ee9c964454b2d4a176170042e3beea5.tar.gz | |
Merged revisions 77461 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
  r77461 | antoine.pitrou | 2010-01-13 08:55:48 +0100 (mer., 13 janv. 2010) | 5 lines
  Issue #7622: Improve the split(), rsplit(), splitlines() and replace()
  methods of bytes, bytearray and unicode objects by using a common
  implementation based on stringlib's fast search.  Patch by Florent Xicluna.
........
Diffstat (limited to 'Objects/stringlib/count.h')
| -rw-r--r-- | Objects/stringlib/count.h | 16 | 
1 files changed, 5 insertions, 11 deletions
| diff --git a/Objects/stringlib/count.h b/Objects/stringlib/count.h index eba37e9cc8..de34f96b3e 100644 --- a/Objects/stringlib/count.h +++ b/Objects/stringlib/count.h @@ -9,28 +9,22 @@  Py_LOCAL_INLINE(Py_ssize_t)  stringlib_count(const STRINGLIB_CHAR* str, Py_ssize_t str_len, -                const STRINGLIB_CHAR* sub, Py_ssize_t sub_len) +                const STRINGLIB_CHAR* sub, Py_ssize_t sub_len, +                Py_ssize_t maxcount)  {      Py_ssize_t count;      if (str_len < 0)          return 0; /* start > len(str) */      if (sub_len == 0) -        return str_len + 1; +        return (str_len < maxcount) ? str_len + 1 : maxcount; -    count = fastsearch(str, str_len, sub, sub_len, FAST_COUNT); +    count = fastsearch(str, str_len, sub, sub_len, maxcount, FAST_COUNT);      if (count < 0) -        count = 0; /* no match */ +        return 0; /* no match */      return count;  }  #endif - -/* -Local variables: -c-basic-offset: 4 -indent-tabs-mode: nil -End: -*/ | 
