mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-30 05:12:40 +00:00
Bug: 1025
2003-10-08 Lars Gullik Bj�nnes <larsbj@gullik.net> * text2.C (incrementItemDepth): new function, use a backtracking algorithm to discover the correct item depth. (resetEnumCounterIfNeeded): new function, use a backtracking algorithm to discover if counter reset is needed. (setCounter): use them. Simplify a bit. Add different labels for different item depths for itemize. * paragraph.C (Paragraph): remove initialization of enumdepth (operator=): ditto * paragraph.h: get rid of enumdepth, and use itemdepth both for enumerate and itemize. Change the type of itemdepth to signed char. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@7882 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
49d09f876f
commit
fc1437e74e
@ -188,6 +188,7 @@ src/mathed/ref_inset.C
|
|||||||
src/paragraph.C
|
src/paragraph.C
|
||||||
src/paragraph_funcs.C
|
src/paragraph_funcs.C
|
||||||
src/rowpainter.C
|
src/rowpainter.C
|
||||||
|
src/support/path_defines.C
|
||||||
src/text.C
|
src/text.C
|
||||||
src/text2.C
|
src/text2.C
|
||||||
src/text3.C
|
src/text3.C
|
||||||
|
@ -1,3 +1,18 @@
|
|||||||
|
2003-10-08 Lars Gullik Bjønnes <larsbj@gullik.net>
|
||||||
|
|
||||||
|
* text2.C (incrementItemDepth): new function, use a backtracking
|
||||||
|
algorithm to discover the correct item depth.
|
||||||
|
(resetEnumCounterIfNeeded): new function, use a backtracking
|
||||||
|
algorithm to discover if counter reset is needed.
|
||||||
|
(setCounter): use them. Simplify a bit. Add different labels for
|
||||||
|
different item depths for itemize.
|
||||||
|
|
||||||
|
* paragraph.C (Paragraph): remove initialization of enumdepth
|
||||||
|
(operator=): ditto
|
||||||
|
|
||||||
|
* paragraph.h: get rid of enumdepth, and use itemdepth both for
|
||||||
|
enumerate and itemize. Change the type of itemdepth to signed char.
|
||||||
|
|
||||||
2003-10-08 André Pönitz <poenitz@gmx.net>
|
2003-10-08 André Pönitz <poenitz@gmx.net>
|
||||||
|
|
||||||
* lyxtext.h: make the paragraphs_ a pointer instead a ref to make the
|
* lyxtext.h: make the paragraphs_ a pointer instead a ref to make the
|
||||||
|
@ -54,7 +54,6 @@ using std::ostringstream;
|
|||||||
Paragraph::Paragraph()
|
Paragraph::Paragraph()
|
||||||
: y(0), pimpl_(new Paragraph::Pimpl(this))
|
: y(0), pimpl_(new Paragraph::Pimpl(this))
|
||||||
{
|
{
|
||||||
enumdepth = 0;
|
|
||||||
itemdepth = 0;
|
itemdepth = 0;
|
||||||
params().clear();
|
params().clear();
|
||||||
}
|
}
|
||||||
@ -63,7 +62,6 @@ Paragraph::Paragraph()
|
|||||||
Paragraph::Paragraph(Paragraph const & lp)
|
Paragraph::Paragraph(Paragraph const & lp)
|
||||||
: y(0), text_(lp.text_), pimpl_(new Paragraph::Pimpl(*lp.pimpl_, this))
|
: y(0), text_(lp.text_), pimpl_(new Paragraph::Pimpl(*lp.pimpl_, this))
|
||||||
{
|
{
|
||||||
enumdepth = 0;
|
|
||||||
itemdepth = 0;
|
itemdepth = 0;
|
||||||
// this is because of the dummy layout of the paragraphs that
|
// this is because of the dummy layout of the paragraphs that
|
||||||
// follow footnotes
|
// follow footnotes
|
||||||
@ -93,7 +91,6 @@ void Paragraph::operator=(Paragraph const & lp)
|
|||||||
delete pimpl_;
|
delete pimpl_;
|
||||||
pimpl_ = new Pimpl(*lp.pimpl_, this);
|
pimpl_ = new Pimpl(*lp.pimpl_, this);
|
||||||
|
|
||||||
enumdepth = lp.enumdepth;
|
|
||||||
itemdepth = lp.itemdepth;
|
itemdepth = lp.itemdepth;
|
||||||
// this is because of the dummy layout of the paragraphs that
|
// this is because of the dummy layout of the paragraphs that
|
||||||
// follow footnotes
|
// follow footnotes
|
||||||
|
@ -135,11 +135,8 @@ public:
|
|||||||
///
|
///
|
||||||
void layout(LyXLayout_ptr const & new_layout);
|
void layout(LyXLayout_ptr const & new_layout);
|
||||||
|
|
||||||
///
|
/// This is the item depth, only used by enumerate and itemize
|
||||||
char enumdepth;
|
signed char itemdepth;
|
||||||
|
|
||||||
///
|
|
||||||
char itemdepth;
|
|
||||||
|
|
||||||
///
|
///
|
||||||
InsetBibitem * bibitem() const; // ale970302
|
InsetBibitem * bibitem() const; // ale970302
|
||||||
|
180
src/text2.C
180
src/text2.C
@ -858,7 +858,82 @@ string expandLabel(LyXTextClass const & textclass,
|
|||||||
return textclass.counters().counterLabel(fmt);
|
return textclass.counters().counterLabel(fmt);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void incrementItemDepth(ParagraphList::iterator pit,
|
||||||
|
ParagraphList::iterator first_pit)
|
||||||
|
{
|
||||||
|
int const cur_labeltype = pit->layout()->labeltype;
|
||||||
|
|
||||||
|
if (cur_labeltype != LABEL_ENUMERATE &&
|
||||||
|
cur_labeltype != LABEL_ITEMIZE)
|
||||||
|
return;
|
||||||
|
|
||||||
|
int const cur_depth = pit->getDepth();
|
||||||
|
|
||||||
|
ParagraphList::iterator prev_pit = boost::prior(pit);
|
||||||
|
while (true) {
|
||||||
|
int const prev_depth = prev_pit->getDepth();
|
||||||
|
int const prev_labeltype = prev_pit->layout()->labeltype;
|
||||||
|
if (prev_depth == 0 && cur_depth > 0) {
|
||||||
|
if (prev_labeltype == cur_labeltype) {
|
||||||
|
pit->itemdepth = prev_pit->itemdepth + 1;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
} else if (prev_depth < cur_depth) {
|
||||||
|
if (prev_labeltype == cur_labeltype) {
|
||||||
|
pit->itemdepth = prev_pit->itemdepth + 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else if (prev_depth == cur_depth) {
|
||||||
|
if (prev_labeltype == cur_labeltype) {
|
||||||
|
pit->itemdepth = prev_pit->itemdepth;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (prev_pit == first_pit)
|
||||||
|
break;
|
||||||
|
|
||||||
|
--prev_pit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void resetEnumCounterIfNeeded(ParagraphList::iterator pit,
|
||||||
|
ParagraphList::iterator firstpit,
|
||||||
|
Counters & counters)
|
||||||
|
{
|
||||||
|
if (pit == firstpit)
|
||||||
|
return;
|
||||||
|
|
||||||
|
int const cur_depth = pit->getDepth();
|
||||||
|
ParagraphList::iterator prev_pit = boost::prior(pit);
|
||||||
|
while (true) {
|
||||||
|
int const prev_depth = prev_pit->getDepth();
|
||||||
|
int const prev_labeltype = prev_pit->layout()->labeltype;
|
||||||
|
if (prev_depth <= cur_depth) {
|
||||||
|
if (prev_labeltype != LABEL_ENUMERATE) {
|
||||||
|
switch (pit->itemdepth) {
|
||||||
|
case 0:
|
||||||
|
counters.reset("enumi");
|
||||||
|
case 1:
|
||||||
|
counters.reset("enumii");
|
||||||
|
case 2:
|
||||||
|
counters.reset("enumiii");
|
||||||
|
case 3:
|
||||||
|
counters.reset("enumiv");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (prev_pit == firstpit)
|
||||||
|
break;
|
||||||
|
|
||||||
|
--prev_pit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // anon namespace
|
||||||
|
|
||||||
|
|
||||||
// set the counter of a paragraph. This includes the labels
|
// set the counter of a paragraph. This includes the labels
|
||||||
@ -867,50 +942,24 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
BufferParams const & bufparams = buf.params();
|
BufferParams const & bufparams = buf.params();
|
||||||
LyXTextClass const & textclass = bufparams.getLyXTextClass();
|
LyXTextClass const & textclass = bufparams.getLyXTextClass();
|
||||||
LyXLayout_ptr const & layout = pit->layout();
|
LyXLayout_ptr const & layout = pit->layout();
|
||||||
|
ParagraphList::iterator first_pit = ownerParagraphs().begin();
|
||||||
|
Counters & counters = textclass.counters();
|
||||||
|
|
||||||
if (pit != ownerParagraphs().begin()) {
|
// Always reset
|
||||||
|
pit->itemdepth = 0;
|
||||||
|
|
||||||
|
if (pit == first_pit) {
|
||||||
|
pit->params().appendix(pit->params().startOfAppendix());
|
||||||
|
} else {
|
||||||
pit->params().appendix(boost::prior(pit)->params().appendix());
|
pit->params().appendix(boost::prior(pit)->params().appendix());
|
||||||
if (!pit->params().appendix() &&
|
if (!pit->params().appendix() &&
|
||||||
pit->params().startOfAppendix()) {
|
pit->params().startOfAppendix()) {
|
||||||
pit->params().appendix(true);
|
pit->params().appendix(true);
|
||||||
textclass.counters().reset();
|
textclass.counters().reset();
|
||||||
}
|
}
|
||||||
pit->enumdepth = boost::prior(pit)->enumdepth;
|
|
||||||
pit->itemdepth = boost::prior(pit)->itemdepth;
|
|
||||||
} else {
|
|
||||||
pit->params().appendix(pit->params().startOfAppendix());
|
|
||||||
pit->enumdepth = 0;
|
|
||||||
pit->itemdepth = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Maybe we have to increment the enumeration depth.
|
// Maybe we have to increment the item depth.
|
||||||
// Bibliographies can't have their depth changed ie. they
|
incrementItemDepth(pit, first_pit);
|
||||||
// are always of depth 0
|
|
||||||
if (pit != ownerParagraphs().begin()
|
|
||||||
&& boost::prior(pit)->getDepth() < pit->getDepth()
|
|
||||||
&& boost::prior(pit)->layout()->labeltype == LABEL_ENUMERATE
|
|
||||||
&& pit->enumdepth < 3
|
|
||||||
&& layout->labeltype != LABEL_BIBLIO) {
|
|
||||||
pit->enumdepth++;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Maybe we have to increment the enumeration depth.
|
|
||||||
// Bibliographies can't have their depth changed ie. they
|
|
||||||
// are always of depth 0
|
|
||||||
if (pit != ownerParagraphs().begin()
|
|
||||||
&& boost::prior(pit)->getDepth() < pit->getDepth()
|
|
||||||
&& boost::prior(pit)->layout()->labeltype == LABEL_ITEMIZE
|
|
||||||
&& pit->itemdepth < 3
|
|
||||||
&& layout->labeltype != LABEL_BIBLIO) {
|
|
||||||
pit->itemdepth++;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Maybe we have to decrement the enumeration depth, see note above
|
|
||||||
if (pit != ownerParagraphs().begin()
|
|
||||||
&& boost::prior(pit)->getDepth() > pit->getDepth()
|
|
||||||
&& layout->labeltype != LABEL_BIBLIO) {
|
|
||||||
pit->enumdepth = depthHook(pit, ownerParagraphs(),
|
|
||||||
pit->getDepth())->enumdepth;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// erase what was there before
|
// erase what was there before
|
||||||
@ -927,25 +976,42 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
if (layout->labeltype == LABEL_COUNTER) {
|
if (layout->labeltype == LABEL_COUNTER) {
|
||||||
BufferParams const & bufparams = buf.params();
|
BufferParams const & bufparams = buf.params();
|
||||||
LyXTextClass const & textclass = bufparams.getLyXTextClass();
|
LyXTextClass const & textclass = bufparams.getLyXTextClass();
|
||||||
textclass.counters().step(layout->counter);
|
counters.step(layout->counter);
|
||||||
string label = expandLabel(textclass, layout, pit->params().appendix());
|
string label = expandLabel(textclass, layout, pit->params().appendix());
|
||||||
pit->params().labelString(label);
|
pit->params().labelString(label);
|
||||||
textclass.counters().reset("enum");
|
|
||||||
} else if (layout->labeltype == LABEL_ITEMIZE) {
|
} else if (layout->labeltype == LABEL_ITEMIZE) {
|
||||||
// At some point of time we should do something more clever here,
|
// At some point of time we should do something more
|
||||||
// like:
|
// clever here, like:
|
||||||
// pit->params().labelString(
|
// pit->params().labelString(
|
||||||
// bufparams.user_defined_bullet(pit->itemdepth).getText());
|
// bufparams.user_defined_bullet(pit->itemdepth).getText());
|
||||||
// for now, use a static label
|
// for now, use a simple hardcoded label
|
||||||
pit->params().labelString("*");
|
string itemlabel;
|
||||||
textclass.counters().reset("enum");
|
switch (pit->itemdepth) {
|
||||||
|
case 0:
|
||||||
|
itemlabel = "*";
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
itemlabel = "-";
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
itemlabel = "@";
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
itemlabel = "·";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pit->params().labelString(itemlabel);
|
||||||
} else if (layout->labeltype == LABEL_ENUMERATE) {
|
} else if (layout->labeltype == LABEL_ENUMERATE) {
|
||||||
|
// Maybe we have to reset the enumeration counter.
|
||||||
|
resetEnumCounterIfNeeded(pit, first_pit, counters);
|
||||||
|
|
||||||
// FIXME
|
// FIXME
|
||||||
// Yes I know this is a really, really! bad solution
|
// Yes I know this is a really, really! bad solution
|
||||||
// (Lgb)
|
// (Lgb)
|
||||||
string enumcounter = "enum";
|
string enumcounter = "enum";
|
||||||
|
|
||||||
switch (pit->enumdepth) {
|
switch (pit->itemdepth) {
|
||||||
case 2:
|
case 2:
|
||||||
enumcounter += 'i';
|
enumcounter += 'i';
|
||||||
case 1:
|
case 1:
|
||||||
@ -961,12 +1027,12 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
textclass.counters().step(enumcounter);
|
counters.step(enumcounter);
|
||||||
|
|
||||||
pit->params().labelString(textclass.counters().enumLabel(enumcounter));
|
pit->params().labelString(counters.enumLabel(enumcounter));
|
||||||
} else if (layout->labeltype == LABEL_BIBLIO) {// ale970302
|
} else if (layout->labeltype == LABEL_BIBLIO) {// ale970302
|
||||||
textclass.counters().step("bibitem");
|
counters.step("bibitem");
|
||||||
int number = textclass.counters().value("bibitem");
|
int number = counters.value("bibitem");
|
||||||
if (pit->bibitem()) {
|
if (pit->bibitem()) {
|
||||||
pit->bibitem()->setCounter(number);
|
pit->bibitem()->setCounter(number);
|
||||||
pit->params().labelString(layout->labelstring());
|
pit->params().labelString(layout->labelstring());
|
||||||
@ -991,7 +1057,7 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
break;
|
break;
|
||||||
} else {
|
} else {
|
||||||
Paragraph const * owner = &ownerPar(buf, in);
|
Paragraph const * owner = &ownerPar(buf, in);
|
||||||
tmppit = ownerParagraphs().begin();
|
tmppit = first_pit;
|
||||||
for ( ; tmppit != end; ++tmppit)
|
for ( ; tmppit != end; ++tmppit)
|
||||||
if (&*tmppit == owner)
|
if (&*tmppit == owner)
|
||||||
break;
|
break;
|
||||||
@ -1010,7 +1076,7 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
|
|
||||||
Floating const & fl = textclass.floats().getType(type);
|
Floating const & fl = textclass.floats().getType(type);
|
||||||
|
|
||||||
textclass.counters().step(fl.type());
|
counters.step(fl.type());
|
||||||
|
|
||||||
// Doesn't work... yet.
|
// Doesn't work... yet.
|
||||||
s = bformat(_("%1$s #:"), buf.B_(fl.name()));
|
s = bformat(_("%1$s #:"), buf.B_(fl.name()));
|
||||||
@ -1022,20 +1088,6 @@ void LyXText::setCounter(Buffer const & buf, ParagraphList::iterator pit)
|
|||||||
}
|
}
|
||||||
pit->params().labelString(s);
|
pit->params().labelString(s);
|
||||||
|
|
||||||
// reset the enumeration counter. They are always reset
|
|
||||||
// when there is any other layout between
|
|
||||||
// Just fall-through between the cases so that all
|
|
||||||
// enum counters deeper than enumdepth is also reset.
|
|
||||||
switch (pit->enumdepth) {
|
|
||||||
case 0:
|
|
||||||
textclass.counters().reset("enumi");
|
|
||||||
case 1:
|
|
||||||
textclass.counters().reset("enumii");
|
|
||||||
case 2:
|
|
||||||
textclass.counters().reset("enumiii");
|
|
||||||
case 3:
|
|
||||||
textclass.counters().reset("enumiv");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user