OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 216 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
227 // --------------------------------------------------------------------------- | 227 // --------------------------------------------------------------------------- |
228 // Scope-specific info. | 228 // Scope-specific info. |
229 | 229 |
230 // Inform the scope that the corresponding code contains a with statement. | 230 // Inform the scope that the corresponding code contains a with statement. |
231 void RecordWithStatement() { scope_contains_with_ = true; } | 231 void RecordWithStatement() { scope_contains_with_ = true; } |
232 | 232 |
233 // Inform the scope that the corresponding code contains an eval call. | 233 // Inform the scope that the corresponding code contains an eval call. |
234 void RecordEvalCall() { if (!is_global_scope()) scope_calls_eval_ = true; } | 234 void RecordEvalCall() { if (!is_global_scope()) scope_calls_eval_ = true; } |
235 | 235 |
236 // Set the strict mode flag (unless disabled by a global flag). | 236 // Set the strict mode flag (unless disabled by a global flag). |
237 void SetLanguageMode(LanguageMode language_mode) { | 237 void SetStrictMode(StrictMode strict_mode) { strict_mode_ = strict_mode; } |
238 language_mode_ = language_mode; | |
239 } | |
240 | 238 |
241 // Position in the source where this scope begins and ends. | 239 // Position in the source where this scope begins and ends. |
242 // | 240 // |
243 // * For the scope of a with statement | 241 // * For the scope of a with statement |
244 // with (obj) stmt | 242 // with (obj) stmt |
245 // start position: start position of first token of 'stmt' | 243 // start position: start position of first token of 'stmt' |
246 // end position: end position of last token of 'stmt' | 244 // end position: end position of last token of 'stmt' |
247 // * For the scope of a block | 245 // * For the scope of a block |
248 // { stmts } | 246 // { stmts } |
249 // start position: start position of '{' | 247 // start position: start position of '{' |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
286 bool is_function_scope() const { return scope_type_ == FUNCTION_SCOPE; } | 284 bool is_function_scope() const { return scope_type_ == FUNCTION_SCOPE; } |
287 bool is_module_scope() const { return scope_type_ == MODULE_SCOPE; } | 285 bool is_module_scope() const { return scope_type_ == MODULE_SCOPE; } |
288 bool is_global_scope() const { return scope_type_ == GLOBAL_SCOPE; } | 286 bool is_global_scope() const { return scope_type_ == GLOBAL_SCOPE; } |
289 bool is_catch_scope() const { return scope_type_ == CATCH_SCOPE; } | 287 bool is_catch_scope() const { return scope_type_ == CATCH_SCOPE; } |
290 bool is_block_scope() const { return scope_type_ == BLOCK_SCOPE; } | 288 bool is_block_scope() const { return scope_type_ == BLOCK_SCOPE; } |
291 bool is_with_scope() const { return scope_type_ == WITH_SCOPE; } | 289 bool is_with_scope() const { return scope_type_ == WITH_SCOPE; } |
292 bool is_declaration_scope() const { | 290 bool is_declaration_scope() const { |
293 return is_eval_scope() || is_function_scope() || | 291 return is_eval_scope() || is_function_scope() || |
294 is_module_scope() || is_global_scope(); | 292 is_module_scope() || is_global_scope(); |
295 } | 293 } |
296 bool is_sloppy_mode() const { | 294 bool is_strict_eval_scope() const { |
297 return language_mode() == SLOPPY_MODE; | 295 return is_eval_scope() && strict_mode_ == STRICT; |
298 } | |
299 bool is_extended_mode() const { | |
300 return language_mode() == EXTENDED_MODE; | |
301 } | |
302 bool is_strict_or_extended_eval_scope() const { | |
303 return is_eval_scope() && !is_sloppy_mode(); | |
304 } | 296 } |
305 | 297 |
306 // Information about which scopes calls eval. | 298 // Information about which scopes calls eval. |
307 bool calls_eval() const { return scope_calls_eval_; } | 299 bool calls_eval() const { return scope_calls_eval_; } |
308 bool calls_sloppy_eval() { return scope_calls_eval_ && is_sloppy_mode(); } | 300 bool calls_sloppy_eval() { |
| 301 return scope_calls_eval_ && strict_mode_ == SLOPPY; |
| 302 } |
309 bool outer_scope_calls_sloppy_eval() const { | 303 bool outer_scope_calls_sloppy_eval() const { |
310 return outer_scope_calls_sloppy_eval_; | 304 return outer_scope_calls_sloppy_eval_; |
311 } | 305 } |
312 | 306 |
313 // Is this scope inside a with statement. | 307 // Is this scope inside a with statement. |
314 bool inside_with() const { return scope_inside_with_; } | 308 bool inside_with() const { return scope_inside_with_; } |
315 // Does this scope contain a with statement. | 309 // Does this scope contain a with statement. |
316 bool contains_with() const { return scope_contains_with_; } | 310 bool contains_with() const { return scope_contains_with_; } |
317 | 311 |
318 // --------------------------------------------------------------------------- | 312 // --------------------------------------------------------------------------- |
319 // Accessors. | 313 // Accessors. |
320 | 314 |
321 // The type of this scope. | 315 // The type of this scope. |
322 ScopeType scope_type() const { return scope_type_; } | 316 ScopeType scope_type() const { return scope_type_; } |
323 | 317 |
324 // The language mode of this scope. | 318 // The language mode of this scope. |
325 LanguageMode language_mode() const { return language_mode_; } | 319 StrictMode strict_mode() const { return strict_mode_; } |
326 | 320 |
327 // The variable corresponding the 'this' value. | 321 // The variable corresponding the 'this' value. |
328 Variable* receiver() { return receiver_; } | 322 Variable* receiver() { return receiver_; } |
329 | 323 |
330 // The variable holding the function literal for named function | 324 // The variable holding the function literal for named function |
331 // literals, or NULL. Only valid for function scopes. | 325 // literals, or NULL. Only valid for function scopes. |
332 VariableDeclaration* function() const { | 326 VariableDeclaration* function() const { |
333 ASSERT(is_function_scope()); | 327 ASSERT(is_function_scope()); |
334 return function_; | 328 return function_; |
335 } | 329 } |
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
484 | 478 |
485 // Scope-specific information computed during parsing. | 479 // Scope-specific information computed during parsing. |
486 // | 480 // |
487 // This scope is inside a 'with' of some outer scope. | 481 // This scope is inside a 'with' of some outer scope. |
488 bool scope_inside_with_; | 482 bool scope_inside_with_; |
489 // This scope contains a 'with' statement. | 483 // This scope contains a 'with' statement. |
490 bool scope_contains_with_; | 484 bool scope_contains_with_; |
491 // This scope or a nested catch scope or with scope contain an 'eval' call. At | 485 // This scope or a nested catch scope or with scope contain an 'eval' call. At |
492 // the 'eval' call site this scope is the declaration scope. | 486 // the 'eval' call site this scope is the declaration scope. |
493 bool scope_calls_eval_; | 487 bool scope_calls_eval_; |
494 // The language mode of this scope. | 488 // The strict mode of this scope. |
495 LanguageMode language_mode_; | 489 StrictMode strict_mode_; |
496 // Source positions. | 490 // Source positions. |
497 int start_position_; | 491 int start_position_; |
498 int end_position_; | 492 int end_position_; |
499 | 493 |
500 // Computed via PropagateScopeInfo. | 494 // Computed via PropagateScopeInfo. |
501 bool outer_scope_calls_sloppy_eval_; | 495 bool outer_scope_calls_sloppy_eval_; |
502 bool inner_scope_calls_eval_; | 496 bool inner_scope_calls_eval_; |
503 bool force_eager_compilation_; | 497 bool force_eager_compilation_; |
504 bool force_context_allocation_; | 498 bool force_context_allocation_; |
505 | 499 |
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
636 void SetDefaults(ScopeType type, | 630 void SetDefaults(ScopeType type, |
637 Scope* outer_scope, | 631 Scope* outer_scope, |
638 Handle<ScopeInfo> scope_info); | 632 Handle<ScopeInfo> scope_info); |
639 | 633 |
640 Zone* zone_; | 634 Zone* zone_; |
641 }; | 635 }; |
642 | 636 |
643 } } // namespace v8::internal | 637 } } // namespace v8::internal |
644 | 638 |
645 #endif // V8_SCOPES_H_ | 639 #endif // V8_SCOPES_H_ |
OLD | NEW |