blob: 775fbd4092e5ebead9cb9f73d65a431171bce484 [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;
import com.sleepycat.compat.DbCompat;
import com.sleepycat.je.DatabaseEntry;
/**
* <!-- begin JE only -->
* @hidden
* <!-- end JE only -->
* An <code>EntryBinding</code> that treats a record number key entry as a
* <code>Long</code> key object.
*
* <p>Record numbers are returned as <code>Long</code> objects, although on
* input any <code>Number</code> object may be used.</p>
*
* @author Mark Hayes
*/
public class RecordNumberBinding implements EntryBinding {
/**
* Creates a byte array binding.
*/
public RecordNumberBinding() {
}
// javadoc is inherited
public Long entryToObject(DatabaseEntry entry) {
return Long.valueOf(entryToRecordNumber(entry));
}
// javadoc is inherited
public void objectToEntry(Object object, DatabaseEntry entry) {
recordNumberToEntry(((Number) object).longValue(), entry);
}
/**
* Utility method for use by bindings to translate a entry buffer to an
* record number integer.
*
* @param entry the entry buffer.
*
* @return the record number.
*/
public static long entryToRecordNumber(DatabaseEntry entry) {
return DbCompat.getRecordNumber(entry) & 0xFFFFFFFFL;
}
/**
* Utility method for use by bindings to translate a record number integer
* to a entry buffer.
*
* @param recordNumber the record number.
*
* @param entry the entry buffer to hold the record number.
*/
public static void recordNumberToEntry(long recordNumber,
DatabaseEntry entry) {
entry.setData(new byte[4], 0, 4);
DbCompat.setRecordNumber(entry, (int) recordNumber);
}
}