From a8f35611c222f26df81c7f82362b91fc7298e54a Mon Sep 17 00:00:00 2001 From: hchockarprasad Date: Tue, 16 May 2023 01:52:13 +0530 Subject: [PATCH] Bugfix - Include index part when patching object value (#1994) --- lib/src/sql/value/cut.rs | 33 +++++++++++++++++++++------------ lib/src/sql/value/del.rs | 10 ++++++++++ lib/src/sql/value/fetch.rs | 4 ++++ lib/src/sql/value/pick.rs | 4 ++++ lib/src/sql/value/put.rs | 8 ++++++++ lib/src/sql/value/set.rs | 9 +++++++++ lib/src/sql/value/walk.rs | 4 ++++ 7 files changed, 60 insertions(+), 12 deletions(-) diff --git a/lib/src/sql/value/cut.rs b/lib/src/sql/value/cut.rs index 108861a8..705b62c7 100644 --- a/lib/src/sql/value/cut.rs +++ b/lib/src/sql/value/cut.rs @@ -9,20 +9,29 @@ impl Value { // Get the current path part match self { // Current path part is an object - Value::Object(v) => { - if let Part::Field(f) = p { - match path.len() { - 1 => { - v.remove(f.as_str()); - } - _ => { - if let Some(v) = v.get_mut(f.as_str()) { - v.cut(path.next()) - } + Value::Object(v) => match p { + Part::Field(f) => match path.len() { + 1 => { + v.remove(f.as_str()); + } + _ => { + if let Some(v) = v.get_mut(f.as_str()) { + v.cut(path.next()) } } - } - } + }, + Part::Index(i) => match path.len() { + 1 => { + v.remove(&i.to_string()); + } + _ => { + if let Some(v) = v.get_mut(&i.to_string()) { + v.cut(path.next()) + } + } + }, + _ => {} + }, // Current path part is an array Value::Array(v) => match p { Part::All => match path.len() { diff --git a/lib/src/sql/value/del.rs b/lib/src/sql/value/del.rs index 47034033..62b9197f 100644 --- a/lib/src/sql/value/del.rs +++ b/lib/src/sql/value/del.rs @@ -36,6 +36,16 @@ impl Value { _ => Ok(()), }, }, + Part::Index(i) => match path.len() { + 1 => { + v.remove(&i.to_string()); + Ok(()) + } + _ => match v.get_mut(&i.to_string()) { + Some(v) if v.is_some() => v.del(ctx, opt, txn, path.next()).await, + _ => Ok(()), + }, + }, _ => Ok(()), }, // Current path part is an array diff --git a/lib/src/sql/value/fetch.rs b/lib/src/sql/value/fetch.rs index 9c67e874..cbfa7e33 100644 --- a/lib/src/sql/value/fetch.rs +++ b/lib/src/sql/value/fetch.rs @@ -34,6 +34,10 @@ impl Value { Some(v) => v.fetch(ctx, opt, txn, path.next()).await, None => Ok(()), }, + Part::Index(i) => match v.get_mut(&i.to_string()) { + Some(v) => v.fetch(ctx, opt, txn, path.next()).await, + None => Ok(()), + }, Part::All => self.fetch(ctx, opt, txn, path.next()).await, _ => Ok(()), }, diff --git a/lib/src/sql/value/pick.rs b/lib/src/sql/value/pick.rs index 46b0d75e..b3a6dc01 100644 --- a/lib/src/sql/value/pick.rs +++ b/lib/src/sql/value/pick.rs @@ -14,6 +14,10 @@ impl Value { Some(v) => v.pick(path.next()), None => Value::None, }, + Part::Index(i) => match v.get(&i.to_string()) { + Some(v) => v.pick(path.next()), + None => Value::None, + }, Part::All => self.pick(path.next()), _ => Value::None, }, diff --git a/lib/src/sql/value/put.rs b/lib/src/sql/value/put.rs index 4257e038..9dd7b967 100644 --- a/lib/src/sql/value/put.rs +++ b/lib/src/sql/value/put.rs @@ -26,6 +26,14 @@ impl Value { v.insert(f.to_raw(), obj); } }, + Part::Index(i) => match v.get_mut(&i.to_string()) { + Some(v) if v.is_some() => v.put(path.next(), val), + _ => { + let mut obj = Value::base(); + obj.put(path.next(), val); + v.insert(i.to_string(), obj); + } + }, _ => (), }, // Current path part is an array diff --git a/lib/src/sql/value/set.rs b/lib/src/sql/value/set.rs index 55a23a06..aea1098c 100644 --- a/lib/src/sql/value/set.rs +++ b/lib/src/sql/value/set.rs @@ -43,6 +43,15 @@ impl Value { Ok(()) } }, + Part::Index(i) => match v.get_mut(&i.to_string()) { + Some(v) if v.is_some() => v.set(ctx, opt, txn, path.next(), val).await, + _ => { + let mut obj = Value::base(); + obj.set(ctx, opt, txn, path.next(), val).await?; + v.insert(i.to_string(), obj); + Ok(()) + } + }, _ => Ok(()), }, // Current path part is an array diff --git a/lib/src/sql/value/walk.rs b/lib/src/sql/value/walk.rs index c9c919b7..c51ec7ef 100644 --- a/lib/src/sql/value/walk.rs +++ b/lib/src/sql/value/walk.rs @@ -17,6 +17,10 @@ impl Value { Some(v) => v._walk(path.next(), prev.push(p.clone())), None => Value::None._walk(path.next(), prev.push(p.clone())), }, + Part::Index(i) => match v.get(&i.to_string()) { + Some(v) => v._walk(path.next(), prev.push(p.clone())), + None => Value::None._walk(path.next(), prev.push(p.clone())), + }, Part::All => self._walk(path.next(), prev.push(p.clone())), _ => vec![], },