Revert r1969 because of test failures.
git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@1973 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
f9790085ed
commit
d34f51df8d
@ -104,7 +104,7 @@ void JumpTarget::ComputeEntryFrame(int mergable_elements) {
|
|||||||
// A list of pointers to frame elements in the entry frame. NULL
|
// A list of pointers to frame elements in the entry frame. NULL
|
||||||
// indicates that the element has not yet been determined.
|
// indicates that the element has not yet been determined.
|
||||||
int length = initial_frame->elements_.length();
|
int length = initial_frame->elements_.length();
|
||||||
ZoneList<FrameElement*> elements(length);
|
List<FrameElement*> elements(length);
|
||||||
|
|
||||||
// Convert the number of mergable elements (counted from the top
|
// Convert the number of mergable elements (counted from the top
|
||||||
// down) to a frame high-water mark (counted from the bottom up).
|
// down) to a frame high-water mark (counted from the bottom up).
|
||||||
|
134
src/parser.cc
134
src/parser.cc
@ -42,50 +42,9 @@ namespace v8 { namespace internal {
|
|||||||
class ParserFactory;
|
class ParserFactory;
|
||||||
class ParserLog;
|
class ParserLog;
|
||||||
class TemporaryScope;
|
class TemporaryScope;
|
||||||
class Target;
|
|
||||||
|
|
||||||
template <typename T> class ZoneListWrapper;
|
template <typename T> class ZoneListWrapper;
|
||||||
|
|
||||||
|
|
||||||
// PositionStack is used for on-stack allocation of token positions for
|
|
||||||
// new expressions. Please look at ParseNewExpression.
|
|
||||||
|
|
||||||
class PositionStack {
|
|
||||||
public:
|
|
||||||
PositionStack() : top_(NULL) {}
|
|
||||||
~PositionStack() { ASSERT(is_empty()); }
|
|
||||||
|
|
||||||
class Element {
|
|
||||||
public:
|
|
||||||
Element(PositionStack* stack, int value) {
|
|
||||||
previous_ = stack->top();
|
|
||||||
value_ = value;
|
|
||||||
stack->set_top(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Element* previous() { return previous_; }
|
|
||||||
int value() { return value_; }
|
|
||||||
friend class PositionStack;
|
|
||||||
Element* previous_;
|
|
||||||
int value_;
|
|
||||||
};
|
|
||||||
|
|
||||||
bool is_empty() { return top_ == NULL; }
|
|
||||||
int pop() {
|
|
||||||
ASSERT(!is_empty());
|
|
||||||
int result = top_->value();
|
|
||||||
top_ = top_->previous();
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Element* top() { return top_; }
|
|
||||||
void set_top(Element* value) { top_ = value; }
|
|
||||||
Element* top_;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class Parser {
|
class Parser {
|
||||||
public:
|
public:
|
||||||
Parser(Handle<Script> script, bool allow_natives_syntax,
|
Parser(Handle<Script> script, bool allow_natives_syntax,
|
||||||
@ -134,8 +93,7 @@ class Parser {
|
|||||||
|
|
||||||
TemporaryScope* temp_scope_;
|
TemporaryScope* temp_scope_;
|
||||||
Mode mode_;
|
Mode mode_;
|
||||||
|
List<Node*>* target_stack_; // for break, continue statements
|
||||||
Target* target_stack_; // for break, continue statements
|
|
||||||
bool allow_natives_syntax_;
|
bool allow_natives_syntax_;
|
||||||
v8::Extension* extension_;
|
v8::Extension* extension_;
|
||||||
ParserFactory* factory_;
|
ParserFactory* factory_;
|
||||||
@ -192,8 +150,7 @@ class Parser {
|
|||||||
Expression* ParseLeftHandSideExpression(bool* ok);
|
Expression* ParseLeftHandSideExpression(bool* ok);
|
||||||
Expression* ParseNewExpression(bool* ok);
|
Expression* ParseNewExpression(bool* ok);
|
||||||
Expression* ParseMemberExpression(bool* ok);
|
Expression* ParseMemberExpression(bool* ok);
|
||||||
Expression* ParseNewPrefix(PositionStack* stack, bool* ok);
|
Expression* ParseMemberWithNewPrefixesExpression(List<int>* new_prefixes,
|
||||||
Expression* ParseMemberWithNewPrefixesExpression(PositionStack* stack,
|
|
||||||
bool* ok);
|
bool* ok);
|
||||||
Expression* ParsePrimaryExpression(bool* ok);
|
Expression* ParsePrimaryExpression(bool* ok);
|
||||||
Expression* ParseArrayLiteral(bool* ok);
|
Expression* ParseArrayLiteral(bool* ok);
|
||||||
@ -251,7 +208,7 @@ class Parser {
|
|||||||
BreakableStatement* LookupBreakTarget(Handle<String> label, bool* ok);
|
BreakableStatement* LookupBreakTarget(Handle<String> label, bool* ok);
|
||||||
IterationStatement* LookupContinueTarget(Handle<String> label, bool* ok);
|
IterationStatement* LookupContinueTarget(Handle<String> label, bool* ok);
|
||||||
|
|
||||||
void RegisterTargetUse(BreakTarget* target, Target* stop);
|
void RegisterTargetUse(BreakTarget* target, int index);
|
||||||
|
|
||||||
// Create a number literal.
|
// Create a number literal.
|
||||||
Literal* NewNumberLiteral(double value);
|
Literal* NewNumberLiteral(double value);
|
||||||
@ -1014,39 +971,35 @@ VariableProxy* PreParser::Declare(Handle<String> name, Variable::Mode mode,
|
|||||||
|
|
||||||
class Target BASE_EMBEDDED {
|
class Target BASE_EMBEDDED {
|
||||||
public:
|
public:
|
||||||
Target(Parser* parser, Node* node)
|
Target(Parser* parser, Node* node) : parser_(parser) {
|
||||||
: parser_(parser), node_(node), previous_(parser_->target_stack_) {
|
parser_->target_stack_->Add(node);
|
||||||
parser_->target_stack_ = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
~Target() {
|
~Target() {
|
||||||
parser_->target_stack_ = previous_;
|
parser_->target_stack_->RemoveLast();
|
||||||
}
|
}
|
||||||
|
|
||||||
Target* previous() { return previous_; }
|
|
||||||
Node* node() { return node_; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Parser* parser_;
|
Parser* parser_;
|
||||||
Node* node_;
|
|
||||||
Target* previous_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class TargetScope BASE_EMBEDDED {
|
class TargetScope BASE_EMBEDDED {
|
||||||
public:
|
public:
|
||||||
explicit TargetScope(Parser* parser)
|
explicit TargetScope(Parser* parser)
|
||||||
: parser_(parser), previous_(parser->target_stack_) {
|
: parser_(parser), previous_(parser->target_stack_), stack_(0) {
|
||||||
parser->target_stack_ = NULL;
|
parser_->target_stack_ = &stack_;
|
||||||
}
|
}
|
||||||
|
|
||||||
~TargetScope() {
|
~TargetScope() {
|
||||||
|
ASSERT(stack_.is_empty());
|
||||||
parser_->target_stack_ = previous_;
|
parser_->target_stack_ = previous_;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Parser* parser_;
|
Parser* parser_;
|
||||||
Target* previous_;
|
List<Node*>* previous_;
|
||||||
|
List<Node*> stack_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -2839,8 +2792,7 @@ Expression* Parser::ParseLeftHandSideExpression(bool* ok) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Expression* Parser::ParseNewExpression(bool* ok) {
|
||||||
Expression* Parser::ParseNewPrefix(PositionStack* stack, bool* ok) {
|
|
||||||
// NewExpression ::
|
// NewExpression ::
|
||||||
// ('new')+ MemberExpression
|
// ('new')+ MemberExpression
|
||||||
|
|
||||||
@ -2852,37 +2804,32 @@ Expression* Parser::ParseNewPrefix(PositionStack* stack, bool* ok) {
|
|||||||
// many we have parsed. This information is then passed on to the
|
// many we have parsed. This information is then passed on to the
|
||||||
// member expression parser, which is only allowed to match argument
|
// member expression parser, which is only allowed to match argument
|
||||||
// lists as long as it has 'new' prefixes left
|
// lists as long as it has 'new' prefixes left
|
||||||
Expect(Token::NEW, CHECK_OK);
|
List<int> new_positions(4);
|
||||||
PositionStack::Element pos(stack, scanner().location().beg_pos);
|
while (peek() == Token::NEW) {
|
||||||
|
Consume(Token::NEW);
|
||||||
Expression* result;
|
new_positions.Add(scanner().location().beg_pos);
|
||||||
if (peek() == Token::NEW) {
|
|
||||||
result = ParseNewPrefix(stack, CHECK_OK);
|
|
||||||
} else {
|
|
||||||
result = ParseMemberWithNewPrefixesExpression(stack, CHECK_OK);
|
|
||||||
}
|
}
|
||||||
|
ASSERT(new_positions.length() > 0);
|
||||||
|
|
||||||
if (!stack->is_empty()) {
|
Expression* result =
|
||||||
int last = stack->pop();
|
ParseMemberWithNewPrefixesExpression(&new_positions, CHECK_OK);
|
||||||
|
while (!new_positions.is_empty()) {
|
||||||
|
int last = new_positions.RemoveLast();
|
||||||
result = NEW(CallNew(result, new ZoneList<Expression*>(0), last));
|
result = NEW(CallNew(result, new ZoneList<Expression*>(0), last));
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Expression* Parser::ParseNewExpression(bool* ok) {
|
|
||||||
PositionStack stack;
|
|
||||||
return ParseNewPrefix(&stack, ok);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
Expression* Parser::ParseMemberExpression(bool* ok) {
|
Expression* Parser::ParseMemberExpression(bool* ok) {
|
||||||
return ParseMemberWithNewPrefixesExpression(NULL, ok);
|
static List<int> new_positions(0);
|
||||||
|
return ParseMemberWithNewPrefixesExpression(&new_positions, ok);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Expression* Parser::ParseMemberWithNewPrefixesExpression(PositionStack* stack,
|
Expression* Parser::ParseMemberWithNewPrefixesExpression(
|
||||||
bool* ok) {
|
List<int>* new_positions,
|
||||||
|
bool* ok) {
|
||||||
// MemberExpression ::
|
// MemberExpression ::
|
||||||
// (PrimaryExpression | FunctionLiteral)
|
// (PrimaryExpression | FunctionLiteral)
|
||||||
// ('[' Expression ']' | '.' Identifier | Arguments)*
|
// ('[' Expression ']' | '.' Identifier | Arguments)*
|
||||||
@ -2918,10 +2865,10 @@ Expression* Parser::ParseMemberWithNewPrefixesExpression(PositionStack* stack,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case Token::LPAREN: {
|
case Token::LPAREN: {
|
||||||
if ((stack == NULL) || stack->is_empty()) return result;
|
if (new_positions->is_empty()) return result;
|
||||||
// Consume one of the new prefixes (already parsed).
|
// Consume one of the new prefixes (already parsed).
|
||||||
ZoneList<Expression*>* args = ParseArguments(CHECK_OK);
|
ZoneList<Expression*>* args = ParseArguments(CHECK_OK);
|
||||||
int last = stack->pop();
|
int last = new_positions->RemoveLast();
|
||||||
result = NEW(CallNew(result, args, last));
|
result = NEW(CallNew(result, args, last));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -3601,8 +3548,8 @@ Handle<String> Parser::ParseIdentifierOrGetOrSet(bool* is_get,
|
|||||||
|
|
||||||
|
|
||||||
bool Parser::TargetStackContainsLabel(Handle<String> label) {
|
bool Parser::TargetStackContainsLabel(Handle<String> label) {
|
||||||
for (Target* t = target_stack_; t != NULL; t = t->previous()) {
|
for (int i = target_stack_->length(); i-- > 0;) {
|
||||||
BreakableStatement* stat = t->node()->AsBreakableStatement();
|
BreakableStatement* stat = target_stack_->at(i)->AsBreakableStatement();
|
||||||
if (stat != NULL && ContainsLabel(stat->labels(), label))
|
if (stat != NULL && ContainsLabel(stat->labels(), label))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -3612,12 +3559,13 @@ bool Parser::TargetStackContainsLabel(Handle<String> label) {
|
|||||||
|
|
||||||
BreakableStatement* Parser::LookupBreakTarget(Handle<String> label, bool* ok) {
|
BreakableStatement* Parser::LookupBreakTarget(Handle<String> label, bool* ok) {
|
||||||
bool anonymous = label.is_null();
|
bool anonymous = label.is_null();
|
||||||
for (Target* t = target_stack_; t != NULL; t = t->previous()) {
|
for (int i = target_stack_->length(); i-- > 0;) {
|
||||||
BreakableStatement* stat = t->node()->AsBreakableStatement();
|
BreakableStatement* stat = target_stack_->at(i)->AsBreakableStatement();
|
||||||
if (stat == NULL) continue;
|
if (stat == NULL) continue;
|
||||||
|
|
||||||
if ((anonymous && stat->is_target_for_anonymous()) ||
|
if ((anonymous && stat->is_target_for_anonymous()) ||
|
||||||
(!anonymous && ContainsLabel(stat->labels(), label))) {
|
(!anonymous && ContainsLabel(stat->labels(), label))) {
|
||||||
RegisterTargetUse(stat->break_target(), t->previous());
|
RegisterTargetUse(stat->break_target(), i);
|
||||||
return stat;
|
return stat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3628,13 +3576,13 @@ BreakableStatement* Parser::LookupBreakTarget(Handle<String> label, bool* ok) {
|
|||||||
IterationStatement* Parser::LookupContinueTarget(Handle<String> label,
|
IterationStatement* Parser::LookupContinueTarget(Handle<String> label,
|
||||||
bool* ok) {
|
bool* ok) {
|
||||||
bool anonymous = label.is_null();
|
bool anonymous = label.is_null();
|
||||||
for (Target* t = target_stack_; t != NULL; t = t->previous()) {
|
for (int i = target_stack_->length(); i-- > 0;) {
|
||||||
IterationStatement* stat = t->node()->AsIterationStatement();
|
IterationStatement* stat = target_stack_->at(i)->AsIterationStatement();
|
||||||
if (stat == NULL) continue;
|
if (stat == NULL) continue;
|
||||||
|
|
||||||
ASSERT(stat->is_target_for_anonymous());
|
ASSERT(stat->is_target_for_anonymous());
|
||||||
if (anonymous || ContainsLabel(stat->labels(), label)) {
|
if (anonymous || ContainsLabel(stat->labels(), label)) {
|
||||||
RegisterTargetUse(stat->continue_target(), t->previous());
|
RegisterTargetUse(stat->continue_target(), i);
|
||||||
return stat;
|
return stat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3642,12 +3590,12 @@ IterationStatement* Parser::LookupContinueTarget(Handle<String> label,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Parser::RegisterTargetUse(BreakTarget* target, Target* stop) {
|
void Parser::RegisterTargetUse(BreakTarget* target, int index) {
|
||||||
// Register that a break target found at the given stop in the
|
// Register that a break target found at the given index in the
|
||||||
// target stack has been used from the top of the target stack. Add
|
// target stack has been used from the top of the target stack. Add
|
||||||
// the break target to any TargetCollectors passed on the stack.
|
// the break target to any TargetCollectors passed on the stack.
|
||||||
for (Target* t = target_stack_; t != stop; t = t->previous()) {
|
for (int i = target_stack_->length(); i-- > index;) {
|
||||||
TargetCollector* collector = t->node()->AsTargetCollector();
|
TargetCollector* collector = target_stack_->at(i)->AsTargetCollector();
|
||||||
if (collector != NULL) collector->AddTarget(target);
|
if (collector != NULL) collector->AddTarget(target);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user