Commit acdf833c authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul

Remove memory leak. Fixes #1027.

git-svn-id: file:///svn/tokudb@5194 c7de825b-a66e-492c-adef-691d508d4ae1
parent 10bdafb7
default: build default: build
TAGS: */*.c */*.h TAGS: */*.c */*.h */*/*.c */*/*.h
etags */*.c */*.h src/lock_tree/*.c src/lock_tree/*.h src/range_tree/*.c src/range_tree/*.h newbrt/tests/*.h etags */*.c */*.h src/tests/*.c src/tests/*.h src/lock_tree/*.c src/lock_tree/*.h src/range_tree/*.c src/range_tree/*.h newbrt/tests/*.h
SRCDIRS = newbrt src cxx utils db-benchmark-test db-benchmark-test-cxx SRCDIRS = newbrt src cxx utils db-benchmark-test db-benchmark-test-cxx
BUILDDIRS = $(SRCDIRS) man/texi BUILDDIRS = $(SRCDIRS) man/texi
......
...@@ -423,7 +423,7 @@ int toku_logger_commit (TOKUTXN txn, int nosync) { ...@@ -423,7 +423,7 @@ int toku_logger_commit (TOKUTXN txn, int nosync) {
int len = strlen(txn->rollentry_filename); int len = strlen(txn->rollentry_filename);
// Don't have to strdup the rollentry_filename because // Don't have to strdup the rollentry_filename because
// we take ownership of it. // we take ownership of it.
BYTESTRING fname = {len, txn->rollentry_filename}; BYTESTRING fname = {len, toku_strdup_in_rollback(txn, txn->rollentry_filename)};
r = toku_logger_save_rollback_rollinclude(txn->parent, fname); r = toku_logger_save_rollback_rollinclude(txn->parent, fname);
if (r!=0) { cleanup_txn(txn); return r; } if (r!=0) { cleanup_txn(txn); return r; }
r = close(txn->rollentry_fd); r = close(txn->rollentry_fd);
...@@ -432,11 +432,13 @@ int toku_logger_commit (TOKUTXN txn, int nosync) { ...@@ -432,11 +432,13 @@ int toku_logger_commit (TOKUTXN txn, int nosync) {
// set txn->rollentry_filename=0 so that the cleanup // set txn->rollentry_filename=0 so that the cleanup
// won't try to close the fd again. // won't try to close the fd again.
unlink(txn->rollentry_filename); unlink(txn->rollentry_filename);
toku_free(txn->rollentry_filename);
txn->rollentry_filename = 0; txn->rollentry_filename = 0;
cleanup_txn(txn); cleanup_txn(txn);
return r; return r;
} }
// Stop the cleanup from closing and unlinking the file. // Stop the cleanup from closing and unlinking the file.
toku_free(txn->rollentry_filename);
txn->rollentry_filename = 0; txn->rollentry_filename = 0;
} }
// Append the list to the front of the parent. // Append the list to the front of the parent.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment