diff options
Diffstat (limited to 'cpp/test/Ice/stringConverter/Server.cpp')
-rw-r--r-- | cpp/test/Ice/stringConverter/Server.cpp | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/cpp/test/Ice/stringConverter/Server.cpp b/cpp/test/Ice/stringConverter/Server.cpp new file mode 100644 index 00000000000..4b9c6a78c20 --- /dev/null +++ b/cpp/test/Ice/stringConverter/Server.cpp @@ -0,0 +1,96 @@ +// ********************************************************************** +// +// 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 <Ice/Ice.h> +#include <TestCommon.h> +#include <Test.h> + +DEFINE_TEST("server"); + +using namespace std; + +// +// Server side is pure unicode +// +class MyObjectI : public Test::MyObject +{ +public: + + virtual wstring widen(const string& msg, const Ice::Current&) + { + const Ice::Byte* cmsg = reinterpret_cast<const Ice::Byte*>(msg.c_str()); + + if(!IceUtil::isLegalUTF8Sequence(cmsg, cmsg + msg.size())) + { + throw Test::BadEncodingException(); + } + + return IceUtil::nativeToWnative(IceUtil::getProcessStringConverter(), + IceUtil::getProcessWstringConverter(), msg); + } + + virtual string narrow(const wstring& wmsg, const Ice::Current&) + { + return IceUtil::wnativeToNative(IceUtil::getProcessStringConverter(), + IceUtil::getProcessWstringConverter(), wmsg); + } + + virtual void shutdown(const Ice::Current& current) + { + current.adapter->getCommunicator()->shutdown(); + } +}; + +int +run(int, char**, const Ice::CommunicatorPtr& communicator) +{ + communicator->getProperties()->setProperty("TestAdapter.Endpoints", "default -p 12010:udp -p 12010"); + Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("TestAdapter"); + adapter->add(new MyObjectI, communicator->stringToIdentity("test")); + adapter->activate(); + + TEST_READY + communicator->waitForShutdown(); + return EXIT_SUCCESS; +} + +int +main(int argc, char* argv[]) +{ + int status; + Ice::CommunicatorPtr communicator; + + try + { + Ice::InitializationData initData; + initData.properties = Ice::createProperties(argc, argv); + communicator = Ice::initialize(argc, argv, initData); + status = run(argc, argv, communicator); + } + catch(const Ice::Exception& ex) + { + cerr << ex << endl; + status = EXIT_FAILURE; + } + + if(communicator) + { + try + { + communicator->destroy(); + } + catch(const Ice::Exception& ex) + { + cerr << ex << endl; + status = EXIT_FAILURE; + } + } + + return status; +} |