One file per class for CodeBlock.h/.cpp
[WebKit-https.git] / Source / JavaScriptCore / runtime / EvalExecutable.cpp
1 /*
2  * Copyright (C) 2009, 2010, 2013, 2015-2016 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #include "config.h"
27
28 #include "BatchedTransitionOptimizer.h"
29 #include "CodeBlock.h"
30 #include "Debugger.h"
31 #include "EvalCodeBlock.h"
32 #include "FunctionCodeBlock.h"
33 #include "JIT.h"
34 #include "JSCInlines.h"
35 #include "LLIntEntrypoint.h"
36 #include "Parser.h"
37 #include "TypeProfiler.h"
38 #include "VMInlines.h"
39 #include <wtf/CommaPrinter.h>
40
41 namespace JSC {
42
43 const ClassInfo EvalExecutable::s_info = { "EvalExecutable", &ScriptExecutable::s_info, 0, CREATE_METHOD_TABLE(EvalExecutable) };
44
45 EvalExecutable* EvalExecutable::create(ExecState* exec, const SourceCode& source, bool isInStrictContext, DerivedContextType derivedContextType, bool isArrowFunctionContext, EvalContextType evalContextType, const VariableEnvironment* variablesUnderTDZ)
46 {
47     VM& vm = exec->vm();
48     auto scope = DECLARE_THROW_SCOPE(vm);
49
50     JSGlobalObject* globalObject = exec->lexicalGlobalObject();
51     if (!globalObject->evalEnabled()) {
52         throwException(exec, scope, createEvalError(exec, globalObject->evalDisabledErrorMessage()));
53         return 0;
54     }
55
56     EvalExecutable* executable = new (NotNull, allocateCell<EvalExecutable>(*exec->heap())) EvalExecutable(exec, source, isInStrictContext, derivedContextType, isArrowFunctionContext, evalContextType);
57     executable->finishCreation(vm);
58
59     UnlinkedEvalCodeBlock* unlinkedEvalCode = globalObject->createEvalCodeBlock(exec, executable, variablesUnderTDZ);
60     if (!unlinkedEvalCode)
61         return 0;
62
63     executable->m_unlinkedEvalCodeBlock.set(vm, executable, unlinkedEvalCode);
64
65     return executable;
66 }
67
68 EvalExecutable::EvalExecutable(ExecState* exec, const SourceCode& source, bool inStrictContext, DerivedContextType derivedContextType, bool isArrowFunctionContext, EvalContextType evalContextType)
69     : ScriptExecutable(exec->vm().evalExecutableStructure.get(), exec->vm(), source, inStrictContext, derivedContextType, isArrowFunctionContext, evalContextType, NoIntrinsic)
70 {
71     ASSERT(source.provider()->sourceType() == SourceProviderSourceType::Program);
72 }
73
74 void EvalExecutable::destroy(JSCell* cell)
75 {
76     static_cast<EvalExecutable*>(cell)->EvalExecutable::~EvalExecutable();
77 }
78
79 void EvalExecutable::visitChildren(JSCell* cell, SlotVisitor& visitor)
80 {
81     EvalExecutable* thisObject = jsCast<EvalExecutable*>(cell);
82     ASSERT_GC_OBJECT_INHERITS(thisObject, info());
83     ScriptExecutable::visitChildren(thisObject, visitor);
84     visitor.append(&thisObject->m_unlinkedEvalCodeBlock);
85     if (thisObject->m_evalCodeBlock)
86         thisObject->m_evalCodeBlock->visitWeakly(visitor);
87 }
88
89 } // namespace JSC