// 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 Cell_nextFree integer Cell_firstFree=0 integer Cell_maxIndex=0 integer array Cell_o endglobals native testSuccess takes nothing returns nothing function initGlobals takes nothing returns nothing set A_firstFree = 0 set A_maxIndex = 0 set Cell_firstFree = 0 set Cell_maxIndex = 0 endfunction function A_foo takes integer this returns integer return 5 endfunction function B_foo takes integer this returns integer return 6 endfunction function error takes string msg returns nothing call BJDebugMsg(msg + "\n" + "") endfunction function dispatch_A_Test_A_foo takes integer this returns integer local integer Test_A_foo_result if A_typeId[this] == 0 then if this == 0 then call error("Nullpointer exception when calling A.foo") else call error("Called A.foo on invalid object.") endif endif if A_typeId[this] <= 1 then set Test_A_foo_result = A_foo(this) else set Test_A_foo_result = B_foo(this) endif return Test_A_foo_result endfunction function alloc_B takes nothing returns integer local integer this if A_firstFree == 0 then if A_maxIndex < 32768 then set A_maxIndex = A_maxIndex + 1 set this = A_maxIndex set A_typeId[this] = 2 else call error("Out of memory: Could not create B.") set this = 0 endif else set A_firstFree = A_firstFree - 1 set this = A_nextFree[A_firstFree] set A_typeId[this] = 2 endif return this endfunction function B_init takes integer this returns nothing endfunction function A_init takes integer this returns nothing endfunction function construct_A takes integer this returns nothing call A_init(this) endfunction function construct_B takes integer this returns nothing call construct_A(this) call B_init(this) endfunction function new_B takes nothing returns integer local integer this = alloc_B() call construct_B(this) return this endfunction function alloc_Cell takes nothing returns integer local integer this if Cell_firstFree == 0 then if Cell_maxIndex < 32768 then set Cell_maxIndex = Cell_maxIndex + 1 set this = Cell_maxIndex else call error("Out of memory: Could not create Cell.") set this = 0 endif else set Cell_firstFree = Cell_firstFree - 1 set this = Cell_nextFree[Cell_firstFree] endif return this endfunction function Cell_init takes integer this returns nothing endfunction function construct_Cell takes integer this returns nothing call Cell_init(this) endfunction function new_Cell takes nothing returns integer local integer this = alloc_Cell() call construct_Cell(this) return this endfunction function init_Test takes nothing returns nothing local integer c = new_Cell() set Cell_o[c] = new_B() if dispatch_A_Test_A_foo(Cell_o[c]) == 6 then call testSuccess() endif endfunction function main takes nothing returns nothing call initGlobals() call init_Test() endfunction function config takes nothing returns nothing endfunction