30 using QQmlJSCompilePass::QQmlJSCompilePass;
32 BlocksAndAnnotations run(
const Function *m_function);
34 void generate_Ret() override;
35 void generate_Debug() override;
36 void generate_LoadConst(
int index) override;
37 void generate_LoadZero() override;
38 void generate_LoadTrue() override;
39 void generate_LoadFalse() override;
40 void generate_LoadNull() override;
41 void generate_LoadUndefined() override;
42 void generate_LoadInt(
int value) override;
43 void generate_MoveConst(
int constIndex,
int destTemp) override;
44 void generate_LoadReg(
int reg) override;
45 void generate_StoreReg(
int reg) override;
46 void generate_MoveReg(
int srcReg,
int destReg) override;
47 void generate_LoadImport(
int index) override;
48 void generate_LoadLocal(
int index) override;
49 void generate_StoreLocal(
int index) override;
50 void generate_LoadScopedLocal(
int scope,
int index) override;
51 void generate_StoreScopedLocal(
int scope,
int index) override;
52 void generate_LoadRuntimeString(
int stringId) override;
53 void generate_MoveRegExp(
int regExpId,
int destReg) override;
54 void generate_LoadClosure(
int value) override;
55 void generate_LoadName(
int nameIndex) override;
56 void generate_LoadGlobalLookup(
int index) override;
57 void generate_LoadQmlContextPropertyLookup(
int index) override;
58 void generate_StoreNameSloppy(
int nameIndex) override;
59 void generate_StoreNameStrict(
int name) override;
60 void generate_LoadElement(
int base) override;
61 void generate_StoreElement(
int base,
int index) override;
62 void generate_LoadProperty(
int nameIndex) override;
63 void generate_LoadOptionalProperty(
int name,
int offset) override;
64 void generate_GetLookup(
int index) override;
65 void generate_GetOptionalLookup(
int index,
int offset) override;
66 void generate_StoreProperty(
int name,
int base) override;
67 void generate_SetLookup(
int index,
int base) override;
68 void generate_LoadSuperProperty(
int property) override;
69 void generate_StoreSuperProperty(
int property) override;
70 void generate_Yield() override;
71 void generate_YieldStar() override;
72 void generate_Resume(
int) override;
74 void generate_CallValue(
int name,
int argc,
int argv) override;
75 void generate_CallWithReceiver(
int name,
int thisObject,
int argc,
int argv) override;
76 void generate_CallProperty(
int name,
int base,
int argc,
int argv) override;
77 void generate_CallPropertyLookup(
int lookupIndex,
int base,
int argc,
int argv) override;
78 void generate_CallName(
int name,
int argc,
int argv) override;
79 void generate_CallPossiblyDirectEval(
int argc,
int argv) override;
80 void generate_CallGlobalLookup(
int index,
int argc,
int argv) override;
81 void generate_CallQmlContextPropertyLookup(
int index,
int argc,
int argv) override;
82 void generate_CallWithSpread(
int func,
int thisObject,
int argc,
int argv) override;
83 void generate_TailCall(
int func,
int thisObject,
int argc,
int argv) override;
84 void generate_Construct(
int func,
int argc,
int argv) override;
85 void generate_ConstructWithSpread(
int func,
int argc,
int argv) override;
86 void generate_SetUnwindHandler(
int offset) override;
87 void generate_UnwindDispatch() override;
88 void generate_UnwindToLabel(
int level,
int offset) override;
89 void generate_DeadTemporalZoneCheck(
int name) override;
90 void generate_ThrowException() override;
91 void generate_GetException() override;
92 void generate_SetException() override;
93 void generate_CreateCallContext() override;
94 void generate_PushCatchContext(
int index,
int name) override;
95 void generate_PushWithContext() override;
96 void generate_PushBlockContext(
int index) override;
97 void generate_CloneBlockContext() override;
98 void generate_PushScriptContext(
int index) override;
99 void generate_PopScriptContext() override;
100 void generate_PopContext() override;
101 void generate_GetIterator(
int iterator) override;
102 void generate_IteratorNext(
int value,
int offset) override;
103 void generate_IteratorNextForYieldStar(
int iterator,
int object,
int offset) override;
104 void generate_IteratorClose() override;
105 void generate_DestructureRestElement() override;
106 void generate_DeleteProperty(
int base,
int index) override;
107 void generate_DeleteName(
int name) override;
108 void generate_TypeofName(
int name) override;
109 void generate_TypeofValue() override;
110 void generate_DeclareVar(
int varName,
int isDeletable) override;
111 void generate_DefineArray(
int argc,
int args) override;
112 void generate_DefineObjectLiteral(
int internalClassId,
int argc,
int args) override;
113 void generate_CreateClass(
int classIndex,
int heritage,
int computedNames) override;
114 void generate_CreateMappedArgumentsObject() override;
115 void generate_CreateUnmappedArgumentsObject() override;
116 void generate_CreateRestParameter(
int argIndex) override;
117 void generate_ConvertThisToObject() override;
118 void generate_LoadSuperConstructor() override;
119 void generate_ToObject() override;
120 void generate_Jump(
int offset) override;
121 void generate_JumpTrue(
int offset) override;
122 void generate_JumpFalse(
int offset) override;
123 void generate_JumpNoException(
int offset) override;
124 void generate_JumpNotUndefined(
int offset) override;
125 void generate_CheckException() override;
126 void generate_CmpEqNull() override;
127 void generate_CmpNeNull() override;
128 void generate_CmpEqInt(
int lhsConst) override;
129 void generate_CmpNeInt(
int lhs) override;
130 void generate_CmpEq(
int lhs) override;
131 void generate_CmpNe(
int lhs) override;
132 void generate_CmpGt(
int lhs) override;
133 void generate_CmpGe(
int lhs) override;
134 void generate_CmpLt(
int lhs) override;
135 void generate_CmpLe(
int lhs) override;
136 void generate_CmpStrictEqual(
int lhs) override;
137 void generate_CmpStrictNotEqual(
int lhs) override;
138 void generate_CmpIn(
int lhs) override;
139 void generate_CmpInstanceOf(
int lhs) override;
140 void generate_As(
int lhs) override;
141 void generate_UNot() override;
142 void generate_UPlus() override;
143 void generate_UMinus() override;
144 void generate_UCompl() override;
145 void generate_Increment() override;
146 void generate_Decrement() override;
147 void generate_Add(
int lhs) override;
148 void generate_BitAnd(
int lhs) override;
149 void generate_BitOr(
int lhs) override;
150 void generate_BitXor(
int lhs) override;
151 void generate_UShr(
int lhs) override;
152 void generate_Shr(
int lhs) override;
153 void generate_Shl(
int lhs) override;
154 void generate_BitAndConst(
int rhsConst) override;
155 void generate_BitOrConst(
int rhsConst) override;
156 void generate_BitXorConst(
int rhsConst) override;
157 void generate_UShrConst(
int rhsConst) override;
158 void generate_ShrConst(
int rhs) override;
159 void generate_ShlConst(
int rhs) override;
160 void generate_Exp(
int lhs) override;
161 void generate_Mul(
int lhs) override;
162 void generate_Div(
int lhs) override;
163 void generate_Mod(
int lhs) override;
164 void generate_Sub(
int lhs) override;
165 void generate_InitializeBlockDeadTemporalZone(
int firstReg,
int count) override;
166 void generate_ThrowOnNullOrUndefined() override;
167 void generate_GetTemplateObject(
int index) override;
169 Verdict startInstruction(QV4::Moth::Instr::Type instr) override;
170 void endInstruction(QV4::Moth::Instr::Type instr) override;
173 struct ExpectedRegisterState
175 int originatingOffset = 0;
176 VirtualRegisters registers;
179 struct PassState : QQmlJSCompilePass::State
181 InstructionAnnotations annotations;
182 QSet<
int> jumpTargets;
183 bool skipInstructionsUntilNextJumpTarget =
false;
184 bool needsMorePasses =
false;
185 bool instructionHasError =
false;
189 virtual void handleUnqualifiedAccess(
const QString &name,
bool isMethod)
const;
190 virtual void handleUnqualifiedAccessAndContextProperties(
const QString &name,
bool isMethod)
const;
191 virtual void checkDeprecated(QQmlJSScope::ConstPtr scope,
const QString &name,
bool isMethod)
const;
192 virtual bool isCallingProperty(QQmlJSScope::ConstPtr scope,
const QString &name)
const;
193 virtual bool handleImportNamespaceLookup(
const QString &propertyName);
194 virtual void handleLookupError(
const QString &propertyName);
195 virtual bool checkForEnumProblems(QQmlJSRegisterContent base,
const QString &propertyName);
196 virtual void warnAboutTypeCoercion(
int lhs);
198 enum PropertyResolution {
200 PropertyTypeUnresolved,
201 PropertyFullyResolved
204 PropertyResolution propertyResolution(QQmlJSScope::ConstPtr scope,
const QString &type)
const;
206 void checkConversion(QQmlJSRegisterContent from, QQmlJSRegisterContent to);
207 void generateUnaryArithmeticOperation(QQmlJSTypeResolver::UnaryOperator op);
209 QQmlJSRegisterContent propagateBinaryOperation(QSOperator::Op op,
int lhs);
210 void generateBinaryArithmeticOperation(QSOperator::Op op,
int lhs);
211 void generateBinaryConstArithmeticOperation(QSOperator::Op op);
213 virtual void generate_StoreNameCommon(
int nameIndex);
214 virtual void propagateCall(
215 const QList<QQmlJSMetaMethod> &methods,
int argc,
int argv,
216 QQmlJSRegisterContent scope);
217 virtual void propagateTranslationMethod_SAcheck(
const QString &methodName);
218 bool propagateTranslationMethod(
const QList<QQmlJSMetaMethod> &methods,
int argc,
int argv);
219 void propagateStringArgCall(QQmlJSRegisterContent base,
int argv);
220 bool propagateArrayMethod(
const QString &name,
int argc,
int argv, QQmlJSRegisterContent valueType);
221 virtual void propagatePropertyLookup(
222 const QString &name,
int lookupIndex = QQmlJSRegisterContent::InvalidLookupIndex);
223 void propagateScopeLookupCall(
const QString &functionName,
int argc,
int argv);
224 void saveRegisterStateForJump(
int offset);
225 bool canConvertFromTo(QQmlJSRegisterContent from, QQmlJSRegisterContent to);
226 bool canConvertFromTo(QQmlJSRegisterContent from,
const QQmlJSScope::ConstPtr &to);
228 QString registerName(
int registerIndex)
const;
230 QQmlJSRegisterContent checkedInputRegister(
int reg);
231 QQmlJSMetaMethod bestMatchForCall(
const QList<QQmlJSMetaMethod> &methods,
int argc,
int argv,
232 QStringList *errors);
234 void setAccumulator(QQmlJSRegisterContent content);
235 void setRegister(
int index, QQmlJSRegisterContent content);
236 void mergeRegister(
int index,
const VirtualRegister &a,
const VirtualRegister &b);
238 void addReadRegister(
int index);
239 void addReadRegister(
int index, QQmlJSRegisterContent convertTo);
240 void addReadRegister(
int index,
const QQmlJSScope::ConstPtr &convertTo);
242 void addReadAccumulator()
244 addReadRegister(Accumulator);
247 void addReadAccumulator(QQmlJSRegisterContent convertTo)
249 addReadRegister(Accumulator, convertTo);
252 void addReadAccumulator(
const QQmlJSScope::ConstPtr &convertTo)
254 addReadRegister(Accumulator, convertTo);
257 bool populatesAccumulator(QV4::Moth::Instr::Type instr)
const;
258 bool isNoop(QV4::Moth::Instr::Type instr)
const;
260 void recordEqualsNullType();
261 void recordEqualsIntType();
262 void recordEqualsType(
int lhs);
263 void recordCompareType(
int lhs);
266 void generate_CallProperty_SCMath(
const QString &name,
int base,
int arcg,
int argv);
267 void generate_CallProperty_SCconsole(
const QString &name,
int base,
int argc,
int argv);
268 void generate_Construct_SCDate(
const QQmlJSMetaMethod &ctor,
int argc,
int argv);
269 void generate_Construct_SCArray(
const QQmlJSMetaMethod &ctor,
int argc,
int argv);
271 static bool isLoggingMethod(
const QString &consoleMethod);
273 void addError(
const QString &message)
275 QQmlJSCompilePass::addError(message);
276 m_state.instructionHasError =
true;
279 void setVarAccumulatorAndError()
281 setAccumulator(m_typeResolver->syntheticType(m_typeResolver->varType()));
282 m_state.instructionHasError =
true;
285 QQmlJSRegisterContent m_returnType;
288 QMultiHash<
int, ExpectedRegisterState> m_jumpOriginRegisterStateByTargetInstructionOffset;
290 InstructionAnnotations m_prevStateAnnotations;