Author: [EMAIL PROTECTED] Date: Mon Sep 8 00:58:54 2008 New Revision: 195
Added: branches/bleeding_edge/test/mjsunit/regress/regress-35.js Modified: branches/bleeding_edge/AUTHORS branches/bleeding_edge/src/parser.cc Log: Fix issue 35 by applying patch by Daniel James. Modified: branches/bleeding_edge/AUTHORS ============================================================================== --- branches/bleeding_edge/AUTHORS (original) +++ branches/bleeding_edge/AUTHORS Mon Sep 8 00:58:54 2008 @@ -8,3 +8,4 @@ Rene Rebe <[EMAIL PROTECTED]> Rafal Krypa <[EMAIL PROTECTED]> Jay Freeman <[EMAIL PROTECTED]> +Daniel James <[EMAIL PROTECTED]> Modified: branches/bleeding_edge/src/parser.cc ============================================================================== --- branches/bleeding_edge/src/parser.cc (original) +++ branches/bleeding_edge/src/parser.cc Mon Sep 8 00:58:54 2008 @@ -1484,7 +1484,7 @@ Handle<String> label(static_cast<String**>(NULL)); Token::Value tok = peek(); if (!scanner_.has_line_terminator_before_next() && - tok != Token::SEMICOLON && tok != Token::RBRACE) { + tok != Token::SEMICOLON && tok != Token::RBRACE && tok != Token::EOS) { label = ParseIdentifier(CHECK_OK); } IterationStatement* target = NULL; @@ -1512,7 +1512,7 @@ Handle<String> label; Token::Value tok = peek(); if (!scanner_.has_line_terminator_before_next() && - tok != Token::SEMICOLON && tok != Token::RBRACE) { + tok != Token::SEMICOLON && tok != Token::RBRACE && tok != Token::EOS) { label = ParseIdentifier(CHECK_OK); } // Parse labelled break statements that target themselves into Added: branches/bleeding_edge/test/mjsunit/regress/regress-35.js ============================================================================== --- (empty file) +++ branches/bleeding_edge/test/mjsunit/regress/regress-35.js Mon Sep 8 00:58:54 2008 @@ -0,0 +1,33 @@ +// Copyright 2008 Google Inc. All Rights Reserved. +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are +// met: +// +// * Redistributions of source code must retain the above copyright +// notice, this list of conditions and the following disclaimer. +// * Redistributions in binary form must reproduce the above +// copyright notice, this list of conditions and the following +// disclaimer in the documentation and/or other materials provided +// with the distribution. +// * Neither the name of Google Inc. nor the names of its +// contributors may be used to endorse or promote products derived +// from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +var result; +eval("result = 42; while(true)break"); +assertEquals(42, result); + +eval("result = 87; while(false)continue"); +assertEquals(87, result); --~--~---------~--~----~------------~-------~--~----~ v8-dev mailing list v8-dev@googlegroups.com http://groups.google.com/group/v8-dev -~----------~----~----~----~------~----~------~--~---