2020-06-29 15:36:01 +00:00
|
|
|
use crate::sql::common::commas;
|
2022-01-16 20:31:50 +00:00
|
|
|
use crate::sql::error::IResult;
|
2022-05-15 08:34:29 +00:00
|
|
|
use crate::sql::escape::escape_ident;
|
2022-10-04 21:51:18 +00:00
|
|
|
use crate::sql::fmt::Fmt;
|
2022-05-30 15:32:26 +00:00
|
|
|
use crate::sql::id::Id;
|
2022-05-15 08:34:29 +00:00
|
|
|
use crate::sql::ident::{ident_raw, Ident};
|
2023-05-09 17:48:14 +00:00
|
|
|
use crate::sql::strand::no_nul_bytes;
|
2022-05-30 15:32:26 +00:00
|
|
|
use crate::sql::thing::Thing;
|
2021-03-29 15:43:37 +00:00
|
|
|
use nom::multi::separated_list1;
|
2020-06-29 15:36:01 +00:00
|
|
|
use serde::{Deserialize, Serialize};
|
2022-10-04 21:51:18 +00:00
|
|
|
use std::fmt::{self, Display, Formatter};
|
2022-05-04 21:59:37 +00:00
|
|
|
use std::ops::Deref;
|
2020-06-29 15:36:01 +00:00
|
|
|
use std::str;
|
|
|
|
|
2023-03-30 10:41:44 +00:00
|
|
|
pub(crate) const TOKEN: &str = "$surrealdb::private::sql::Table";
|
|
|
|
|
2022-10-27 12:23:24 +00:00
|
|
|
#[derive(Clone, Debug, Default, Eq, PartialEq, PartialOrd, Serialize, Deserialize, Hash)]
|
2022-01-13 17:36:41 +00:00
|
|
|
pub struct Tables(pub Vec<Table>);
|
2020-06-29 15:36:01 +00:00
|
|
|
|
2022-06-05 23:35:44 +00:00
|
|
|
impl From<Table> for Tables {
|
|
|
|
fn from(v: Table) -> Self {
|
|
|
|
Tables(vec![v])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-31 20:30:56 +00:00
|
|
|
impl Deref for Tables {
|
|
|
|
type Target = Vec<Table>;
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
&self.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-04 21:51:18 +00:00
|
|
|
impl Display for Tables {
|
|
|
|
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
|
|
|
Display::fmt(&Fmt::comma_separated(&self.0), f)
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn tables(i: &str) -> IResult<&str, Tables> {
|
2021-03-29 15:43:37 +00:00
|
|
|
let (i, v) = separated_list1(commas, table)(i)?;
|
2020-06-29 15:36:01 +00:00
|
|
|
Ok((i, Tables(v)))
|
|
|
|
}
|
|
|
|
|
2023-04-29 15:58:22 +00:00
|
|
|
#[derive(Clone, Debug, Default, Eq, PartialEq, PartialOrd, Serialize, Deserialize, Hash)]
|
|
|
|
#[serde(rename = "$surrealdb::private::sql::Table")]
|
2023-05-09 17:48:14 +00:00
|
|
|
pub struct Table(#[serde(with = "no_nul_bytes")] pub String);
|
2020-06-29 15:36:01 +00:00
|
|
|
|
2022-03-07 18:15:57 +00:00
|
|
|
impl From<String> for Table {
|
|
|
|
fn from(v: String) -> Self {
|
2022-10-04 21:51:18 +00:00
|
|
|
Self(v)
|
2022-05-04 21:59:37 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-27 12:21:41 +00:00
|
|
|
impl From<&str> for Table {
|
|
|
|
fn from(v: &str) -> Self {
|
2022-10-04 21:51:18 +00:00
|
|
|
Self::from(String::from(v))
|
2022-05-27 12:21:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-15 08:34:29 +00:00
|
|
|
impl From<Ident> for Table {
|
|
|
|
fn from(v: Ident) -> Self {
|
2022-10-04 21:51:18 +00:00
|
|
|
Self(v.0)
|
2022-05-15 08:34:29 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-04 21:59:37 +00:00
|
|
|
impl Deref for Table {
|
|
|
|
type Target = String;
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
&self.0
|
2022-03-07 18:15:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-30 15:32:26 +00:00
|
|
|
impl Table {
|
|
|
|
pub fn generate(&self) -> Thing {
|
|
|
|
Thing {
|
|
|
|
tb: self.0.to_owned(),
|
|
|
|
id: Id::rand(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-04 21:51:18 +00:00
|
|
|
impl Display for Table {
|
|
|
|
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
|
|
|
Display::fmt(&escape_ident(&self.0), f)
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn table(i: &str) -> IResult<&str, Table> {
|
|
|
|
let (i, v) = ident_raw(i)?;
|
2022-05-04 21:59:37 +00:00
|
|
|
Ok((i, Table(v)))
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn table_normal() {
|
|
|
|
let sql = "test";
|
|
|
|
let res = table(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("test", format!("{}", out));
|
2022-05-04 21:59:37 +00:00
|
|
|
assert_eq!(out, Table(String::from("test")));
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn table_quoted_backtick() {
|
|
|
|
let sql = "`test`";
|
|
|
|
let res = table(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("test", format!("{}", out));
|
2022-05-04 21:59:37 +00:00
|
|
|
assert_eq!(out, Table(String::from("test")));
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn table_quoted_brackets() {
|
|
|
|
let sql = "⟨test⟩";
|
|
|
|
let res = table(sql);
|
|
|
|
assert!(res.is_ok());
|
|
|
|
let out = res.unwrap().1;
|
|
|
|
assert_eq!("test", format!("{}", out));
|
2022-05-04 21:59:37 +00:00
|
|
|
assert_eq!(out, Table(String::from("test")));
|
2020-06-29 15:36:01 +00:00
|
|
|
}
|
|
|
|
}
|