diff options
author | Simon Hausmann <simon.hausmann@qt.io> | 2020-03-23 21:30:21 +0100 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@qt.io> | 2020-03-27 13:29:47 +0100 |
commit | f3ce9e9332820a8b5084fb4d75994e8eb19ddfd3 (patch) | |
tree | 92efbcf85b11d4eb30d91e553b68180551943e9e /src/corelib/kernel/qproperty_p.h | |
parent | 96de3e26dbd14be6e43db7116c3ce815f9fc9d4b (diff) |
Make QPropertyBindingPrivate accessible to QtQml
QtQml needs the private just for one detail which nobody else should
need it for: Tracking additional dependencies and marking the binding as
dirty. Exporting the private requires hiding some variables and
providing accessors, to compile with MSVC - including the removal of
QVarLengthArray usage. Upside: The binding structure shrinks by 8 bytes
and the encapsulation makes it a little easier to change things without
breaking declarative, ... in the unlikely event ;-)
Also remove setDirty() from the public API as it's not needed by QtQml
and using it is dangerous, because it means that there's a risk of
somebody keeping a reference (count) to the untyped binding from within
the binding closure, which introduces a memory leak.
Change-Id: I43bd56f4bdf218efb54fa23e2d627ad3acfafeb5
Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
Diffstat (limited to 'src/corelib/kernel/qproperty_p.h')
-rw-r--r-- | src/corelib/kernel/qproperty_p.h | 2 |
1 files changed, 0 insertions, 2 deletions
diff --git a/src/corelib/kernel/qproperty_p.h b/src/corelib/kernel/qproperty_p.h index 1fbe5231fe..a50ae0dee1 100644 --- a/src/corelib/kernel/qproperty_p.h +++ b/src/corelib/kernel/qproperty_p.h @@ -90,7 +90,6 @@ struct QPropertyObserverPointer void notify(QPropertyBindingPrivate *triggeringBinding); void observeProperty(QPropertyBasePointer property); - void prependToBinding(QPropertyBindingPrivate *binding); explicit operator bool() const { return ptr != nullptr; } @@ -110,7 +109,6 @@ struct BindingEvaluationState BindingEvaluationState(QPropertyBindingPrivate *binding); ~BindingEvaluationState(); QPropertyBindingPrivate *binding; - QVarLengthArray<QPropertyObserver, 4> *dependencyObservers = nullptr; BindingEvaluationState *previousState = nullptr; }; |