2015-04-24 23:11:47 +02:00
|
|
|
// Copyright (c) 2014 Couchbase, Inc.
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
|
|
|
|
// except in compliance with the License. You may obtain a copy of the License at
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
// Unless required by applicable law or agreed to in writing, software distributed under the
|
|
|
|
// License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
|
|
// either express or implied. See the License for the specific language governing permissions
|
|
|
|
// and limitations under the License.
|
|
|
|
|
|
|
|
package store
|
|
|
|
|
|
|
|
type op struct {
|
|
|
|
K []byte
|
|
|
|
V []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
type EmulatedBatch struct {
|
2015-09-23 20:25:47 +02:00
|
|
|
Ops []*op
|
|
|
|
Merger *EmulatedMerge
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func NewEmulatedBatch(mo MergeOperator) *EmulatedBatch {
|
2015-04-24 23:11:47 +02:00
|
|
|
return &EmulatedBatch{
|
2015-09-23 20:25:47 +02:00
|
|
|
Ops: make([]*op, 0, 1000),
|
|
|
|
Merger: NewEmulatedMerge(mo),
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *EmulatedBatch) Set(key, val []byte) {
|
2015-09-23 20:25:47 +02:00
|
|
|
ck := make([]byte, len(key))
|
|
|
|
copy(ck, key)
|
|
|
|
cv := make([]byte, len(val))
|
|
|
|
copy(cv, val)
|
|
|
|
b.Ops = append(b.Ops, &op{ck, cv})
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *EmulatedBatch) Delete(key []byte) {
|
2015-09-23 20:25:47 +02:00
|
|
|
ck := make([]byte, len(key))
|
|
|
|
copy(ck, key)
|
|
|
|
b.Ops = append(b.Ops, &op{ck, nil})
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (b *EmulatedBatch) Merge(key, val []byte) {
|
2015-09-23 20:25:47 +02:00
|
|
|
ck := make([]byte, len(key))
|
|
|
|
copy(ck, key)
|
|
|
|
cv := make([]byte, len(val))
|
|
|
|
copy(cv, val)
|
|
|
|
b.Merger.Merge(key, val)
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
|
|
|
|
2015-09-23 20:25:47 +02:00
|
|
|
func (b *EmulatedBatch) Reset() {
|
|
|
|
b.Ops = b.Ops[:0]
|
2015-04-24 23:11:47 +02:00
|
|
|
}
|
2016-01-08 02:54:21 +01:00
|
|
|
|
|
|
|
func (b *EmulatedBatch) Close() error {
|
|
|
|
return nil
|
|
|
|
}
|