108 lines
2.9 KiB
Go
Raw Normal View History

2014-07-06 14:46:48 +02:00
// Copyright (c) 2012, Suryandaru Triandana <syndtr@gmail.com>
// All rights reserved.
//
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
package leveldb
import (
"github.com/syndtr/goleveldb/leveldb/filter"
"github.com/syndtr/goleveldb/leveldb/opt"
)
2014-11-18 16:24:42 +04:00
func dupOptions(o *opt.Options) *opt.Options {
newo := &opt.Options{}
2014-07-06 14:46:48 +02:00
if o != nil {
2014-11-18 16:24:42 +04:00
*newo = *o
2014-07-06 14:46:48 +02:00
}
2014-11-24 11:57:31 +01:00
if newo.Strict == 0 {
newo.Strict = opt.DefaultStrict
}
2014-11-18 16:24:42 +04:00
return newo
}
func (s *session) setOptions(o *opt.Options) {
no := dupOptions(o)
2014-07-06 14:46:48 +02:00
// Alternative filters.
if filters := o.GetAltFilters(); len(filters) > 0 {
2014-11-18 16:24:42 +04:00
no.AltFilters = make([]filter.Filter, len(filters))
2014-07-06 14:46:48 +02:00
for i, filter := range filters {
2014-11-18 16:24:42 +04:00
no.AltFilters[i] = &iFilter{filter}
2014-07-06 14:46:48 +02:00
}
}
// Comparer.
2014-07-06 23:13:10 +02:00
s.icmp = &iComparer{o.GetComparer()}
2014-11-18 16:24:42 +04:00
no.Comparer = s.icmp
2014-07-06 14:46:48 +02:00
// Filter.
if filter := o.GetFilter(); filter != nil {
2014-11-18 16:24:42 +04:00
no.Filter = &iFilter{filter}
2014-07-06 14:46:48 +02:00
}
2014-11-18 16:24:42 +04:00
s.o = &cachedOptions{Options: no}
s.o.cache()
}
const optCachedLevel = 7
2014-11-18 16:24:42 +04:00
type cachedOptions struct {
*opt.Options
compactionExpandLimit []int
compactionGPOverlaps []int
compactionSourceLimit []int
compactionTableSize []int
compactionTotalSize []int64
}
func (co *cachedOptions) cache() {
co.compactionExpandLimit = make([]int, optCachedLevel)
co.compactionGPOverlaps = make([]int, optCachedLevel)
co.compactionSourceLimit = make([]int, optCachedLevel)
co.compactionTableSize = make([]int, optCachedLevel)
co.compactionTotalSize = make([]int64, optCachedLevel)
2014-11-18 16:24:42 +04:00
for level := 0; level < optCachedLevel; level++ {
2014-11-18 16:24:42 +04:00
co.compactionExpandLimit[level] = co.Options.GetCompactionExpandLimit(level)
co.compactionGPOverlaps[level] = co.Options.GetCompactionGPOverlaps(level)
co.compactionSourceLimit[level] = co.Options.GetCompactionSourceLimit(level)
co.compactionTableSize[level] = co.Options.GetCompactionTableSize(level)
co.compactionTotalSize[level] = co.Options.GetCompactionTotalSize(level)
}
}
func (co *cachedOptions) GetCompactionExpandLimit(level int) int {
if level < optCachedLevel {
return co.compactionExpandLimit[level]
}
return co.Options.GetCompactionExpandLimit(level)
2014-11-18 16:24:42 +04:00
}
func (co *cachedOptions) GetCompactionGPOverlaps(level int) int {
if level < optCachedLevel {
return co.compactionGPOverlaps[level]
}
return co.Options.GetCompactionGPOverlaps(level)
2014-11-18 16:24:42 +04:00
}
func (co *cachedOptions) GetCompactionSourceLimit(level int) int {
if level < optCachedLevel {
return co.compactionSourceLimit[level]
}
return co.Options.GetCompactionSourceLimit(level)
2014-11-18 16:24:42 +04:00
}
func (co *cachedOptions) GetCompactionTableSize(level int) int {
if level < optCachedLevel {
return co.compactionTableSize[level]
}
return co.Options.GetCompactionTableSize(level)
2014-11-18 16:24:42 +04:00
}
func (co *cachedOptions) GetCompactionTotalSize(level int) int64 {
if level < optCachedLevel {
return co.compactionTotalSize[level]
}
return co.Options.GetCompactionTotalSize(level)
2014-07-06 14:46:48 +02:00
}