OLD | NEW |
1 // Copyright 2006-2008 the V8 project authors. All rights reserved. | 1 // Copyright 2006-2008 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
60 | 60 |
61 VariableProxy::VariableProxy(Handle<String> name, | 61 VariableProxy::VariableProxy(Handle<String> name, |
62 bool is_this, | 62 bool is_this, |
63 bool inside_with) | 63 bool inside_with) |
64 : name_(name), | 64 : name_(name), |
65 var_(NULL), | 65 var_(NULL), |
66 is_this_(is_this), | 66 is_this_(is_this), |
67 inside_with_(inside_with) { | 67 inside_with_(inside_with) { |
68 // names must be canonicalized for fast equality checks | 68 // names must be canonicalized for fast equality checks |
69 ASSERT(name->IsSymbol()); | 69 ASSERT(name->IsSymbol()); |
70 // at least one access, otherwise no need for a VariableProxy | |
71 var_uses_.RecordRead(1); | |
72 } | 70 } |
73 | 71 |
74 | 72 |
75 VariableProxy::VariableProxy(bool is_this) | 73 VariableProxy::VariableProxy(bool is_this) |
76 : is_this_(is_this) { | 74 : is_this_(is_this) { |
77 } | 75 } |
78 | 76 |
79 | 77 |
80 void VariableProxy::BindTo(Variable* var) { | 78 void VariableProxy::BindTo(Variable* var) { |
81 ASSERT(var_ == NULL); // must be bound only once | 79 ASSERT(var_ == NULL); // must be bound only once |
82 ASSERT(var != NULL); // must bind | 80 ASSERT(var != NULL); // must bind |
83 ASSERT((is_this() && var->is_this()) || name_.is_identical_to(var->name())); | 81 ASSERT((is_this() && var->is_this()) || name_.is_identical_to(var->name())); |
84 // Ideally CONST-ness should match. However, this is very hard to achieve | 82 // Ideally CONST-ness should match. However, this is very hard to achieve |
85 // because we don't know the exact semantics of conflicting (const and | 83 // because we don't know the exact semantics of conflicting (const and |
86 // non-const) multiple variable declarations, const vars introduced via | 84 // non-const) multiple variable declarations, const vars introduced via |
87 // eval() etc. Const-ness and variable declarations are a complete mess | 85 // eval() etc. Const-ness and variable declarations are a complete mess |
88 // in JS. Sigh... | 86 // in JS. Sigh... |
89 var_ = var; | 87 var_ = var; |
90 var->var_uses()->RecordUses(&var_uses_); | 88 var->set_is_used(true); |
91 var->obj_uses()->RecordUses(&obj_uses_); | |
92 } | 89 } |
93 | 90 |
94 | 91 |
95 Token::Value Assignment::binary_op() const { | 92 Token::Value Assignment::binary_op() const { |
96 switch (op_) { | 93 switch (op_) { |
97 case Token::ASSIGN_BIT_OR: return Token::BIT_OR; | 94 case Token::ASSIGN_BIT_OR: return Token::BIT_OR; |
98 case Token::ASSIGN_BIT_XOR: return Token::BIT_XOR; | 95 case Token::ASSIGN_BIT_XOR: return Token::BIT_XOR; |
99 case Token::ASSIGN_BIT_AND: return Token::BIT_AND; | 96 case Token::ASSIGN_BIT_AND: return Token::BIT_AND; |
100 case Token::ASSIGN_SHL: return Token::SHL; | 97 case Token::ASSIGN_SHL: return Token::SHL; |
101 case Token::ASSIGN_SAR: return Token::SAR; | 98 case Token::ASSIGN_SAR: return Token::SAR; |
(...skipping 380 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
482 if (kInfinity - max_match_ < node_max_match) { | 479 if (kInfinity - max_match_ < node_max_match) { |
483 max_match_ = kInfinity; | 480 max_match_ = kInfinity; |
484 } else { | 481 } else { |
485 max_match_ += node->max_match(); | 482 max_match_ += node->max_match(); |
486 } | 483 } |
487 } | 484 } |
488 } | 485 } |
489 | 486 |
490 | 487 |
491 } } // namespace v8::internal | 488 } } // namespace v8::internal |
OLD | NEW |