<https://bugs.webkit.org/show_bug.cgi?id=23049> [jsfunfuzz] With blocks do not correc...
[WebKit-https.git] / JavaScriptCore / parser / Parser.cpp
1 /*
2  *  Copyright (C) 1999-2001 Harri Porten (porten@kde.org)
3  *  Copyright (C) 2001 Peter Kelly (pmk@post.com)
4  *  Copyright (C) 2003, 2006, 2007, 2008 Apple Inc. All rights reserved.
5  *
6  *  This library is free software; you can redistribute it and/or
7  *  modify it under the terms of the GNU Library General Public
8  *  License as published by the Free Software Foundation; either
9  *  version 2 of the License, or (at your option) any later version.
10  *
11  *  This library is distributed in the hope that it will be useful,
12  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  *  Library General Public License for more details.
15  *
16  *  You should have received a copy of the GNU Library General Public License
17  *  along with this library; see the file COPYING.LIB.  If not, write to
18  *  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19  *  Boston, MA 02110-1301, USA.
20  *
21  */
22
23 #include "config.h"
24 #include "Parser.h"
25
26 #include "Debugger.h"
27 #include "Lexer.h"
28 #include <wtf/HashSet.h>
29 #include <wtf/Vector.h>
30 #include <memory>
31
32 using std::auto_ptr;
33
34 extern int kjsyyparse(void*);
35
36 namespace JSC {
37
38 void Parser::parse(JSGlobalData* globalData, int* errLine, UString* errMsg)
39 {
40     ASSERT(!m_sourceElements);
41
42     int defaultErrLine;
43     UString defaultErrMsg;
44
45     if (!errLine)
46         errLine = &defaultErrLine;
47     if (!errMsg)
48         errMsg = &defaultErrMsg;
49
50     *errLine = -1;
51     *errMsg = 0;
52
53     Lexer& lexer = *globalData->lexer;
54     lexer.setCode(*m_source);
55
56     int parseError = kjsyyparse(globalData);
57     bool lexError = lexer.sawError();
58     lexer.clear();
59
60     ParserRefCounted::deleteNewObjects(globalData);
61
62     if (parseError || lexError) {
63         *errLine = lexer.lineNo();
64         *errMsg = "Parse error";
65         m_sourceElements.clear();
66     }
67 }
68
69 void Parser::reparse(JSGlobalData* globalData, FunctionBodyNode* functionBodyNode)
70 {
71     ASSERT(!functionBodyNode->data());
72
73     m_source = &functionBodyNode->source();
74     globalData->lexer->setIsReparsing();
75     parse(globalData, 0, 0);
76     ASSERT(m_sourceElements);
77
78     functionBodyNode->adoptData(std::auto_ptr<ScopeNodeData>(new ScopeNodeData(m_sourceElements.get(),
79                                                                                m_varDeclarations ? &m_varDeclarations->data : 0, 
80                                                                                m_funcDeclarations ? &m_funcDeclarations->data : 0,
81                                                                                m_numConstants)));
82     bool usesArguments = functionBodyNode->usesArguments();
83     functionBodyNode->setFeatures(m_features);
84     if (usesArguments && !functionBodyNode->usesArguments())
85         functionBodyNode->setUsesArguments();
86
87     m_source = 0;
88     m_sourceElements = 0;
89     m_varDeclarations = 0;
90     m_funcDeclarations = 0;
91 }
92
93 void Parser::didFinishParsing(SourceElements* sourceElements, ParserRefCountedData<DeclarationStacks::VarStack>* varStack, 
94                               ParserRefCountedData<DeclarationStacks::FunctionStack>* funcStack, CodeFeatures features, int lastLine, int numConstants)
95 {
96     m_sourceElements = sourceElements;
97     m_varDeclarations = varStack;
98     m_funcDeclarations = funcStack;
99     m_features = features;
100     m_lastLine = lastLine;
101     m_numConstants = numConstants;
102 }
103
104 } // namespace JSC