37 static QQmlRefPointer<QQmlContextData> createRefCounted(
38 const QQmlRefPointer<QQmlContextData> &parent)
40 return QQmlRefPointer<QQmlContextData>(
new QQmlContextData(RefCounted,
nullptr, parent),
41 QQmlRefPointer<QQmlContextData>::Adopt);
45 static QQmlRefPointer<QQmlContextData> createChild(
46 const QQmlRefPointer<QQmlContextData> &parent)
48 Q_ASSERT(!parent.isNull());
49 return QQmlRefPointer<QQmlContextData>(
new QQmlContextData(OwnedByParent,
nullptr, parent));
52 void addref()
const { ++m_refCount; }
53 void release()
const {
if (--m_refCount == 0)
delete this; }
54 int count()
const {
return m_refCount; }
55 int refCount()
const {
return m_refCount; }
57 QQmlRefPointer<QV4::ExecutableCompilationUnit> typeCompilationUnit()
const
59 return m_typeCompilationUnit;
61 void initFromTypeCompilationUnit(
const QQmlRefPointer<QV4::ExecutableCompilationUnit> &unit,
62 int subComponentIndex);
64 static QQmlRefPointer<QQmlContextData> get(QQmlContext *context) {
65 return QQmlContextPrivate::get(context)->m_data;
68 void emitDestruction();
69 void clearExpressions();
70 void clearContextRecursively();
71 void clearChildrenAndSiblings();
72 void clearImportedScripts();
73 void clearOwnedObjects();
74 void clearContextGuards();
80 return m_engine && (!m_isInternal || !m_contextObject
81 || !QObjectPrivate::get(m_contextObject)->wasDeleted);
84 bool isInternal()
const {
return m_isInternal; }
85 void setInternal(
bool isInternal) { m_isInternal = isInternal; }
87 bool isJSContext()
const {
return m_isJSContext; }
88 void setJSContext(
bool isJSContext) { m_isJSContext = isJSContext; }
90 bool isPragmaLibraryContext()
const {
return m_isPragmaLibraryContext; }
91 void setPragmaLibraryContext(
bool library) { m_isPragmaLibraryContext = library; }
93 QQmlRefPointer<QQmlContextData> parent()
const {
return m_parent; }
100 if (m_ownedByParent) {
101 m_ownedByParent =
false;
106 void refreshExpressions();
108 void addOwnedObject(QQmlData *ownedObject);
109 QQmlData *ownedObjects()
const {
return m_ownedObjects; }
110 void setOwnedObjects(QQmlData *ownedObjects) { m_ownedObjects = ownedObjects; }
116 void installContext(QQmlData *ddata, QmlObjectKind kind);
118 QUrl resolvedUrl(
const QUrl &)
const;
122 QQmlContext *asQQmlContext()
124 if (!m_publicContext)
125 m_publicContext =
new QQmlContext(*
new QQmlContextPrivate(
this));
126 return m_publicContext;
129 QQmlContextPrivate *asQQmlContextPrivate()
131 return QQmlContextPrivate::get(asQQmlContext());
134 QObject *contextObject()
const {
return m_contextObject; }
135 void setContextObject(QObject *contextObject) { m_contextObject = contextObject; }
137 template<
typename HandleSelf,
typename HandleLinked>
138 void deepClearContextObject(
139 QObject *contextObject, HandleSelf &&handleSelf, HandleLinked &&handleLinked) {
140 for (QQmlContextData *lc = m_linkedContext.data(); lc; lc = lc->m_linkedContext.data()) {
142 if (lc->m_contextObject == contextObject)
143 lc->m_contextObject =
nullptr;
147 if (m_contextObject == contextObject)
148 m_contextObject =
nullptr;
151 void deepClearContextObject(QObject *contextObject)
153 deepClearContextObject(
155 [](QQmlContextData *self) { self->emitDestruction(); },
156 [](QQmlContextData *){});
159 QQmlEngine *engine()
const {
return m_engine; }
160 void setEngine(QQmlEngine *engine) { m_engine = engine; }
162 QQmlContext *publicContext()
const {
return m_publicContext; }
163 void clearPublicContext()
165 if (!m_publicContext)
168 m_publicContext =
nullptr;
169 if (m_ownedByPublicContext) {
170 m_ownedByPublicContext =
false;
175 int propertyIndex(
const QString &name)
const
177 ensurePropertyNames();
178 return m_propertyNameCache.value(name);
181 int propertyIndex(QV4::Heap::String *name)
const
183 ensurePropertyNames();
184 return m_propertyNameCache.value(name);
187 QString propertyName(
int index)
const
189 ensurePropertyNames();
190 return m_propertyNameCache.key<QString>(index);
193 void addPropertyNameAndIndex(
const QString &name,
int index)
195 Q_ASSERT(m_propertyNameCache.isValid());
196 m_propertyNameCache.add(name, index);
199 void setExpressions(QQmlJavaScriptExpression *expressions) { m_expressions = expressions; }
200 QQmlJavaScriptExpression *takeExpressions()
202 QQmlJavaScriptExpression *expressions = m_expressions;
203 m_expressions =
nullptr;
207 void setChildContexts(
const QQmlRefPointer<QQmlContextData> &childContexts)
209 m_childContexts = childContexts.data();
211 QQmlRefPointer<QQmlContextData> childContexts()
const {
return m_childContexts; }
212 QQmlRefPointer<QQmlContextData> takeChildContexts()
214 QQmlRefPointer<QQmlContextData> childContexts = m_childContexts;
215 m_childContexts =
nullptr;
216 return childContexts;
218 QQmlRefPointer<QQmlContextData> nextChild()
const {
return m_nextChild; }
220 int numIdValues()
const {
return m_idValueCount; }
221 void setIdValue(
int index, QObject *idValue);
222 bool isIdValueSet(
int index)
const {
return m_idValues[index].wasSet(); }
223 QQmlNotifier *idValueBindings(
int index)
const {
return m_idValues[index].bindings(); }
224 QObject *idValue(
int index)
const {
return m_idValues[index].data(); }
227 QString findObjectId(
const QObject *obj)
const;
235 QString urlString()
const;
237 void setBaseUrlString(
const QString &baseUrlString) { m_baseUrlString = baseUrlString; }
238 QString baseUrlString()
const
240 for (
const QQmlContextData *data =
this; data; data = data->m_parent) {
241 if (!data->m_baseUrlString.isEmpty())
242 return data->m_baseUrlString;
243 if (data->m_typeCompilationUnit)
244 return data->m_typeCompilationUnit->finalUrlString();
249 void setBaseUrl(
const QUrl &baseUrl) { m_baseUrl = baseUrl; }
252 for (
const QQmlContextData *data =
this; data; data = data->m_parent) {
253 if (!data->m_baseUrl.isEmpty())
254 return data->m_baseUrl;
255 if (data->m_typeCompilationUnit)
256 return data->m_typeCompilationUnit->finalUrl();
261 QQmlRefPointer<QQmlTypeNameCache> imports()
const {
return m_imports; }
262 void setImports(
const QQmlRefPointer<QQmlTypeNameCache> &imports) { m_imports = imports; }
264 QQmlIncubatorPrivate *incubator()
const {
return m_hasExtraObject ?
nullptr : m_incubator; }
265 void setIncubator(QQmlIncubatorPrivate *incubator)
267 Q_ASSERT(!m_hasExtraObject || m_extraObject ==
nullptr);
268 m_hasExtraObject =
false;
269 m_incubator = incubator;
272 QObject *extraObject()
const {
return m_hasExtraObject ? m_extraObject :
nullptr; }
273 void setExtraObject(QObject *extraObject)
275 Q_ASSERT(m_hasExtraObject || m_incubator ==
nullptr);
276 m_hasExtraObject =
true;
277 m_extraObject = extraObject;
280 bool isRootObjectInCreation()
const {
return m_isRootObjectInCreation; }
281 void setRootObjectInCreation(
bool rootInCreation) { m_isRootObjectInCreation = rootInCreation; }
283 QV4::ReturnedValue importedScripts()
const
285 if (m_hasWeakImportedScripts)
286 return m_weakImportedScripts.value();
288 return m_importedScripts.value();
290 void setImportedScripts(QV4::ExecutionEngine *engine, QV4::Value scripts) {
292 Q_ASSERT(!m_hasWeakImportedScripts);
293 m_importedScripts.set(engine, scripts);
297
298
299
300
301 void setImportedScripts(QV4::ExecutionEngine *engine, QV4::ReturnedValue scripts) {
303 Q_ASSERT(!m_hasWeakImportedScripts);
304 m_importedScripts.set(engine, scripts);
307 QQmlRefPointer<QQmlContextData> linkedContext()
const {
return m_linkedContext; }
308 void setLinkedContext(
const QQmlRefPointer<QQmlContextData> &context) { m_linkedContext = context; }
310 bool hasUnresolvedNames()
const {
return m_unresolvedNames; }
311 void setUnresolvedNames(
bool hasUnresolvedNames) { m_unresolvedNames = hasUnresolvedNames; }
313 QQmlComponentAttached *componentAttacheds()
const {
return m_componentAttacheds; }
314 void addComponentAttached(QQmlComponentAttached *attached);
316 void addExpression(QQmlJavaScriptExpression *expression);
318 bool valueTypesAreAddressable()
const {
319 return m_typeCompilationUnit && m_typeCompilationUnit->valueTypesAreAddressable();
322 bool valueTypesAreAssertable()
const {
323 return m_typeCompilationUnit && m_typeCompilationUnit->valueTypesAreAssertable();
327 friend class QQmlGuardedContextData;
328 friend class QQmlContextPrivate;
337 struct ContextGuard :
public QQmlGuard<QObject>
344 inline ContextGuard() : QQmlGuard<QObject>(&ContextGuard::objectDestroyedImpl,
nullptr), m_context(
nullptr) {}
345 inline ContextGuard &operator=(QObject *obj);
347 inline bool wasSet()
const;
349 QQmlNotifier *bindings() {
return &m_bindings; }
350 void setContext(
const QQmlRefPointer<QQmlContextData> &context)
352 m_context = context.data();
356 inline static void objectDestroyedImpl(QQmlGuardImpl *);
358 QTaggedPointer<QQmlContextData, Tag> m_context;
359 QQmlNotifier m_bindings;
365 Ownership ownership, QQmlContext *publicContext,
366 const QQmlRefPointer<QQmlContextData> &parent, QQmlEngine *engine =
nullptr)
367 : m_parent(parent.data()),
368 m_engine(engine ? engine : (parent.isNull() ?
nullptr : parent->engine())),
369 m_isInternal(
false), m_isJSContext(
false), m_isPragmaLibraryContext(
false),
370 m_unresolvedNames(
false), m_hasEmittedDestruction(
false), m_isRootObjectInCreation(
false),
371 m_ownedByParent(ownership == OwnedByParent),
372 m_ownedByPublicContext(ownership == OwnedByPublicContext), m_hasExtraObject(
false),
373 m_hasWeakImportedScripts(
false), m_dummy(0), m_publicContext(publicContext), m_incubator(
nullptr)
375 Q_ASSERT(!m_ownedByParent || !m_ownedByPublicContext);
379 m_nextChild = m_parent->m_childContexts;
381 m_nextChild->m_prevChild = &m_nextChild;
382 m_prevChild = &m_parent->m_childContexts;
383 m_parent->m_childContexts =
this;
388 bool hasExpressionsToRun(
bool isGlobalRefresh)
const
390 return m_expressions && (!isGlobalRefresh || m_unresolvedNames);
393 void refreshExpressionsRecursive(
bool isGlobal);
394 void refreshExpressionsRecursive(QQmlJavaScriptExpression *);
395 void initPropertyNames()
const;
397 void ensurePropertyNames()
const
399 if (!m_propertyNameCache.isValid())
401 Q_ASSERT(m_propertyNameCache.isValid());
405 QQmlContextData *m_parent =
nullptr;
406 QQmlEngine *m_engine =
nullptr;
408 mutable quint32 m_refCount = 1;
409 quint32 m_isInternal:1;
410 quint32 m_isJSContext:1;
411 quint32 m_isPragmaLibraryContext:1;
412 quint32 m_unresolvedNames:1;
413 quint32 m_hasEmittedDestruction:1;
414 quint32 m_isRootObjectInCreation:1;
415 quint32 m_ownedByParent:1;
416 quint32 m_ownedByPublicContext:1;
417 quint32 m_hasExtraObject:1;
418 quint32 m_hasWeakImportedScripts:1;
419 Q_DECL_UNUSED_MEMBER quint32 m_dummy:22;
420 QQmlContext *m_publicContext =
nullptr;
424 QQmlIncubatorPrivate *m_incubator;
426 QObject *m_extraObject;
430 QQmlRefPointer<QV4::ExecutableCompilationUnit> m_typeCompilationUnit;
433 int m_componentObjectIndex = -1;
436 mutable QV4::IdentifierHash m_propertyNameCache;
439 QObject *m_contextObject =
nullptr;
444
445
446
447 QV4::PersistentValue m_importedScripts = {};
448 QV4::WeakValue m_weakImportedScripts;
452 QString m_baseUrlString;
455 QQmlRefPointer<QQmlTypeNameCache> m_imports;
458 QQmlContextData *m_childContexts =
nullptr;
461 QQmlContextData *m_nextChild =
nullptr;
462 QQmlContextData **m_prevChild =
nullptr;
465 QQmlJavaScriptExpression *m_expressions =
nullptr;
468 QQmlData *m_ownedObjects =
nullptr;
471 QQmlGuardedContextData *m_contextGuards =
nullptr;
473 ContextGuard *m_idValues =
nullptr;
474 int m_idValueCount = 0;
477 QQmlRefPointer<QQmlContextData> m_linkedContext;
480 QQmlComponentAttached *m_componentAttacheds =
nullptr;