From b0811b263ea787df25b25f762b768502b55cf7e0 Mon Sep 17 00:00:00 2001 From: Finn Bear Date: Mon, 13 Mar 2023 19:54:21 -0700 Subject: [PATCH] Fix #1698 - reduce code duplication in TiKV txn. (#1699) --- lib/src/kvs/tikv/mod.rs | 55 +++++++++++++++-------------------------- 1 file changed, 20 insertions(+), 35 deletions(-) diff --git a/lib/src/kvs/tikv/mod.rs b/lib/src/kvs/tikv/mod.rs index 0def3b3c..87003aca 100644 --- a/lib/src/kvs/tikv/mod.rs +++ b/lib/src/kvs/tikv/mod.rs @@ -32,41 +32,26 @@ impl Datastore { } /// Start a new transaction pub async fn transaction(&self, write: bool, lock: bool) -> Result { - match lock { - false => { - // Set the behaviour when dropping an unfinished transaction - let mut opt = TransactionOptions::new_optimistic().drop_check(CheckLevel::Warn); - // Set this transaction as read only if possible - if !write { - opt = opt.read_only(); - } - // Create a new optimistic transaction - match self.db.begin_with_options(opt).await { - Ok(tx) => Ok(Transaction { - ok: false, - rw: write, - tx, - }), - Err(e) => Err(Error::Tx(e.to_string())), - } - } - true => { - // Set the behaviour when dropping an unfinished transaction - let mut opt = TransactionOptions::new_pessimistic().drop_check(CheckLevel::Warn); - // Set this transaction as read only if possible - if !write { - opt = opt.read_only(); - } - // Create a new pessimistic transaction - match self.db.begin_with_options(opt).await { - Ok(tx) => Ok(Transaction { - ok: false, - rw: write, - tx, - }), - Err(e) => Err(Error::Tx(e.to_string())), - } - } + // Set whether this should be an optimistic or pessimistic transaction + let mut opt = if lock { + TransactionOptions::new_pessimistic() + } else { + TransactionOptions::new_optimistic() + }; + // Set the behaviour when dropping an unfinished transaction + opt = opt.drop_check(CheckLevel::Warn); + // Set this transaction as read only if possible + if !write { + opt = opt.read_only(); + } + // Create a new distributed transaction + match self.db.begin_with_options(opt).await { + Ok(tx) => Ok(Transaction { + ok: false, + rw: write, + tx, + }), + Err(e) => Err(Error::Tx(e.to_string())), } } }