// this script was compiled with wurst 1.8.1.0-jenkins-Wurst-1367 globals integer array A_nextFree integer A_firstFree=0 integer A_maxIndex=0 integer array A_typeId integer wurst_stack_depth=0 string array wurst_stack endglobals native testFail takes string msg returns nothing native testSuccess takes nothing returns nothing function initGlobals takes nothing returns nothing endfunction function error takes string msg, string w__wurst_stackPos returns nothing local integer stacktraceIndex local integer stacktraceLimit set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set w__wurst_stackPos = "" set stacktraceIndex = wurst_stack_depth set stacktraceLimit = 0 loop set stacktraceIndex = stacktraceIndex - 1 set stacktraceLimit = stacktraceLimit + 1 exitwhen stacktraceLimit > 20 or stacktraceIndex < 0 set w__wurst_stackPos = w__wurst_stackPos + "\n " + wurst_stack[stacktraceIndex] endloop call BJDebugMsg(msg + "\n" + w__wurst_stackPos) set wurst_stack_depth = wurst_stack_depth - 1 endfunction function dispatch_A_test_A_foo takes integer this, string w__wurst_stackPos returns integer set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 if A_typeId[this] == 0 then if this == 0 then call error("Nullpointer exception when calling A.foo", "when calling error in override_valid_trans_big, line 6") else call error("Called A.foo on invalid object.", "when calling error in override_valid_trans_big, line 6") endif endif if A_typeId[this] <= 6 then if A_typeId[this] <= 1 then set this = 7 else set this = 8 endif else set this = 9 endif set wurst_stack_depth = wurst_stack_depth - 1 return this endfunction function new_A takes string w__wurst_stackPos returns integer local integer this set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling alloc_A in override_valid_trans_big, line 5" set wurst_stack_depth = wurst_stack_depth + 1 if A_firstFree == 0 then if A_maxIndex < 32768 then set A_maxIndex = A_maxIndex + 1 set this = A_maxIndex set A_typeId[this] = 1 else call error("Out of memory: Could not create A.", "when calling error in override_valid_trans_big, line 5") set this = 0 endif else set A_firstFree = A_firstFree - 1 set this = A_nextFree[A_firstFree] set A_typeId[this] = 1 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function new_B11 takes string w__wurst_stackPos returns integer local integer this set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling alloc_B11 in override_valid_trans_big, line 13" set wurst_stack_depth = wurst_stack_depth + 1 if A_firstFree == 0 then if A_maxIndex < 32768 then set A_maxIndex = A_maxIndex + 1 set this = A_maxIndex set A_typeId[this] = 4 else call error("Out of memory: Could not create B11.", "when calling error in override_valid_trans_big, line 13") set this = 0 endif else set A_firstFree = A_firstFree - 1 set this = A_nextFree[A_firstFree] set A_typeId[this] = 4 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function new_C takes string w__wurst_stackPos returns integer local integer this set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling alloc_C in override_valid_trans_big, line 15" set wurst_stack_depth = wurst_stack_depth + 1 if A_firstFree == 0 then if A_maxIndex < 32768 then set A_maxIndex = A_maxIndex + 1 set this = A_maxIndex set A_typeId[this] = 7 else call error("Out of memory: Could not create C.", "when calling error in override_valid_trans_big, line 15") set this = 0 endif else set A_firstFree = A_firstFree - 1 set this = A_nextFree[A_firstFree] set A_typeId[this] = 7 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function new_C11 takes string w__wurst_stackPos returns integer local integer this set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling alloc_C11 in override_valid_trans_big, line 20" set wurst_stack_depth = wurst_stack_depth + 1 if A_firstFree == 0 then if A_maxIndex < 32768 then set A_maxIndex = A_maxIndex + 1 set this = A_maxIndex set A_typeId[this] = 9 else call error("Out of memory: Could not create C11.", "when calling error in override_valid_trans_big, line 20") set this = 0 endif else set A_firstFree = A_firstFree - 1 set this = A_nextFree[A_firstFree] set A_typeId[this] = 9 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function init_test takes string w__wurst_stackPos returns nothing local integer a set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set a = new_C11("when calling new_C11 in override_valid_trans_big, line 23") if dispatch_A_test_A_foo(a, "when calling foo in override_valid_trans_big, line 24") != 9 then call testFail("c11") endif set a = new_B11("when calling new_B11 in override_valid_trans_big, line 26") if dispatch_A_test_A_foo(a, "when calling foo in override_valid_trans_big, line 27") != 8 then call testFail("b11") endif set a = new_C("when calling new_C in override_valid_trans_big, line 29") if dispatch_A_test_A_foo(a, "when calling foo in override_valid_trans_big, line 30") != 9 then call testFail("C") endif set a = new_A("when calling new_A in override_valid_trans_big, line 32") if dispatch_A_test_A_foo(a, "when calling foo in override_valid_trans_big, line 33") != 7 then call testFail("A") endif call testSuccess() set wurst_stack_depth = wurst_stack_depth - 1 endfunction function main takes nothing returns nothing call initGlobals() call init_test("when calling init_test in override_valid_trans_big, line 1") endfunction function config takes nothing returns nothing endfunction