diff options
| author | blake2-ppc <blake2-ppc> | 2013-08-29 15:21:05 +0200 |
|---|---|---|
| committer | blake2-ppc <blake2-ppc> | 2013-08-29 15:51:39 +0200 |
| commit | b656bfaaa96dd8d242e6045e7e38b355992aca31 (patch) | |
| tree | 7ef98fddff583e4242363955a3b945c6ff074245 /src/libstd | |
| parent | 518bd073b4b41a5cca0892c1a7878a7b16836db1 (diff) | |
| download | rust-b656bfaaa96dd8d242e6045e7e38b355992aca31.tar.gz rust-b656bfaaa96dd8d242e6045e7e38b355992aca31.zip | |
std::str: Remove functions count_chars, count_bytes
These are very easy to replace with methods on string slices, basically
`.char_len()` and `.len()`.
These are the replacement implementations I did to clean these
functions up, but seeing this I propose removal:
/// ...
pub fn count_chars(s: &str, begin: uint, end: uint) -> uint {
// .slice() checks the char boundaries
s.slice(begin, end).char_len()
}
/// Counts the number of bytes taken by the first `n` chars in `s`
/// starting from byte index `begin`.
///
/// Fails if there are less than `n` chars past `begin`
pub fn count_bytes<'b>(s: &'b str, begin: uint, n: uint) -> uint {
s.slice_from(begin).slice_chars(0, n).len()
}
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/str.rs | 40 |
1 files changed, 0 insertions, 40 deletions
diff --git a/src/libstd/str.rs b/src/libstd/str.rs index 9ca6e8ad089..f70204d0274 100644 --- a/src/libstd/str.rs +++ b/src/libstd/str.rs @@ -907,46 +907,6 @@ pub fn with_capacity(capacity: uint) -> ~str { } } -/// As char_len but for a slice of a string -/// -/// # Arguments -/// -/// * s - A valid string -/// * start - The position inside `s` where to start counting in bytes -/// * end - The position where to stop counting -/// -/// # Return value -/// -/// The number of Unicode characters in `s` between the given indices. -pub fn count_chars(s: &str, start: uint, end: uint) -> uint { - assert!(s.is_char_boundary(start)); - assert!(s.is_char_boundary(end)); - let mut i = start; - let mut len = 0u; - while i < end { - let next = s.char_range_at(i).next; - len += 1u; - i = next; - } - return len; -} - -/// Counts the number of bytes taken by the first `n` chars in `s` -/// starting from `start`. -pub fn count_bytes<'b>(s: &'b str, start: uint, n: uint) -> uint { - assert!(s.is_char_boundary(start)); - let mut end = start; - let mut cnt = n; - let l = s.len(); - while cnt > 0u { - assert!(end < l); - let next = s.char_range_at(end).next; - cnt -= 1u; - end = next; - } - end - start -} - // https://tools.ietf.org/html/rfc3629 static UTF8_CHAR_WIDTH: [u8, ..256] = [ 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1, |
