blob: e8891a1a56a79afbc62ef38b2504b159f00c63ba [file] [log] [blame]
/*-
* Copyright (C) 2002, 2018, Oracle and/or its affiliates. All rights reserved.
*
* This file was distributed by Oracle as part of a version of Oracle Berkeley
* DB Java Edition made available at:
*
* http://www.oracle.com/technetwork/database/database-technologies/berkeleydb/downloads/index.html
*
* Please see the LICENSE file included in the top-level directory of the
* appropriate version of Oracle Berkeley DB Java Edition for a copy of the
* license and additional information.
*/
package com.sleepycat.bind.tuple;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.util.PackedInteger;
/**
* A concrete <code>TupleBinding</code> for a sorted <code>Integer</code>
* primitive wrapper or a sorted <code>int</code> primitive, that stores the
* value in the smallest number of bytes possible.
*
* <p>There are two ways to use this class:</p>
* <ol>
* <li>When using the {@link com.sleepycat.je} package directly, the static
* methods in this class can be used to convert between primitive values and
* {@link DatabaseEntry} objects.</li>
* <li>When using the {@link com.sleepycat.collections} package, an instance of
* this class can be used with any stored collection.</li>
* </ol>
*
* @see <a href="package-summary.html#integerFormats">Integer Formats</a>
*/
public class SortedPackedIntegerBinding extends TupleBinding<Integer> {
// javadoc is inherited
public Integer entryToObject(TupleInput input) {
return input.readSortedPackedInt();
}
// javadoc is inherited
public void objectToEntry(Integer object, TupleOutput output) {
output.writeSortedPackedInt(object);
}
// javadoc is inherited
protected TupleOutput getTupleOutput(Integer object) {
return sizedOutput();
}
/**
* Converts an entry buffer into a simple <code>int</code> value.
*
* @param entry is the source entry buffer.
*
* @return the resulting value.
*/
public static int entryToInt(DatabaseEntry entry) {
return entryToInput(entry).readSortedPackedInt();
}
/**
* Converts a simple <code>int</code> value into an entry buffer, using
* SortedPackedInteger format.
*
* @param val is the source value.
*
* @param entry is the destination entry buffer.
*/
public static void intToEntry(int val, DatabaseEntry entry) {
outputToEntry(sizedOutput().writeSortedPackedInt(val), entry);
}
/**
* Returns a tuple output object of the maximum size needed, to avoid
* wasting space when a single primitive is output.
*/
private static TupleOutput sizedOutput() {
return new TupleOutput(new byte[PackedInteger.MAX_LENGTH]);
}
}