diff options
author | Jose <jose@zeroc.com> | 2014-11-11 22:33:50 +0100 |
---|---|---|
committer | Jose <jose@zeroc.com> | 2014-11-11 22:33:50 +0100 |
commit | fefe5c503a8bec0882443e994db64f916f806b5e (patch) | |
tree | f1881528106f75b50ab0f72ea6b5da6f90dc5b2e /cpp/demo/Manual/evictor_filesystem/Server.cpp | |
parent | ICE-5863 - merge Java RPMs (diff) | |
download | ice-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.cpp | 86 |
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"); +} |