Bug 891215 (part 5) - Remove Parser-inl.h. r=terrence.

--HG--
extra : rebase_source : c511369509fdeb8d28c5e0df0970d342b34bb01e
This commit is contained in:
Nicholas Nethercote 2013-07-08 20:43:11 -07:00
parent c842453d5a
commit 4b7191bfe3
5 changed files with 55 additions and 136 deletions

View File

@ -17,7 +17,6 @@
#include "jsscriptinlines.h"
#include "frontend/ParseMaps-inl.h"
#include "frontend/Parser-inl.h"
#include "frontend/SharedContext-inl.h"
#include "vm/ScopeObject-inl.h"

View File

@ -8,8 +8,6 @@
#include "frontend/ParseNode.h"
#include "frontend/Parser.h"
#include "frontend/Parser-inl.h"
using namespace js;
using namespace js::frontend;

View File

@ -1,121 +0,0 @@
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
* vim: set ts=8 sts=4 et sw=4 tw=99:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef frontend_Parser_inl
#define frontend_Parser_inl
#include "frontend/BytecodeCompiler.h"
#include "frontend/Parser.h"
#include "frontend/SharedContext-inl.h"
namespace js {
namespace frontend {
template <typename ParseHandler>
inline unsigned
ParseContext<ParseHandler>::blockid()
{
return topStmt ? topStmt->blockid : bodyid;
}
template <typename ParseHandler>
inline bool
ParseContext<ParseHandler>::atBodyLevel()
{
return !topStmt;
}
inline
GenericParseContext::GenericParseContext(GenericParseContext *parent, SharedContext *sc)
: parent(parent),
sc(sc),
funHasReturnExpr(false),
funHasReturnVoid(false),
parsingForInit(false),
parsingWith(parent ? parent->parsingWith : false)
{
}
template <typename ParseHandler>
inline
ParseContext<ParseHandler>::ParseContext(Parser<ParseHandler> *prs,
GenericParseContext *parent, SharedContext *sc,
unsigned staticLevel, uint32_t bodyid)
: GenericParseContext(parent, sc),
bodyid(0), // initialized in init()
blockidGen(bodyid), // used to set |bodyid| and subsequently incremented in init()
topStmt(NULL),
topScopeStmt(NULL),
blockChain(prs->context),
staticLevel(staticLevel),
parenDepth(0),
yieldCount(0),
blockNode(ParseHandler::null()),
decls_(prs->context),
args_(prs->context),
vars_(prs->context),
yieldOffset(0),
parserPC(&prs->pc),
oldpc(prs->pc),
lexdeps(prs->context),
funcStmts(NULL),
innerFunctions(prs->context),
inDeclDestructuring(false),
funBecameStrict(false)
{
prs->pc = this;
}
template <typename ParseHandler>
inline bool
ParseContext<ParseHandler>::init()
{
if (!frontend::GenerateBlockId(this, this->bodyid))
return false;
return decls_.init() && lexdeps.ensureMap(sc->context);
}
template <typename ParseHandler>
inline
ParseContext<ParseHandler>::~ParseContext()
{
// |*parserPC| pointed to this object. Now that this object is about to
// die, make |*parserPC| point to this object's parent.
JS_ASSERT(*parserPC == this);
*parserPC = this->oldpc;
js_delete(funcStmts);
}
/*
* Check that it is permitted to introduce a binding for atom. Strict mode
* forbids introducing new definitions for 'eval', 'arguments', or for any
* strict mode reserved keyword. Use pn for reporting error locations, or use
* pc's token stream if pn is NULL.
*/
template <typename ParseHandler>
static bool
CheckStrictBinding(JSContext *cx, ParseHandler *handler, ParseContext<ParseHandler> *pc,
HandlePropertyName name, ParseNode *pn)
{
if (!pc->sc->needStrictChecks())
return true;
if (name == cx->names().eval || name == cx->names().arguments || IsKeyword(name)) {
JSAutoByteString bytes;
if (!js_AtomToPrintableString(cx, name, &bytes))
return false;
return handler->report(ParseStrictError, pn, JSMSG_BAD_BINDING, bytes.ptr());
}
return true;
}
} // namespace frontend
} // namespace js
#endif /* frontend_Parser_inl */

