mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-01 00:31:21 +00:00
save
This commit is contained in:
parent
5c2433d8cf
commit
c8cd6f567f
@ -188,6 +188,7 @@ type RwDB interface {
|
|||||||
RoDB
|
RoDB
|
||||||
|
|
||||||
Update(ctx context.Context, f func(tx RwTx) error) error
|
Update(ctx context.Context, f func(tx RwTx) error) error
|
||||||
|
UpdateAsync(ctx context.Context, f func(tx RwTx) error) error
|
||||||
|
|
||||||
BeginRw(ctx context.Context) (RwTx, error)
|
BeginRw(ctx context.Context) (RwTx, error)
|
||||||
BeginRwAsync(ctx context.Context) (RwTx, error)
|
BeginRwAsync(ctx context.Context) (RwTx, error)
|
||||||
|
@ -669,6 +669,27 @@ func (db *MdbxKV) View(ctx context.Context, f func(tx kv.Tx) error) (err error)
|
|||||||
return f(tx)
|
return f(tx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (db *MdbxKV) UpdateAsync(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
||||||
|
if db.closed.Load() {
|
||||||
|
return fmt.Errorf("db closed")
|
||||||
|
}
|
||||||
|
|
||||||
|
tx, err := db.BeginRwAsync(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer tx.Rollback()
|
||||||
|
err = f(tx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = tx.Commit()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func (db *MdbxKV) Update(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
func (db *MdbxKV) Update(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
||||||
if db.closed.Load() {
|
if db.closed.Load() {
|
||||||
return fmt.Errorf("db closed")
|
return fmt.Errorf("db closed")
|
||||||
|
@ -50,6 +50,10 @@ func (t *TemporaryMdbx) Update(ctx context.Context, f func(kv.RwTx) error) error
|
|||||||
return t.db.Update(ctx, f)
|
return t.db.Update(ctx, f)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (t *TemporaryMdbx) UpdateAsync(ctx context.Context, f func(kv.RwTx) error) error {
|
||||||
|
return t.db.UpdateAsync(ctx, f)
|
||||||
|
}
|
||||||
|
|
||||||
func (t *TemporaryMdbx) BeginRw(ctx context.Context) (kv.RwTx, error) {
|
func (t *TemporaryMdbx) BeginRw(ctx context.Context) (kv.RwTx, error) {
|
||||||
return t.db.BeginRw(ctx)
|
return t.db.BeginRw(ctx)
|
||||||
}
|
}
|
||||||
|
@ -178,6 +178,9 @@ func (db *RemoteKV) View(ctx context.Context, f func(tx kv.Tx) error) (err error
|
|||||||
func (db *RemoteKV) Update(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
func (db *RemoteKV) Update(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
||||||
return fmt.Errorf("remote db provider doesn't support .Update method")
|
return fmt.Errorf("remote db provider doesn't support .Update method")
|
||||||
}
|
}
|
||||||
|
func (db *RemoteKV) UpdateAsync(ctx context.Context, f func(tx kv.RwTx) error) (err error) {
|
||||||
|
return fmt.Errorf("remote db provider doesn't support .Update method")
|
||||||
|
}
|
||||||
|
|
||||||
func (tx *remoteTx) ViewID() uint64 { return tx.id }
|
func (tx *remoteTx) ViewID() uint64 { return tx.id }
|
||||||
func (tx *remoteTx) CollectMetrics() {}
|
func (tx *remoteTx) CollectMetrics() {}
|
||||||
|
Loading…
Reference in New Issue
Block a user