@ -11,12 +11,14 @@
# include <memory>
# include <memory>
# include "db/column_family.h"
# include "db/column_family.h"
# include "db/db_impl.h"
# include "db/merge_context.h"
# include "db/merge_context.h"
# include "db/merge_helper.h"
# include "db/merge_helper.h"
# include "db/skiplist.h"
# include "db/skiplist.h"
# include "rocksdb/comparator.h"
# include "rocksdb/comparator.h"
# include "rocksdb/iterator.h"
# include "rocksdb/iterator.h"
# include "util/arena.h"
# include "util/arena.h"
# include "util/db_options.h"
# include "utilities/write_batch_with_index/write_batch_with_index_internal.h"
# include "utilities/write_batch_with_index/write_batch_with_index_internal.h"
namespace rocksdb {
namespace rocksdb {
@ -680,11 +682,12 @@ Status WriteBatchWithIndex::GetFromBatch(ColumnFamilyHandle* column_family,
const Slice & key , std : : string * value ) {
const Slice & key , std : : string * value ) {
Status s ;
Status s ;
MergeContext merge_context ;
MergeContext merge_context ;
const ImmutableDBOptions immuable_db_options ( options ) ;
WriteBatchWithIndexInternal : : Result result =
WriteBatchWithIndexInternal : : Result result =
WriteBatchWithIndexInternal : : GetFromBatch (
WriteBatchWithIndexInternal : : GetFromBatch (
options , this , column_family , key , & merge_context , & rep - > comparator ,
immuable_db_ options, this , column_family , key , & merge_context ,
value , rep - > overwrite_key , & s ) ;
& rep - > comparator , value , rep - > overwrite_key , & s ) ;
switch ( result ) {
switch ( result ) {
case WriteBatchWithIndexInternal : : Result : : kFound :
case WriteBatchWithIndexInternal : : Result : : kFound :
@ -720,13 +723,14 @@ Status WriteBatchWithIndex::GetFromBatchAndDB(DB* db,
std : : string * value ) {
std : : string * value ) {
Status s ;
Status s ;
MergeContext merge_context ;
MergeContext merge_context ;
const DBOptions & options = db - > GetDBOptions ( ) ;
const ImmutableDBOptions & immuable_db_options =
reinterpret_cast < DBImpl * > ( db ) - > immutable_db_options ( ) ;
std : : string batch_value ;
std : : string batch_value ;
WriteBatchWithIndexInternal : : Result result =
WriteBatchWithIndexInternal : : Result result =
WriteBatchWithIndexInternal : : GetFromBatch (
WriteBatchWithIndexInternal : : GetFromBatch (
options , this , column_family , key , & merge_context , & rep - > comparator ,
immuable_db_ options, this , column_family , key , & merge_context ,
& batch_value , rep - > overwrite_key , & s ) ;
& rep - > comparator , & batch_value , rep - > overwrite_key , & s ) ;
if ( result = = WriteBatchWithIndexInternal : : Result : : kFound ) {
if ( result = = WriteBatchWithIndexInternal : : Result : : kFound ) {
value - > assign ( batch_value . data ( ) , batch_value . size ( ) ) ;
value - > assign ( batch_value . data ( ) , batch_value . size ( ) ) ;
@ -758,9 +762,9 @@ Status WriteBatchWithIndex::GetFromBatchAndDB(DB* db,
auto cfh = reinterpret_cast < ColumnFamilyHandleImpl * > ( column_family ) ;
auto cfh = reinterpret_cast < ColumnFamilyHandleImpl * > ( column_family ) ;
const MergeOperator * merge_operator =
const MergeOperator * merge_operator =
cfh - > cfd ( ) - > ioptions ( ) - > merge_operator ;
cfh - > cfd ( ) - > ioptions ( ) - > merge_operator ;
Statistics * statistics = options . statistics . get ( ) ;
Statistics * statistics = immuable_db_ options. statistics . get ( ) ;
Env * env = options . env ;
Env * env = immuable_db_ options. env ;
Logger * logger = options . info_log . get ( ) ;
Logger * logger = immuable_db_ options. info_log . get ( ) ;
Slice db_slice ( * value ) ;
Slice db_slice ( * value ) ;
Slice * merge_data ;
Slice * merge_data ;