use crate::ctx::Context; use crate::dbs::Options; use crate::dbs::Statement; use crate::dbs::Transaction; use crate::dbs::Workable; use crate::doc::Document; use crate::err::Error; use crate::sql::paths::EDGE; use crate::sql::paths::IN; use crate::sql::paths::OUT; use crate::sql::value::Value; use crate::sql::Dir; impl<'a> Document<'a> { pub async fn edges( &mut self, ctx: &Context<'_>, opt: &Options, txn: &Transaction, _stm: &Statement<'_>, ) -> Result<(), Error> { // Check if the table is a view if self.tb(opt, txn).await?.drop { return Ok(()); } // Clone transaction let run = txn.clone(); // Claim transaction let mut run = run.lock().await; // Get the record id let rid = self.id.as_ref().unwrap(); // Store the record edges if let Workable::Relate(l, r) = &self.extras { // Get temporary edge references let (ref o, ref i) = (Dir::Out, Dir::In); // Store the left pointer edge let key = crate::key::graph::new(opt.ns(), opt.db(), &l.tb, &l.id, o, rid); run.set(key, vec![]).await?; // Store the left inner edge let key = crate::key::graph::new(opt.ns(), opt.db(), &rid.tb, &rid.id, i, l); run.set(key, vec![]).await?; // Store the right inner edge let key = crate::key::graph::new(opt.ns(), opt.db(), &rid.tb, &rid.id, o, r); run.set(key, vec![]).await?; // Store the right pointer edge let key = crate::key::graph::new(opt.ns(), opt.db(), &r.tb, &r.id, i, rid); run.set(key, vec![]).await?; // Store the edges on the record self.current.to_mut().set(ctx, opt, txn, &*EDGE, Value::Bool(true)).await?; self.current.to_mut().set(ctx, opt, txn, &*IN, l.clone().into()).await?; self.current.to_mut().set(ctx, opt, txn, &*OUT, r.clone().into()).await?; } // Carry on Ok(()) } }