// this script was compiled with wurst 1.8.1.0-jenkins-Wurst-1366 globals string test_s=null integer array T_nextFree integer T_firstFree=0 integer T_maxIndex=0 integer array T_typeId integer wurst_stack_depth=0 string array wurst_stack endglobals native testSuccess takes nothing returns nothing 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_T_destroyT takes integer this, string w__wurst_stackPos returns nothing set wurst_stack[wurst_stack_depth] = w__wurst_stackPos set wurst_stack_depth = wurst_stack_depth + 1 if T_typeId[this] == 0 then if this == 0 then call error("Nullpointer exception when calling T.T", "when calling error in ondestroy_dynamicdispatchFrotty2, line 8") else call error("Called T.T on invalid object.", "when calling error in ondestroy_dynamicdispatchFrotty2, line 8") endif endif if T_typeId[this] <= 2 then if T_typeId[this] <= 1 then set wurst_stack[wurst_stack_depth] = "when calling destroyT in ondestroy_dynamicdispatchFrotty2, line 8" set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling dealloc_T in ondestroy_dynamicdispatchFrotty2, line 8" set wurst_stack_depth = wurst_stack_depth + 1 if T_typeId[this] == 0 then call error("Double free: object of type T", "when calling error in ondestroy_dynamicdispatchFrotty2, line 8") else set T_nextFree[T_firstFree] = this set T_firstFree = T_firstFree + 1 set T_typeId[this] = 0 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 else set wurst_stack[wurst_stack_depth] = "when calling destroyA in ondestroy_dynamicdispatchFrotty2, line 8" set wurst_stack_depth = wurst_stack_depth + 1 set wurst_stack[wurst_stack_depth] = "when calling dealloc_A in ondestroy_dynamicdispatchFrotty2, line 4" set wurst_stack_depth = wurst_stack_depth + 1 if T_typeId[this] == 0 then call error("Double free: object of type A", "when calling error in ondestroy_dynamicdispatchFrotty2, line 4") else set T_nextFree[T_firstFree] = this set T_firstFree = T_firstFree + 1 set T_typeId[this] = 0 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 endif else set wurst_stack[wurst_stack_depth] = "when calling destroyB in ondestroy_dynamicdispatchFrotty2, line 8" set wurst_stack_depth = wurst_stack_depth + 1 set test_s = test_s + "B" set wurst_stack[wurst_stack_depth] = "when calling dealloc_B in ondestroy_dynamicdispatchFrotty2, line 6" set wurst_stack_depth = wurst_stack_depth + 1 if T_typeId[this] == 0 then call error("Double free: object of type B", "when calling error in ondestroy_dynamicdispatchFrotty2, line 5") else set T_nextFree[T_firstFree] = this set T_firstFree = T_firstFree + 1 set T_typeId[this] = 0 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 endif set wurst_stack_depth = wurst_stack_depth - 1 endfunction function initGlobals takes nothing returns nothing 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 ondestroy_dynamicdispatchFrotty2, line 4" set wurst_stack_depth = wurst_stack_depth + 1 if T_firstFree == 0 then if T_maxIndex < 32768 then set T_maxIndex = T_maxIndex + 1 set this = T_maxIndex set T_typeId[this] = 2 else call error("Out of memory: Could not create A.", "when calling error in ondestroy_dynamicdispatchFrotty2, line 4") set this = 0 endif else set T_firstFree = T_firstFree - 1 set this = T_nextFree[T_firstFree] set T_typeId[this] = 2 endif set wurst_stack_depth = wurst_stack_depth - 1 - 1 return this endfunction function main takes nothing returns nothing call initGlobals() set wurst_stack[wurst_stack_depth] = "when calling init_test in ondestroy_dynamicdispatchFrotty2, line 1" set wurst_stack_depth = wurst_stack_depth + 1 set test_s = "" call dispatch_T_destroyT(new_A("when calling new_A in ondestroy_dynamicdispatchFrotty2, line 12"), "when calling dispatch_T_destroyT in ondestroy_dynamicdispatchFrotty2, line 13") if test_s == "" then call testSuccess() endif set wurst_stack_depth = wurst_stack_depth - 1 endfunction function config takes nothing returns nothing endfunction