#!/usr/bin/env python
# **********************************************************************
#
# Copyright (c) 2003-2007 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.
#
# **********************************************************************
import os, sys, traceback, threading
for toplevel in [".", "..", "../..", "../../..", "../../../.."]:
toplevel = os.path.normpath(toplevel)
if os.path.exists(os.path.join(toplevel, "python", "Ice.py")):
break
else:
raise "can't find toplevel directory!"
sys.path.insert(0, os.path.join(toplevel, "python"))
sys.path.insert(0, os.path.join(toplevel, "lib"))
import Ice
#
# Find Slice directory.
#
slice_dir = os.getenv('ICEPY_HOME', '')
if len(slice_dir) == 0 or not os.path.exists(os.path.join(slice_dir, "slice")):
slice_dir = os.getenv('ICE_HOME', '')
if len(slice_dir) == 0 or not os.path.exists(os.path.join(slice_dir, "slice")):
print sys.argv[0] + ': Slice directory not found. Define ICEPY_HOME or ICE_HOME.'
sys.exit(1)
Ice.loadSlice('-I' + slice_dir + '/slice TestAMD.ice')
import Test
def test(b):
if not b:
raise RuntimeError('test assertion failed')
class Thread_opVoid(threading.Thread):
def __init__(self, cb):
threading.Thread.__init__(self)
self.cb = cb
def run(self):
self.cb.ice_response()
class MyDerivedClassI(Test.MyDerivedClass):
def __init__(self, adapter, identity):
self.adapter = adapter
self.identity = identity
self.opVoidThread = None
def shutdown_async(self, cb, current=None):
if self.opVoidThread:
self.opVoidThread.join()
self.opVoidThread = None
self.adapter.getCommunicator().shutdown()
cb.ice_response()
def opVoid_async(self, cb, current=None):
if self.opVoidThread:
self.opVoidThread.join()
self.opVoidThread = None
self.opVoidThread = Thread_opVoid(cb)
self.opVoidThread.start()
def opByte_async(self, cb, p1, p2, current=None):
cb.ice_response(p1, p1 ^ p2)
def opBool_async(self, cb, p1, p2, current=None):
cb.ice_response(p2, p1)
def opShortIntLong_async(self, cb, p1, p2, p3, current=None):
cb.ice_response(p3, p1, p2, p3)
def opFloatDouble_async(self, cb, p1, p2, current=None):
cb.ice_response(p2, p1, p2)
def opString_async(self, cb, p1, p2, current=None):
cb.ice_response(p1 + " " + p2, p2 + " " + p1)
def opMyEnum_async(self, cb, p1, current=None):
cb.ice_response(Test.MyEnum.enum3, p1)
def opMyClass_async(self, cb, p1, current=None):
p2 = p1
p3 = Test.MyClassPrx.uncheckedCast(self.adapter.createProxy(communicator.stringToIdentity("noSuchIdentity")))
cb.ice_response(Test.MyClassPrx.uncheckedCast(self.adapter.createProxy(self.identity)), p2, p3)
def opStruct_async(self, cb, p1, p2, current=None):
p1.s.s = "a new string"
cb.ice_response(p2, p1)
def opByteS_async(self, cb, p1, p2, current=None):
# By default sequence<byte> maps to a string.
p3 = map(ord, p1)
p3.reverse()
r = map(ord, p1)
r.extend(map(ord, p2))
cb.ice_response(r, p3)
def opBoolS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.extend(p2)
r = p1[0:]
r.reverse();
cb.ice_response(r, p3)
def opShortIntLongS_async(self, cb, p1, p2, p3, current=None):
p4 = p1[0:]
p5 = p2[0:]
p5.reverse()
p6 = p3[0:]
p6.extend(p3)
cb.ice_response(p3, p4, p5, p6)
def opFloatDoubleS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p4 = p2[0:]
p4.reverse()
r = p2[0:]
r.extend(p1)
cb.ice_response(r, p3, p4)
def opStringS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.extend(p2)
r = p1[0:]
r.reverse()
cb.ice_response(r, p3)
def opByteSS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.reverse()
r = p1[0:]
r.extend(p2)
cb.ice_response(r, p3)
def opBoolSS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.extend(p2)
r = p1[0:]
r.reverse()
cb.ice_response(r, p3)
def opShortIntLongSS_async(self, cb, p1, p2, p3, current=None):
p4 = p1[0:]
p5 = p2[0:]
p5.reverse()
p6 = p3[0:]
p6.extend(p3)
cb.ice_response(p3, p4, p5, p6)
def opFloatDoubleSS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p4 = p2[0:]
p4.reverse()
r = p2[0:]
r.extend(p2)
cb.ice_response(r, p3, p4)
def opStringSS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.extend(p2)
r = p2[0:]
r.reverse()
cb.ice_response(r, p3)
def opStringSSS_async(self, cb, p1, p2, current=None):
p3 = p1[0:]
p3.extend(p2)
r = p2[0:]
r.reverse()
cb.ice_response(r, p3)
def opByteBoolD_async(self, cb, p1, p2, current=None):
p3 = p1.copy()
r = p1.copy()
r.update(p2)
cb.ice_response(r, p3)
def opShortIntD_async(self, cb, p1, p2, current=None):
p3 = p1.copy()
r = p1.copy()
r.update(p2)
cb.ice_response(r, p3)
def opLongFloatD_async(self, cb, p1, p2, current=None):
p3 = p1.copy()
r = p1.copy()
r.update(p2)
cb.ice_response(r, p3)
def opStringStringD_async(self, cb, p1, p2, current=None):
p3 = p1.copy()
r = p1.copy()
r.update(p2)
cb.ice_response(r, p3)
def opStringMyEnumD_async(self, cb, p1, p2, current=None):
p3 = p1.copy()
r = p1.copy()
r.update(p2)
cb.ice_response(r, p3)
def opIntS_async(self, cb, s, current=None):
cb.ice_response([-x for x in s])
def opContext_async(self, cb, current=None):
cb.ice_response(current.ctx)
def opDerived_async(self, cb, current=None):
cb.ice_response()
class TestCheckedCastI(Test.TestCheckedCast):
def __init__(self):
self.ctx = None
def getContext(self, current):
return self.ctx;
def ice_isA(self, s, current):
self.ctx = current.ctx
return Test.TestCheckedCast.ice_isA(self, s, current)
def run(args, communicator):
communicator.getProperties().setProperty("TestAdapter.Endpoints", "default -p 12010 -t 10000:udp")
adapter = communicator.createObjectAdapter("TestAdapter")
id = communicator.stringToIdentity("test")
adapter.add(MyDerivedClassI(adapter, id), id)
adapter.add(TestCheckedCastI(), communicator.stringToIdentity("context"))
adapter.activate()
communicator.waitForShutdown()
return True
try:
communicator = Ice.initialize(sys.argv)
status = run(sys.argv, communicator)
except:
traceback.print_exc()
status = False
if communicator:
try:
communicator.destroy()
except:
traceback.print_exc()
status = False
sys.exit(not status)
syntax highlighted by Code2HTML, v. 0.9.1