tuple_match.golden 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. ********** source program **********
  2. fn main () -> Int {
  3. var auto: t = (0 = 5, 1 = 2);
  4. match (t) {
  5. case (0 = auto: a, 1 = auto: b) =>
  6. return ((a + b) - 7);
  7. }
  8. }
  9. ********** type checking **********
  10. --- step exp Int --->
  11. --- step exp Int --->
  12. --- step exp auto --->
  13. --- step exp auto --->
  14. --- step exp auto --->
  15. ********** type checking complete **********
  16. fn main () -> Int {
  17. var auto: t = (0 = 5, 1 = 2);
  18. match (t) {
  19. case (0 = auto: a, 1 = auto: b) =>
  20. return ((a + b) - 7);
  21. }
  22. }
  23. ********** starting execution **********
  24. ********** initializing globals **********
  25. --- step exp () --->
  26. ********** calling main function **********
  27. {
  28. stack: top{main()<-1>}
  29. heap: fun<main>,
  30. env: main: fun<main>,
  31. }
  32. --- step exp main() --->
  33. {
  34. stack: top{main<-1> :: main()<0>}
  35. heap: fun<main>,
  36. env: main: fun<main>,
  37. }
  38. --- step exp main --->
  39. {
  40. stack: top{fun<main><-1> :: main()<0>}
  41. heap: fun<main>,
  42. env: main: fun<main>,
  43. }
  44. --- handle value fun<main> with main()<1>(fun<main>,) --->
  45. {
  46. stack: top{()<-1> :: main()<1>(fun<main>,)}
  47. heap: fun<main>,
  48. env: main: fun<main>,
  49. }
  50. --- step exp () --->
  51. {
  52. stack: top{()<-1> :: main()<1>(fun<main>,)}
  53. heap: fun<main>,
  54. env: main: fun<main>,
  55. }
  56. --- handle value () with main()<2>(fun<main>,(),) --->
  57. pattern_match((), ())
  58. {
  59. stack: main{var auto: t = (0 = 5, 1 = 2); ... <-1>} :: top{}
  60. heap: fun<main>,
  61. env: main: fun<main>,
  62. }
  63. --- step stmt var auto: t = (0 = 5, 1 = 2); ... --->
  64. {
  65. stack: main{var auto: t = (0 = 5, 1 = 2);<-1> :: match (t) {...}<-1>} :: top{}
  66. heap: fun<main>,
  67. env: main: fun<main>,
  68. }
  69. --- step stmt var auto: t = (0 = 5, 1 = 2); --->
  70. {
  71. stack: main{(0 = 5, 1 = 2)<-1> :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  72. heap: fun<main>,
  73. env: main: fun<main>,
  74. }
  75. --- step exp (0 = 5, 1 = 2) --->
  76. {
  77. stack: main{5<-1> :: (0 = 5, 1 = 2)<0> :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  78. heap: fun<main>,
  79. env: main: fun<main>,
  80. }
  81. --- step exp 5 --->
  82. {
  83. stack: main{5<-1> :: (0 = 5, 1 = 2)<0> :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  84. heap: fun<main>,
  85. env: main: fun<main>,
  86. }
  87. --- handle value 5 with (0 = 5, 1 = 2)<1>(5,) --->
  88. {
  89. stack: main{2<-1> :: (0 = 5, 1 = 2)<1>(5,) :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  90. heap: fun<main>,
  91. env: main: fun<main>,
  92. }
  93. --- step exp 2 --->
  94. {
  95. stack: main{2<-1> :: (0 = 5, 1 = 2)<1>(5,) :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  96. heap: fun<main>,
  97. env: main: fun<main>,
  98. }
  99. --- handle value 2 with (0 = 5, 1 = 2)<2>(5,2,) --->
  100. {
  101. stack: main{(0 = 5@1, 1 = 2@2)<-1> :: var auto: t = (0 = 5, 1 = 2);<0> :: match (t) {...}<-1>} :: top{}
  102. heap: fun<main>, 5, 2,
  103. env: main: fun<main>,
  104. }
  105. --- handle value (0 = 5@1, 1 = 2@2) with var auto: t = (0 = 5, 1 = 2);<1>((0 = 5@1, 1 = 2@2),) --->
  106. {
  107. stack: main{auto: t<-1> :: var auto: t = (0 = 5, 1 = 2);<1>((0 = 5@1, 1 = 2@2),) :: match (t) {...}<-1>} :: top{}
  108. heap: fun<main>, 5, 2,
  109. env: main: fun<main>,
  110. }
  111. --- step exp auto: t --->
  112. {
  113. stack: main{auto<-1> :: auto: t<0> :: var auto: t = (0 = 5, 1 = 2);<1>((0 = 5@1, 1 = 2@2),) :: match (t) {...}<-1>} :: top{}
  114. heap: fun<main>, 5, 2,
  115. env: main: fun<main>,
  116. }
  117. --- step exp auto --->
  118. {
  119. stack: main{auto<-1> :: auto: t<0> :: var auto: t = (0 = 5, 1 = 2);<1>((0 = 5@1, 1 = 2@2),) :: match (t) {...}<-1>} :: top{}
  120. heap: fun<main>, 5, 2,
  121. env: main: fun<main>,
  122. }
  123. --- handle value auto with auto: t<1>(auto,) --->
  124. {
  125. stack: main{auto: t<-1> :: var auto: t = (0 = 5, 1 = 2);<1>((0 = 5@1, 1 = 2@2),) :: match (t) {...}<-1>} :: top{}
  126. heap: fun<main>, 5, 2,
  127. env: main: fun<main>,
  128. }
  129. --- handle value auto: t with var auto: t = (0 = 5, 1 = 2);<2>((0 = 5@1, 1 = 2@2),auto: t,) --->
  130. pattern_match(auto: t, (0 = 5@1, 1 = 2@2))
  131. {
  132. stack: main{match (t) {...}<-1>} :: top{}
  133. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  134. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  135. }
  136. --- step stmt match (t) {...} --->
  137. {
  138. stack: main{t<-1> :: match (t) {...}<0>} :: top{}
  139. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  140. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  141. }
  142. --- step exp t --->
  143. {
  144. stack: main{(0 = 5@3, 1 = 2@4)<-1> :: match (t) {...}<0>} :: top{}
  145. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  146. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  147. }
  148. --- handle value (0 = 5@3, 1 = 2@4) with match (t) {...}<1>((0 = 5@3, 1 = 2@4),) --->
  149. {
  150. stack: main{(0 = auto: a, 1 = auto: b)<-1> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  151. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  152. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  153. }
  154. --- step exp (0 = auto: a, 1 = auto: b) --->
  155. {
  156. stack: main{auto: a<-1> :: (0 = auto: a, 1 = auto: b)<0> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  157. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  158. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  159. }
  160. --- step exp auto: a --->
  161. {
  162. stack: main{auto<-1> :: auto: a<0> :: (0 = auto: a, 1 = auto: b)<0> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  163. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  164. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  165. }
  166. --- step exp auto --->
  167. {
  168. stack: main{auto<-1> :: auto: a<0> :: (0 = auto: a, 1 = auto: b)<0> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  169. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  170. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  171. }
  172. --- handle value auto with auto: a<1>(auto,) --->
  173. {
  174. stack: main{auto: a<-1> :: (0 = auto: a, 1 = auto: b)<0> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  175. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  176. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  177. }
  178. --- handle value auto: a with (0 = auto: a, 1 = auto: b)<1>(auto: a,) --->
  179. {
  180. stack: main{auto: b<-1> :: (0 = auto: a, 1 = auto: b)<1>(auto: a,) :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  181. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  182. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  183. }
  184. --- step exp auto: b --->
  185. {
  186. stack: main{auto<-1> :: auto: b<0> :: (0 = auto: a, 1 = auto: b)<1>(auto: a,) :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  187. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  188. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  189. }
  190. --- step exp auto --->
  191. {
  192. stack: main{auto<-1> :: auto: b<0> :: (0 = auto: a, 1 = auto: b)<1>(auto: a,) :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  193. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  194. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  195. }
  196. --- handle value auto with auto: b<1>(auto,) --->
  197. {
  198. stack: main{auto: b<-1> :: (0 = auto: a, 1 = auto: b)<1>(auto: a,) :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  199. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4),
  200. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  201. }
  202. --- handle value auto: b with (0 = auto: a, 1 = auto: b)<2>(auto: a,auto: b,) --->
  203. {
  204. stack: main{(0 = auto: a@6, 1 = auto: b@7)<-1> :: match (t) {...}<1>((0 = 5@3, 1 = 2@4),)} :: top{}
  205. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b,
  206. env: t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  207. }
  208. --- handle value (0 = auto: a@6, 1 = auto: b@7) with match (t) {...}<2>((0 = 5@3, 1 = 2@4),(0 = auto: a@6, 1 = auto: b@7),) --->
  209. pattern_match((0 = auto: a@6, 1 = auto: b@7), (0 = 5@3, 1 = 2@4))
  210. pattern_match(auto: a, 5)
  211. pattern_match(auto: b, 2)
  212. {
  213. stack: main{return ((a + b) - 7);<-1> :: {
  214. ...
  215. }
  216. <0>} :: top{}
  217. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  218. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  219. }
  220. --- step stmt return ((a + b) - 7); --->
  221. {
  222. stack: main{((a + b) - 7)<-1> :: return ((a + b) - 7);<0> :: {
  223. ...
  224. }
  225. <0>} :: top{}
  226. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  227. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  228. }
  229. --- step exp ((a + b) - 7) --->
  230. {
  231. stack: main{(a + b)<-1> :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  232. ...
  233. }
  234. <0>} :: top{}
  235. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  236. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  237. }
  238. --- step exp (a + b) --->
  239. {
  240. stack: main{a<-1> :: (a + b)<0> :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  241. ...
  242. }
  243. <0>} :: top{}
  244. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  245. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  246. }
  247. --- step exp a --->
  248. {
  249. stack: main{5<-1> :: (a + b)<0> :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  250. ...
  251. }
  252. <0>} :: top{}
  253. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  254. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  255. }
  256. --- handle value 5 with (a + b)<1>(5,) --->
  257. {
  258. stack: main{b<-1> :: (a + b)<1>(5,) :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  259. ...
  260. }
  261. <0>} :: top{}
  262. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  263. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  264. }
  265. --- step exp b --->
  266. {
  267. stack: main{2<-1> :: (a + b)<1>(5,) :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  268. ...
  269. }
  270. <0>} :: top{}
  271. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  272. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  273. }
  274. --- handle value 2 with (a + b)<2>(5,2,) --->
  275. {
  276. stack: main{7<-1> :: ((a + b) - 7)<0> :: return ((a + b) - 7);<0> :: {
  277. ...
  278. }
  279. <0>} :: top{}
  280. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  281. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  282. }
  283. --- handle value 7 with ((a + b) - 7)<1>(7,) --->
  284. {
  285. stack: main{7<-1> :: ((a + b) - 7)<1>(7,) :: return ((a + b) - 7);<0> :: {
  286. ...
  287. }
  288. <0>} :: top{}
  289. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  290. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  291. }
  292. --- step exp 7 --->
  293. {
  294. stack: main{7<-1> :: ((a + b) - 7)<1>(7,) :: return ((a + b) - 7);<0> :: {
  295. ...
  296. }
  297. <0>} :: top{}
  298. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  299. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  300. }
  301. --- handle value 7 with ((a + b) - 7)<2>(7,7,) --->
  302. {
  303. stack: main{0<-1> :: return ((a + b) - 7);<0> :: {
  304. ...
  305. }
  306. <0>} :: top{}
  307. heap: fun<main>, 5, 2, 5, 2, (0 = 5@3, 1 = 2@4), auto: a, auto: b, 5, 2,
  308. env: b: 2, a: 5, t: (0 = 5@3, 1 = 2@4), main: fun<main>,
  309. }
  310. --- handle value 0 with return ((a + b) - 7);<1>(0,) --->
  311. {
  312. stack: top{0<-1>}
  313. heap: fun<main>, 5, 2, !!5, !!2, !!(0 = !!5@3, 1 = !!2@4), auto: a, auto: b, !!5, !!2,
  314. env: main: fun<main>,
  315. }
  316. result: 0