1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
|
172c172
< locals: value x$1, value temp1
---
> locals: value x$1, value temp1, variable boxed1
174c174
< blocks: [1,2,3,4]
---
> blocks: [1,2,3]
187,189d186
< 92 JUMP 4
<
< 4:
195a193,194
> 92 STORE_LOCAL(variable boxed1)
> 92 LOAD_LOCAL(variable boxed1)
386c385
< blocks: [1,2,3,4,5,7,8,10]
---
> blocks: [1,2,3,4,5,7,8,10,11]
410c409,418
< 103 THROW(MyException)
---
> ? STORE_LOCAL(value ex$1)
> ? JUMP 11
>
> 11:
> 101 LOAD_LOCAL(value ex$1)
> 101 STORE_LOCAL(value temp2)
> 101 SCOPE_ENTER value temp2
> 101 LOAD_LOCAL(value temp2)
> 101 IS_INSTANCE REF(class MyException)
> 101 CZJUMP (BOOL)NE ? 4 : 5
501c509
< blocks: [1,2,3,4,6,7,8,9,10]
---
> blocks: [1,2,3,4,6,7,8,9,10,11,12,13]
530c538,543
< 306 THROW(MyException)
---
> ? JUMP 11
>
> 11:
> ? LOAD_LOCAL(variable monitor4)
> 305 MONITOR_EXIT
> ? JUMP 12
536c549,555
< ? THROW(Throwable)
---
> ? JUMP 12
>
> 12:
> ? LOAD_LOCAL(variable monitor3)
> 304 MONITOR_EXIT
> ? STORE_LOCAL(value t)
> ? JUMP 13
542c561,574
< ? THROW(Throwable)
---
> ? STORE_LOCAL(value t)
> ? JUMP 13
>
> 13:
> 310 LOAD_MODULE object Predef
> 310 CALL_PRIMITIVE(StartConcat)
> 310 CONSTANT("Caught crash: ")
> 310 CALL_PRIMITIVE(StringConcat(REF(class String)))
> 310 LOAD_LOCAL(value t)
> 310 CALL_METHOD java.lang.Throwable.toString (dynamic)
> 310 CALL_PRIMITIVE(StringConcat(REF(class String)))
> 310 CALL_PRIMITIVE(EndConcat)
> 310 CALL_METHOD scala.Predef.println (dynamic)
> 310 JUMP 2
566c598
< catch (Throwable) in ArrayBuffer(7, 8, 9, 10) starting at: 6
---
> catch (Throwable) in ArrayBuffer(7, 8, 9, 10, 11) starting at: 6
569c601
< catch (Throwable) in ArrayBuffer(4, 6, 7, 8, 9, 10) starting at: 3
---
> catch (Throwable) in ArrayBuffer(4, 6, 7, 8, 9, 10, 11, 12) starting at: 3
601c633
< blocks: [1,2,3,4,5,6,7,9,10]
---
> blocks: [1,2,3,4,5,6,7,9,10,11,12]
625c657,663
< 78 THROW(IllegalArgumentException)
---
> ? STORE_LOCAL(value e)
> ? JUMP 11
>
> 11:
> 81 LOAD_LOCAL(value e)
> ? STORE_LOCAL(variable exc1)
> ? JUMP 12
654c692,706
< 81 THROW(Exception)
---
> ? STORE_LOCAL(variable exc1)
> ? JUMP 12
>
> 12:
> 83 LOAD_MODULE object Predef
> 83 CONSTANT("finally")
> 83 CALL_METHOD scala.Predef.println (dynamic)
> 84 LOAD_LOCAL(variable result)
> 84 CONSTANT(1)
> 84 CALL_PRIMITIVE(Arithmetic(SUB,INT))
> 84 CONSTANT(2)
> 84 CALL_PRIMITIVE(Arithmetic(DIV,INT))
> 84 STORE_LOCAL(variable result)
> 84 LOAD_LOCAL(variable exc1)
> 84 THROW(Throwable)
676c728
< catch (<none>) in ArrayBuffer(4, 6, 7, 9) starting at: 3
---
> catch (<none>) in ArrayBuffer(4, 6, 7, 9, 11) starting at: 3
702c754
< blocks: [1,2,3,4,5,6,7,8,11,12,13,14,15,16,18,19]
---
> blocks: [1,2,3,4,5,6,7,8,11,12,13,14,15,16,18,19,20,21,22]
726c778,787
< 172 THROW(MyException)
---
> ? STORE_LOCAL(value ex$4)
> ? JUMP 20
>
> 20:
> 170 LOAD_LOCAL(value ex$4)
> 170 STORE_LOCAL(value temp11)
> 170 SCOPE_ENTER value temp11
> 170 LOAD_LOCAL(value temp11)
> 170 IS_INSTANCE REF(class MyException)
> 170 CZJUMP (BOOL)NE ? 12 : 13
780c841,842
< 177 THROW(MyException)
---
> ? STORE_LOCAL(value ex$5)
> ? JUMP 21
784c846,855
< 170 THROW(Throwable)
---
> ? STORE_LOCAL(value ex$5)
> ? JUMP 21
>
> 21:
> 169 LOAD_LOCAL(value ex$5)
> 169 STORE_LOCAL(value temp14)
> 169 SCOPE_ENTER value temp14
> 169 LOAD_LOCAL(value temp14)
> 169 IS_INSTANCE REF(class MyException)
> 169 CZJUMP (BOOL)NE ? 5 : 6
815c886,887
< 182 THROW(MyException)
---
> ? STORE_LOCAL(variable exc2)
> ? JUMP 22
819c891,905
< 169 THROW(Throwable)
---
> ? STORE_LOCAL(variable exc2)
> ? JUMP 22
>
> 22:
> 184 LOAD_MODULE object Predef
> 184 CONSTANT("finally")
> 184 CALL_METHOD scala.Predef.println (dynamic)
> 185 LOAD_LOCAL(variable result)
> 185 CONSTANT(1)
> 185 CALL_PRIMITIVE(Arithmetic(SUB,INT))
> 185 CONSTANT(2)
> 185 CALL_PRIMITIVE(Arithmetic(DIV,INT))
> 185 STORE_LOCAL(variable result)
> 185 LOAD_LOCAL(variable exc2)
> 185 THROW(Throwable)
841c927
< catch (Throwable) in ArrayBuffer(11, 12, 13, 14, 15, 16, 18) starting at: 4
---
> catch (Throwable) in ArrayBuffer(11, 12, 13, 14, 15, 16, 18, 20) starting at: 4
844c930
< catch (<none>) in ArrayBuffer(4, 5, 6, 7, 11, 12, 13, 14, 15, 16, 18) starting at: 3
---
> catch (<none>) in ArrayBuffer(4, 5, 6, 7, 11, 12, 13, 14, 15, 16, 18, 20, 21) starting at: 3
870c956
< blocks: [1,2,3,6,7,8,10,11,13]
---
> blocks: [1,2,3,6,7,8,10,11,13,14]
894c980,989
< 124 THROW(MyException)
---
> ? STORE_LOCAL(value ex$2)
> ? JUMP 14
>
> 14:
> 122 LOAD_LOCAL(value ex$2)
> 122 STORE_LOCAL(value temp5)
> 122 SCOPE_ENTER value temp5
> 122 LOAD_LOCAL(value temp5)
> 122 IS_INSTANCE REF(class MyException)
> 122 CZJUMP (BOOL)NE ? 7 : 8
942c1037
< catch (IllegalArgumentException) in ArrayBuffer(6, 7, 8, 10, 11, 13) starting at: 3
---
> catch (IllegalArgumentException) in ArrayBuffer(6, 7, 8, 10, 11, 13, 14) starting at: 3
968c1063
< blocks: [1,2,3,4,5,9,10,11,13]
---
> blocks: [1,2,3,4,5,9,10,11,13,14]
992c1087,1096
< 148 THROW(MyException)
---
> ? STORE_LOCAL(value ex$3)
> ? JUMP 14
>
> 14:
> 145 LOAD_LOCAL(value ex$3)
> 145 STORE_LOCAL(value temp8)
> 145 SCOPE_ENTER value temp8
> 145 LOAD_LOCAL(value temp8)
> 145 IS_INSTANCE REF(class MyException)
> 145 CZJUMP (BOOL)NE ? 4 : 5
1236c1340
< blocks: [1,2,3,4,5,7]
---
> blocks: [1,2,3,4,5,7,8]
1260c1364,1371
< 38 THROW(IllegalArgumentException)
---
> ? STORE_LOCAL(value e)
> ? JUMP 8
>
> 8:
> 42 LOAD_MODULE object Predef
> 42 CONSTANT("IllegalArgumentException")
> 42 CALL_METHOD scala.Predef.println (dynamic)
> 42 JUMP 2
1309c1420
< blocks: [1,2,3,4,5,7,8,10,11,13]
---
> blocks: [1,2,3,4,5,7,8,10,11,13,14]
1333c1444,1445
< 203 THROW(MyException)
---
> ? STORE_LOCAL(value ex$6)
> ? JUMP 14
1353c1465,1474
< 209 THROW(MyException)
---
> ? STORE_LOCAL(value ex$6)
> ? JUMP 14
>
> 14:
> 200 LOAD_LOCAL(value ex$6)
> 200 STORE_LOCAL(value temp17)
> 200 SCOPE_ENTER value temp17
> 200 LOAD_LOCAL(value temp17)
> 200 IS_INSTANCE REF(class MyException)
> 200 CZJUMP (BOOL)NE ? 4 : 5
1416c1537
< blocks: [1,2,3,4,5,7]
---
> blocks: [1,2,3,4,5,7,8]
1440c1561,1568
< 58 THROW(IllegalArgumentException)
---
> ? STORE_LOCAL(value e)
> ? JUMP 8
>
> 8:
> 62 LOAD_MODULE object Predef
> 62 CONSTANT("RuntimeException")
> 62 CALL_METHOD scala.Predef.println (dynamic)
> 62 JUMP 2
1489c1617
< blocks: [1,2,3,4]
---
> blocks: [1,2,3,4,5]
1509c1637,1642
< 229 THROW(MyException)
---
> ? JUMP 5
>
> 5:
> ? LOAD_LOCAL(variable monitor1)
> 228 MONITOR_EXIT
> 228 THROW(Throwable)
1515c1648
< ? THROW(Throwable)
---
> 228 THROW(Throwable)
1543c1676
< locals: value args, variable result, variable monitor2, variable monitorResult1
---
> locals: value exception$1, value args, variable result, variable monitor2, variable monitorResult1
1545c1678
< blocks: [1,2,3,4]
---
> blocks: [1,2,3,4,5]
1568c1701,1709
< 245 THROW(MyException)
---
> ? STORE_LOCAL(value exception$1)
> ? DROP ConcatClass
> ? LOAD_LOCAL(value exception$1)
> ? JUMP 5
>
> 5:
> ? LOAD_LOCAL(variable monitor2)
> 244 MONITOR_EXIT
> 244 THROW(Throwable)
1574c1715
< ? THROW(Throwable)
---
> 244 THROW(Throwable)
|