Am 14.09.2010 um 15:46 schrieb Abdelrazak Younes:

> On 09/14/2010 02:48 PM, [email protected] wrote:
>> Author: switt
>> Date: Tue Sep 14 14:48:03 2010
>> New Revision: 35369
>> URL: 
>> http://www.lyx.org/trac/changeset/35369
>> 
>> 
>> Log:
>> reduce nesting levels in markMisspelledWords; simplify range check of 
>> fontspan
> 
> I have a compile error:
> 
> /home/younes/devel/lyx/trunk/src/Paragraph.cpp: In member function ‘void 
> lyx::Paragraph::Private::markMisspelledWords(const lyx::pos_type&, const 
> lyx::pos_type&, lyx::SpellChecker::Result, const lyx::docstring&, const 
> std::vector<long int, std::allocator<long int> >&)’:
> /home/younes/devel/lyx/trunk/src/Paragraph.cpp:3538: error: no matching 
> function for call to 
> ‘lyx::Paragraph::Private::countSoftbreaks(__gnu_cxx::__normal_iterator<const 
> long int*, std::vector<long int, std::allocator<long int> > >&, 
> __gnu_cxx::__normal_iterator<const long int*, std::vector<long int, 
> std::allocator<long int> > >&, int&)’
> /home/younes/devel/lyx/trunk/src/Paragraph.cpp:366: note: candidates are: int 
> lyx::Paragraph::Private::countSoftbreaks(__gnu_cxx::__normal_iterator<const 
> long int*, std::vector<long int, std::allocator<long int> > >&, 
> __gnu_cxx::__normal_iterator<const long int*, std::vector<long int, 
> std::allocator<long int> > >, lyx::pos_type&) const
> make[2]: *** 
> [src/CMakeFiles/lyx2.0.dir/home/younes/devel/lyx/trunk/src/Paragraph.cpp.o] 
> Error 1
> 
> Abdel.

Of course the function Paragraph::Private::countSoftbreaks() should have int 
argument, 
but why did it compile here with gcc 4.2.1 on Mac and gcc 4.4 on Linux?

What's your environment?

Another question:
I want to replace the map of the speller state by a vector to make it more 
similar to the FontList.
The patch is attached. Is it ok?

Stephan

Index: src/Paragraph.cpp
===================================================================
--- src/Paragraph.cpp   (Revision 35413)
+++ src/Paragraph.cpp   (Arbeitskopie)
@@ -73,9 +73,54 @@
 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
 //
 /////////////////////////////////////////////////////////////////////
@@ -91,7 +136,7 @@
        {
                eraseCoveredRanges(fp);
                if (state != SpellChecker::WORD_OK)
-                       ranges_[fp] = state;
+                       ranges_.push_back(SpellResultRange(fp, state));
        }
 
        void increasePosAfterPos(pos_type pos)
@@ -112,10 +157,8 @@
                RangesIterator et = ranges_.end();
                RangesIterator it = ranges_.begin();
                for (; it != et; ++it) {
-                       FontSpan fc = it->first;
-                       if(fc.first <= pos && pos <= fc.last) {
-                               result = it->second;
-                               break;
+                       if(it->inside(pos)) {
+                               return it->result();
                        }
                }
                return result;
@@ -155,52 +198,35 @@
        }
 
 private:
-       /// store the ranges as map of FontSpan and spell result pairs
-       typedef map<FontSpan, SpellChecker::Result> Ranges;
+       typedef vector<SpellResultRange> Ranges;
        typedef Ranges::const_iterator RangesIterator;
        Ranges ranges_;
-       ///
+       /// the area of the paragraph with pending spell check
        FontSpan refresh_;
        bool needs_refresh_;
+       /// spell state cache version number
        SpellChecker::ChangeNumber current_change_number_;
 
+       
        void eraseCoveredRanges(FontSpan const fp)
        {
                Ranges result;
                RangesIterator et = ranges_.end();
                RangesIterator it = ranges_.begin();
                for (; it != et; ++it) {
-                       FontSpan fc = it->first;
-                       // 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
-                       if (fc.inside(fp.first) || fc.inside(fp.last) ||
-                               fp.inside(fc.first) || fp.inside(fc.last))
-                       {
-                               continue;
-                       }
-                       result[fc] = it->second;
+                       if (!it->covered(fp))
+                               result.push_back(SpellResultRange(it->range(), 
it->result()));
                }
                ranges_ = result;
        }
 
        void correctRangesAfterPos(pos_type pos, int offset)
        {
-               Ranges result;
                RangesIterator et = ranges_.end();
-               RangesIterator it = ranges_.begin();
+               Ranges::iterator it = ranges_.begin();
                for (; it != et; ++it) {
-                       FontSpan m = it->first;
-                       if (m.first > pos) {
-                               m.first += offset;
-                               m.last += offset;
-                       } else if (m.last > pos) {
-                               m.last += offset;
-                       }
-                       result[m] = it->second;
+                       it->shift(pos, offset);
                }
-               ranges_ = result;
        }
 
 };
@@ -3564,6 +3590,11 @@
        pos_type start;
        pos_type endpos;
        d->rangeOfSpellCheck(start, endpos);
+       if (endpos > size()) {
+               LYXERR(Debug::GUI, "should not happen: \"" <<
+                          endpos << ">" << size());
+               endpos = size();
+       }
        if (speller->canCheckParagraph()) {
                // loop until we leave the range
                for (pos_type first = start; first < endpos; ) {

Reply via email to