aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/gitea.com/lunny/nodb/batch.go
diff options
context:
space:
mode:
author6543 <6543@obermui.de>2020-11-03 07:04:09 +0100
committerGitHub <noreply@github.com>2020-11-03 08:04:09 +0200
commit70ea2300ca24311f033d85b41e938e86b1d50acd (patch)
treeeb25c089d5def4df2c036ab2820df7c895798572 /vendor/gitea.com/lunny/nodb/batch.go
parentb687707014b31d0f388d1dfb60c09b5dcd48fc4c (diff)
downloadgitea-70ea2300ca24311f033d85b41e938e86b1d50acd.tar.gz
gitea-70ea2300ca24311f033d85b41e938e86b1d50acd.zip
[Vendor] update macaron related (#13409)
* Vendor: update gitea.com/macaron/session to a177a270 * make vendor * Vendor: update gitea.com/macaron/macaron to 0db5d458 * make vendor * Vendor: update gitea.com/macaron/cache to 905232fb * make vendor * Vendor: update gitea.com/macaron/i18n to 4ca3dd0c * make vendor * Vendor: update gitea.com/macaron/gzip to efa5e847 * make vendor * Vendor: update gitea.com/macaron/captcha to e8597820 * make vendor
Diffstat (limited to 'vendor/gitea.com/lunny/nodb/batch.go')
-rw-r--r--vendor/gitea.com/lunny/nodb/batch.go106
1 files changed, 106 insertions, 0 deletions
diff --git a/vendor/gitea.com/lunny/nodb/batch.go b/vendor/gitea.com/lunny/nodb/batch.go
new file mode 100644
index 0000000000..e2bc28995b
--- /dev/null
+++ b/vendor/gitea.com/lunny/nodb/batch.go
@@ -0,0 +1,106 @@
+package nodb
+
+import (
+ "sync"
+
+ "gitea.com/lunny/nodb/store"
+)
+
+type batch struct {
+ l *Nodb
+
+ store.WriteBatch
+
+ sync.Locker
+
+ logs [][]byte
+
+ tx *Tx
+}
+
+func (b *batch) Commit() error {
+ b.l.commitLock.Lock()
+ defer b.l.commitLock.Unlock()
+
+ err := b.WriteBatch.Commit()
+
+ if b.l.binlog != nil {
+ if err == nil {
+ if b.tx == nil {
+ b.l.binlog.Log(b.logs...)
+ } else {
+ b.tx.logs = append(b.tx.logs, b.logs...)
+ }
+ }
+ b.logs = [][]byte{}
+ }
+
+ return err
+}
+
+func (b *batch) Lock() {
+ b.Locker.Lock()
+}
+
+func (b *batch) Unlock() {
+ if b.l.binlog != nil {
+ b.logs = [][]byte{}
+ }
+ b.WriteBatch.Rollback()
+ b.Locker.Unlock()
+}
+
+func (b *batch) Put(key []byte, value []byte) {
+ if b.l.binlog != nil {
+ buf := encodeBinLogPut(key, value)
+ b.logs = append(b.logs, buf)
+ }
+ b.WriteBatch.Put(key, value)
+}
+
+func (b *batch) Delete(key []byte) {
+ if b.l.binlog != nil {
+ buf := encodeBinLogDelete(key)
+ b.logs = append(b.logs, buf)
+ }
+ b.WriteBatch.Delete(key)
+}
+
+type dbBatchLocker struct {
+ l *sync.Mutex
+ wrLock *sync.RWMutex
+}
+
+func (l *dbBatchLocker) Lock() {
+ l.wrLock.RLock()
+ l.l.Lock()
+}
+
+func (l *dbBatchLocker) Unlock() {
+ l.l.Unlock()
+ l.wrLock.RUnlock()
+}
+
+type txBatchLocker struct {
+}
+
+func (l *txBatchLocker) Lock() {}
+func (l *txBatchLocker) Unlock() {}
+
+type multiBatchLocker struct {
+}
+
+func (l *multiBatchLocker) Lock() {}
+func (l *multiBatchLocker) Unlock() {}
+
+func (l *Nodb) newBatch(wb store.WriteBatch, locker sync.Locker, tx *Tx) *batch {
+ b := new(batch)
+ b.l = l
+ b.WriteBatch = wb
+
+ b.tx = tx
+ b.Locker = locker
+
+ b.logs = [][]byte{}
+ return b
+}