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/map_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/map_filesystem/Server.cpp')
-rw-r--r-- | cpp/demo/Manual/map_filesystem/Server.cpp | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/cpp/demo/Manual/map_filesystem/Server.cpp b/cpp/demo/Manual/map_filesystem/Server.cpp new file mode 100644 index 00000000000..6a043804884 --- /dev/null +++ b/cpp/demo/Manual/map_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 <FilesystemI.h> +#include <IdentityFileEntryMap.h> +#include <IdentityDirectoryEntryMap.h> +#include <Ice/Ice.h> +#include <Freeze/Freeze.h> + +using namespace std; +using namespace Filesystem; +using namespace FilesystemDB; + +class FilesystemApp : public Ice::Application +{ +public: + + FilesystemApp(const string& envName) + : _envName(envName) + { + } + + virtual int run(int, char*[]) + { + // + // Terminate cleanly on receipt of a signal + // + shutdownOnInterrupt(); + + // + // Create an object adapter + // + Ice::ObjectAdapterPtr adapter = communicator()->createObjectAdapter("MapFilesystem"); + + // + // Open a connection to the files and directories database. This should remain open + // for the duration of the application for performance reasons. + // + const Freeze::ConnectionPtr connection(Freeze::createConnection(communicator(), _envName)); + const IdentityFileEntryMap fileDB(connection, FileI::filesDB()); + const IdentityDirectoryEntryMap dirDB(connection, DirectoryI::directoriesDB()); + + // + // Add default servants for the file and directory. + // + adapter->addDefaultServant(new FileI(communicator(), _envName), "file"); + adapter->addDefaultServant(new DirectoryI(communicator(), _envName), ""); + + // + // Ready to accept requests now + // + adapter->activate(); + + // + // Wait until we are done + // + communicator()->waitForShutdown(); + + // + // Clean up + // + 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"); +} |