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

io.sirix.cache.TransactionIntentLog Maven / Gradle / Ivy

Go to download

SirixDB is a hybrid on-disk and in-memory document oriented, versioned database system. It has a lightweight buffer manager, stores everything in a huge persistent and durable tree and allows efficient reconstruction of every revision. Furthermore, SirixDB implements change tracking, diffing and supports time travel queries.

There is a newer version: 0.11.0
Show newest version
package io.sirix.cache;

import io.sirix.page.PageReference;
import io.sirix.settings.Constants;

import java.util.ArrayList;
import java.util.List;

/**
 * The transaction intent log, used for caching everything the read/write-transaction changes.
 *
 * @author Johannes Lichtenberger
 */
public final class TransactionIntentLog implements AutoCloseable {

  /**
   * The collection to hold the maps.
   */
  private final List list;

  /**
   * The log key.
   */
  private int logKey;

  /**
   * Creates a new transaction intent log.
   *
   * @param maxInMemoryCapacity the maximum size of the in-memory map
   */
  public TransactionIntentLog(final int maxInMemoryCapacity) {
    logKey = 0;
    list = new ArrayList<>(maxInMemoryCapacity);
  }

  /**
   * Retrieves an entry from the cache.
* * @param key the key whose associated value is to be returned. * @return the value associated to this key, or {@code null} if no value with this key exists in the * cache */ public PageContainer get(final PageReference key) { var logKey = key.getLogKey(); if ((logKey >= this.logKey) || logKey < 0) { return null; } return list.get(logKey); } /** * Adds an entry to this cache. If the cache is full, the LRU (least recently used) entry is * dropped. * * @param key the key with which the specified value is to be associated * @param value a value to be associated with the specified key */ public void put(final PageReference key, final PageContainer value) { key.setKey(Constants.NULL_ID_LONG); key.setPage(null); key.setLogKey(logKey); list.add(value); logKey++; } /** * Clears the cache. */ public void clear() { logKey = 0; list.clear(); } /** * Get a view of the underlying map. * * @return an unmodifiable view of all entries in the cache */ public List getList() { return list; } @Override public void close() { logKey = 0; list.clear(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy