2019-01-11 16:32:31 +00:00
|
|
|
// Original implementation taken from rust-memchr.
|
2016-09-22 00:10:37 +00:00
|
|
|
// Copyright 2015 Andrew Gallant, bluss and Nicolas Koch
|
|
|
|
|
|
|
|
|
|
pub fn memchr(needle: u8, haystack: &[u8]) -> Option<usize> {
|
|
|
|
|
let p = unsafe {
|
|
|
|
|
libc::memchr(
|
|
|
|
|
haystack.as_ptr() as *const libc::c_void,
|
|
|
|
|
needle as libc::c_int,
|
2019-11-27 10:28:39 -08:00
|
|
|
haystack.len(),
|
|
|
|
|
)
|
2016-09-22 00:10:37 +00:00
|
|
|
};
|
2019-11-27 10:28:39 -08:00
|
|
|
if p.is_null() { None } else { Some(p as usize - (haystack.as_ptr() as usize)) }
|
2016-09-22 00:10:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub fn memrchr(needle: u8, haystack: &[u8]) -> Option<usize> {
|
|
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
|
fn memrchr_specific(needle: u8, haystack: &[u8]) -> Option<usize> {
|
|
|
|
|
// GNU's memrchr() will - unlike memchr() - error if haystack is empty.
|
2019-11-27 10:28:39 -08:00
|
|
|
if haystack.is_empty() {
|
|
|
|
|
return None;
|
|
|
|
|
}
|
2016-09-22 00:10:37 +00:00
|
|
|
let p = unsafe {
|
|
|
|
|
libc::memrchr(
|
|
|
|
|
haystack.as_ptr() as *const libc::c_void,
|
|
|
|
|
needle as libc::c_int,
|
2019-11-27 10:28:39 -08:00
|
|
|
haystack.len(),
|
|
|
|
|
)
|
2016-09-22 00:10:37 +00:00
|
|
|
};
|
2019-11-27 10:28:39 -08:00
|
|
|
if p.is_null() { None } else { Some(p as usize - (haystack.as_ptr() as usize)) }
|
2016-09-22 00:10:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[cfg(not(target_os = "linux"))]
|
|
|
|
|
fn memrchr_specific(needle: u8, haystack: &[u8]) -> Option<usize> {
|
2019-02-11 04:23:21 +09:00
|
|
|
core::slice::memchr::memrchr(needle, haystack)
|
2016-09-22 00:10:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
memrchr_specific(needle, haystack)
|
|
|
|
|
}
|