OLD | NEW |
---|---|
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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/flow_graph_builder.h" | 5 #include "vm/flow_graph_builder.h" |
6 | 6 |
7 #include "lib/invocation_mirror.h" | 7 #include "lib/invocation_mirror.h" |
8 #include "vm/ast_printer.h" | 8 #include "vm/ast_printer.h" |
9 #include "vm/bit_vector.h" | 9 #include "vm/bit_vector.h" |
10 #include "vm/code_descriptors.h" | 10 #include "vm/code_descriptors.h" |
(...skipping 1693 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1704 | 1704 |
1705 owner()->IncrementLoopDepth(); | 1705 owner()->IncrementLoopDepth(); |
1706 // Compose body to set any jump labels. | 1706 // Compose body to set any jump labels. |
1707 EffectGraphVisitor for_body(owner(), temp_index()); | 1707 EffectGraphVisitor for_body(owner(), temp_index()); |
1708 node->body()->Visit(&for_body); | 1708 node->body()->Visit(&for_body); |
1709 | 1709 |
1710 EffectGraphVisitor for_increment(owner(), temp_index()); | 1710 EffectGraphVisitor for_increment(owner(), temp_index()); |
1711 node->increment()->Visit(&for_increment); | 1711 node->increment()->Visit(&for_increment); |
1712 | 1712 |
1713 // Join the loop body and increment and then tie the loop. | 1713 // Join the loop body and increment and then tie the loop. |
1714 JoinEntryInstr* join = node->label()->join_for_continue(); | 1714 JoinEntryInstr* continue_join = node->label()->join_for_continue(); |
1715 if ((join != NULL) || for_body.is_open()) { | 1715 if ((continue_join != NULL) || for_body.is_open()) { |
1716 JoinEntryInstr* loop_start = | 1716 JoinEntryInstr* loop_entry = |
1717 new JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 1717 new JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); |
1718 if (join != NULL) { | 1718 if (continue_join != NULL) { |
1719 if (for_body.is_open()) for_body.Goto(join); | 1719 if (for_body.is_open()) for_body.Goto(continue_join); |
1720 AppendFragment(join, for_increment); | 1720 Instruction* current = AppendFragment(continue_join, for_increment); |
1721 for_increment.Goto(loop_start); | 1721 current->Goto(loop_entry); |
Kevin Millikin (Google)
2013/06/20 09:44:24
The bug is in the order of side effects here. If
| |
1722 } else { | 1722 } else { |
1723 for_body.Append(for_increment); | 1723 for_body.Append(for_increment); |
1724 for_body.Goto(loop_start); | 1724 for_body.Goto(loop_entry); |
1725 } | 1725 } |
1726 Goto(loop_start); | 1726 Goto(loop_entry); |
1727 exit_ = loop_start; | 1727 exit_ = loop_entry; |
1728 AddInstruction( | 1728 AddInstruction( |
1729 new CheckStackOverflowInstr(node->token_pos(), owner()->loop_depth())); | 1729 new CheckStackOverflowInstr(node->token_pos(), owner()->loop_depth())); |
1730 } | 1730 } |
1731 | 1731 |
1732 if (node->condition() == NULL) { | 1732 if (node->condition() == NULL) { |
1733 // Endless loop, no test. | 1733 // Endless loop, no test. |
1734 JoinEntryInstr* body_entry = | 1734 Append(for_body); |
1735 new JoinEntryInstr(owner()->AllocateBlockId(), owner()->try_index()); | 1735 exit_ = node->label()->join_for_break(); // May be NULL. |
1736 AppendFragment(body_entry, for_body); | |
1737 Goto(body_entry); | |
1738 if (node->label()->join_for_break() != NULL) { | |
1739 // Control flow of ForLoop continues into join_for_break. | |
1740 exit_ = node->label()->join_for_break(); | |
1741 } | |
1742 } else { | 1736 } else { |
1743 TestGraphVisitor for_test(owner(), | 1737 TestGraphVisitor for_test(owner(), |
1744 temp_index(), | 1738 temp_index(), |
1745 node->condition()->token_pos()); | 1739 node->condition()->token_pos()); |
1746 node->condition()->Visit(&for_test); | 1740 node->condition()->Visit(&for_test); |
1747 Append(for_test); | 1741 Append(for_test); |
1748 | 1742 |
1749 BlockEntryInstr* body_entry = for_test.CreateTrueSuccessor(); | 1743 BlockEntryInstr* body_entry = for_test.CreateTrueSuccessor(); |
1750 AppendFragment(body_entry, for_body); | 1744 AppendFragment(body_entry, for_body); |
1751 | 1745 |
(...skipping 1759 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
3511 intptr_t len = OS::SNPrint(NULL, 0, kFormat, function_name, reason) + 1; | 3505 intptr_t len = OS::SNPrint(NULL, 0, kFormat, function_name, reason) + 1; |
3512 char* chars = Isolate::Current()->current_zone()->Alloc<char>(len); | 3506 char* chars = Isolate::Current()->current_zone()->Alloc<char>(len); |
3513 OS::SNPrint(chars, len, kFormat, function_name, reason); | 3507 OS::SNPrint(chars, len, kFormat, function_name, reason); |
3514 const Error& error = Error::Handle( | 3508 const Error& error = Error::Handle( |
3515 LanguageError::New(String::Handle(String::New(chars)))); | 3509 LanguageError::New(String::Handle(String::New(chars)))); |
3516 Isolate::Current()->long_jump_base()->Jump(1, error); | 3510 Isolate::Current()->long_jump_base()->Jump(1, error); |
3517 } | 3511 } |
3518 | 3512 |
3519 | 3513 |
3520 } // namespace dart | 3514 } // namespace dart |
OLD | NEW |