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

io.permazen.index.Index2 Maven / Gradle / Ivy

There is a newer version: 5.1.0
Show newest version

/*
 * Copyright (C) 2015 Archie L. Cobbs. All rights reserved.
 */

package io.permazen.index;

import io.permazen.tuple.Tuple2;
import io.permazen.tuple.Tuple3;
import io.permazen.util.Bounds;

import java.util.NavigableMap;
import java.util.NavigableSet;

/**
 * An index on two fields.
 *
 * 

* Indexes are read-only and "live", always reflecting the current transaction state. * * @param first indexed value type * @param second indexed value type * @param index target type * @see io.permazen.index */ public interface Index2 extends Index { @Override default int numberOfFields() { return 2; } /** * View this index as a {@link NavigableSet} of tuples. * * @return {@link NavigableSet} of tuples containing indexed values and target value */ NavigableSet> asSet(); /** * View this index as a {@link NavigableMap} of target values keyed by indexed value tuples. * * @return {@link NavigableMap} from indexed value tuple to the corresponding set of target objects */ NavigableMap, NavigableSet> asMap(); /** * View this index as a {@link NavigableMap} of {@link Index1}s keyed by the first value. * * @return {@link NavigableMap} from first value to {@link Index1} */ NavigableMap> asMapOfIndex1(); /** * Get the prefix of this instance that only includes the first two indexed fields. * * @return prefix of this index */ Index1 asIndex1(); /** * Impose {@link Bounds} that restrict the range of the first indexed value. * * @param bounds bounds to impose on the first indexed value * @return a view of this index in which only first values within {@code bounds} are visible */ Index2 withValue1Bounds(Bounds bounds); /** * Impose {@link Bounds} that restrict the range of the second indexed value. * * @param bounds bounds to impose on the second indexed value * @return a view of this index in which only second values within {@code bounds} are visible */ Index2 withValue2Bounds(Bounds bounds); /** * Impose {@link Bounds} that restrict the range of the target value. * * @param bounds bounds to impose on the target value * @return a view of this index in which only target values within {@code bounds} are visible */ Index2 withTargetBounds(Bounds bounds); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy