diff options
Diffstat (limited to 'cpp/src/Freeze/IndexI.cpp')
-rw-r--r-- | cpp/src/Freeze/IndexI.cpp | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/cpp/src/Freeze/IndexI.cpp b/cpp/src/Freeze/IndexI.cpp index 11ea57a6db4..29b89cffcdb 100644 --- a/cpp/src/Freeze/IndexI.cpp +++ b/cpp/src/Freeze/IndexI.cpp @@ -318,14 +318,42 @@ Freeze::IndexI::associate(ObjectStoreBase* store, DbTxn* txn, _db->set_flags(DB_DUP | DB_DUPSORT); _db->set_app_private(this); + _dbName = EvictorIBase::indexPrefix + store->dbName() + "." + _index.name(); + + Ice::PropertiesPtr properties = store->communicator()->getProperties(); + string propPrefix = "Freeze.Evictor." + store->evictor()->filename() + "."; + + int btreeMinKey = properties->getPropertyAsInt(propPrefix + _dbName + ".BtreeMinKey"); + if(btreeMinKey > 2) + { + if(store->evictor()->trace() >= 1) + { + Trace out(store->evictor()->communicator()->getLogger(), "Freeze.Evictor"); + out << "Setting \"" << store->evictor()->filename() + "." + _dbName << "\"'s btree minkey to " << btreeMinKey; + } + _db->set_bt_minkey(btreeMinKey); + } + + bool checksum = properties->getPropertyAsInt(propPrefix + "Checksum") > 0; + if(checksum) + { + // + // No tracing on purpose + // + + _db->set_flags(DB_CHKSUM); + } + + // + // pagesize can't change + // + u_int32_t flags = 0; if(createDb) { flags = DB_CREATE; } - _dbName = EvictorIBase::indexPrefix + store->dbName() + "." + _index.name(); - _db->open(txn, store->evictor()->filename().c_str(), _dbName.c_str(), DB_BTREE, flags, FREEZE_DB_MODE); flags = 0; |