replace the map of the speller state with a vector

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@35447 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Stephan Witt 2010-09-19 16:00:32 +00:00
parent 7aaffe6111
commit 5671e2dc4d

View File

@ -74,6 +74,53 @@ char_type const META_INSET = 0x200001;
}; };
/////////////////////////////////////////////////////////////////////
//
// SpellResultRange
//
/////////////////////////////////////////////////////////////////////
class SpellResultRange {
public:
SpellResultRange(FontSpan range, SpellChecker::Result result)
: range_(range), result_(result)
{}
///
FontSpan range() const { return range_; }
///
void range(FontSpan r) { range_ = r; }
///
SpellChecker::Result result() const { return result_; }
///
void result(SpellChecker::Result r) { result_ = r; }
///
bool inside(pos_type pos) const { return range_.inside(pos); }
///
bool covered(FontSpan r) const
{
// 1. first of new range inside current range or
// 2. last of new range inside current range or
// 3. first of current range inside new range or
// 4. last of current range inside new range
return range_.inside(r.first) || range_.inside(r.last) ||
r.inside(range_.first) || r.inside(range_.last);
}
///
void shift(pos_type pos, int offset)
{
if (range_.first > pos) {
range_.first += offset;
range_.last += offset;
} else if (range_.last > pos) {
range_.last += offset;
}
}
private:
FontSpan range_ ;
SpellChecker::Result result_ ;
};
///////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////
// //
// SpellCheckerState // SpellCheckerState
@ -91,7 +138,7 @@ public:
{ {
eraseCoveredRanges(fp); eraseCoveredRanges(fp);
if (state != SpellChecker::WORD_OK) if (state != SpellChecker::WORD_OK)
ranges_[fp] = state; ranges_.push_back(SpellResultRange(fp, state));
} }
void increasePosAfterPos(pos_type pos) void increasePosAfterPos(pos_type pos)
@ -112,10 +159,8 @@ public:
RangesIterator et = ranges_.end(); RangesIterator et = ranges_.end();
RangesIterator it = ranges_.begin(); RangesIterator it = ranges_.begin();
for (; it != et; ++it) { for (; it != et; ++it) {
FontSpan fc = it->first; if(it->inside(pos)) {
if(fc.first <= pos && pos <= fc.last) { return it->result();
result = it->second;
break;
} }
} }
return result; return result;
@ -155,52 +200,35 @@ public:
} }
private: private:
/// store the ranges as map of FontSpan and spell result pairs typedef vector<SpellResultRange> Ranges;
typedef map<FontSpan, SpellChecker::Result> Ranges;
typedef Ranges::const_iterator RangesIterator; typedef Ranges::const_iterator RangesIterator;
Ranges ranges_; Ranges ranges_;
/// /// the area of the paragraph with pending spell check
FontSpan refresh_; FontSpan refresh_;
bool needs_refresh_; bool needs_refresh_;
/// spell state cache version number
SpellChecker::ChangeNumber current_change_number_; SpellChecker::ChangeNumber current_change_number_;
void eraseCoveredRanges(FontSpan const fp) void eraseCoveredRanges(FontSpan const fp)
{ {
Ranges result; Ranges result;
RangesIterator et = ranges_.end(); RangesIterator et = ranges_.end();
RangesIterator it = ranges_.begin(); RangesIterator it = ranges_.begin();
for (; it != et; ++it) { for (; it != et; ++it) {
FontSpan fc = it->first; if (!it->covered(fp))
// 1. first of new range inside current range or result.push_back(SpellResultRange(it->range(), it->result()));
// 2. last of new range inside current range or
// 3. first of current range inside new range or
// 4. last of current range inside new range
if (fc.inside(fp.first) || fc.inside(fp.last) ||
fp.inside(fc.first) || fp.inside(fc.last))
{
continue;
}
result[fc] = it->second;
} }
ranges_ = result; ranges_ = result;
} }
void correctRangesAfterPos(pos_type pos, int offset) void correctRangesAfterPos(pos_type pos, int offset)
{ {
Ranges result;
RangesIterator et = ranges_.end(); RangesIterator et = ranges_.end();
RangesIterator it = ranges_.begin(); Ranges::iterator it = ranges_.begin();
for (; it != et; ++it) { for (; it != et; ++it) {
FontSpan m = it->first; it->shift(pos, offset);
if (m.first > pos) {
m.first += offset;
m.last += offset;
} else if (m.last > pos) {
m.last += offset;
}
result[m] = it->second;
} }
ranges_ = result;
} }
}; };
@ -3492,11 +3520,10 @@ SpellChecker::Result Paragraph::spellCheck(pos_type & from, pos_type & to,
bool const trailing_dot = to < size() && d->text_[to] == '.'; bool const trailing_dot = to < size() && d->text_[to] == '.';
result = speller->check(wl); result = speller->check(wl);
if (SpellChecker::misspelled(result) && trailing_dot) { if (SpellChecker::misspelled(result) && trailing_dot) {
word = word.append(from_ascii(".")); wl = WordLangTuple(word.append(from_ascii(".")), lang);
wl = WordLangTuple(word, lang);
result = speller->check(wl); result = speller->check(wl);
if (!SpellChecker::misspelled(result)) { if (!SpellChecker::misspelled(result)) {
LYXERR(Debug::GUI, "misspelled word now correct was: \"" << LYXERR(Debug::GUI, "misspelled word is correct with dot: \"" <<
word << "\" [" << word << "\" [" <<
from << ".." << to << "]"); from << ".." << to << "]");
} }