summaryrefslogtreecommitdiff
path: root/cpp/src/Freeze/ObjectStore.cpp
diff options
context:
space:
mode:
authorBernard Normier <bernard@zeroc.com>2007-10-12 15:48:24 -0400
committerBernard Normier <bernard@zeroc.com>2007-10-12 15:48:24 -0400
commitf038c925c49876569efcaf28c185b20bc4a939d2 (patch)
treef6e2874b9a0c8014ab81df05360658535838ec19 /cpp/src/Freeze/ObjectStore.cpp
parentFurther fix for bug 2502. (diff)
downloadice-f038c925c49876569efcaf28c185b20bc4a939d2.tar.bz2
ice-f038c925c49876569efcaf28c185b20bc4a939d2.tar.xz
ice-f038c925c49876569efcaf28c185b20bc4a939d2.zip
Fixed bug #702
Diffstat (limited to 'cpp/src/Freeze/ObjectStore.cpp')
-rw-r--r--cpp/src/Freeze/ObjectStore.cpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/cpp/src/Freeze/ObjectStore.cpp b/cpp/src/Freeze/ObjectStore.cpp
index f472cba7614..1d554c6bc2a 100644
--- a/cpp/src/Freeze/ObjectStore.cpp
+++ b/cpp/src/Freeze/ObjectStore.cpp
@@ -71,6 +71,46 @@ Freeze::ObjectStoreBase::ObjectStoreBase(const string& facet, const string& face
{
_db.reset(new Db(dbEnv, 0));
+ Ice::PropertiesPtr properties = evictor->communicator()->getProperties();
+ string propPrefix = "Freeze.Evictor." + evictor->filename() + ".";
+
+ int btreeMinKey = properties->getPropertyAsInt(propPrefix + _dbName + ".BtreeMinKey");
+ if(btreeMinKey > 2)
+ {
+ if(evictor->trace() >= 1)
+ {
+ Trace out(evictor->communicator()->getLogger(), "Freeze.Evictor");
+ out << "Setting \"" << evictor->filename() + "." + _dbName << "\"'s btree minkey to " << btreeMinKey;
+ }
+
+ _db->set_bt_minkey(btreeMinKey);
+ }
+
+ bool checksum = properties->getPropertyAsInt(propPrefix + "Checksum") > 0;
+ if(checksum)
+ {
+ if(evictor->trace() >= 1)
+ {
+ Trace out(evictor->communicator()->getLogger(), "Freeze.Evictor");
+ out << "Turning checksum on for \"" << evictor->filename() << "\"";
+ }
+
+ _db->set_flags(DB_CHKSUM);
+ }
+
+ int pageSize = properties->getPropertyAsInt(propPrefix + "PageSize");
+ if(pageSize > 0)
+ {
+ if(evictor->trace() >= 1)
+ {
+ Trace out(evictor->communicator()->getLogger(), "Freeze.Evictor");
+ out << "Setting \"" << evictor->filename() << "\"'s pagesize to " << pageSize;
+ }
+
+ _db->set_pagesize(pageSize);
+ }
+
+
TransactionPtr tx = catalogConnection->beginTransaction();
DbTxn* txn = getTxn(tx);
@@ -79,6 +119,7 @@ Freeze::ObjectStoreBase::ObjectStoreBase(const string& facet, const string& face
{
flags |= DB_CREATE;
}
+
_db->open(txn, evictor->filename().c_str(), _dbName.c_str(), DB_BTREE, flags, FREEZE_DB_MODE);
for(size_t i = 0; i < _indices.size(); ++i)