Use new SQL Block
type for <future>
expressions
This commit is contained in:
parent
9fcf4c9419
commit
9c18025cca
2 changed files with 13 additions and 10 deletions
|
@ -322,7 +322,7 @@ impl Datastore {
|
||||||
/// async fn main() -> Result<(), Error> {
|
/// async fn main() -> Result<(), Error> {
|
||||||
/// let ds = Datastore::new("memory").await?;
|
/// let ds = Datastore::new("memory").await?;
|
||||||
/// let ses = Session::for_kv();
|
/// let ses = Session::for_kv();
|
||||||
/// let val = Value::Future(Box::new(Future(Value::True)));
|
/// let val = Value::Future(Box::new(Future::from(Value::True)));
|
||||||
/// let res = ds.compute(val, &ses, None, false).await?;
|
/// let res = ds.compute(val, &ses, None, false).await?;
|
||||||
/// Ok(())
|
/// Ok(())
|
||||||
/// }
|
/// }
|
||||||
|
|
|
@ -2,16 +2,23 @@ use crate::ctx::Context;
|
||||||
use crate::dbs::Options;
|
use crate::dbs::Options;
|
||||||
use crate::dbs::Transaction;
|
use crate::dbs::Transaction;
|
||||||
use crate::err::Error;
|
use crate::err::Error;
|
||||||
|
use crate::sql::block::{block, Block};
|
||||||
use crate::sql::comment::mightbespace;
|
use crate::sql::comment::mightbespace;
|
||||||
use crate::sql::error::IResult;
|
use crate::sql::error::IResult;
|
||||||
use crate::sql::value::{value, Value};
|
use crate::sql::value::Value;
|
||||||
use nom::bytes::complete::tag;
|
use nom::bytes::complete::tag;
|
||||||
use nom::character::complete::char;
|
use nom::character::complete::char;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
#[derive(Clone, Debug, Eq, PartialEq, PartialOrd, Serialize, Deserialize, Hash)]
|
#[derive(Clone, Debug, Eq, PartialEq, PartialOrd, Serialize, Deserialize, Hash)]
|
||||||
pub struct Future(pub Value);
|
pub struct Future(pub Block);
|
||||||
|
|
||||||
|
impl From<Value> for Future {
|
||||||
|
fn from(v: Value) -> Self {
|
||||||
|
Future(Block::from(v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Future {
|
impl Future {
|
||||||
pub(crate) async fn compute(
|
pub(crate) async fn compute(
|
||||||
|
@ -33,7 +40,7 @@ impl Future {
|
||||||
|
|
||||||
impl fmt::Display for Future {
|
impl fmt::Display for Future {
|
||||||
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
write!(f, "<future> {{ {} }}", self.0)
|
write!(f, "<future> {}", self.0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,11 +49,7 @@ pub fn future(i: &str) -> IResult<&str, Future> {
|
||||||
let (i, _) = tag("future")(i)?;
|
let (i, _) = tag("future")(i)?;
|
||||||
let (i, _) = char('>')(i)?;
|
let (i, _) = char('>')(i)?;
|
||||||
let (i, _) = mightbespace(i)?;
|
let (i, _) = mightbespace(i)?;
|
||||||
let (i, _) = char('{')(i)?;
|
let (i, v) = block(i)?;
|
||||||
let (i, _) = mightbespace(i)?;
|
|
||||||
let (i, v) = value(i)?;
|
|
||||||
let (i, _) = mightbespace(i)?;
|
|
||||||
let (i, _) = char('}')(i)?;
|
|
||||||
Ok((i, Future(v)))
|
Ok((i, Future(v)))
|
||||||
}
|
}
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -63,6 +66,6 @@ mod tests {
|
||||||
assert!(res.is_ok());
|
assert!(res.is_ok());
|
||||||
let out = res.unwrap().1;
|
let out = res.unwrap().1;
|
||||||
assert_eq!("<future> { 1.2345 + 5.4321 }", format!("{}", out));
|
assert_eq!("<future> { 1.2345 + 5.4321 }", format!("{}", out));
|
||||||
assert_eq!(out, Future(Value::from(Expression::parse("1.2345 + 5.4321"))));
|
assert_eq!(out, Future(Block::from(Value::from(Expression::parse("1.2345 + 5.4321")))));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue