org.sirix.page.PageUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sirix-core Show documentation
Show all versions of sirix-core Show documentation
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.
package org.sirix.page;
import org.sirix.access.DatabaseType;
import org.sirix.access.ResourceConfiguration;
import org.sirix.api.PageReadOnlyTrx;
import org.sirix.cache.PageContainer;
import org.sirix.cache.TransactionIntentLog;
import org.sirix.index.IndexType;
import org.sirix.node.SirixDeweyID;
import org.sirix.page.delegates.BitmapReferencesPage;
import org.sirix.page.delegates.FullReferencesPage;
import org.sirix.page.delegates.ReferencesPage4;
import org.sirix.page.interfaces.Page;
import org.sirix.settings.Constants;
import org.sirix.settings.Fixed;
import org.checkerframework.checker.nullness.qual.NonNull;
import java.io.DataInput;
import java.io.IOException;
import java.io.UncheckedIOException;
/**
* Page utilities.
*
* @author Johannes Lichtenberger
*/
public final class PageUtils {
/**
* Private constructor to prevent instantiation.
*/
private PageUtils() {
throw new AssertionError("May never be instantiated!");
}
public static Page setReference(Page pageDelegate, int offset, PageReference pageReference) {
final var hasToGrow = pageDelegate.setOrCreateReference(offset, pageReference);
if (hasToGrow) {
if (pageDelegate instanceof ReferencesPage4) {
pageDelegate = new BitmapReferencesPage(Constants.INP_REFERENCE_COUNT, (ReferencesPage4) pageDelegate);
} else {
assert pageDelegate instanceof BitmapReferencesPage;
pageDelegate = new FullReferencesPage((BitmapReferencesPage) pageDelegate);
}
pageDelegate.setOrCreateReference(offset, pageReference);
}
return pageDelegate;
}
public static Page createDelegate(DataInput in, SerializationType type) {
try {
final byte kind = in.readByte();
return switch (kind) {
case 0 -> new ReferencesPage4(in, type);
case 1 -> new BitmapReferencesPage(Constants.INP_REFERENCE_COUNT, in, type);
case 2 -> new FullReferencesPage(in, type);
default -> throw new IllegalStateException();
};
} catch (final IOException e) {
throw new UncheckedIOException(e);
}
}
/**
* Create the initial tree structure.
*
* @param databaseType The type of database.
* @param reference reference from revision root
* @param indexType the index type
*/
public static void createTree(final DatabaseType databaseType,
@NonNull PageReference reference, final IndexType indexType,
final PageReadOnlyTrx pageReadTrx, final TransactionIntentLog log) {
final Page page = new IndirectPage();
log.put(reference, PageContainer.getInstance(page, page));
reference = page.getOrCreateReference(0);
// Create new record page.
final UnorderedKeyValuePage recordPage =
new UnorderedKeyValuePage(Fixed.ROOT_PAGE_KEY.getStandardProperty(), indexType, pageReadTrx);
final ResourceConfiguration resourceConfiguration = pageReadTrx.getResourceManager().getResourceConfig();
// Create a {@link DocumentRootNode}.
final SirixDeweyID id = resourceConfiguration.areDeweyIDsStored ? SirixDeweyID.newRootID() : null;
recordPage.setRecord(0L, databaseType.getDocumentNode(id));
log.put(reference, PageContainer.getInstance(recordPage, recordPage));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy