| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| package; |
| |
| import org.apache.thrift.*; |
| import org.apache.thrift.protocol.*; |
| import org.apache.thrift.transport.*; |
| import org.apache.thrift.server.*; |
| import org.apache.thrift.meta_data.*; |
| import org.apache.thrift.helper.*; |
| |
| import haxe.Int32; |
| import haxe.Int64; |
| import haxe.io.Bytes; |
| import haxe.ds.IntMap; |
| import haxe.ds.StringMap; |
| import haxe.ds.ObjectMap; |
| |
| import thrift.test.*; // generated code |
| |
| |
| class TestServerHandler implements ThriftTest { |
| |
| public var server:TServer; |
| |
| public function new() { |
| } |
| |
| /** |
| * Prints "testVoid()" and returns nothing. |
| */ |
| public function testVoid():Void |
| { |
| trace("testVoid()"); |
| } |
| |
| /** |
| * Prints 'testString("%s")' with thing as '%s' |
| * @param string thing - the string to print |
| * @return string - returns the string 'thing' |
| * |
| * @param thing |
| */ |
| public function testString(thing:String):String |
| { |
| trace("teststring(\"" + thing + "\")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testByte("%d")' with thing as '%d' |
| * @param byte thing - the byte to print |
| * @return byte - returns the byte 'thing' |
| * |
| * @param thing |
| */ |
| public function testByte(thing:haxe.Int32):haxe.Int32 |
| { |
| trace("testByte(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testI32("%d")' with thing as '%d' |
| * @param i32 thing - the i32 to print |
| * @return i32 - returns the i32 'thing' |
| * |
| * @param thing |
| */ |
| public function testI32(thing:haxe.Int32):haxe.Int32 |
| { |
| trace("testI32(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testI64("%d")' with thing as '%d' |
| * @param i64 thing - the i64 to print |
| * @return i64 - returns the i64 'thing' |
| * |
| * @param thing |
| */ |
| public function testI64(thing:haxe.Int64):haxe.Int64 |
| { |
| trace("testI64(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testDouble("%f")' with thing as '%f' |
| * @param double thing - the double to print |
| * @return double - returns the double 'thing' |
| * |
| * @param thing |
| */ |
| public function testDouble(thing:Float):Float |
| { |
| trace("testDouble(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testStruct("{%s}")' where thing has been formatted |
| * into a string of comma seperated values |
| * @param Xtruct thing - the Xtruct to print |
| * @return Xtruct - returns the Xtruct 'thing' |
| * |
| * @param thing |
| */ |
| public function testStruct(thing:Xtruct):Xtruct |
| { |
| trace("testStruct({" + |
| "\"" + thing.string_thing + "\", " + |
| thing.byte_thing + ", " + |
| thing.i32_thing + ", " + |
| Int64.toStr(thing.i64_thing) + "})"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testNest("{%s}")' where thing has been formatted |
| * into a string of the nested struct |
| * @param Xtruct2 thing - the Xtruct2 to print |
| * @return Xtruct2 - returns the Xtruct2 'thing' |
| * |
| * @param thing |
| */ |
| public function testNest(nest:Xtruct2):Xtruct2 |
| { |
| var thing:Xtruct = nest.struct_thing; |
| trace("testNest({" + |
| nest.byte_thing + ", {" + |
| "\"" + thing.string_thing + "\", " + |
| thing.byte_thing + ", " + |
| thing.i32_thing + ", " + |
| Int64.toStr(thing.i64_thing) + "}, " + |
| nest.i32_thing + "})"); |
| return nest; |
| } |
| |
| /** |
| * Prints 'testMap("{%s")' where thing has been formatted |
| * into a string of 'key => value' pairs |
| * seperated by commas and new lines |
| * @param map<i32,i32> thing - the map<i32,i32> to print |
| * @return map<i32,i32> - returns the map<i32,i32> 'thing' |
| * |
| * @param thing |
| */ |
| public function testMap(thing:IntMap<haxe.Int32>):IntMap<haxe.Int32> |
| { |
| trace("testMap({"); |
| var first:Bool = true; |
| for (key in thing.keys()) { |
| if (first) { |
| first = false; |
| } else { |
| trace(", "); |
| }; |
| trace(key + " => " + thing.get(key)); |
| }; |
| trace("})"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testStringMap("{%s}")' where thing has been formatted |
| * into a string of 'key => value' pairs |
| * seperated by commas and new lines |
| * @param map<string,string> thing - the map<string,string> to print |
| * @return map<string,string> - returns the map<string,string> 'thing' |
| * |
| * @param thing |
| */ |
| public function testStringMap(thing:StringMap<String>):StringMap<String> |
| { |
| trace("testStringMap({"); |
| var first:Bool = true; |
| for (key in thing.keys()) { |
| if (first) { |
| first = false; |
| } else { |
| trace(", "); |
| }; |
| trace(key + " => " + thing.get(key)); |
| }; |
| trace("})"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testSet("{%s}")' where thing has been formatted |
| * into a string of values |
| * seperated by commas and new lines |
| * @param set<i32> thing - the set<i32> to print |
| * @return set<i32> - returns the set<i32> 'thing' |
| * |
| * @param thing |
| */ |
| public function testSet(thing:IntSet):IntSet |
| { |
| trace("testSet({"); |
| var first:Bool = true; |
| for (elem in thing) { |
| if (first) { |
| first = false; |
| } else { |
| trace(", "); |
| }; |
| trace(elem); |
| }; |
| trace("})"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testList("{%s}")' where thing has been formatted |
| * into a string of values |
| * seperated by commas and new lines |
| * @param list<i32> thing - the list<i32> to print |
| * @return list<i32> - returns the list<i32> 'thing' |
| * |
| * @param thing |
| */ |
| public function testList(thing:List<haxe.Int32>):List<haxe.Int32> |
| { |
| trace("testList({"); |
| var first:Bool = true; |
| for (elem in thing) { |
| if (first) { |
| first = false; |
| } else { |
| trace(", "); |
| }; |
| trace(elem); |
| }; |
| trace("})"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testEnum("%d")' where thing has been formatted into it's numeric value |
| * @param Numberz thing - the Numberz to print |
| * @return Numberz - returns the Numberz 'thing' |
| * |
| * @param thing |
| */ |
| public function testEnum(thing:Int):Int |
| { |
| trace("testEnum(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testTypedef("%d")' with thing as '%d' |
| * @param UserId thing - the UserId to print |
| * @return UserId - returns the UserId 'thing' |
| * |
| * @param thing |
| */ |
| public function testTypedef(thing:haxe.Int64):haxe.Int64 |
| { |
| trace("testTypedef(" + thing + ")"); |
| return thing; |
| } |
| |
| /** |
| * Prints 'testMapMap("%d")' with hello as '%d' |
| * @param i32 hello - the i32 to print |
| * @return map<i32,map<i32,i32>> - returns a dictionary with these values: |
| * {-4 => {-4 => -4, -3 => -3, -2 => -2, -1 => -1, }, |
| * 4 => {1 => 1, 2 => 2, 3 => 3, 4 => 4, }, } |
| * |
| * @param hello |
| */ |
| public function testMapMap(hello:haxe.Int32):IntMap<IntMap<haxe.Int32>> |
| { |
| trace("testMapMap(" + hello + ")"); |
| var mapmap = new IntMap<IntMap<Int>>(); |
| var pos = new IntMap<Int>(); |
| var neg = new IntMap<Int>(); |
| for (i in 1 ... 5) { |
| pos.set(i, i); |
| neg.set(-i, -i); |
| }; |
| mapmap.set(4, pos); |
| mapmap.set(-4, neg); |
| return mapmap; |
| } |
| |
| /** |
| * So you think you've got this all worked, out eh? |
| * |
| * Creates a the returned map with these values and prints it out: |
| * { 1 => { 2 => argument, |
| * 3 => argument, |
| * }, |
| * 2 => { 6 => <empty Insanity struct>, }, |
| * } |
| * @return map<UserId, map<Numberz,Insanity>> - a map with the above values |
| * |
| * @param argument |
| */ |
| public function testInsanity(argument : Insanity) : Int64Map< IntMap< Insanity>> |
| { |
| trace("testInsanity()"); |
| |
| var hello = new Xtruct(); |
| hello.string_thing = "Hello2"; |
| hello.byte_thing = 2; |
| hello.i32_thing = 2; |
| hello.i64_thing = Int64.make(0, 2); |
| |
| var goodbye = new Xtruct(); |
| goodbye.string_thing = "Goodbye4"; |
| goodbye.byte_thing = 4; |
| goodbye.i32_thing = 4; |
| goodbye.i64_thing = Int64.make(0, 4); |
| |
| var crazy = new Insanity(); |
| crazy.userMap = new IntMap< haxe.Int64>(); |
| crazy.userMap.set(Numberz.EIGHT, Int64.make(0,8)); |
| crazy.xtructs = new List<Xtruct>(); |
| crazy.xtructs.add(goodbye); |
| |
| var looney = new Insanity(); |
| crazy.userMap.set(Numberz.FIVE, Int64.make(0,5)); |
| crazy.xtructs.add(hello); |
| |
| var first_map = new IntMap< Insanity>(); |
| first_map.set(Numberz.TWO, crazy); |
| first_map.set(Numberz.THREE, crazy); |
| |
| var second_map = new IntMap< Insanity>(); |
| second_map.set(Numberz.SIX, looney); |
| |
| var insane = new Int64Map< IntMap< Insanity>>(); |
| insane.set( Int64.make(0,1), first_map); |
| insane.set( Int64.make(0,2), second_map); |
| |
| return insane; |
| } |
| |
| /** |
| * Prints 'testMulti()' |
| * @param byte arg0 - |
| * @param i32 arg1 - |
| * @param i64 arg2 - |
| * @param map<i16, string> arg3 - |
| * @param Numberz arg4 - |
| * @param UserId arg5 - |
| * @return Xtruct - returns an Xtruct |
| * with string_thing = "Hello2, byte_thing = arg0, i32_thing = arg1 |
| * and i64_thing = arg2 |
| * |
| * @param arg0 |
| * @param arg1 |
| * @param arg2 |
| * @param arg3 |
| * @param arg4 |
| * @param arg5 |
| */ |
| public function testMulti(arg0:haxe.Int32, arg1:haxe.Int32, arg2:haxe.Int64, |
| arg3:IntMap<String>, arg4:Int, arg5:haxe.Int64):Xtruct |
| { |
| trace("testMulti()"); |
| var hello = new Xtruct(); |
| hello.string_thing = "Hello2"; |
| hello.byte_thing = arg0; |
| hello.i32_thing = arg1; |
| hello.i64_thing = arg2; |
| return hello; |
| } |
| |
| /** |
| * Print 'testException(%s)' with arg as '%s' |
| * @param string arg - a string indication what type of exception to throw |
| * if arg == "Xception" throw Xception with errorCode = 1001 and message = arg |
| * elsen if arg == "TException" throw TException |
| * else do not throw anything |
| * |
| * @param arg |
| */ |
| public function testException(arg:String):Void |
| { |
| trace("testException(" + arg + ")"); |
| if (arg == "Xception") { |
| var x = new Xception(); |
| x.errorCode = 1001; |
| x.message = arg; |
| throw x; |
| }; |
| if (arg == "TException") { |
| throw new TException(); |
| }; |
| return; |
| } |
| |
| /** |
| * Print 'testMultiException(%s, %s)' with arg0 as '%s' and arg1 as '%s' |
| * @param string arg - a string indication what type of exception to throw |
| * if arg0 == "Xception" |
| * throw Xception with errorCode = 1001 and message = "This is an Xception" |
| * else if arg0 == "Xception2" |
| * throw Xception2 with errorCode = 2002 and message = "This is an Xception2" |
| * else do not throw anything |
| * @return Xtruct - an Xtruct with string_thing = arg1 |
| * |
| * @param arg0 |
| * @param arg1 |
| */ |
| public function testMultiException(arg0:String, arg1:String):Xtruct |
| { |
| trace("testMultiException(" + arg0 + ", " + arg1 + ")"); |
| if (arg0 == "Xception") { |
| var x = new Xception(); |
| x.errorCode = 1001; |
| x.message = "This is an Xception"; |
| throw x; |
| } else if (arg0 == "Xception2") { |
| var x = new Xception2(); |
| x.errorCode = 2002; |
| x.struct_thing = new Xtruct(); |
| x.struct_thing.string_thing = "This is an Xception2"; |
| throw x; |
| }; |
| var result = new Xtruct(); |
| result.string_thing = arg1; |
| return result; |
| } |
| |
| /** |
| * Print 'testOneway(%d): Sleeping...' with secondsToSleep as '%d' |
| * sleep 'secondsToSleep' |
| * Print 'testOneway(%d): done sleeping!' with secondsToSleep as '%d' |
| * @param i32 secondsToSleep - the number of seconds to sleep |
| * |
| * @param secondsToSleep |
| */ |
| public function testOneway(secondsToSleep:haxe.Int32):Void |
| { |
| trace("testOneway(" + secondsToSleep + "), sleeping..."); |
| Sys.sleep(secondsToSleep); |
| trace("testOneway finished"); |
| } |
| |
| public function testStop():Void |
| { |
| if (server != null) { |
| server.Stop(); |
| }; |
| } |
| } |