Commit 92076c12 authored by linj's avatar linj Committed by vipwzw

impl exec del local

parent 1a17af6c
...@@ -7,39 +7,58 @@ package executor ...@@ -7,39 +7,58 @@ package executor
import ( import (
"github.com/33cn/chain33/types" "github.com/33cn/chain33/types"
uf "github.com/33cn/plugin/plugin/dapp/unfreeze/types" uf "github.com/33cn/plugin/plugin/dapp/unfreeze/types"
"github.com/33cn/chain33/system/dapp"
) )
func (u *Unfreeze) execDelLocal(receiptData *types.ReceiptData) (*types.LocalDBSet, error) { func (u *Unfreeze) execDelLocal(receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) {
dbSet := &types.LocalDBSet{} dbSet := &types.LocalDBSet{}
if receiptData.GetTy() != types.ExecOk { if receiptData.GetTy() != types.ExecOk {
return dbSet, nil return dbSet, nil
} }
table := NewAddrTable(u.GetLocalDB())
txIndex := dapp.HeightIndexStr(u.GetHeight(), int64(index))
for _, log := range receiptData.Logs { for _, log := range receiptData.Logs {
switch log.Ty { switch log.Ty {
case uf.TyLogCreateUnfreeze, uf.TyLogWithdrawUnfreeze, uf.TyLogTerminateUnfreeze: case uf.TyLogWithdrawUnfreeze, uf.TyLogTerminateUnfreeze:
var receipt uf.ReceiptUnfreeze var receipt uf.ReceiptUnfreeze
err := types.Decode(log.Log, &receipt) err := types.Decode(log.Log, &receipt)
if err != nil { if err != nil {
return nil, err return nil, err
} }
kv := u.rollbackUnfreezeCreate(&receipt) err = update(table, receipt.Prev)
dbSet.KV = append(dbSet.KV, kv...) if err != nil {
return nil, err
}
case uf.TyLogCreateUnfreeze:
err := table.Del([]byte(txIndex))
if err != nil {
return nil, err
}
} }
} }
kv, err := table.Save()
if err != nil {
return nil, err
}
dbSet.KV = append(dbSet.KV, kv...)
for _, kv := range dbSet.KV {
u.GetLocalDB().Set(kv.Key, kv.Value)
}
return dbSet, nil return dbSet, nil
} }
// ExecDelLocal_Create 本地撤销执行创建冻结合约 // ExecDelLocal_Create 本地撤销执行创建冻结合约
func (u *Unfreeze) ExecDelLocal_Create(payload *uf.UnfreezeCreate, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) { func (u *Unfreeze) ExecDelLocal_Create(payload *uf.UnfreezeCreate, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) {
return u.execDelLocal(receiptData) return u.execDelLocal(receiptData, index)
} }
// ExecDelLocal_Withdraw 本地撤销执行冻结合约中提币 // ExecDelLocal_Withdraw 本地撤销执行冻结合约中提币
func (u *Unfreeze) ExecDelLocal_Withdraw(payload *uf.UnfreezeWithdraw, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) { func (u *Unfreeze) ExecDelLocal_Withdraw(payload *uf.UnfreezeWithdraw, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) {
return u.execDelLocal(receiptData) return u.execDelLocal(receiptData, index)
} }
// ExecDelLocal_Terminate 本地撤销执行冻结合约的终止 // ExecDelLocal_Terminate 本地撤销执行冻结合约的终止
func (u *Unfreeze) ExecDelLocal_Terminate(payload *uf.UnfreezeTerminate, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) { func (u *Unfreeze) ExecDelLocal_Terminate(payload *uf.UnfreezeTerminate, tx *types.Transaction, receiptData *types.ReceiptData, index int) (*types.LocalDBSet, error) {
return u.execDelLocal(receiptData) return u.execDelLocal(receiptData, index)
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment