| OLD | NEW | 
|---|
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include <cmath> | 5 #include <cmath> | 
| 6 | 6 | 
| 7 #include "src/allocation.h" | 7 #include "src/allocation.h" | 
| 8 #include "src/base/logging.h" | 8 #include "src/base/logging.h" | 
| 9 #include "src/conversions-inl.h" | 9 #include "src/conversions-inl.h" | 
| 10 #include "src/conversions.h" | 10 #include "src/conversions.h" | 
| (...skipping 210 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 221     InferName infer) { | 221     InferName infer) { | 
| 222   if (track_unresolved_variables_) { | 222   if (track_unresolved_variables_) { | 
| 223     AstNodeFactory factory(ast_value_factory()); | 223     AstNodeFactory factory(ast_value_factory()); | 
| 224     // Setting the Zone is necessary because zone_ might be the temp Zone, and | 224     // Setting the Zone is necessary because zone_ might be the temp Zone, and | 
| 225     // AstValueFactory doesn't know about it. | 225     // AstValueFactory doesn't know about it. | 
| 226     factory.set_zone(zone()); | 226     factory.set_zone(zone()); | 
| 227     DCHECK_NOT_NULL(name.string_); | 227     DCHECK_NOT_NULL(name.string_); | 
| 228     scope()->NewUnresolved(&factory, name.string_, start_position, end_position, | 228     scope()->NewUnresolved(&factory, name.string_, start_position, end_position, | 
| 229                            NORMAL_VARIABLE); | 229                            NORMAL_VARIABLE); | 
| 230   } | 230   } | 
| 231   return PreParserExpression::FromIdentifier(name); | 231   return PreParserExpression::FromIdentifier(name, zone()); | 
| 232 } | 232 } | 
| 233 | 233 | 
| 234 void PreParser::DeclareAndInitializeVariables( | 234 void PreParser::DeclareAndInitializeVariables( | 
| 235     PreParserStatement block, | 235     PreParserStatement block, | 
| 236     const DeclarationDescriptor* declaration_descriptor, | 236     const DeclarationDescriptor* declaration_descriptor, | 
| 237     const DeclarationParsingResult::Declaration* declaration, | 237     const DeclarationParsingResult::Declaration* declaration, | 
| 238     ZoneList<const AstRawString*>* names, bool* ok) { | 238     ZoneList<const AstRawString*>* names, bool* ok) { | 
| 239   if (declaration->pattern.string_) { | 239   if (declaration->pattern.identifiers_ != nullptr) { | 
|  | 240     DCHECK(FLAG_lazy_inner_functions); | 
| 240     /* Mimic what Parser does when declaring variables (see | 241     /* Mimic what Parser does when declaring variables (see | 
| 241        Parser::PatternRewriter::VisitVariableProxy). | 242        Parser::PatternRewriter::VisitVariableProxy). | 
| 242 | 243 | 
| 243        var + no initializer -> RemoveUnresolved | 244        var + no initializer -> RemoveUnresolved | 
| 244        let + no initializer -> RemoveUnresolved | 245        let / const + no initializer -> RemoveUnresolved | 
| 245        var + initializer -> RemoveUnresolved followed by NewUnresolved | 246        var + initializer -> RemoveUnresolved followed by NewUnresolved | 
| 246        let + initializer -> RemoveUnresolved | 247        let / const + initializer -> RemoveUnresolved | 
| 247     */ | 248     */ | 
| 248 | 249 | 
| 249     if (declaration->initializer.IsEmpty() || | 250     if (declaration->initializer.IsEmpty() || | 
| 250         declaration_descriptor->mode == VariableMode::LET) { | 251         (declaration_descriptor->mode == VariableMode::LET || | 
| 251       declaration_descriptor->scope->RemoveUnresolved( | 252          declaration_descriptor->mode == VariableMode::CONST)) { | 
| 252           declaration->pattern.string_); | 253       for (auto identifier : *(declaration->pattern.identifiers_)) { | 
|  | 254         declaration_descriptor->scope->RemoveUnresolved(identifier); | 
|  | 255       } | 
| 253     } | 256     } | 
| 254   } | 257   } | 
| 255 } | 258 } | 
| 256 | 259 | 
| 257 #undef CHECK_OK | 260 #undef CHECK_OK | 
| 258 #undef CHECK_OK_CUSTOM | 261 #undef CHECK_OK_CUSTOM | 
| 259 | 262 | 
| 260 | 263 | 
| 261 }  // namespace internal | 264 }  // namespace internal | 
| 262 }  // namespace v8 | 265 }  // namespace v8 | 
| OLD | NEW | 
|---|