diff options
author | Don Anderson <dda@ddanderson.com> | 2015-11-02 09:26:22 -0500 |
---|---|---|
committer | Don Anderson <dda@ddanderson.com> | 2015-11-02 09:26:22 -0500 |
commit | 5a3b104d58071fc9ca4013fd9febd74cfa2e248a (patch) | |
tree | 01a799ad94c313e60a43c1604913a37480bc9490 /lang | |
parent | 7518a6926ffc5745b1118fcb2ec41282bfd2617a (diff) | |
download | mongo-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.i | 17 |
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); } |