| 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 2468 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 2479   if (tok == Token::CATCH) { | 2479   if (tok == Token::CATCH) { | 
| 2480     Consume(Token::CATCH); | 2480     Consume(Token::CATCH); | 
| 2481 | 2481 | 
| 2482     Expect(Token::LPAREN, CHECK_OK); | 2482     Expect(Token::LPAREN, CHECK_OK); | 
| 2483     catch_scope = NewScope(top_scope_, CATCH_SCOPE); | 2483     catch_scope = NewScope(top_scope_, CATCH_SCOPE); | 
| 2484     catch_scope->set_start_position(scanner().location().beg_pos); | 2484     catch_scope->set_start_position(scanner().location().beg_pos); | 
| 2485     name = ParseIdentifier(kDontAllowEvalOrArguments, CHECK_OK); | 2485     name = ParseIdentifier(kDontAllowEvalOrArguments, CHECK_OK); | 
| 2486 | 2486 | 
| 2487     Expect(Token::RPAREN, CHECK_OK); | 2487     Expect(Token::RPAREN, CHECK_OK); | 
| 2488 | 2488 | 
| 2489     if (peek() == Token::LBRACE) { | 2489     Target target(&this->target_stack_, &catch_collector); | 
| 2490       Target target(&this->target_stack_, &catch_collector); | 2490     VariableMode mode = is_extended_mode() ? LET : VAR; | 
| 2491       VariableMode mode = is_extended_mode() ? LET : VAR; | 2491     catch_variable = | 
| 2492       catch_variable = | 2492         catch_scope->DeclareLocal(name, mode, kCreatedInitialized); | 
| 2493           catch_scope->DeclareLocal(name, mode, kCreatedInitialized); |  | 
| 2494 | 2493 | 
| 2495       BlockState block_state(this, catch_scope); | 2494     BlockState block_state(this, catch_scope); | 
| 2496       catch_block = ParseBlock(NULL, CHECK_OK); | 2495     catch_block = ParseBlock(NULL, CHECK_OK); | 
| 2497     } else { | 2496 | 
| 2498       Expect(Token::LBRACE, CHECK_OK); |  | 
| 2499     } |  | 
| 2500     catch_scope->set_end_position(scanner().location().end_pos); | 2497     catch_scope->set_end_position(scanner().location().end_pos); | 
| 2501     tok = peek(); | 2498     tok = peek(); | 
| 2502   } | 2499   } | 
| 2503 | 2500 | 
| 2504   Block* finally_block = NULL; | 2501   Block* finally_block = NULL; | 
| 2505   if (tok == Token::FINALLY || catch_block == NULL) { | 2502   ASSERT(tok == Token::FINALLY || catch_block != NULL); | 
|  | 2503   if (tok == Token::FINALLY) { | 
| 2506     Consume(Token::FINALLY); | 2504     Consume(Token::FINALLY); | 
| 2507     finally_block = ParseBlock(NULL, CHECK_OK); | 2505     finally_block = ParseBlock(NULL, CHECK_OK); | 
| 2508   } | 2506   } | 
| 2509 | 2507 | 
| 2510   // Simplify the AST nodes by converting: | 2508   // Simplify the AST nodes by converting: | 
| 2511   //   'try B0 catch B1 finally B2' | 2509   //   'try B0 catch B1 finally B2' | 
| 2512   // to: | 2510   // to: | 
| 2513   //   'try { try B0 catch B1 } finally B2' | 2511   //   'try { try B0 catch B1 } finally B2' | 
| 2514 | 2512 | 
| 2515   if (catch_block != NULL && finally_block != NULL) { | 2513   if (catch_block != NULL && finally_block != NULL) { | 
| (...skipping 3178 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 5694       ASSERT(info()->isolate()->has_pending_exception()); | 5692       ASSERT(info()->isolate()->has_pending_exception()); | 
| 5695     } else { | 5693     } else { | 
| 5696       result = ParseProgram(); | 5694       result = ParseProgram(); | 
| 5697     } | 5695     } | 
| 5698   } | 5696   } | 
| 5699   info()->SetFunction(result); | 5697   info()->SetFunction(result); | 
| 5700   return (result != NULL); | 5698   return (result != NULL); | 
| 5701 } | 5699 } | 
| 5702 | 5700 | 
| 5703 } }  // namespace v8::internal | 5701 } }  // namespace v8::internal | 
| OLD | NEW | 
|---|