View File

@ -42,7 +42,6 @@
#include "frontend/ParseMaps-inl.h"
#include "frontend/ParseNode-inl.h"
#include "frontend/Parser-inl.h"
#include "frontend/SharedContext-inl.h"
#include "vm/NumericConversions.h"

View File

@ -64,9 +64,20 @@ struct GenericParseContext
// chain (which stops at the top-level or an eval()
bool parsingWith:1;
inline GenericParseContext(GenericParseContext *parent, SharedContext *sc);
GenericParseContext(GenericParseContext *parent, SharedContext *sc)
: parent(parent),
sc(sc),
funHasReturnExpr(false),
funHasReturnVoid(false),
parsingForInit(false),
parsingWith(parent ? parent->parsingWith : false)
{}
};
template <typename ParseHandler>
bool
GenerateBlockId(ParseContext<ParseHandler> *pc, uint32_t &blockid);
/*
* The struct ParseContext stores information about the current parsing context,
* which is part of the parser state (see the field Parser::pc). The current
@ -217,14 +228,51 @@ struct ParseContext : public GenericParseContext
// strict before.
bool funBecameStrict:1;
inline ParseContext(Parser<ParseHandler> *prs, GenericParseContext *parent,
SharedContext *sc, unsigned staticLevel, uint32_t bodyid);
inline ~ParseContext();
ParseContext(Parser<ParseHandler> *prs, GenericParseContext *parent,
SharedContext *sc, unsigned staticLevel, uint32_t bodyid)
: GenericParseContext(parent, sc),
bodyid(0), // initialized in init()
blockidGen(bodyid), // used to set |bodyid| and subsequently incremented in init()
topStmt(NULL),
topScopeStmt(NULL),
blockChain(prs->context),
staticLevel(staticLevel),
parenDepth(0),
yieldCount(0),
blockNode(ParseHandler::null()),
decls_(prs->context),
args_(prs->context),
vars_(prs->context),
yieldOffset(0),
parserPC(&prs->pc),
oldpc(prs->pc),
lexdeps(prs->context),
funcStmts(NULL),
innerFunctions(prs->context),
inDeclDestructuring(false),
funBecameStrict(false)
{
prs->pc = this;
}
inline bool init();
~ParseContext() {
// |*parserPC| pointed to this object. Now that this object is about to
// die, make |*parserPC| point to this object's parent.
JS_ASSERT(*parserPC == this);
*parserPC = this->oldpc;
js_delete(funcStmts);
}
inline bool init()
{
if (!frontend::GenerateBlockId(this, this->bodyid))
return false;
return decls_.init() && lexdeps.ensureMap(sc->context);
}
InBlockBool inBlock() const { return InBlockBool(!topStmt || topStmt->type == STMT_BLOCK); }
unsigned blockid();
unsigned blockid() { return topStmt ? topStmt->blockid : bodyid; }
// True if we are at the topmost level of a entire script or function body.
// For example, while parsing this code we would encounter f1 and f2 at
@ -233,17 +281,13 @@ struct ParseContext : public GenericParseContext
// function f1() { function f2() { } }
// if (cond) { function f3() { if (cond) { function f4() { } } } }
//
bool atBodyLevel();
bool atBodyLevel() { return !topStmt; }
inline bool useAsmOrInsideUseAsm() const {
return sc->isFunctionBox() && sc->asFunctionBox()->useAsmOrInsideUseAsm();
}
};
template <typename ParseHandler>
bool
GenerateBlockId(ParseContext<ParseHandler> *pc, uint32_t &blockid);
template <typename ParseHandler>
struct BindData;