2022-01-16 20:31:50 +00:00
|
|
|
use crate::sql::error::IResult;
|
2020-06-29 15:36:01 +00:00
|
|
|
use crate::sql::statement::{statements, Statement, Statements};
|
|
|
|
use nom::combinator::all_consuming;
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use std::fmt;
|
|
|
|
use std::str;
|
|
|
|
|
2021-03-29 15:43:37 +00:00
|
|
|
#[derive(Clone, Debug, Default, Eq, PartialEq, Serialize, Deserialize)]
|
2020-06-29 15:36:01 +00:00
|
|
|
pub struct Query {
|
2022-05-03 23:08:31 +00:00
|
|
|
pub statements: Statements,
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Query {
|
|
|
|
pub fn statements(&self) -> &Vec<Statement> {
|
|
|
|
&self.statements.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Display for Query {
|
|
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
|
|
|
write!(f, "{}", self.statements)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn query(i: &str) -> IResult<&str, Query> {
|
|
|
|
let (i, v) = all_consuming(statements)(i)?;
|
2021-03-29 15:43:37 +00:00
|
|
|
Ok((
|
|
|
|
i,
|
|
|
|
Query {
|
|
|
|
statements: v,
|
|
|
|
},
|
|
|
|
))
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn single_query() {
|
|
|
|
let sql = "CREATE test";
|
|
|
|
let res = query(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("CREATE test;", format!("{}", out))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_query() {
|
|
|
|
let sql = "CREATE test; CREATE temp;";
|
|
|
|
let res = query(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("CREATE test;\nCREATE temp;", format!("{}", out))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_query_semicolons() {
|
|
|
|
let sql = "CREATE test;;;CREATE temp;;;";
|
|
|
|
let res = query(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("CREATE test;\nCREATE temp;", format!("{}", out))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_query_semicolons_comments() {
|
|
|
|
let sql = "CREATE test;;;CREATE temp;;;/* some comment */";
|
|
|
|
let res = query(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("CREATE test;\nCREATE temp;", format!("{}", out))
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_query_semicolons_multi_comments() {
|
|
|
|
let sql = "CREATE test;;;CREATE temp;;;/* some comment */;;;/* other comment */";
|
|
|
|
let res = query(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("CREATE test;\nCREATE temp;", format!("{}", out))
|
|
|
|
}
|
|
|
|
}
|