// this script was compiled with wurst 1.8.1.0-jenkins-Wurst-1366 globals integer array C_nextFree integer C_firstFree=0 integer C_maxIndex=0 integer array C_typeId integer array Iterator_nextFree integer Iterator_firstFree=0 integer Iterator_maxIndex=0 integer array Iterator_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_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 genericForFrom, line 3" set wurst_stack_depth = wurst_stack_depth + 1 if C_firstFree == 0 then if C_maxIndex < 32768 then set C_maxIndex = C_maxIndex + 1 set this = C_maxIndex set C_typeId[this] = 1 else call error("Out of memory: Could not create C.", "when calling error in genericForFrom, line 3") set this = 0 endif else set C_firstFree = C_firstFree - 1 set this = C_nextFree[C_firstFree] set C_typeId[this] = 1 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function new_Iterator 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_Iterator in genericForFrom, line 6" set wurst_stack_depth = wurst_stack_depth + 1 if Iterator_firstFree == 0 then if Iterator_maxIndex < 32768 then set Iterator_maxIndex = Iterator_maxIndex + 1 set this = Iterator_maxIndex else call error("Out of memory: Could not create Iterator.", "when calling error in genericForFrom, line 6") set this = 0 endif else set Iterator_firstFree = Iterator_firstFree - 1 set this = Iterator_nextFree[Iterator_firstFree] endif set wurst_stack_depth = wurst_stack_depth - 1 set Iterator_i[this] = 0 set wurst_stack_depth = wurst_stack_depth - 1 return this endfunction function init_test takes string w__wurst_stackPos returns nothing local integer c set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set c = new_C("when calling new_C in genericForFrom, line 14") set wurst_stack[wurst_stack_depth] = "when calling iterator in genericForFrom, line 15" set wurst_stack_depth = wurst_stack_depth + 1 if C_typeId[c] == 0 then if c == 0 then call error("Nullpointer exception when calling C.iterator", "when calling error in genericForFrom, line 4") else call error("Called C.iterator on invalid object.", "when calling error in genericForFrom, line 4") endif endif set wurst_stack[wurst_stack_depth] = "when calling iterator in genericForFrom, line 4" set wurst_stack_depth = wurst_stack_depth + 1 set c = new_Iterator("when calling new_Iterator in genericForFrom, line 5") set wurst_stack_depth = wurst_stack_depth - 1 - 1 loop exitwhen Iterator_i[c] >= 10 set Iterator_i[c] = Iterator_i[c] + 1 if Iterator_i[c] == 5 then call testSuccess() endif endloop 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 genericForFrom, line 1") endfunction function config takes nothing returns nothing endfunction