Files
mongo/lang/java/wiredtiger.i
2016-01-01 16:37:39 -05:00

2033 lines
52 KiB
OpenEdge ABL

/*-
* Public Domain 2014-2016 MongoDB, Inc.
* Public Domain 2008-2014 WiredTiger, Inc.
*
* This is free and unencumbered software released into the public domain.
*
* Anyone is free to copy, modify, publish, use, compile, sell, or
* distribute this software, either in source code form or as a compiled
* binary, for any purpose, commercial or non-commercial, and by any
* means.
*
* In jurisdictions that recognize copyright laws, the author or authors
* of this software dedicate any and all copyright interest in the
* software to the public domain. We make this dedication for the benefit
* of the public at large and to the detriment of our heirs and
* successors. We intend this dedication to be an overt act of
* relinquishment in perpetuity of all present and future rights to this
* software under copyright law.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
* IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*
* wiredtiger.i
* The SWIG interface file defining the wiredtiger Java API.
*/
%module wiredtiger
%include "enums.swg"
%include "typemaps.i"
%include "stdint.i"
%pragma(java) jniclasscode=%{
static {
try {
System.loadLibrary("wiredtiger_java");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load. \n" + e);
System.exit(1);
}
}
%}
%{
#include "src/include/wt_internal.h"
/*
* Closed handle checking:
*
* The typedef WT_CURSOR_NULLABLE used in wiredtiger.h is only made
* visible to the SWIG parser and is used to identify arguments of
* Cursor type that are permitted to be null. Likewise, typedefs
* WT_{CURSOR,SESSION,CONNECTION}_CLOSED identify 'close' calls that
* need explicit nulling of the swigCPtr. These typedefs permit
* special casing in typemaps for input args.
*
* We want SWIG to see these 'fake' typenames, but not the compiler.
*/
#define WT_CURSOR_NULLABLE WT_CURSOR
#define WT_CURSOR_CLOSED WT_CURSOR
#define WT_SESSION_CLOSED WT_SESSION
#define WT_CONNECTION_CLOSED WT_CONNECTION
/*
* For Connections, Sessions and Cursors created in Java, each of
* WT_CONNECTION_IMPL, WT_SESSION_IMPL and WT_CURSOR have a
* lang_private field that store a pointer to a JAVA_CALLBACK, alloced
* during the various open calls. {conn,session,cursor}CloseHandler()
* functions reach into the associated java object, set the swigCPtr
* to 0, and free the JAVA_CALLBACK. Typemaps matching Connection,
* Session, Cursor args use the NULL_CHECK macro, which checks if
* swigCPtr is 0.
*/
typedef struct {
JavaVM *javavm; /* Used in async threads to craft a jnienv */
JNIEnv *jnienv; /* jni env that created the Session/Cursor */
WT_SESSION_IMPL *session; /* session used for alloc/free */
jobject jobj; /* the java Session/Cursor/AsyncOp object */
jobject jcallback; /* callback object for async ops */
jfieldID cptr_fid; /* cached Cursor.swigCPtr field id in session */
jfieldID asynccptr_fid; /* cached AsyncOp.swigCptr fid in conn */
jfieldID kunp_fid; /* cached AsyncOp.keyUnpacker fid in conn */
jfieldID vunp_fid; /* cached AsyncOp.valueUnpacker fid in conn */
jmethodID notify_mid; /* cached AsyncCallback.notify mid in conn */
} JAVA_CALLBACK;
static void throwWiredTigerException(JNIEnv *jenv, int err) {
const char *clname;
jclass excep;
clname = NULL;
excep = NULL;
if (err == WT_PANIC)
clname = "com/wiredtiger/db/WiredTigerPanicException";
else if (err == WT_ROLLBACK)
clname = "com/wiredtiger/db/WiredTigerRollbackException";
else
clname = "com/wiredtiger/db/WiredTigerException";
if (clname)
excep = (*jenv)->FindClass(jenv, clname);
if (excep)
(*jenv)->ThrowNew(jenv, excep, wiredtiger_strerror(err));
}
%}
/* No finalizers */
%typemap(javafinalize) SWIGTYPE ""
/* Event handlers are not supported in Java. */
%typemap(in, numinputs=0) WT_EVENT_HANDLER * %{ $1 = NULL; %}
/* Allow silently passing the Java object and JNIEnv into our code. */
%typemap(in, numinputs=0) jobject *jthis %{ $1 = jarg1_; %}
%typemap(in, numinputs=0) JNIEnv * %{ $1 = jenv; %}
/* 64 bit typemaps. */
%typemap(jni) uint64_t "jlong"
%typemap(jtype) uint64_t "long"
%typemap(jstype) uint64_t "long"
%typemap(javain) uint64_t "$javainput"
%typemap(javaout) uint64_t {
return $jnicall;
}
/* Return byte[] from cursor.get_value */
%typemap(jni) WT_ITEM, WT_ITEM * "jbyteArray"
%typemap(jtype) WT_ITEM, WT_ITEM * "byte[]"
%typemap(jstype) WT_ITEM, WT_ITEM * "byte[]"
%typemap(javain) WT_ITEM, WT_ITEM * "$javainput"
%typemap(javaout) WT_ITEM, WT_ITEM * {
return $jnicall;
}
%typemap(in) WT_ITEM * (WT_ITEM item) %{
$1 = &item;
$1->data = (*jenv)->GetByteArrayElements(jenv, $input, 0);
$1->size = (size_t)(*jenv)->GetArrayLength(jenv, $input);
%}
%typemap(argout) WT_ITEM * %{
(*jenv)->ReleaseByteArrayElements(jenv, $input, (void *)$1->data, 0);
%}
%typemap(out) WT_ITEM %{
if ($1.data == NULL)
$result = NULL;
else if (($result = (*jenv)->NewByteArray(jenv, (jsize)$1.size)) != NULL) {
(*jenv)->SetByteArrayRegion(jenv,
$result, 0, (jsize)$1.size, $1.data);
}
%}
/* Don't require empty config strings. */
%typemap(default) const char *config %{ $1 = NULL; %}
%typemap(out) int %{
if ($1 != 0 && $1 != WT_NOTFOUND) {
throwWiredTigerException(jenv, $1);
return $null;
}
$result = $1;
%}
%define NULL_CHECK(val, name)
if (!val) {
SWIG_JavaThrowException(jenv, SWIG_JavaNullPointerException,
#name " is null");
return $null;
}
%enddef
/*
* 'Declare' a WiredTiger class. This sets up boilerplate typemaps.
*/
%define WT_CLASS(type, class, name)
/*
* Extra 'self' elimination.
* The methods we're wrapping look like this:
* struct __wt_xxx {
* int method(WT_XXX *, ...otherargs...);
* };
* To SWIG, that is equivalent to:
* int method(struct __wt_xxx *self, WT_XXX *, ...otherargs...);
* and we use consecutive argument matching of typemaps to convert two args to
* one.
*/
%typemap(in, numinputs=0) type *name {
$1 = *(type **)&jarg1;
NULL_CHECK($1, $1_name)
}
%typemap(in) class ## _NULLABLE * {
$1 = *(type **)&$input;
}
%typemap(in) type * {
$1 = *(type **)&$input;
NULL_CHECK($1, $1_name)
}
%typemap(javaimports) type "
/**
* @copydoc class
* @ingroup wt_java
*/"
%enddef
/*
* Declare a WT_CLASS so that close methods call a specified closeHandler,
* after the WT core close function has completed. Arguments to the
* closeHandler are saved in advance since, as macro args, they may refer to
* values that are freed/zeroed by the close.
*/
%define WT_CLASS_WITH_CLOSE_HANDLER(type, class, name, closeHandler,
sess, priv)
WT_CLASS(type, class, name)
/*
* This typemap recognizes a close function via a special declaration on its
* first argument. See WT_HANDLE_CLOSED in wiredtiger.h . Like
* WT_CURSOR_NULLABLE, the WT_{CURSOR,SESSION,CONNECTION}_CLOSED typedefs
* are only visible to the SWIG parser.
*/
%typemap(in, numinputs=0) class ## _CLOSED *name (
WT_SESSION *savesess, JAVA_CALLBACK *jcb) {
$1 = *(type **)&jarg1;
NULL_CHECK($1, $1_name)
savesess = sess;
jcb = (JAVA_CALLBACK *)(priv);
}
%typemap(freearg, numinputs=0) class ## _CLOSED *name {
closeHandler(jenv, savesess2, jcb2);
priv = NULL;
}
%enddef
%pragma(java) moduleimports=%{
/**
* @defgroup wt_java WiredTiger Java API
*
* Java wrappers around the WiredTiger C API.
*/
/**
* @ingroup wt_java
*/
%}
WT_CLASS_WITH_CLOSE_HANDLER(struct __wt_connection, WT_CONNECTION, connection,
closeHandler, NULL, ((WT_CONNECTION_IMPL *)$1)->lang_private)
WT_CLASS_WITH_CLOSE_HANDLER(struct __wt_session, WT_SESSION, session,
closeHandler, $1, ((WT_SESSION_IMPL *)$1)->lang_private)
WT_CLASS_WITH_CLOSE_HANDLER(struct __wt_cursor, WT_CURSOR, cursor,
cursorCloseHandler, $1->session, ((WT_CURSOR *)$1)->lang_private)
WT_CLASS(struct __wt_async_op, WT_ASYNC_OP, op)
%define COPYDOC(SIGNATURE_CLASS, CLASS, METHOD)
%javamethodmodifiers SIGNATURE_CLASS::METHOD "
/**
* @copydoc CLASS::METHOD
*/
public ";
%enddef
%include "java_doc.i"
/* WT_ASYNC_OP customization. */
/* First, replace the varargs get / set methods with Java equivalents. */
%ignore __wt_async_op::get_key;
%ignore __wt_async_op::get_value;
%ignore __wt_async_op::set_key;
%ignore __wt_async_op::set_value;
%ignore __wt_async_op::insert;
%ignore __wt_async_op::remove;
%ignore __wt_async_op::search;
%ignore __wt_async_op::update;
%immutable __wt_async_op::connection;
%immutable __wt_async_op::key_format;
%immutable __wt_async_op::value_format;
%javamethodmodifiers __wt_async_op::key_format "protected";
%javamethodmodifiers __wt_async_op::value_format "protected";
/* WT_CURSOR customization. */
/* First, replace the varargs get / set methods with Java equivalents. */
%ignore __wt_cursor::get_key;
%ignore __wt_cursor::get_value;
%ignore __wt_cursor::set_key;
%ignore __wt_cursor::set_value;
%ignore __wt_cursor::insert;
%ignore __wt_cursor::remove;
%ignore __wt_cursor::reset;
%ignore __wt_cursor::search;
%ignore __wt_cursor::search_near;
%ignore __wt_cursor::update;
%javamethodmodifiers __wt_cursor::next "protected";
%rename (next_wrap) __wt_cursor::next;
%javamethodmodifiers __wt_cursor::prev "protected";
%rename (prev_wrap) __wt_cursor::prev;
%javamethodmodifiers __wt_cursor::key_format "protected";
%javamethodmodifiers __wt_cursor::value_format "protected";
%ignore __wt_cursor::compare(WT_CURSOR *, WT_CURSOR *, int *);
%rename (compare_wrap) __wt_cursor::compare;
%ignore __wt_cursor::equals(WT_CURSOR *, WT_CURSOR *, int *);
%rename (equals_wrap) __wt_cursor::equals;
%rename (AsyncOpType) WT_ASYNC_OPTYPE;
%rename (getKeyFormat) __wt_async_op::getKey_format;
%rename (getValueFormat) __wt_async_op::getValue_format;
%rename (getType) __wt_async_op::get_type;
/* SWIG magic to turn Java byte strings into data / size. */
%apply (char *STRING, int LENGTH) { (char *data, int size) };
/* Status from search_near */
%javaconst(1);
%inline %{
enum SearchStatus { FOUND, NOTFOUND, SMALLER, LARGER };
%}
%wrapper %{
/* Zero out SWIG's pointer to the C object,
* equivalent to 'jobj.swigCPtr = 0;' in java.
* We expect that either env in non-null (if called
* via an explicit session/cursor close() call), or
* that session is non-null (if called implicitly
* as part of connection/session close).
*/
static int
javaClose(JNIEnv *env, WT_SESSION *session, JAVA_CALLBACK *jcb, jfieldID *pfid)
{
jclass cls;
jfieldID fid;
WT_CONNECTION_IMPL *conn;
/* If we were not called via an implicit close call,
* we won't have a JNIEnv yet. Get one from the connection,
* since the thread that started the session may have
* terminated.
*/
if (env == NULL) {
conn = (WT_CONNECTION_IMPL *)session->connection;
env = ((JAVA_CALLBACK *)conn->lang_private)->jnienv;
}
if (pfid == NULL || *pfid == NULL) {
cls = (*env)->GetObjectClass(env, jcb->jobj);
fid = (*env)->GetFieldID(env, cls, "swigCPtr", "J");
if (pfid != NULL)
*pfid = fid;
} else
fid = *pfid;
(*env)->SetLongField(env, jcb->jobj, fid, 0L);
(*env)->DeleteGlobalRef(env, jcb->jobj);
__wt_free(jcb->session, jcb);
return (0);
}
/* Connection and Session close handler. */
static int
closeHandler(JNIEnv *env, WT_SESSION *session, JAVA_CALLBACK *jcb)
{
return (javaClose(env, session, jcb, NULL));
}
/* Cursor specific close handler. */
static int
cursorCloseHandler(JNIEnv *env, WT_SESSION *wt_session, JAVA_CALLBACK *jcb)
{
int ret;
JAVA_CALLBACK *sess_jcb;
WT_SESSION_IMPL *session;
session = (WT_SESSION_IMPL *)wt_session;
sess_jcb = (JAVA_CALLBACK *)session->lang_private;
ret = javaClose(env, wt_session, jcb,
sess_jcb ? &sess_jcb->cptr_fid : NULL);
return (ret);
}
/* Add event handler support. */
static int
javaCloseHandler(WT_EVENT_HANDLER *handler, WT_SESSION *session,
WT_CURSOR *cursor)
{
int ret;
JAVA_CALLBACK *jcb;
WT_UNUSED(handler);
ret = 0;
if (cursor != NULL) {
if ((jcb = (JAVA_CALLBACK *)cursor->lang_private) != NULL) {
ret = cursorCloseHandler(NULL, session, jcb);
cursor->lang_private = NULL;
}
} else if ((jcb = ((WT_SESSION_IMPL *)session)->lang_private) != NULL) {
ret = closeHandler(NULL, session, jcb);
((WT_SESSION_IMPL *)session)->lang_private = NULL;
}
return (ret);
}
WT_EVENT_HANDLER javaApiEventHandler = {NULL, NULL, NULL, javaCloseHandler};
static int
javaAsyncHandler(WT_ASYNC_CALLBACK *cb, WT_ASYNC_OP *asyncop, int opret,
uint32_t flags)
{
int ret, envret;
JAVA_CALLBACK *jcb, *conn_jcb;
JavaVM *javavm;
jclass cls;
jfieldID fid;
jmethodID mid;
jobject jcallback;
JNIEnv *jenv;
WT_ASYNC_OP_IMPL *op;
WT_SESSION_IMPL *session;
WT_UNUSED(cb);
WT_UNUSED(flags);
op = (WT_ASYNC_OP_IMPL *)asyncop;
session = O2S(op);
jcb = (JAVA_CALLBACK *)asyncop->c.lang_private;
conn_jcb = (JAVA_CALLBACK *)S2C(session)->lang_private;
asyncop->c.lang_private = NULL;
jcallback = jcb->jcallback;
/*
* We rely on the fact that the async machinery uses a pool of
* threads. Here we attach the current native (POSIX)
* thread to a Java thread and never detach it. If the native
* thread was previously seen by this callback, it will be
* attached to the same Java thread as before without
* incurring the cost of the thread initialization.
* Marking the Java thread as a daemon means its existence
* won't keep an application from exiting.
*/
javavm = jcb->javavm;
envret = (*javavm)->GetEnv(javavm, (void **)&jenv, JNI_VERSION_1_6);
if (envret == JNI_EDETACHED) {
if ((*javavm)->AttachCurrentThreadAsDaemon(javavm,
(void **)&jenv, NULL) != 0) {
ret = EBUSY;
goto err;
}
} else if (envret != JNI_OK) {
ret = EBUSY;
goto err;
}
/*
* Look up any needed field and method ids, and cache them
* in the connection's lang_private. fid and mids are
* stable.
*/
if (conn_jcb->notify_mid == NULL) {
/* Any JNI error until the actual callback is unexpected. */
ret = EINVAL;
cls = (*jenv)->GetObjectClass(jenv, jcb->jobj);
if (cls == NULL)
goto err;
fid = (*jenv)->GetFieldID(jenv, cls,
"keyUnpacker", "Lcom/wiredtiger/db/PackInputStream;");
if (fid == NULL)
goto err;
conn_jcb->kunp_fid = fid;
fid = (*jenv)->GetFieldID(jenv, cls,
"valueUnpacker", "Lcom/wiredtiger/db/PackInputStream;");
if (fid == NULL)
goto err;
conn_jcb->vunp_fid = fid;
cls = (*jenv)->GetObjectClass(jenv, jcallback);
if (cls == NULL)
goto err;
mid = (*jenv)->GetMethodID(jenv, cls, "notify",
"(Lcom/wiredtiger/db/AsyncOp;II)I");
if (mid == NULL)
goto err;
conn_jcb->notify_mid = mid;
}
/*
* Invalidate the unpackers so any calls to op.getKey()
* and op.getValue get fresh results.
*/
(*jenv)->SetObjectField(jenv, jcb->jobj, conn_jcb->kunp_fid, NULL);
(*jenv)->SetObjectField(jenv, jcb->jobj, conn_jcb->vunp_fid, NULL);
/* Call the registered callback. */
ret = (*jenv)->CallIntMethod(jenv, jcallback, conn_jcb->notify_mid,
jcb->jobj, opret, flags);
if ((*jenv)->ExceptionOccurred(jenv)) {
(*jenv)->ExceptionDescribe(jenv);
(*jenv)->ExceptionClear(jenv);
}
if (0) {
err: __wt_err(session, ret, "Java async callback error");
}
/* Invalidate the AsyncOp, further use throws NullPointerException. */
ret = javaClose(jenv, NULL, jcb, &conn_jcb->asynccptr_fid);
(*jenv)->DeleteGlobalRef(jenv, jcallback);
if (ret == 0 && (opret == 0 || opret == WT_NOTFOUND))
return (0);
else
return (1);
}
WT_ASYNC_CALLBACK javaApiAsyncHandler = {javaAsyncHandler};
%}
%extend __wt_async_op {
%javamethodmodifiers get_key_wrap "protected";
WT_ITEM get_key_wrap(JNIEnv *jenv) {
WT_ITEM k;
int ret;
k.data = NULL;
if ((ret = $self->get_key($self, &k)) != 0)
throwWiredTigerException(jenv, ret);
return k;
}
%javamethodmodifiers get_value_wrap "protected";
WT_ITEM get_value_wrap(JNIEnv *jenv) {
WT_ITEM v;
int ret;
v.data = NULL;
if ((ret = $self->get_value($self, &v)) != 0)
throwWiredTigerException(jenv, ret);
return v;
}
%javamethodmodifiers insert_wrap "protected";
int insert_wrap(WT_ITEM *k, WT_ITEM *v) {
$self->set_key($self, k);
$self->set_value($self, v);
return $self->insert($self);
}
%javamethodmodifiers remove_wrap "protected";
int remove_wrap(WT_ITEM *k) {
$self->set_key($self, k);
return $self->remove($self);
}
%javamethodmodifiers search_wrap "protected";
int search_wrap(WT_ITEM *k) {
$self->set_key($self, k);
return $self->search($self);
}
%javamethodmodifiers update_wrap "protected";
int update_wrap(WT_ITEM *k, WT_ITEM *v) {
$self->set_key($self, k);
$self->set_value($self, v);
return $self->update($self);
}
%javamethodmodifiers java_init "protected";
int java_init(jobject jasyncop) {
JAVA_CALLBACK *jcb =
(JAVA_CALLBACK *)$self->c.lang_private;
jcb->jobj = JCALL1(NewGlobalRef, jcb->jnienv, jasyncop);
JCALL1(DeleteLocalRef, jcb->jnienv, jasyncop);
return (0);
}
}
/* Cache key/value formats in Async_op */
%typemap(javabody) struct __wt_async_op %{
private long swigCPtr;
protected boolean swigCMemOwn;
protected String keyFormat;
protected String valueFormat;
protected PackOutputStream keyPacker;
protected PackOutputStream valuePacker;
protected PackInputStream keyUnpacker;
protected PackInputStream valueUnpacker;
protected $javaclassname(long cPtr, boolean cMemoryOwn) {
swigCMemOwn = cMemoryOwn;
swigCPtr = cPtr;
keyFormat = getKey_format();
valueFormat = getValue_format();
keyPacker = new PackOutputStream(keyFormat);
valuePacker = new PackOutputStream(valueFormat);
wiredtigerJNI.AsyncOp_java_init(swigCPtr, this, this);
}
protected static long getCPtr($javaclassname obj) {
return (obj == null) ? 0 : obj.swigCPtr;
}
%}
%typemap(javacode) struct __wt_async_op %{
/**
* Retrieve the format string for this async_op's key.
*/
public String getKeyFormat() {
return keyFormat;
}
/**
* Retrieve the format string for this async_op's value.
*/
public String getValueFormat() {
return valueFormat;
}
/**
* Append a byte to the async_op's key.
*
* \param value The value to append.
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyByte(byte value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addByte(value);
return this;
}
/**
* Append a byte array to the async_op's key.
*
* \param value The value to append.
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyByteArray(byte[] value)
throws WiredTigerPackingException {
this.putKeyByteArray(value, 0, value.length);
return this;
}
/**
* Append a byte array to the async_op's key.
*
* \param value The value to append.
* \param off The offset into value at which to start.
* \param len The length of the byte array.
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyByteArray(byte[] value, int off, int len)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addByteArray(value, off, len);
return this;
}
/**
* Append an integer to the async_op's key.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyInt(int value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addInt(value);
return this;
}
/**
* Append a long to the async_op's key.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyLong(long value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addLong(value);
return this;
}
/**
* Append a record number to the async_op's key.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyRecord(long value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addRecord(value);
return this;
}
/**
* Append a short integer to the async_op's key.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyShort(short value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addShort(value);
return this;
}
/**
* Append a string to the async_op's key.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putKeyString(String value)
throws WiredTigerPackingException {
keyUnpacker = null;
keyPacker.addString(value);
return this;
}
/**
* Append a byte to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueByte(byte value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addByte(value);
return this;
}
/**
* Append a byte array to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueByteArray(byte[] value)
throws WiredTigerPackingException {
this.putValueByteArray(value, 0, value.length);
return this;
}
/**
* Append a byte array to the async_op's value.
*
* \param value The value to append
* \param off The offset into value at which to start.
* \param len The length of the byte array.
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueByteArray(byte[] value, int off, int len)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addByteArray(value, off, len);
return this;
}
/**
* Append an integer to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueInt(int value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addInt(value);
return this;
}
/**
* Append a long to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueLong(long value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addLong(value);
return this;
}
/**
* Append a record number to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueRecord(long value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addRecord(value);
return this;
}
/**
* Append a short integer to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueShort(short value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addShort(value);
return this;
}
/**
* Append a string to the async_op's value.
*
* \param value The value to append
* \return This async_op object, so put calls can be chained.
*/
public AsyncOp putValueString(String value)
throws WiredTigerPackingException {
valueUnpacker = null;
valuePacker.addString(value);
return this;
}
/**
* Retrieve a byte from the async_op's key.
*
* \return The requested value.
*/
public byte getKeyByte()
throws WiredTigerPackingException {
return getKeyUnpacker().getByte();
}
/**
* Retrieve a byte array from the async_op's key.
*
* \param output The byte array where the returned value will be stored.
* The array should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getKeyByteArray(byte[] output)
throws WiredTigerPackingException {
this.getKeyByteArray(output, 0, output.length);
}
/**
* Retrieve a byte array from the async_op's key.
*
* \param output The byte array where the returned value will be stored.
* \param off Offset into the destination buffer to start copying into.
* \param len The length should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getKeyByteArray(byte[] output, int off, int len)
throws WiredTigerPackingException {
getKeyUnpacker().getByteArray(output, off, len);
}
/**
* Retrieve a byte array from the async_op's key.
*
* \return The requested value.
*/
public byte[] getKeyByteArray()
throws WiredTigerPackingException {
return getKeyUnpacker().getByteArray();
}
/**
* Retrieve an integer from the async_op's key.
*
* \return The requested value.
*/
public int getKeyInt()
throws WiredTigerPackingException {
return getKeyUnpacker().getInt();
}
/**
* Retrieve a long from the async_op's key.
*
* \return The requested value.
*/
public long getKeyLong()
throws WiredTigerPackingException {
return getKeyUnpacker().getLong();
}
/**
* Retrieve a record number from the async_op's key.
*
* \return The requested value.
*/
public long getKeyRecord()
throws WiredTigerPackingException {
return getKeyUnpacker().getRecord();
}
/**
* Retrieve a short integer from the async_op's key.
*
* \return The requested value.
*/
public short getKeyShort()
throws WiredTigerPackingException {
return getKeyUnpacker().getShort();
}
/**
* Retrieve a string from the async_op's key.
*
* \return The requested value.
*/
public String getKeyString()
throws WiredTigerPackingException {
return getKeyUnpacker().getString();
}
/**
* Retrieve a byte from the async_op's value.
*
* \return The requested value.
*/
public byte getValueByte()
throws WiredTigerPackingException {
return getValueUnpacker().getByte();
}
/**
* Retrieve a byte array from the async_op's value.
*
* \param output The byte array where the returned value will be stored.
* The array should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getValueByteArray(byte[] output)
throws WiredTigerPackingException {
this.getValueByteArray(output, 0, output.length);
}
/**
* Retrieve a byte array from the async_op's value.
*
* \param output The byte array where the returned value will be stored.
* \param off Offset into the destination buffer to start copying into.
* \param len The length should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getValueByteArray(byte[] output, int off, int len)
throws WiredTigerPackingException {
getValueUnpacker().getByteArray(output, off, len);
}
/**
* Retrieve a byte array from the async_op's value.
*
* \return The requested value.
*/
public byte[] getValueByteArray()
throws WiredTigerPackingException {
return getValueUnpacker().getByteArray();
}
/**
* Retrieve an integer from the async_op's value.
*
* \return The requested value.
*/
public int getValueInt()
throws WiredTigerPackingException {
return getValueUnpacker().getInt();
}
/**
* Retrieve a long from the async_op's value.
*
* \return The requested value.
*/
public long getValueLong()
throws WiredTigerPackingException {
return getValueUnpacker().getLong();
}
/**
* Retrieve a record number from the async_op's value.
*
* \return The requested value.
*/
public long getValueRecord()
throws WiredTigerPackingException {
return getValueUnpacker().getRecord();
}
/**
* Retrieve a short integer from the async_op's value.
*
* \return The requested value.
*/
public short getValueShort()
throws WiredTigerPackingException {
return getValueUnpacker().getShort();
}
/**
* Retrieve a string from the async_op's value.
*
* \return The requested value.
*/
public String getValueString()
throws WiredTigerPackingException {
return getValueUnpacker().getString();
}
/**
* Insert the async_op's current key/value into the table.
*
* \return The status of the operation.
*/
public int insert()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
byte[] value = valuePacker.getValue();
keyPacker.reset();
valuePacker.reset();
return insert_wrap(key, value);
}
/**
* Update the async_op's current key/value into the table.
*
* \return The status of the operation.
*/
public int update()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
byte[] value = valuePacker.getValue();
keyPacker.reset();
valuePacker.reset();
return update_wrap(key, value);
}
/**
* Remove the async_op's current key/value into the table.
*
* \return The status of the operation.
*/
public int remove()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
keyPacker.reset();
return remove_wrap(key);
}
/**
* Search for an item in the table.
*
* \return The result of the comparison.
*/
public int search()
throws WiredTigerException {
int ret = search_wrap(keyPacker.getValue());
keyPacker.reset();
valuePacker.reset();
return ret;
}
/**
* Set up the key unpacker or return previously cached value.
*
* \return The key unpacker.
*/
private PackInputStream getKeyUnpacker()
throws WiredTigerPackingException {
if (keyUnpacker == null)
keyUnpacker =
new PackInputStream(keyFormat, get_key_wrap());
return keyUnpacker;
}
/**
* Set up the value unpacker or return previously cached value.
*
* \return The value unpacker.
*/
private PackInputStream getValueUnpacker()
throws WiredTigerPackingException {
if (valueUnpacker == null)
valueUnpacker =
new PackInputStream(valueFormat, get_value_wrap());
return valueUnpacker;
}
%}
%extend __wt_cursor {
%javamethodmodifiers get_key_wrap "protected";
WT_ITEM get_key_wrap(JNIEnv *jenv) {
WT_ITEM k;
int ret;
k.data = NULL;
if ((ret = $self->get_key($self, &k)) != 0)
throwWiredTigerException(jenv, ret);
return k;
}
%javamethodmodifiers get_value_wrap "protected";
WT_ITEM get_value_wrap(JNIEnv *jenv) {
WT_ITEM v;
int ret;
v.data = NULL;
if ((ret = $self->get_value($self, &v)) != 0)
throwWiredTigerException(jenv, ret);
return v;
}
%javamethodmodifiers insert_wrap "protected";
int insert_wrap(WT_ITEM *k, WT_ITEM *v) {
$self->set_key($self, k);
$self->set_value($self, v);
return $self->insert($self);
}
%javamethodmodifiers remove_wrap "protected";
int remove_wrap(WT_ITEM *k) {
$self->set_key($self, k);
return $self->remove($self);
}
%javamethodmodifiers reset_wrap "protected";
int reset_wrap() {
return $self->reset($self);
}
%javamethodmodifiers search_wrap "protected";
int search_wrap(WT_ITEM *k) {
$self->set_key($self, k);
return $self->search($self);
}
%javamethodmodifiers search_near_wrap "protected";
enum SearchStatus search_near_wrap(JNIEnv *jenv, WT_ITEM *k) {
int cmp, ret;
$self->set_key($self, k);
ret = $self->search_near(self, &cmp);
if (ret != 0 && ret != WT_NOTFOUND)
throwWiredTigerException(jenv, ret);
if (ret == 0)
return (cmp == 0 ? FOUND : cmp < 0 ? SMALLER : LARGER);
return (NOTFOUND);
}
%javamethodmodifiers update_wrap "protected";
int update_wrap(WT_ITEM *k, WT_ITEM *v) {
$self->set_key($self, k);
$self->set_value($self, v);
return $self->update($self);
}
int compare_wrap(JNIEnv *jenv, WT_CURSOR *other) {
int cmp, ret = $self->compare($self, other, &cmp);
if (ret != 0)
throwWiredTigerException(jenv, ret);
return cmp;
}
int equals_wrap(JNIEnv *jenv, WT_CURSOR *other) {
int cmp, ret = $self->equals($self, other, &cmp);
if (ret != 0)
throwWiredTigerException(jenv, ret);
return cmp;
}
%javamethodmodifiers java_init "protected";
int java_init(jobject jcursor) {
JAVA_CALLBACK *jcb = (JAVA_CALLBACK *)$self->lang_private;
jcb->jobj = JCALL1(NewGlobalRef, jcb->jnienv, jcursor);
JCALL1(DeleteLocalRef, jcb->jnienv, jcursor);
return (0);
}
}
/* Cache key/value formats in Cursor */
%typemap(javabody) struct __wt_cursor %{
private long swigCPtr;
protected boolean swigCMemOwn;
protected String keyFormat;
protected String valueFormat;
protected PackOutputStream keyPacker;
protected PackOutputStream valuePacker;
protected PackInputStream keyUnpacker;
protected PackInputStream valueUnpacker;
protected $javaclassname(long cPtr, boolean cMemoryOwn) {
swigCMemOwn = cMemoryOwn;
swigCPtr = cPtr;
keyFormat = getKey_format();
valueFormat = getValue_format();
keyPacker = new PackOutputStream(keyFormat);
valuePacker = new PackOutputStream(valueFormat);
wiredtigerJNI.Cursor_java_init(swigCPtr, this, this);
}
protected static long getCPtr($javaclassname obj) {
return (obj == null) ? 0 : obj.swigCPtr;
}
%}
%typemap(javacode) struct __wt_cursor %{
/**
* Retrieve the format string for this cursor's key.
*/
public String getKeyFormat() {
return keyFormat;
}
/**
* Retrieve the format string for this cursor's value.
*/
public String getValueFormat() {
return valueFormat;
}
/**
* Append a byte to the cursor's key.
*
* \param value The value to append.
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyByte(byte value)
throws WiredTigerPackingException {
keyPacker.addByte(value);
return this;
}
/**
* Append a byte array to the cursor's key.
*
* \param value The value to append.
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyByteArray(byte[] value)
throws WiredTigerPackingException {
this.putKeyByteArray(value, 0, value.length);
return this;
}
/**
* Append a byte array to the cursor's key.
*
* \param value The value to append.
* \param off The offset into value at which to start.
* \param len The length of the byte array.
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyByteArray(byte[] value, int off, int len)
throws WiredTigerPackingException {
keyPacker.addByteArray(value, off, len);
return this;
}
/**
* Append an integer to the cursor's key.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyInt(int value)
throws WiredTigerPackingException {
keyPacker.addInt(value);
return this;
}
/**
* Append a long to the cursor's key.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyLong(long value)
throws WiredTigerPackingException {
keyPacker.addLong(value);
return this;
}
/**
* Append a record number to the cursor's key.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyRecord(long value)
throws WiredTigerPackingException {
keyPacker.addRecord(value);
return this;
}
/**
* Append a short integer to the cursor's key.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyShort(short value)
throws WiredTigerPackingException {
keyPacker.addShort(value);
return this;
}
/**
* Append a string to the cursor's key.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putKeyString(String value)
throws WiredTigerPackingException {
keyPacker.addString(value);
return this;
}
/**
* Append a byte to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueByte(byte value)
throws WiredTigerPackingException {
valuePacker.addByte(value);
return this;
}
/**
* Append a byte array to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueByteArray(byte[] value)
throws WiredTigerPackingException {
this.putValueByteArray(value, 0, value.length);
return this;
}
/**
* Append a byte array to the cursor's value.
*
* \param value The value to append
* \param off The offset into value at which to start.
* \param len The length of the byte array.
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueByteArray(byte[] value, int off, int len)
throws WiredTigerPackingException {
valuePacker.addByteArray(value, off, len);
return this;
}
/**
* Append an integer to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueInt(int value)
throws WiredTigerPackingException {
valuePacker.addInt(value);
return this;
}
/**
* Append a long to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueLong(long value)
throws WiredTigerPackingException {
valuePacker.addLong(value);
return this;
}
/**
* Append a record number to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueRecord(long value)
throws WiredTigerPackingException {
valuePacker.addRecord(value);
return this;
}
/**
* Append a short integer to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueShort(short value)
throws WiredTigerPackingException {
valuePacker.addShort(value);
return this;
}
/**
* Append a string to the cursor's value.
*
* \param value The value to append
* \return This cursor object, so put calls can be chained.
*/
public Cursor putValueString(String value)
throws WiredTigerPackingException {
valuePacker.addString(value);
return this;
}
/**
* Retrieve a byte from the cursor's key.
*
* \return The requested value.
*/
public byte getKeyByte()
throws WiredTigerPackingException {
return keyUnpacker.getByte();
}
/**
* Retrieve a byte array from the cursor's key.
*
* \param output The byte array where the returned value will be stored.
* The array should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getKeyByteArray(byte[] output)
throws WiredTigerPackingException {
this.getKeyByteArray(output, 0, output.length);
}
/**
* Retrieve a byte array from the cursor's key.
*
* \param output The byte array where the returned value will be stored.
* \param off Offset into the destination buffer to start copying into.
* \param len The length should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getKeyByteArray(byte[] output, int off, int len)
throws WiredTigerPackingException {
keyUnpacker.getByteArray(output, off, len);
}
/**
* Retrieve a byte array from the cursor's key.
*
* \return The requested value.
*/
public byte[] getKeyByteArray()
throws WiredTigerPackingException {
return keyUnpacker.getByteArray();
}
/**
* Retrieve an integer from the cursor's key.
*
* \return The requested value.
*/
public int getKeyInt()
throws WiredTigerPackingException {
return keyUnpacker.getInt();
}
/**
* Retrieve a long from the cursor's key.
*
* \return The requested value.
*/
public long getKeyLong()
throws WiredTigerPackingException {
return keyUnpacker.getLong();
}
/**
* Retrieve a record number from the cursor's key.
*
* \return The requested value.
*/
public long getKeyRecord()
throws WiredTigerPackingException {
return keyUnpacker.getRecord();
}
/**
* Retrieve a short integer from the cursor's key.
*
* \return The requested value.
*/
public short getKeyShort()
throws WiredTigerPackingException {
return keyUnpacker.getShort();
}
/**
* Retrieve a string from the cursor's key.
*
* \return The requested value.
*/
public String getKeyString()
throws WiredTigerPackingException {
return keyUnpacker.getString();
}
/**
* Retrieve a byte from the cursor's value.
*
* \return The requested value.
*/
public byte getValueByte()
throws WiredTigerPackingException {
return valueUnpacker.getByte();
}
/**
* Retrieve a byte array from the cursor's value.
*
* \param output The byte array where the returned value will be stored.
* The array should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getValueByteArray(byte[] output)
throws WiredTigerPackingException {
this.getValueByteArray(output, 0, output.length);
}
/**
* Retrieve a byte array from the cursor's value.
*
* \param output The byte array where the returned value will be stored.
* \param off Offset into the destination buffer to start copying into.
* \param len The length should be large enough to store the entire
* data item, if not a truncated value will be returned.
*/
public void getValueByteArray(byte[] output, int off, int len)
throws WiredTigerPackingException {
valueUnpacker.getByteArray(output, off, len);
}
/**
* Retrieve a byte array from the cursor's value.
*
* \return The requested value.
*/
public byte[] getValueByteArray()
throws WiredTigerPackingException {
return valueUnpacker.getByteArray();
}
/**
* Retrieve an integer from the cursor's value.
*
* \return The requested value.
*/
public int getValueInt()
throws WiredTigerPackingException {
return valueUnpacker.getInt();
}
/**
* Retrieve a long from the cursor's value.
*
* \return The requested value.
*/
public long getValueLong()
throws WiredTigerPackingException {
return valueUnpacker.getLong();
}
/**
* Retrieve a record number from the cursor's value.
*
* \return The requested value.
*/
public long getValueRecord()
throws WiredTigerPackingException {
return valueUnpacker.getRecord();
}
/**
* Retrieve a short integer from the cursor's value.
*
* \return The requested value.
*/
public short getValueShort()
throws WiredTigerPackingException {
return valueUnpacker.getShort();
}
/**
* Retrieve a string from the cursor's value.
*
* \return The requested value.
*/
public String getValueString()
throws WiredTigerPackingException {
return valueUnpacker.getString();
}
/**
* Insert the cursor's current key/value into the table.
*
* \return The status of the operation.
*/
public int insert()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
byte[] value = valuePacker.getValue();
keyPacker.reset();
valuePacker.reset();
return insert_wrap(key, value);
}
/**
* Update the cursor's current key/value into the table.
*
* \return The status of the operation.
*/
public int update()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
byte[] value = valuePacker.getValue();
keyPacker.reset();
valuePacker.reset();
return update_wrap(key, value);
}
/**
* Remove the cursor's current key/value into the table.
*
* \return The status of the operation.
*/
public int remove()
throws WiredTigerException {
byte[] key = keyPacker.getValue();
keyPacker.reset();
return remove_wrap(key);
}
/**
* Compare this cursor's position to another Cursor.
*
* \return The result of the comparison.
*/
public int compare(Cursor other)
throws WiredTigerException {
return compare_wrap(other);
}
/**
* Compare this cursor's position to another Cursor.
*
* \return The result of the comparison.
*/
public int equals(Cursor other)
throws WiredTigerException {
return equals_wrap(other);
}
/**
* Retrieve the next item in the table.
*
* \return The result of the comparison.
*/
public int next()
throws WiredTigerException {
int ret = next_wrap();
keyPacker.reset();
valuePacker.reset();
keyUnpacker = initKeyUnpacker(ret == 0);
valueUnpacker = initValueUnpacker(ret == 0);
return ret;
}
/**
* Retrieve the previous item in the table.
*
* \return The result of the comparison.
*/
public int prev()
throws WiredTigerException {
int ret = prev_wrap();
keyPacker.reset();
valuePacker.reset();
keyUnpacker = initKeyUnpacker(ret == 0);
valueUnpacker = initValueUnpacker(ret == 0);
return ret;
}
/**
* Reset a cursor.
*
* \return The status of the operation.
*/
public int reset()
throws WiredTigerException {
int ret = reset_wrap();
keyPacker.reset();
valuePacker.reset();
keyUnpacker = null;
valueUnpacker = null;
return ret;
}
/**
* Search for an item in the table.
*
* \return The result of the comparison.
*/
public int search()
throws WiredTigerException {
int ret = search_wrap(keyPacker.getValue());
keyPacker.reset();
valuePacker.reset();
keyUnpacker = initKeyUnpacker(ret == 0);
valueUnpacker = initValueUnpacker(ret == 0);
return ret;
}
/**
* Search for an item in the table.
*
* \return The result of the comparison.
*/
public SearchStatus search_near()
throws WiredTigerException {
SearchStatus ret = search_near_wrap(keyPacker.getValue());
keyPacker.reset();
valuePacker.reset();
keyUnpacker = initKeyUnpacker(ret != SearchStatus.NOTFOUND);
valueUnpacker = initValueUnpacker(ret != SearchStatus.NOTFOUND);
return ret;
}
/**
* Initialize a key unpacker after an operation that changes
* the cursor position.
*
* \param success Whether the associated operation succeeded.
* \return The key unpacker.
*/
private PackInputStream initKeyUnpacker(boolean success)
throws WiredTigerException {
if (!success || keyFormat.equals(""))
return null;
else
return new PackInputStream(keyFormat, get_key_wrap());
}
/**
* Initialize a value unpacker after an operation that changes
* the cursor position.
*
* \param success Whether the associated operation succeeded.
* \return The value unpacker.
*/
private PackInputStream initValueUnpacker(boolean success)
throws WiredTigerException {
if (!success || valueFormat.equals(""))
return null;
else
return new PackInputStream(valueFormat,
get_value_wrap());
}
%}
/* Put a WiredTigerException on all wrapped methods. We'd like this
* to only apply to methods returning int. SWIG doesn't have a way
* to do this, so we remove the exception for simple getters and such.
*/
%javaexception("com.wiredtiger.db.WiredTigerException") { $action; }
%javaexception("") wiredtiger_strerror { $action; }
%javaexception("") __wt_async_op::connection { $action; }
%javaexception("") __wt_async_op::get_type { $action; }
%javaexception("") __wt_async_op::get_id { $action; }
%javaexception("") __wt_async_op::key_format { $action; }
%javaexception("") __wt_async_op::value_format { $action; }
%javaexception("") __wt_connection::get_home { $action; }
%javaexception("") __wt_connection::is_new { $action; }
%javaexception("") __wt_connection::java_init { $action; }
%javaexception("") __wt_cursor::key_format { $action; }
%javaexception("") __wt_cursor::session { $action; }
%javaexception("") __wt_cursor::uri { $action; }
%javaexception("") __wt_cursor::value_format { $action; }
%javaexception("") __wt_session::connection { $action; }
%javaexception("") __wt_session::java_init { $action; }
/* Remove / rename parts of the C API that we don't want in Java. */
%immutable __wt_cursor::session;
%immutable __wt_cursor::uri;
%immutable __wt_cursor::key_format;
%immutable __wt_cursor::value_format;
%immutable __wt_session::connection;
%ignore __wt_collator;
%ignore __wt_connection::add_collator;
%ignore __wt_compressor;
%ignore __wt_connection::add_compressor;
%ignore __wt_data_source;
%ignore __wt_connection::add_data_source;
%ignore __wt_encryptor;
%ignore __wt_connection::add_encryptor;
%ignore __wt_event_handler;
%ignore __wt_extractor;
%ignore __wt_connection::add_extractor;
%ignore __wt_item;
%ignore __wt_lsn;
%ignore __wt_session::msg_printf;
%ignore wiredtiger_struct_pack;
%ignore wiredtiger_struct_size;
%ignore wiredtiger_struct_unpack;
%ignore wiredtiger_version;
%ignore __wt_connection::get_extension_api;
%ignore wiredtiger_extension_init;
%ignore wiredtiger_extension_terminate;
%define REQUIRE_WRAP(typedefname, name, javaname)
%ignore name;
%javamethodmodifiers name##_wrap "
/**
* @copydoc typedefname
*/
public ";
%rename(javaname) name##_wrap;
%enddef
REQUIRE_WRAP(::wiredtiger_open, wiredtiger_open, open)
REQUIRE_WRAP(WT_CONNECTION::async_new_op,
__wt_connection::async_new_op, async_new_op)
REQUIRE_WRAP(WT_CONNECTION::open_session,
__wt_connection::open_session, open_session)
REQUIRE_WRAP(WT_SESSION::transaction_pinned_range,
__wt_session::transaction_pinned_range, transaction_pinned_range)
REQUIRE_WRAP(WT_SESSION::open_cursor, __wt_session::open_cursor, open_cursor)
REQUIRE_WRAP(WT_ASYNC_OP::get_id, __wt_async_op::get_id,getId)
%rename(AsyncOp) __wt_async_op;
%rename(Cursor) __wt_cursor;
%rename(Session) __wt_session;
%rename(Connection) __wt_connection;
%define TRACKED_CLASS(jclassname, ctypename, java_init_fcn, implclass)
%ignore jclassname::jclassname();
%typemap(javabody) struct ctypename %{
private long swigCPtr;
protected boolean swigCMemOwn;
protected $javaclassname(long cPtr, boolean cMemoryOwn) {
swigCMemOwn = cMemoryOwn;
swigCPtr = cPtr;
java_init_fcn(swigCPtr, this, this);
}
protected static long getCPtr($javaclassname obj) {
return (obj == null) ? 0 : obj.swigCPtr;
}
%}
%extend ctypename {
%javamethodmodifiers java_init "protected";
int java_init(jobject jsess) {
implclass *session = (implclass *)$self;
JAVA_CALLBACK *jcb = (JAVA_CALLBACK *)session->lang_private;
jcb->jobj = JCALL1(NewGlobalRef, jcb->jnienv, jsess);
JCALL1(DeleteLocalRef, jcb->jnienv, jsess);
return (0);
}
}
%enddef
TRACKED_CLASS(Session, __wt_session, wiredtigerJNI.Session_java_init, WT_SESSION_IMPL)
TRACKED_CLASS(Connection, __wt_connection, wiredtigerJNI.Connection_java_init, WT_CONNECTION_IMPL)
/* Note: Cursor incorporates the elements of TRACKED_CLASS into its
* custom constructor and %extend clause.
*/
%include "wiredtiger.h"
/* Return new connections, sessions and cursors. */
%inline {
WT_CONNECTION *wiredtiger_open_wrap(JNIEnv *jenv, const char *home, const char *config) {
extern WT_EVENT_HANDLER javaApiEventHandler;
WT_CONNECTION *conn = NULL;
WT_CONNECTION_IMPL *connimpl;
JAVA_CALLBACK *jcb;
int ret;
if ((ret = wiredtiger_open(home, &javaApiEventHandler, config, &conn)) != 0)
goto err;
connimpl = (WT_CONNECTION_IMPL *)conn;
if ((ret = __wt_calloc_def(connimpl->default_session, 1, &jcb)) != 0)
goto err;
jcb->jnienv = jenv;
connimpl->lang_private = jcb;
err: if (ret != 0)
throwWiredTigerException(jenv, ret);
return conn;
}
}
%extend __wt_connection {
WT_ASYNC_OP *async_new_op_wrap(JNIEnv *jenv, const char *uri,
const char *config, jobject callbackObject) {
extern WT_ASYNC_CALLBACK javaApiAsyncHandler;
WT_ASYNC_OP *asyncop = NULL;
WT_CONNECTION_IMPL *connimpl;
JAVA_CALLBACK *jcb;
int ret;
if ((ret = $self->async_new_op($self, uri, config, &javaApiAsyncHandler, &asyncop)) != 0)
goto err;
connimpl = (WT_CONNECTION_IMPL *)$self;
if ((ret = __wt_calloc_def(connimpl->default_session, 1, &jcb)) != 0)
goto err;
jcb->jnienv = jenv;
jcb->session = connimpl->default_session;
(*jenv)->GetJavaVM(jenv, &jcb->javavm);
jcb->jcallback = JCALL1(NewGlobalRef, jenv, callbackObject);
JCALL1(DeleteLocalRef, jenv, callbackObject);
asyncop->c.lang_private = jcb;
asyncop->c.flags |= WT_CURSTD_RAW;
err: if (ret != 0)
throwWiredTigerException(jenv, ret);
return asyncop;
}
}
%extend __wt_connection {
WT_SESSION *open_session_wrap(JNIEnv *jenv, const char *config) {
extern WT_EVENT_HANDLER javaApiEventHandler;
WT_SESSION *session = NULL;
WT_SESSION_IMPL *sessionimpl;
JAVA_CALLBACK *jcb;
int ret;
if ((ret = $self->open_session($self, &javaApiEventHandler, config, &session)) != 0)
goto err;
sessionimpl = (WT_SESSION_IMPL *)session;
if ((ret = __wt_calloc_def(sessionimpl, 1, &jcb)) != 0)
goto err;
jcb->jnienv = jenv;
sessionimpl->lang_private = jcb;
err: if (ret != 0)
throwWiredTigerException(jenv, ret);
return session;
}
}
%extend __wt_session {
WT_CURSOR *open_cursor_wrap(JNIEnv *jenv, const char *uri, WT_CURSOR_NULLABLE *to_dup, const char *config) {
WT_CURSOR *cursor = NULL;
JAVA_CALLBACK *jcb;
int ret;
if ((ret = $self->open_cursor($self, uri, to_dup, config, &cursor)) != 0)
goto err;
if ((cursor->flags & WT_CURSTD_DUMP_JSON) == 0)
cursor->flags |= WT_CURSTD_RAW;
if ((ret = __wt_calloc_def((WT_SESSION_IMPL *)cursor->session,
1, &jcb)) != 0)
goto err;
jcb->jnienv = jenv;
jcb->session = (WT_SESSION_IMPL *)cursor->session;
cursor->lang_private = jcb;
err: if (ret != 0)
throwWiredTigerException(jenv, ret);
return cursor;
}
}
%extend __wt_async_op {
long get_id_wrap(JNIEnv *jenv) {
WT_UNUSED(jenv);
return (self->get_id(self));
}
}
%extend __wt_session {
long transaction_pinned_range_wrap(JNIEnv *jenv) {
int ret;
uint64_t range = 0;
ret = self->transaction_pinned_range(self, &range);
if (ret != 0)
throwWiredTigerException(jenv, ret);
return range;
}
}