From eab862b9e472051d281023bf914b889157857427 Mon Sep 17 00:00:00 2001 From: Tobie Morgan Hitchcock Date: Sat, 27 Aug 2022 00:23:24 +0100 Subject: [PATCH] Add support for Objects and Arrays as Record IDs --- lib/src/sql/id.rs | 15 ++++++++++++++- lib/src/sql/value/value.rs | 2 ++ 2 files changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/src/sql/id.rs b/lib/src/sql/id.rs index b4897bd7..21ed641f 100644 --- a/lib/src/sql/id.rs +++ b/lib/src/sql/id.rs @@ -1,8 +1,10 @@ use crate::cnf::ID_CHARS; +use crate::sql::array::{array, Array}; use crate::sql::error::IResult; use crate::sql::escape::escape_id; use crate::sql::ident::ident_raw; use crate::sql::number::integer; +use crate::sql::object::{object, Object}; use nanoid::nanoid; use nom::branch::alt; use nom::combinator::map; @@ -13,6 +15,8 @@ use std::fmt; pub enum Id { Number(i64), String(String), + Object(Object), + Array(Array), } impl From for Id { @@ -53,6 +57,8 @@ impl Id { match self { Id::Number(v) => v.to_string(), Id::String(v) => v.to_string(), + Id::Object(v) => v.to_string(), + Id::Array(v) => v.to_string(), } } } @@ -62,12 +68,19 @@ impl fmt::Display for Id { match self { Id::Number(v) => write!(f, "{}", v), Id::String(v) => write!(f, "{}", escape_id(v)), + Id::Object(v) => write!(f, "{}", v), + Id::Array(v) => write!(f, "{}", v), } } } pub fn id(i: &str) -> IResult<&str, Id> { - alt((map(integer, Id::Number), map(ident_raw, Id::String)))(i) + alt(( + map(integer, Id::Number), + map(ident_raw, Id::String), + map(object, Id::Object), + map(array, Id::Array), + ))(i) } #[cfg(test)] diff --git a/lib/src/sql/value/value.rs b/lib/src/sql/value/value.rs index 06f33ee4..2f0f9056 100644 --- a/lib/src/sql/value/value.rs +++ b/lib/src/sql/value/value.rs @@ -430,6 +430,8 @@ impl From for Value { match v { Id::Number(v) => v.into(), Id::String(v) => Strand::from(v).into(), + Id::Object(v) => v.into(), + Id::Array(v) => v.into(), } } }