Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* Copyright (c) 2020 Simer JS Plaha ([email protected] - @simerplaha)
*
* This file is a part of SwayDB.
*
* SwayDB is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* SwayDB is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with SwayDB. If not, see .
*
* Additional permission under the GNU Affero GPL version 3 section 7:
* If you modify this Program or any covered work, only by linking or
* combining it with separate works, the licensors of this Program grant
* you additional permission to convey the resulting work.
*/
package swaydb.memory
import com.typesafe.scalalogging.LazyLogging
import swaydb.core.util.Eithers
import swaydb.data.accelerate.{Accelerator, LevelZeroMeter}
import swaydb.data.compaction.{LevelMeter, Throttle}
import swaydb.data.config.{FileCache, ThreadStateCache}
import swaydb.data.order.KeyOrder
import swaydb.data.slice.Slice
import swaydb.data.util.StorageUnits._
import swaydb.serializers.Serializer
import scala.concurrent.duration.FiniteDuration
import scala.reflect.ClassTag
object SetMap extends LazyLogging {
/**
* For custom configurations read documentation on website: http://www.swaydb.io/configuring-levels
*/
def apply[K, V, F, BAG[_]](mapSize: Int = 4.mb,
minSegmentSize: Int = 2.mb,
maxKeyValuesPerSegment: Int = Int.MaxValue,
fileCache: FileCache.Enable = DefaultConfigs.fileCache(),
deleteSegmentsEventually: Boolean = true,
acceleration: LevelZeroMeter => Accelerator = Accelerator.noBrakes(),
levelZeroThrottle: LevelZeroMeter => FiniteDuration = DefaultConfigs.levelZeroThrottle,
lastLevelThrottle: LevelMeter => Throttle = DefaultConfigs.lastLevelThrottle,
threadStateCache: ThreadStateCache = ThreadStateCache.Limit(hashMapMaxSize = 100, maxProbe = 10))(implicit keySerializer: Serializer[K],
valueSerializer: Serializer[V],
functionClassTag: ClassTag[F],
bag: swaydb.Bag[BAG],
functions: swaydb.Set.Functions[(K, V), F],
byteKeyOrder: KeyOrder[Slice[Byte]] = null,
typedKeyOrder: KeyOrder[K] = null): BAG[swaydb.SetMap[K, V, F, BAG]] =
bag.suspend {
val serialiser: Serializer[(K, V)] = swaydb.SetMap.serialiser(keySerializer, valueSerializer)
val keyOrder = Eithers.nullCheck(byteKeyOrder, typedKeyOrder, KeyOrder.default)
val ordering: KeyOrder[Slice[Byte]] = swaydb.SetMap.ordering(keyOrder)
val set =
Set[(K, V), F, BAG](
mapSize = mapSize,
minSegmentSize = minSegmentSize,
maxKeyValuesPerSegment = maxKeyValuesPerSegment,
fileCache = fileCache,
deleteSegmentsEventually = deleteSegmentsEventually,
acceleration = acceleration,
levelZeroThrottle = levelZeroThrottle,
lastLevelThrottle = lastLevelThrottle,
threadStateCache = threadStateCache
)(serializer = serialiser,
functionClassTag = functionClassTag,
bag = bag,
functions = functions,
byteKeyOrder = ordering
)
bag.transform(set) {
set =>
swaydb.SetMap[K, V, F, BAG](set)
}
}
}