Details
-
Bug
-
Resolution: Done
-
P1: Critical
-
5.12.0 Alpha
-
None
-
-
33d85e20037e83d10b8ce66f8745f00d84baccd8 (qt/qtdeclarative/5.12)
Description
Patch https://codereview.qt-project.org/#/c/211785/ introduces fine-grained signals for some properties.
Consider the follow code:
import QtQuick 2.11
Flickable {
onAtXEndChanged: console.trace()
}
The notifier of atXEnd is changed from isAtBoundaryChanged() to atXEndChanged() and the latter signal is Q_REVISION(12), so on Qt-5.11 the code works fine and the property change handler connects to isAtBoundaryChanged.
On the other side, the same code on 5.12 fails with error
"Flickable.onAtYEndChanged" is not available in QtQuick 2.10.
The engine can not connect to the new signal because of the old import statement and it has no idea that the property has had another notifier that it still can try connect to.
As far as I can see, the proper solution would be to extend revisions support in Q_PROPERTY macro so it will be possible to write
Q_PROPERTY(bool atXEnd READ isAtXEnd NOTIFY isAtBoundaryChanged) Q_PROPERTY(bool atXEnd READ isAtXEnd NOTIFY atXEndChanged REVISION 12)
and make the engine to use the older notifier on older import statement.
However such change is a significant development and it is too late to include it into the upcoming release.
We have to choose between two evils — break the (QML) source compatibility for all Flickable.
{atXEnd,atXBeginning,atYEnd,atYBeginning}notifier users or break source compatibility for users who maybe added a conflict signals with same names (atXEndChanged and so on).
Attachments
For Gerrit Dashboard: QTBUG-71243 | ||||||
---|---|---|---|---|---|---|
# | Subject | Branch | Project | Status | CR | V |
243131,3 | Fix backward QML compatibility for Flickable.isAtBoundaryChanged() | 5.12 | qt/qtdeclarative | Status: MERGED | +2 | 0 |