| /*- |
| * 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]); |
| } |
| } |