6#include <private/qqmlirbuilder_p.h>
10QQmlIRLoader::QQmlIRLoader(
const QV4::CompiledData::Unit *qmlData, QmlIR::Document *output)
14 pool = output->jsParserEngine.pool();
17void QQmlIRLoader::load()
19 output->jsGenerator.stringTable.initializeFromBackingUnit(unit);
21 const QV4::CompiledData::QmlUnit *qmlUnit = unit->qmlUnit();
23 for (quint32 i = 0; i < qmlUnit->nImports; ++i)
24 output->imports << qmlUnit->importAt(i);
27 const auto createPragma = [&](Pragma::PragmaType type) {
28 Pragma *p = New<Pragma>();
29 p->location = QV4::CompiledData::Location();
35 const auto createListPragma = [&](
36 Pragma::PragmaType type,
37 Pragma::ListPropertyAssignBehaviorValue value) {
38 createPragma(type)->listPropertyAssignBehavior = value;
41 const auto createComponentPragma = [&](
42 Pragma::PragmaType type,
43 Pragma::ComponentBehaviorValue value) {
44 createPragma(type)->componentBehavior = value;
47 const auto createFunctionSignaturePragma = [&](
48 Pragma::PragmaType type,
49 Pragma::FunctionSignatureBehaviorValue value) {
50 createPragma(type)->functionSignatureBehavior = value;
53 const auto createNativeMethodPragma = [&](
54 Pragma::PragmaType type,
55 Pragma::NativeMethodBehaviorValue value) {
56 createPragma(type)->nativeMethodBehavior = value;
59 const auto createValueTypePragma = [&](
60 Pragma::PragmaType type,
61 Pragma::ValueTypeBehaviorValues value) {
62 createPragma(type)->valueTypeBehavior = value;
65 if (unit->flags & QV4::CompiledData::Unit::IsSingleton)
66 createPragma(Pragma::Singleton);
67 if (unit->flags & QV4::CompiledData::Unit::IsStrict)
68 createPragma(Pragma::Strict);
70 if (unit->flags & QV4::CompiledData::Unit::ListPropertyAssignReplace)
71 createListPragma(Pragma::ListPropertyAssignBehavior, Pragma::Replace);
72 else if (unit->flags & QV4::CompiledData::Unit::ListPropertyAssignReplaceIfNotDefault)
73 createListPragma(Pragma::ListPropertyAssignBehavior, Pragma::ReplaceIfNotDefault);
75 if (unit->flags & QV4::CompiledData::Unit::ComponentsBound)
76 createComponentPragma(Pragma::ComponentBehavior, Pragma::Bound);
78 if (unit->flags & QV4::CompiledData::Unit::FunctionSignaturesIgnored)
79 createFunctionSignaturePragma(Pragma::FunctionSignatureBehavior, Pragma::Ignored);
81 if (unit->flags & QV4::CompiledData::Unit::NativeMethodsAcceptThisObject)
82 createNativeMethodPragma(Pragma::NativeMethodBehavior, Pragma::AcceptThisObject);
84 Pragma::ValueTypeBehaviorValues valueTypeBehavior = {};
85 if (unit->flags & QV4::CompiledData::Unit::ValueTypesCopied)
86 valueTypeBehavior |= Pragma::Copy;
87 if (unit->flags & QV4::CompiledData::Unit::ValueTypesAddressable)
88 valueTypeBehavior |= Pragma::Addressable;
89 if (unit->flags & QV4::CompiledData::Unit::ValueTypesAssertable)
90 valueTypeBehavior |= Pragma::Assertable;
91 if (valueTypeBehavior)
92 createValueTypePragma(Pragma::ValueTypeBehavior, valueTypeBehavior);
94 for (uint i = 0; i < qmlUnit->nObjects; ++i) {
95 const QV4::CompiledData::Object *serializedObject = qmlUnit->objectAt(i);
96 QmlIR::Object *object = loadObject(serializedObject);
97 output->objects.append(object);
114 QQmlJS::SourceLocation location;
117QmlIR::Object *QQmlIRLoader::loadObject(
const QV4::CompiledData::Object *serializedObject)
119 QmlIR::Object *object = pool->New<QmlIR::Object>();
120 object->init(pool, serializedObject->inheritedTypeNameIndex, serializedObject->idNameIndex,
121 serializedObject->location);
123 object->indexOfDefaultPropertyOrAlias = serializedObject->indexOfDefaultPropertyOrAlias;
124 object->defaultPropertyIsAlias = serializedObject->hasAliasAsDefaultProperty();
125 object->flags = serializedObject->flags();
126 object->id = serializedObject->objectId();
127 object->locationOfIdProperty = serializedObject->locationOfIdProperty;
129 QList<
int> functionIndices;
130 functionIndices.reserve(serializedObject->nFunctions + serializedObject->nBindings / 2);
132 for (uint i = 0; i < serializedObject->nBindings; ++i) {
133 QmlIR::Binding *b = pool->New<QmlIR::Binding>();
134 *
static_cast<QV4::CompiledData::Binding*>(b) = serializedObject->bindingTable()[i];
135 object->bindings->append(b);
136 if (b->type() == QV4::CompiledData::Binding::Type_Script) {
137 functionIndices.append(b->value.compiledScriptIndex);
138 b->value.compiledScriptIndex = functionIndices.size() - 1;
140 QmlIR::CompiledFunctionOrExpression *foe = pool->New<QmlIR::CompiledFunctionOrExpression>();
143 QQmlJS::AST::ExpressionNode *expr;
145 if (b->stringIndex != quint32(0)) {
146 const int start = output->code.size();
147 const QString script = output->stringAt(b->stringIndex);
148 const int length = script.size();
149 output->code.append(script);
150 expr =
new (pool) FakeExpression(start, length);
152 expr =
new (pool) QQmlJS::AST::NullExpression();
153 foe->node =
new (pool) QQmlJS::AST::ExpressionStatement(expr);
154 object->functionsAndExpressions->append(foe);
158 Q_ASSERT(object->functionsAndExpressions->count == functionIndices.size());
160 for (uint i = 0; i < serializedObject->nSignals; ++i) {
161 const QV4::CompiledData::Signal *serializedSignal = serializedObject->signalAt(i);
162 QmlIR::Signal *s = pool->New<QmlIR::Signal>();
163 s->nameIndex = serializedSignal->nameIndex;
164 s->location = serializedSignal->location;
165 s->parameters = pool->New<QmlIR::PoolList<QmlIR::Parameter> >();
167 for (uint i = 0; i < serializedSignal->nParameters; ++i) {
168 QmlIR::Parameter *p = pool->New<QmlIR::Parameter>();
169 *
static_cast<QV4::CompiledData::Parameter*>(p) = *serializedSignal->parameterAt(i);
170 s->parameters->append(p);
173 object->qmlSignals->append(s);
176 for (uint i = 0; i < serializedObject->nEnums; ++i) {
177 const QV4::CompiledData::Enum *serializedEnum = serializedObject->enumAt(i);
178 QmlIR::Enum *e = pool->New<QmlIR::Enum>();
179 e->nameIndex = serializedEnum->nameIndex;
180 e->location = serializedEnum->location;
181 e->enumValues = pool->New<QmlIR::PoolList<QmlIR::EnumValue> >();
183 for (uint i = 0; i < serializedEnum->nEnumValues; ++i) {
184 QmlIR::EnumValue *v = pool->New<QmlIR::EnumValue>();
185 *
static_cast<QV4::CompiledData::EnumValue*>(v) = *serializedEnum->enumValueAt(i);
186 e->enumValues->append(v);
189 object->qmlEnums->append(e);
192 const QV4::CompiledData::Property *serializedProperty = serializedObject->propertyTable();
193 for (uint i = 0; i < serializedObject->nProperties; ++i, ++serializedProperty) {
194 QmlIR::Property *p = pool->New<QmlIR::Property>();
195 *
static_cast<QV4::CompiledData::Property*>(p) = *serializedProperty;
196 object->properties->append(p);
200 const QV4::CompiledData::Alias *serializedAlias = serializedObject->aliasTable();
201 for (uint i = 0; i < serializedObject->nAliases; ++i, ++serializedAlias) {
202 QmlIR::Alias *a = pool->New<QmlIR::Alias>();
203 *
static_cast<QV4::CompiledData::Alias*>(a) = *serializedAlias;
204 object->aliases->append(a);
208 const quint32_le *functionIdx = serializedObject->functionOffsetTable();
209 for (uint i = 0; i < serializedObject->nFunctions; ++i, ++functionIdx) {
210 QmlIR::Function *f = pool->New<QmlIR::Function>();
211 const QV4::CompiledData::Function *compiledFunction = unit->functionAt(*functionIdx);
213 functionIndices.append(*functionIdx);
214 f->index = functionIndices.size() - 1;
215 f->location = compiledFunction->location;
216 f->nameIndex = compiledFunction->nameIndex;
217 f->returnType = compiledFunction->returnType;
219 f->formals.allocate(pool,
int(compiledFunction->nFormals));
220 const QV4::CompiledData::Parameter *formalNameIdx = compiledFunction->formalsTable();
221 for (uint i = 0; i < compiledFunction->nFormals; ++i, ++formalNameIdx)
222 *
static_cast<QV4::CompiledData::Parameter*>(&f->formals[i]) = *formalNameIdx;
224 object->functions->append(f);
227 object->runtimeFunctionIndices.allocate(pool, functionIndices);
229 const QV4::CompiledData::InlineComponent *serializedInlineComponent = serializedObject->inlineComponentTable();
230 for (uint i = 0; i < serializedObject->nInlineComponents; ++i, ++serializedInlineComponent) {
231 QmlIR::InlineComponent *ic = pool->New<QmlIR::InlineComponent>();
232 *
static_cast<QV4::CompiledData::InlineComponent*>(ic) = *serializedInlineComponent;
233 object->inlineComponents->append(ic);
236 const QV4::CompiledData::RequiredPropertyExtraData *serializedRequiredPropertyExtraData = serializedObject->requiredPropertyExtraDataTable();
237 for (uint i = 0u; i < serializedObject->nRequiredPropertyExtraData; ++i, ++serializedRequiredPropertyExtraData) {
238 QmlIR::RequiredPropertyExtraData *extra = pool->New<QmlIR::RequiredPropertyExtraData>();
239 *
static_cast<QV4::CompiledData::RequiredPropertyExtraData *>(extra) = *serializedRequiredPropertyExtraData;
240 object->requiredPropertyExtraDatas->append(extra);
Combined button and popup list for selecting options.
QQmlJS::SourceLocation firstSourceLocation() const override
QQmlJS::SourceLocation lastSourceLocation() const override
FakeExpression(int start, int length)