From 1f4ded6ec4a0b54ee50ca857c5e471e6e0238274 Mon Sep 17 00:00:00 2001 From: Olivier Goffart <olivier.goffart@nokia.com> Date: Wed, 14 Jul 2010 11:34:55 +0200 Subject: [PATCH] QmlJsDelta: better support for order change --- src/plugins/qmljsinspector/qmljsdelta.cpp | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/plugins/qmljsinspector/qmljsdelta.cpp b/src/plugins/qmljsinspector/qmljsdelta.cpp index 40546839b30..e01bc0bd80d 100644 --- a/src/plugins/qmljsinspector/qmljsdelta.cpp +++ b/src/plugins/qmljsinspector/qmljsdelta.cpp @@ -177,10 +177,17 @@ Map MatchFragment(UiObjectMember *x, UiObjectMember *y, const Map &M, Document:: if(label(x, doc1) != label(y, doc2)) return M2; M2.insert(x, y); - const QList<UiObjectMember *> list1 = children(x); - const QList<UiObjectMember *> list2 = children(y); - for (int i = 0; i < qMin(list1.count(), list2.count()); i++) { - M2 += MatchFragment(list1[i], list2[i], M, doc1, doc2); + QList<UiObjectMember *> list1 = children(x); + QList<UiObjectMember *> list2 = children(y); + for (int i = 0; i < list1.count(); i++) { + QString l = label(list1[i], doc1); + for (int j = 0; j < list2.count(); j++) { + if (l != label(list2[j], doc2)) + continue; + M2 += MatchFragment(list1[i], list2[j], M, doc1, doc2); + list2.removeAt(j); + break; + } } return M2; } -- GitLab