// Copyright 2014-2017 The html5ever Project Developers. See the // COPYRIGHT file at the top-level directory of this distribution. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. /// If `c` is an ASCII letter, return the corresponding lowercase /// letter, otherwise None. pub fn lower_ascii_letter(c: char) -> Option { match c { 'a'..='z' => Some(c), 'A'..='Z' => Some((c as u8 - b'A' + b'a') as char), _ => None, } } /// Is the character an ASCII alphanumeric character? pub fn is_ascii_alnum(c: char) -> bool { matches!(c, '0'..='9' | 'a'..='z' | 'A'..='Z') } #[cfg(test)] #[allow(non_snake_case)] mod test { use super::{is_ascii_alnum, lower_ascii_letter}; /// Generate a test function `$name` which asserts that `$left` and `$right` /// are equal. macro_rules! test_eq { ($name:ident, $left:expr, $right:expr) => { #[test] fn $name() { assert_eq!($left, $right); } }; } test_eq!(lower_letter_a_is_a, lower_ascii_letter('a'), Some('a')); test_eq!(lower_letter_A_is_a, lower_ascii_letter('A'), Some('a')); test_eq!(lower_letter_symbol_is_None, lower_ascii_letter('!'), None); test_eq!( lower_letter_nonascii_is_None, lower_ascii_letter('\u{a66e}'), None ); test_eq!(is_alnum_a, is_ascii_alnum('a'), true); test_eq!(is_alnum_A, is_ascii_alnum('A'), true); test_eq!(is_alnum_1, is_ascii_alnum('1'), true); test_eq!(is_not_alnum_symbol, is_ascii_alnum('!'), false); test_eq!(is_not_alnum_nonascii, is_ascii_alnum('\u{a66e}'), false); }