use std::cmp::Ordering;
const GENERAL_CATEGORY_MARK: &'static [(char, char)] = include!("tables/general_category_mark.rsv");
pub fn is_combining_mark(c: char) -> bool {
bsearch_range_table(c, GENERAL_CATEGORY_MARK)
}
fn bsearch_range_table(c: char, r: &'static [(char, char)]) -> bool {
r.binary_search_by(|&(lo, hi)| if lo <= c && c <= hi {
Ordering::Equal
} else if hi < c {
Ordering::Less
} else {
Ordering::Greater
}).is_ok()
}
#[cfg(test)]
mod tests {
use std::char;
use super::*;
#[test]
fn test_is_combining_mark_ascii() {
for cp in 0..0x7f {
assert!(!is_combining_mark(char::from_u32(cp).unwrap()));
}
}
#[test]
fn test_is_combining_mark_misc() {
assert!(is_combining_mark('\u{11C3A}'));
assert!(is_combining_mark('\u{11C3F}'));
}
}