OLD | NEW |
---|---|
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/code_generator.h" | 5 #include "vm/code_generator.h" |
6 | 6 |
7 #include "vm/assembler.h" | 7 #include "vm/assembler.h" |
8 #include "vm/ast.h" | 8 #include "vm/ast.h" |
9 #include "vm/code_patcher.h" | 9 #include "vm/code_patcher.h" |
10 #include "vm/compiler.h" | 10 #include "vm/compiler.h" |
(...skipping 1174 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1185 } | 1185 } |
1186 | 1186 |
1187 uword interrupt_bits = isolate->GetAndClearInterrupts(); | 1187 uword interrupt_bits = isolate->GetAndClearInterrupts(); |
1188 if ((interrupt_bits & Isolate::kStoreBufferInterrupt) != 0) { | 1188 if ((interrupt_bits & Isolate::kStoreBufferInterrupt) != 0) { |
1189 if (FLAG_verbose_gc) { | 1189 if (FLAG_verbose_gc) { |
1190 OS::PrintErr("Scavenge scheduled by store buffer overflow.\n"); | 1190 OS::PrintErr("Scavenge scheduled by store buffer overflow.\n"); |
1191 } | 1191 } |
1192 isolate->heap()->CollectGarbage(Heap::kNew); | 1192 isolate->heap()->CollectGarbage(Heap::kNew); |
1193 } | 1193 } |
1194 if ((interrupt_bits & Isolate::kMessageInterrupt) != 0) { | 1194 if ((interrupt_bits & Isolate::kMessageInterrupt) != 0) { |
1195 isolate->message_handler()->HandleOOBMessages(); | 1195 bool ok = isolate->message_handler()->HandleOOBMessages(); |
1196 if (!ok) { | |
1197 const String& msg = String::Handle(String::New("unwind")); | |
siva
2014/12/13 00:24:05
why not "isolate terminated" instead of "unwind" s
Ivan Posva
2014/12/13 00:36:47
Done and added a comment.
| |
1198 const UnwindError& error = UnwindError::Handle(UnwindError::New(msg)); | |
1199 Exceptions::PropagateError(error); | |
Lasse Reichstein Nielsen
2014/12/13 02:04:46
If an UnwindError terminates the isolate without r
Ivan Posva
2014/12/15 22:25:59
PropagateError does propagate the error to the nex
| |
1200 UNREACHABLE(); | |
1201 } | |
1196 } | 1202 } |
1197 if ((interrupt_bits & Isolate::kApiInterrupt) != 0) { | 1203 if ((interrupt_bits & Isolate::kApiInterrupt) != 0) { |
1198 // Signal isolate interrupt event. | 1204 // Signal isolate interrupt event. |
1199 Debugger::SignalIsolateInterrupted(); | 1205 Debugger::SignalIsolateInterrupted(); |
1200 | 1206 |
1201 Dart_IsolateInterruptCallback callback = isolate->InterruptCallback(); | 1207 Dart_IsolateInterruptCallback callback = isolate->InterruptCallback(); |
1202 if (callback) { | 1208 if (callback) { |
1203 if ((*callback)()) { | 1209 if ((*callback)()) { |
1204 return; | 1210 return; |
1205 } else { | 1211 } else { |
(...skipping 439 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1645 field.RecordStore(value); | 1651 field.RecordStore(value); |
1646 } | 1652 } |
1647 | 1653 |
1648 | 1654 |
1649 DEFINE_RUNTIME_ENTRY(InitStaticField, 1) { | 1655 DEFINE_RUNTIME_ENTRY(InitStaticField, 1) { |
1650 const Field& field = Field::CheckedHandle(arguments.ArgAt(0)); | 1656 const Field& field = Field::CheckedHandle(arguments.ArgAt(0)); |
1651 field.EvaluateInitializer(); | 1657 field.EvaluateInitializer(); |
1652 } | 1658 } |
1653 | 1659 |
1654 } // namespace dart | 1660 } // namespace dart |
OLD | NEW |