* buffer_funcs.[Ch]: new needsUpdateCounters function

* text.C:
 - LyXText::breakParagraph(): test if needsUpdateCounters() is enough before a full updateCounter
 - LyXText::backspacePos0(): ditto

* text2.C:
 - LyXText::deleteEmptyParagraphMechanism(): ditto


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@13593 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Abdelrazak Younes 2006-04-07 22:16:09 +00:00
parent 98e729c767
commit 4b0a5549b1
4 changed files with 45 additions and 3 deletions

View File

@ -503,6 +503,29 @@ void setCounter(Buffer const & buf, ParIterator & it)
} // anon namespace } // anon namespace
bool needsUpdateCounters(Buffer const & buf, ParIterator & it)
{
switch (it->layout()->labeltype) {
case LABEL_NO_LABEL:
case LABEL_MANUAL:
case LABEL_BIBLIO:
case LABEL_TOP_ENVIRONMENT:
case LABEL_CENTERED_TOP_ENVIRONMENT:
case LABEL_STATIC:
case LABEL_ITEMIZE:
setCounter(buf, it);
return false;
case LABEL_SENSITIVE:
case LABEL_COUNTER:
// do more things with enumerate later
case LABEL_ENUMERATE:
return true;
}
}
void updateCounters(Buffer const & buf) void updateCounters(Buffer const & buf)
{ {
// start over // start over

View File

@ -21,6 +21,7 @@ class Buffer;
class DocIterator; class DocIterator;
class ErrorList; class ErrorList;
class TeXErrors; class TeXErrors;
class ParIterator;
/** /**
* Loads a LyX file \c filename into \c Buffer * Loads a LyX file \c filename into \c Buffer
@ -48,6 +49,13 @@ int countWords(DocIterator const & from, DocIterator const & to);
std::string expandLabel(Buffer const & buf, LyXLayout_ptr const & layout, std::string expandLabel(Buffer const & buf, LyXLayout_ptr const & layout,
bool appendix); bool appendix);
/// updates current counter and/or label if possible.
/**
\retval true if a full updateCounters is required.
\retval false if a full updateCounters is not required.
*/
bool needsUpdateCounters(Buffer const & buf, ParIterator & it);
/// updates all counters /// updates all counters
void updateCounters(Buffer const &); void updateCounters(Buffer const &);

View File

@ -24,6 +24,7 @@
#include "bufferparams.h" #include "bufferparams.h"
#include "BufferView.h" #include "BufferView.h"
#include "cursor.h" #include "cursor.h"
#include "pariterator.h"
#include "coordcache.h" #include "coordcache.h"
#include "CutAndPaste.h" #include "CutAndPaste.h"
#include "debug.h" #include "debug.h"
@ -1087,6 +1088,11 @@ void LyXText::breakParagraph(LCursor & cur, bool keep_layout)
while (!pars_[next_par].empty() && pars_[next_par].isNewline(0)) while (!pars_[next_par].empty() && pars_[next_par].isNewline(0))
pars_[next_par].erase(0); pars_[next_par].erase(0);
ParIterator current_it(cur);
ParIterator next_it(cur); next_it.pit() = next_par;
if (needsUpdateCounters(cur.buffer(), current_it)
|| needsUpdateCounters(cur.buffer(), next_it))
updateCounters(cur.buffer()); updateCounters(cur.buffer());
// Mark "carriage return" as inserted if change tracking: // Mark "carriage return" as inserted if change tracking:
@ -1669,7 +1675,10 @@ bool LyXText::backspacePos0(LCursor & cur)
--cur.pos(); --cur.pos();
// the counters may have changed // the counters may have changed
ParIterator par_it(cur);
if (needsUpdateCounters(cur.buffer(), par_it))
updateCounters(cur.buffer()); updateCounters(cur.buffer());
setCursor(cur, cur.pit(), cur.pos(), false); setCursor(cur, cur.pit(), cur.pos(), false);
} }
return needsUpdate; return needsUpdate;

View File

@ -1274,6 +1274,8 @@ bool LyXText::deleteEmptyParagraphMechanism(LCursor & cur, LCursor & old)
cur.resetAnchor(); cur.resetAnchor();
} }
} }
ParIterator par_it(old);
if (needsUpdateCounters(old.buffer(), par_it))
updateCounters(old.buffer()); updateCounters(old.buffer());
return true; return true;
} }