********** source program ********** fn f () -> (); fn main () -> Int { f(); return 0; } ********** type checking ********** --- step exp () ---> --- step exp Int ---> --- step exp () ---> --- step exp Int ---> ********** type checking complete ********** fn f () -> () { return (); } fn main () -> Int { f(); return 0; } ********** starting execution ********** ********** initializing globals ********** --- step exp () ---> --- step exp () ---> ********** calling main function ********** { stack: top{main()<-1>} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp main() ---> { stack: top{main<-1> :: main()<0>} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp main ---> { stack: top{fun
<-1> :: main()<0>} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value fun
with main()<1>(fun
,) ---> { stack: top{()<-1> :: main()<1>(fun
,)} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp () ---> { stack: top{()<-1> :: main()<1>(fun
,)} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value () with main()<2>(fun
,(),) ---> pattern_match((), ()) { stack: main{f(); ... <-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step stmt f(); ... ---> { stack: main{f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step stmt f(); ---> { stack: main{f()<-1> :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp f() ---> { stack: main{f<-1> :: f()<0> :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp f ---> { stack: main{fun<-1> :: f()<0> :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value fun with f()<1>(fun,) ---> { stack: main{()<-1> :: f()<1>(fun,) :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp () ---> { stack: main{()<-1> :: f()<1>(fun,) :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value () with f()<2>(fun,(),) ---> pattern_match((), ()) { stack: f{return ();<-1>} :: main{f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step stmt return (); ---> { stack: f{()<-1> :: return ();<0>} :: main{f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp () ---> { stack: f{()<-1> :: return ();<0>} :: main{f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value () with return ();<1>((),) ---> { stack: main{()<-1> :: f();<-1> :: return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value () with f();<0>((),) ---> { stack: main{return 0;<-1>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step stmt return 0; ---> { stack: main{0<-1> :: return 0;<0>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- step exp 0 ---> { stack: main{0<-1> :: return 0;<0>} :: top{} heap: fun, fun
, env: main: fun
, f: fun, } --- handle value 0 with return 0;<1>(0,) ---> { stack: top{0<-1>} heap: fun, fun
, env: main: fun
, f: fun, } result: 0