summaryrefslogtreecommitdiff
path: root/cpp/demo/manual/evictor_filesystem/Server.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2014-11-03 15:58:54 +0100
committerBenoit Foucher <benoit@zeroc.com>2014-11-03 15:58:54 +0100
commit581d0449b2c5f1bbfd5bb3d6d1216040b832b273 (patch)
treec3ebc0b05f1ad8d5dc2156e471c799b30be8ecde /cpp/demo/manual/evictor_filesystem/Server.cpp
parentFixed ICE-5816: Silverlight build failure (diff)
downloadice-581d0449b2c5f1bbfd5bb3d6d1216040b832b273.tar.bz2
ice-581d0449b2c5f1bbfd5bb3d6d1216040b832b273.tar.xz
ice-581d0449b2c5f1bbfd5bb3d6d1216040b832b273.zip
Fixed ICE-5811: renamed book demos to manual demos
Diffstat (limited to 'cpp/demo/manual/evictor_filesystem/Server.cpp')
-rw-r--r--cpp/demo/manual/evictor_filesystem/Server.cpp86
1 files changed, 86 insertions, 0 deletions
diff --git a/cpp/demo/manual/evictor_filesystem/Server.cpp b/cpp/demo/manual/evictor_filesystem/Server.cpp
new file mode 100644
index 00000000000..7ff0eefb4b3
--- /dev/null
+++ b/cpp/demo/manual/evictor_filesystem/Server.cpp
@@ -0,0 +1,86 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2014 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+#include <PersistentFilesystemI.h>
+
+using namespace std;
+using namespace Filesystem;
+
+class FilesystemApp : public Ice::Application
+{
+public:
+
+ FilesystemApp(const string& envName) :
+ _envName(envName)
+ {
+ }
+
+ virtual int run(int, char*[])
+ {
+ //
+ // Install object factories.
+ //
+ Ice::ObjectFactoryPtr factory = new NodeFactory;
+ communicator()->addObjectFactory(factory, PersistentFile::ice_staticId());
+ communicator()->addObjectFactory(factory, PersistentDirectory::ice_staticId());
+
+ //
+ // Create an object adapter.
+ //
+ Ice::ObjectAdapterPtr adapter = communicator()->createObjectAdapter("EvictorFilesystem");
+
+ //
+ // Create the Freeze evictor.
+ //
+ Freeze::EvictorPtr evictor = Freeze::createTransactionalEvictor(adapter, _envName, "evictorfs");
+ FileI::_evictor = evictor;
+ DirectoryI::_evictor = evictor;
+
+ adapter->addServantLocator(evictor, "");
+
+ //
+ // Create the root node if it doesn't exist.
+ //
+ Ice::Identity rootId;
+ rootId.name = "RootDir";
+ if(!evictor->hasObject(rootId))
+ {
+ PersistentDirectoryPtr root = new DirectoryI;
+ root->nodeName = "/";
+ evictor->add(root, rootId);
+ }
+
+ //
+ // Ready to accept requests now.
+ //
+ adapter->activate();
+
+ //
+ // Wait until we are done.
+ //
+ communicator()->waitForShutdown();
+ if(interrupted())
+ {
+ cerr << appName() << ": received signal, shutting down" << endl;
+ }
+
+ return 0;
+ }
+
+private:
+
+ string _envName;
+};
+
+int
+main(int argc, char* argv[])
+{
+ FilesystemApp app("db");
+ return app.main(argc, argv, "config.server");
+}