// this script was compiled with wurst 1.8.1.0-jenkins-Wurst-1365 globals integer array Func_nextFree integer Func_firstFree=0 integer Func_maxIndex=0 integer array Func_typeId integer array C_nextFree integer C_firstFree=0 integer C_maxIndex=0 integer array C_typeId integer array C_x 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 integer x, 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 generic1, line 7" 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 generic1, line 5") 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 set C_x[this] = x set wurst_stack_depth = wurst_stack_depth - 1 return this endfunction function dispatch_C_A_C_map takes integer this, integer f, string w__wurst_stackPos returns integer local integer x set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 if C_typeId[this] == 0 then if this == 0 then call error("Nullpointer exception when calling C.map", "when calling error in generic1, line 9") else call error("Called C.map on invalid object.", "when calling error in generic1, line 9") endif endif set wurst_stack[wurst_stack_depth] = "when calling map in generic1, line 9" set wurst_stack_depth = wurst_stack_depth + 1 set x = C_x[this] set wurst_stack[wurst_stack_depth] = "when calling apply in generic1, line 10" set wurst_stack_depth = wurst_stack_depth + 1 if Func_typeId[f] == 0 then if f == 0 then call error("Nullpointer exception when calling Func.apply", "when calling error in generic1, line 4") else call error("Called Func.apply on invalid object.", "when calling error in generic1, line 4") endif endif set wurst_stack_depth = wurst_stack_depth - 1 set this = new_C(2 * x, "when calling new_C in generic1, line 10") set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function init_A takes string w__wurst_stackPos returns nothing local integer a local integer this set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 set a = new_C(5, "when calling new_C in generic1, line 12") set wurst_stack[wurst_stack_depth] = "when calling alloc_Func_map_A in generic1, line 13" set wurst_stack_depth = wurst_stack_depth + 1 if Func_firstFree == 0 then if Func_maxIndex < 32768 then set Func_maxIndex = Func_maxIndex + 1 set this = Func_maxIndex set Func_typeId[this] = 3 else call error("Out of memory: Could not create Func_map_A.", "when calling error in generic1, line 13") set this = 0 endif else set Func_firstFree = Func_firstFree - 1 set this = Func_nextFree[Func_firstFree] set Func_typeId[this] = 3 endif set wurst_stack_depth = wurst_stack_depth - 1 if C_x[dispatch_C_A_C_map(a, this, "when calling map in generic1, line 13")] == 10 then call testSuccess() endif set wurst_stack_depth = wurst_stack_depth - 1 endfunction function main takes nothing returns nothing call initGlobals() call init_A("when calling init_A in generic1, line 1") endfunction function config takes nothing returns nothing endfunction