// this script was compiled with wurst 1.8.1.0-jenkins-Wurst-1366 globals integer array A_nextFree integer A_firstFree=0 integer A_maxIndex=0 integer array A_typeId integer array A_i integer wurst_stack_depth=0 string array wurst_stack endglobals 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 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 dotdotOperator, line 3" 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 dotdotOperator, line 3") 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 init_test takes string w__wurst_stackPos returns nothing local integer receiver set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set receiver = new_A("when calling new_A in dotdotOperator, line 10") set wurst_stack[wurst_stack_depth] = "when calling plus in dotdotOperator, line 11" set wurst_stack_depth = wurst_stack_depth + 1 if A_typeId[receiver] == 0 then if receiver == 0 then call error("Nullpointer exception when calling A.plus", "when calling error in dotdotOperator, line 5") else call error("Called A.plus on invalid object.", "when calling error in dotdotOperator, line 5") endif endif set A_i[receiver] = A_i[receiver] + 3 set wurst_stack_depth = wurst_stack_depth - 1 set wurst_stack[wurst_stack_depth] = "when calling minus in dotdotOperator, line 12" set wurst_stack_depth = wurst_stack_depth + 1 if A_typeId[receiver] == 0 then if receiver == 0 then call error("Nullpointer exception when calling A.minus", "when calling error in dotdotOperator, line 7") else call error("Called A.minus on invalid object.", "when calling error in dotdotOperator, line 7") endif endif set A_i[receiver] = A_i[receiver] - 4 set wurst_stack_depth = wurst_stack_depth - 1 set wurst_stack[wurst_stack_depth] = "when calling plus in dotdotOperator, line 13" set wurst_stack_depth = wurst_stack_depth + 1 if A_typeId[receiver] == 0 then if receiver == 0 then call error("Nullpointer exception when calling A.plus", "when calling error in dotdotOperator, line 5") else call error("Called A.plus on invalid object.", "when calling error in dotdotOperator, line 5") endif endif set A_i[receiver] = A_i[receiver] + 5 set wurst_stack_depth = wurst_stack_depth - 1 if A_i[receiver] == 4 then call testSuccess() endif 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 dotdotOperator, line 1") endfunction function config takes nothing returns nothing endfunction