summaryrefslogtreecommitdiff
path: root/cpp/demo/Manual/evictor_filesystem/Server.cpp
diff options
context:
space:
mode:
authorJose <jose@zeroc.com>2014-11-11 22:33:50 +0100
committerJose <jose@zeroc.com>2014-11-11 22:33:50 +0100
commitfefe5c503a8bec0882443e994db64f916f806b5e (patch)
treef1881528106f75b50ab0f72ea6b5da6f90dc5b2e /cpp/demo/Manual/evictor_filesystem/Server.cpp
parentICE-5863 - merge Java RPMs (diff)
downloadice-fefe5c503a8bec0882443e994db64f916f806b5e.tar.bz2
ice-fefe5c503a8bec0882443e994db64f916f806b5e.tar.xz
ice-fefe5c503a8bec0882443e994db64f916f806b5e.zip
Fixed (ICE-5857) rename manual -> Manual
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");
+}