All Downloads are FREE. Search and download functionalities are using the official Maven repository.

dev.tauri.choam.internal.mcas.AbstractDescriptor.scala Maven / Gradle / Ivy

/*
 * SPDX-License-Identifier: Apache-2.0
 * Copyright 2016-2024 Daniel Urban and contributors listed in NOTICE.txt
 *
 * 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 dev.tauri.choam
package internal
package mcas

object AbstractDescriptor {

  type Aux[d <: AbstractDescriptor] = AbstractDescriptor {
    type D = d
  }
}

abstract class AbstractDescriptor extends AbstractDescriptorPlatform {

  type D <: AbstractDescriptor

  def readOnly: Boolean

  def validTs: Long

  def versionIncr: Long

  def toImmutable: Descriptor

  final def size: Int =
    this.hamt.size + (if (this.hasVersionCas) 1 else 0)

  protected def hamt: AbstractHamt[_, _, _, _, _, _]

  private[mcas] final def nonEmpty: Boolean =
    this.size > 0

  private[mcas] def hasVersionCas: Boolean

  private[mcas] def addVersionCas(commitTsRef: MemoryLocation[Long]): AbstractDescriptor.Aux[D]

  private[mcas] final def newVersion: Long =
    this.validTs + this.versionIncr

  private[choam] def hwdIterator: Iterator[LogEntry[Any]]

  private[choam] def getOrElseNull[A](ref: MemoryLocation[A]): LogEntry[A]

  private[choam] def add[A](desc: LogEntry[A]): AbstractDescriptor.Aux[D]

  private[choam] def overwrite[A](desc: LogEntry[A]): AbstractDescriptor.Aux[D]

  private[choam] def addOrOverwrite[A](desc: LogEntry[A]): AbstractDescriptor.Aux[D]

  private[choam] def computeIfAbsent[A, T](
    ref: MemoryLocation[A],
    tok: T,
    visitor: Hamt.EntryVisitor[MemoryLocation[A], LogEntry[A], T],
  ): AbstractDescriptor.Aux[D]

  private[choam] def computeOrModify[A, T](
    ref: MemoryLocation[A],
    tok: T,
    visitor: Hamt.EntryVisitor[MemoryLocation[A], LogEntry[A], T],
  ): AbstractDescriptor.Aux[D]

  final def isValidHwd[A](hwd: LogEntry[A]): Boolean = {
    hwd.version <= this.validTs
  }

  /**
   * Tries to revalidate `this` based on the current
   * versions of the refs it contains.
   *
   * @return true, iff `this` is still valid.
   */
  private[mcas] def revalidate(ctx: Mcas.ThreadContext): Boolean

  private[mcas] def validateAndTryExtend(
    commitTsRef: MemoryLocation[Long],
    ctx: Mcas.ThreadContext,
    additionalHwd: LogEntry[_], // can be null
  ): AbstractDescriptor.Aux[D]

  private[mcas] def validateAndTryExtendVer(
    currentTs: Long,
    ctx: Mcas.ThreadContext,
    additionalHwd: LogEntry[_], // can be null
  ): AbstractDescriptor.Aux[D]

  private[mcas] def withNoNewVersion: AbstractDescriptor.Aux[D]
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy