From 1e461a5c06bcbcaa610858d4b7db7e559b96ae80 Mon Sep 17 00:00:00 2001 From: Pierre Rossi Date: Wed, 20 Oct 2010 11:54:48 +0200 Subject: Fix highlighting of the last character Thanks to pano for noticing the bad behavior. AutoTest updated with the testcase. Reviewed-By: Benjamin Poulain --- src/tests/listitem_test.cpp | 3 ++- src/urlbar/listitem.cpp | 25 ++++++++++++++----------- 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/src/tests/listitem_test.cpp b/src/tests/listitem_test.cpp index 961f4b6a..fc0b62ec 100644 --- a/src/tests/listitem_test.cpp +++ b/src/tests/listitem_test.cpp @@ -74,7 +74,8 @@ void ListItemTest::wordHighLighting_data() QTest::newRow("<") << "Subject < Section < Wiki" << "<" << "Subject < Section < Wiki"; QTest::newRow("&") << "http://www.google.com/search?q=qt test&ie=UTF-8&oe=UTF-8" << "&" << "http://www.google.com/search?q=qt test&ie=UTF-8&oe=UTF-8"; - + QTest::newRow("ciao") << "ciao" << "ciao" << "ciao"; + QTest::newRow("http://ciao") << "http://ciao" << "ciao" << "http://ciao"; } void ListItemTest::wordHighLighting() diff --git a/src/urlbar/listitem.cpp b/src/urlbar/listitem.cpp index 8b908149..df9ef286 100644 --- a/src/urlbar/listitem.cpp +++ b/src/urlbar/listitem.cpp @@ -211,28 +211,31 @@ static QString highlightWordsInText(const QString &text, const QStringList &word foreach (const QString &wordToPointOut, words) { int index = ret.indexOf(wordToPointOut, 0, Qt::CaseInsensitive); while(index > -1) { - boldSections.fill(true,index + 1, index + wordToPointOut.size() + 1); + boldSections.fill(true, index, index + wordToPointOut.size()); index = ret.indexOf(wordToPointOut, index + wordToPointOut.size(), Qt::CaseInsensitive); } } int numSections = 0; - bool bold = false; - for(int i=0; i < boldSections.size() - 1; ++i ) { - if (boldSections.testBit(i) && (i == boldSections.size() || !boldSections.testBit(i+1))) - numSections++; + for (int i = 0; i < boldSections.size() - 1; ++i){ + if (boldSections.testBit(i) && !boldSections.testBit(i + 1)) + ++numSections; } + if (boldSections.testBit(boldSections.size() - 1)) //last char was still part of a bold section + ++numSections; const int tagLength = 7; // length of "" and "" we're going to add for each bold section. ret.reserve(ret.size() + numSections * tagLength); - bold = false; - for (int i = boldSections.size() - 1; i >= 0; --i) { - if (!bold && boldSections.testBit(i)) { - ret.insert(i, QL1S("")); + bool bold = false; + for (int i = boldSections.size() - 1; i >= 0; --i){ + if (!bold && boldSections.testBit(i)){ + ret.insert(i + 1, QL1S("")); bold = true; - } else if (bold && !boldSections.testBit(i)) { - ret.insert(i, QL1S("")); + } else if (bold && !boldSections.testBit(i)){ + ret.insert(i + 1, QL1S("")); bold = false; } } + if (bold) + ret.insert(0, QL1S("")); return ret; } -- cgit v1.2.1