[ES6] Support Module Syntax
[WebKit-https.git] / Source / JavaScriptCore / runtime / Completion.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, 2007, 2013 Apple Inc.
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 "Completion.h"
25
26 #include "CallFrame.h"
27 #include "CodeProfiling.h"
28 #include "Debugger.h"
29 #include "Exception.h"
30 #include "Interpreter.h"
31 #include "JSGlobalObject.h"
32 #include "JSLock.h"
33 #include "JSCInlines.h"
34 #include "Parser.h"
35 #include <wtf/WTFThreadData.h>
36
37 namespace JSC {
38
39 bool checkSyntax(ExecState* exec, const SourceCode& source, JSValue* returnedException)
40 {
41     JSLockHolder lock(exec);
42     RELEASE_ASSERT(exec->vm().atomicStringTable() == wtfThreadData().atomicStringTable());
43
44     ProgramExecutable* program = ProgramExecutable::create(exec, source);
45     JSObject* error = program->checkSyntax(exec);
46     if (error) {
47         if (returnedException)
48             *returnedException = error;
49         return false;
50     }
51
52     return true;
53 }
54     
55 bool checkSyntax(VM& vm, const SourceCode& source, ParserError& error)
56 {
57     JSLockHolder lock(vm);
58     RELEASE_ASSERT(vm.atomicStringTable() == wtfThreadData().atomicStringTable());
59     return !!parse<ProgramNode>(
60         &vm, source, Identifier(), JSParserBuiltinMode::NotBuiltin, 
61         JSParserStrictMode::NotStrict, JSParserCodeType::Program, error);
62 }
63
64 bool checkModuleSyntax(VM& vm, const SourceCode& source, ParserError& error)
65 {
66     JSLockHolder lock(vm);
67     RELEASE_ASSERT(vm.atomicStringTable() == wtfThreadData().atomicStringTable());
68     return !!parse<ModuleProgramNode>(
69         &vm, source, Identifier(), JSParserBuiltinMode::NotBuiltin,
70         JSParserStrictMode::Strict, JSParserCodeType::Module, error);
71 }
72
73 JSValue evaluate(ExecState* exec, const SourceCode& source, JSValue thisValue, NakedPtr<Exception>& returnedException)
74 {
75     JSLockHolder lock(exec);
76     RELEASE_ASSERT(exec->vm().atomicStringTable() == wtfThreadData().atomicStringTable());
77     RELEASE_ASSERT(!exec->vm().isCollectorBusy());
78
79     CodeProfiling profile(source);
80
81     ProgramExecutable* program = ProgramExecutable::create(exec, source);
82     if (!program) {
83         returnedException = exec->vm().exception();
84         exec->vm().clearException();
85         return jsUndefined();
86     }
87
88     if (!thisValue || thisValue.isUndefinedOrNull())
89         thisValue = exec->vmEntryGlobalObject();
90     JSObject* thisObj = jsCast<JSObject*>(thisValue.toThis(exec, NotStrictMode));
91     JSValue result = exec->interpreter()->execute(program, exec, thisObj);
92
93     if (exec->hadException()) {
94         returnedException = exec->exception();
95         exec->clearException();
96         return jsUndefined();
97     }
98
99     RELEASE_ASSERT(result);
100     return result;
101 }
102
103 } // namespace JSC