summaryrefslogtreecommitdiff
path: root/lang
diff options
context:
space:
mode:
authorDon Anderson <dda@ddanderson.com>2015-11-02 09:26:22 -0500
committerDon Anderson <dda@ddanderson.com>2015-11-02 09:26:22 -0500
commit5a3b104d58071fc9ca4013fd9febd74cfa2e248a (patch)
tree01a799ad94c313e60a43c1604913a37480bc9490 /lang
parent7518a6926ffc5745b1118fcb2ec41282bfd2617a (diff)
downloadmongo-5a3b104d58071fc9ca4013fd9febd74cfa2e248a.tar.gz
WT-2194 Handle close callbacks for cursors that were not opened by Java.
This can now happen, as WiredTigerLAS.wt is opened internally.
Diffstat (limited to 'lang')
-rw-r--r--lang/java/wiredtiger.i17
1 files changed, 11 insertions, 6 deletions
diff --git a/lang/java/wiredtiger.i b/lang/java/wiredtiger.i
index ae370ec89f5..1326b9ebb90 100644
--- a/lang/java/wiredtiger.i
+++ b/lang/java/wiredtiger.i
@@ -395,15 +395,20 @@ javaCloseHandler(WT_EVENT_HANDLER *handler, WT_SESSION *session,
WT_CURSOR *cursor)
{
int ret;
+ JAVA_CALLBACK *jcb;
WT_UNUSED(handler);
- if (cursor != NULL)
- ret = cursorCloseHandler(NULL, session, (JAVA_CALLBACK *)
- cursor->lang_private);
- else
- ret = closeHandler(NULL, session, (JAVA_CALLBACK *)
- ((WT_SESSION_IMPL *)session)->lang_private);
+ 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);
}