diff options
author | Benoit Foucher <benoit@zeroc.com> | 2014-11-03 15:58:54 +0100 |
---|---|---|
committer | Benoit Foucher <benoit@zeroc.com> | 2014-11-03 15:58:54 +0100 |
commit | 581d0449b2c5f1bbfd5bb3d6d1216040b832b273 (patch) | |
tree | c3ebc0b05f1ad8d5dc2156e471c799b30be8ecde /cpp/demo/manual/evictor_filesystem/Server.cpp | |
parent | Fixed ICE-5816: Silverlight build failure (diff) | |
download | ice-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.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"); +} |