2022-01-13 17:36:41 +00:00
|
|
|
use crate::sql::comment::mightbespace;
|
2022-01-16 20:31:50 +00:00
|
|
|
use crate::sql::error::Error::ParserError;
|
|
|
|
use crate::sql::error::IResult;
|
2020-06-29 15:36:01 +00:00
|
|
|
use nom::bytes::complete::tag;
|
|
|
|
use nom::bytes::complete::take_while;
|
|
|
|
use nom::bytes::complete::take_while_m_n;
|
|
|
|
use nom::character::is_alphanumeric;
|
|
|
|
use nom::combinator::map;
|
|
|
|
use nom::multi::many1;
|
2022-01-16 20:31:50 +00:00
|
|
|
use nom::Err::Error;
|
2020-06-29 15:36:01 +00:00
|
|
|
use std::ops::RangeBounds;
|
|
|
|
use std::str;
|
|
|
|
|
|
|
|
pub fn colons(i: &str) -> IResult<&str, ()> {
|
2022-01-13 17:36:41 +00:00
|
|
|
let (i, _) = mightbespace(i)?;
|
2020-06-29 15:36:01 +00:00
|
|
|
let (i, _) = many1(tag(";"))(i)?;
|
2022-01-13 17:36:41 +00:00
|
|
|
let (i, _) = mightbespace(i)?;
|
2020-06-29 15:36:01 +00:00
|
|
|
Ok((i, ()))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn commas(i: &str) -> IResult<&str, ()> {
|
2022-01-13 17:36:41 +00:00
|
|
|
let (i, _) = mightbespace(i)?;
|
2020-06-29 15:36:01 +00:00
|
|
|
let (i, _) = tag(",")(i)?;
|
2022-01-13 17:36:41 +00:00
|
|
|
let (i, _) = mightbespace(i)?;
|
2020-06-29 15:36:01 +00:00
|
|
|
Ok((i, ()))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn is_digit(chr: char) -> bool {
|
|
|
|
let chr = chr as u8;
|
|
|
|
chr >= 0x30 && chr <= 0x39
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn to_u32(s: &str) -> u32 {
|
|
|
|
str::FromStr::from_str(s).unwrap()
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn to_u64(s: &str) -> u64 {
|
|
|
|
str::FromStr::from_str(s).unwrap()
|
|
|
|
}
|
|
|
|
|
2022-01-20 20:26:28 +00:00
|
|
|
#[inline]
|
|
|
|
pub fn to_usize(s: &str) -> usize {
|
|
|
|
str::FromStr::from_str(s).unwrap()
|
|
|
|
}
|
|
|
|
|
2020-06-29 15:36:01 +00:00
|
|
|
#[inline]
|
|
|
|
pub fn val_char(chr: char) -> bool {
|
|
|
|
is_alphanumeric(chr as u8) || chr == '_' as char
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn escape(s: &str, f: &dyn Fn(char) -> bool, c: &str) -> String {
|
|
|
|
for x in s.chars() {
|
|
|
|
if !f(x) {
|
|
|
|
return format!("{}{}{}", c, s, c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
s.to_owned()
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn take_u32(i: &str) -> IResult<&str, u32> {
|
|
|
|
let (i, v) = map(take_while(is_digit), to_u32)(i)?;
|
|
|
|
Ok((i, v))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn take_u64(i: &str) -> IResult<&str, u64> {
|
|
|
|
let (i, v) = map(take_while(is_digit), to_u64)(i)?;
|
|
|
|
Ok((i, v))
|
|
|
|
}
|
|
|
|
|
2022-01-20 20:26:28 +00:00
|
|
|
pub fn take_usize(i: &str) -> IResult<&str, usize> {
|
|
|
|
let (i, v) = map(take_while(is_digit), to_usize)(i)?;
|
|
|
|
Ok((i, v))
|
|
|
|
}
|
|
|
|
|
2020-06-29 15:36:01 +00:00
|
|
|
pub fn take_digits(i: &str, n: usize) -> IResult<&str, u32> {
|
|
|
|
let (i, v) = map(take_while_m_n(n, n, is_digit), to_u32)(i)?;
|
|
|
|
Ok((i, v))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn take_digits_range(i: &str, n: usize, range: impl RangeBounds<u32>) -> IResult<&str, u32> {
|
|
|
|
let (i, v) = map(take_while_m_n(n, n, is_digit), to_u32)(i)?;
|
|
|
|
if range.contains(&v) {
|
|
|
|
Ok((i, v))
|
|
|
|
} else {
|
2022-01-16 20:31:50 +00:00
|
|
|
Err(Error(ParserError(i)))
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
}
|