mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-11 11:08:41 +00:00
My simple testing of Martins patch, shows that it works as expected.
Applied. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@4883 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
6b5c9696b6
commit
960db78b52
@ -1,3 +1,11 @@
|
|||||||
|
2002-08-06 Martin Vermeer <martin.vermeer@hut.fi>
|
||||||
|
|
||||||
|
* counters.[Ch]
|
||||||
|
* text2.C
|
||||||
|
* paragraph.[Ch]
|
||||||
|
* makefile.am: move counters functionality over from
|
||||||
|
text2.C/paragraph.[Ch] to counters.[Ch], and make proper C++.
|
||||||
|
|
||||||
2002-08-06 John Levon <levon@movementarian.org>
|
2002-08-06 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* WordLangTuple.h: new file for word + language code tuple
|
* WordLangTuple.h: new file for word + language code tuple
|
||||||
@ -27,70 +35,78 @@
|
|||||||
2002-08-06 John Levon <levon@movementarian.org>
|
2002-08-06 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* pspell.C: fix a crash, and allow new aspell to work
|
* pspell.C: fix a crash, and allow new aspell to work
|
||||||
|
|
||||||
2002-08-06 John Levon <levon@movementarian.org>
|
2002-08-06 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* lyxfunc.C:
|
* lyxfunc.C:
|
||||||
* kbmap.C: small cleanup
|
* kbmap.C: small cleanup
|
||||||
|
|
||||||
* vspace.h:
|
* vspace.h:
|
||||||
* vspace.C: add const
|
* vspace.C: add const
|
||||||
|
|
||||||
2002-08-05 John Levon <levon@movementarian.org>
|
2002-08-05 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* LyXAction.C: back to tabular-insert
|
* LyXAction.C: back to tabular-insert
|
||||||
|
|
||||||
2002-08-04 John Levon <levon@movementarian.org>
|
2002-08-04 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* BufferView.h:
|
* BufferView.h:
|
||||||
* BufferView.C: cosmetic change
|
* BufferView.C: cosmetic change
|
||||||
|
|
||||||
* BufferView_pimpl.C: s/IGNORE_CODE/NOTE_CODE/
|
* BufferView_pimpl.C: s/IGNORE_CODE/NOTE_CODE/
|
||||||
|
|
||||||
* bufferlist.C:
|
* bufferlist.C:
|
||||||
* buffer.h:
|
* buffer.h:
|
||||||
* buffer.C:
|
* buffer.C:
|
||||||
* lyxcb.h:
|
* lyxcb.h:
|
||||||
* lyxcb.C:
|
* lyxcb.C:
|
||||||
* lyxserver.C:
|
* lyxserver.C:
|
||||||
* lyxvc.C:
|
* lyxvc.C:
|
||||||
* vc-backend.C:
|
* vc-backend.C:
|
||||||
* BufferView2.C: purge all "Lyx" not "LyX" strings
|
* BufferView2.C: purge all "Lyx" not "LyX" strings
|
||||||
|
|
||||||
* lyxcursor.h:
|
* lyxcursor.h:
|
||||||
* lyxcursor.C: attempt to add some documentation
|
* lyxcursor.C: attempt to add some documentation
|
||||||
|
|
||||||
* lyxfunc.C:
|
* lyxfunc.C:
|
||||||
* commandtags.h:
|
* commandtags.h:
|
||||||
* LyXAction.C:
|
* LyXAction.C:
|
||||||
* ToolbarDefaults.C:
|
* ToolbarDefaults.C:
|
||||||
* BufferView_pimpl.C: remove LFUN_DIALOG_TABULAR_INSERT and
|
* BufferView_pimpl.C: remove LFUN_DIALOG_TABULAR_INSERT and
|
||||||
merge with LFUN_TABULAR_INSERT
|
merge with LFUN_TABULAR_INSERT
|
||||||
|
|
||||||
* Makefile.am:
|
* Makefile.am:
|
||||||
* SpellBase.h:
|
* SpellBase.h:
|
||||||
* ispell.h:
|
* ispell.h:
|
||||||
* ispell.C:
|
* ispell.C:
|
||||||
* pspell.h:
|
* pspell.h:
|
||||||
* pspell.C: split up i/pspell implementations into separate
|
* pspell.C: split up i/pspell implementations into separate
|
||||||
files, many cleanups
|
files, many cleanups
|
||||||
|
|
||||||
* lyxlex.C: unrevert, with a proper fix for prefix.length() == 0
|
* lyxlex.C: unrevert, with a proper fix for prefix.length() == 0
|
||||||
|
|
||||||
* text2.C: some cleanup
|
* text2.C: some cleanup
|
||||||
|
|
||||||
* lyxfunc.C: don't check for isp_command == "none" any more, it
|
* lyxfunc.C: don't check for isp_command == "none" any more, it
|
||||||
didn't make any sense
|
didn't make any sense
|
||||||
|
|
||||||
|
2002-08-06 Martin Vermeer <martin.vermeer@hut.fi>
|
||||||
|
|
||||||
|
* counters.[Ch]
|
||||||
|
* text2.C
|
||||||
|
* paragraph.[Ch]
|
||||||
|
* makefile.am: move counters functionality over
|
||||||
|
from text2.C/paragraph.[Ch] to counters.[Ch], and
|
||||||
|
make proper C++.
|
||||||
2002-08-02 John Levon <levon@movementarian.org>
|
2002-08-02 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* buffer.C: s/lyxconvert/lyx2lyx/
|
* buffer.C: s/lyxconvert/lyx2lyx/
|
||||||
|
|
||||||
2002-08-02 Angus Leeming <leeming@lyx.org>
|
2002-08-02 Angus Leeming <leeming@lyx.org>
|
||||||
|
|
||||||
* lyxlex.C: revert John's change as it breaks reading of the user
|
* lyxlex.C: revert John's change as it breaks reading of the user
|
||||||
preamble.
|
preamble.
|
||||||
|
|
||||||
2002-08-02 Angus Leeming <leeming@lyx.org>
|
2002-08-02 Angus Leeming <leeming@lyx.org>
|
||||||
|
|
||||||
* importer.C (Import):
|
* importer.C (Import):
|
||||||
@ -100,14 +116,14 @@
|
|||||||
2002-08-02 John Levon <levon@movementarian.org>
|
2002-08-02 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* lyxlex.C: small cleanup
|
* lyxlex.C: small cleanup
|
||||||
|
|
||||||
2002-08-02 John Levon <levon@movementarian.org>
|
2002-08-02 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* text2.C (status): small cleanup, no logic change
|
* text2.C (status): small cleanup, no logic change
|
||||||
|
|
||||||
2002-08-01 John Levon <levon@movementarian.org>
|
2002-08-01 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* buffer.h:
|
* buffer.h:
|
||||||
* buffer.C (writeFile): don't output alerts, caller
|
* buffer.C (writeFile): don't output alerts, caller
|
||||||
handles this
|
handles this
|
||||||
|
|
||||||
@ -120,20 +136,20 @@
|
|||||||
|
|
||||||
* lyxserver.C: don't let incidental errors get
|
* lyxserver.C: don't let incidental errors get
|
||||||
in the way (errno)
|
in the way (errno)
|
||||||
|
|
||||||
2002-07-30 John Levon <levon@movementarian.org>
|
2002-07-30 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* lyxfunc.C: disable character dialog in ERT inset (partial fix)
|
* lyxfunc.C: disable character dialog in ERT inset (partial fix)
|
||||||
|
|
||||||
2002-07-30 John Levon <levon@movementarian.org>
|
2002-07-30 John Levon <levon@movementarian.org>
|
||||||
|
|
||||||
* lyxserver.h:
|
* lyxserver.h:
|
||||||
* lyxserver.C: remove I/O callback too
|
* lyxserver.C: remove I/O callback too
|
||||||
|
|
||||||
2002-07-30 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
|
2002-07-30 Jean-Marc Lasgouttes <lasgouttes@freesurf.fr>
|
||||||
|
|
||||||
* lyxfunc.C (getStatus): disable LFUN_LATEX_LOG when there is no
|
* lyxfunc.C (getStatus): disable LFUN_LATEX_LOG when there is no
|
||||||
log.
|
log.
|
||||||
|
|
||||||
2002-07-29 Lars Gullik Bjønnes <larsbj@gullik.net>
|
2002-07-29 Lars Gullik Bjønnes <larsbj@gullik.net>
|
||||||
|
|
||||||
|
@ -35,8 +35,6 @@ EXTRA_DIST = config.h.in stamp-h.in cheaders ext_l10n.h version.C.in \
|
|||||||
Sectioning.C \
|
Sectioning.C \
|
||||||
Variables.C \
|
Variables.C \
|
||||||
Variables.h \
|
Variables.h \
|
||||||
counters.C \
|
|
||||||
counters.h \
|
|
||||||
tracer.C \
|
tracer.C \
|
||||||
tracer.h
|
tracer.h
|
||||||
|
|
||||||
@ -109,6 +107,8 @@ lyx_SOURCES = \
|
|||||||
config.h.in \
|
config.h.in \
|
||||||
converter.C \
|
converter.C \
|
||||||
converter.h \
|
converter.h \
|
||||||
|
counters.C \
|
||||||
|
counters.h \
|
||||||
debug.C \
|
debug.C \
|
||||||
debug.h \
|
debug.h \
|
||||||
encoding.C \
|
encoding.C \
|
||||||
|
270
src/counters.C
270
src/counters.C
@ -17,8 +17,10 @@
|
|||||||
|
|
||||||
#include "counters.h"
|
#include "counters.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
#include "support/lstrings.h"
|
||||||
|
|
||||||
using std::endl;
|
using std::endl;
|
||||||
|
using std::vector;
|
||||||
|
|
||||||
|
|
||||||
Counter::Counter()
|
Counter::Counter()
|
||||||
@ -48,7 +50,6 @@ int Counter::value() const
|
|||||||
void Counter::step()
|
void Counter::step()
|
||||||
{
|
{
|
||||||
++value_;
|
++value_;
|
||||||
onstep.emit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -57,15 +58,54 @@ void Counter::reset()
|
|||||||
value_ = 0;
|
value_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
string Counter::master() const
|
||||||
Counters::~Counters()
|
|
||||||
{
|
{
|
||||||
// We need this since we store the Counter's as pointers in
|
return master_;
|
||||||
// the counterList.
|
}
|
||||||
for (CounterList::iterator it = counterList.begin();
|
|
||||||
it != counterList.end();
|
void Counter::setMaster(string const & m)
|
||||||
++it)
|
{
|
||||||
delete it->second;
|
master_ = m;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Counters::Counters()
|
||||||
|
{
|
||||||
|
// Ehh, should this take a textclass arg?
|
||||||
|
|
||||||
|
// Sectioning counters:
|
||||||
|
newCounter("part");
|
||||||
|
newCounter("chapter");
|
||||||
|
newCounter("section", "chapter");
|
||||||
|
newCounter("subsection", "section");
|
||||||
|
newCounter("subsubsection", "subsection");
|
||||||
|
newCounter("paragraph", "subsubsection");
|
||||||
|
newCounter("subparagraph", "paragraph");
|
||||||
|
|
||||||
|
sects.push_back("chapter");
|
||||||
|
sects.push_back("section");
|
||||||
|
sects.push_back("subsection");
|
||||||
|
sects.push_back("subsubsection");
|
||||||
|
sects.push_back("paragraph");
|
||||||
|
sects.push_back("subparagraph");
|
||||||
|
|
||||||
|
// Enumeration counters:
|
||||||
|
newCounter("enumi");
|
||||||
|
newCounter("enumii", "enumi");
|
||||||
|
newCounter("enumiii", "enumii");
|
||||||
|
newCounter("enumiv", "enumiii");
|
||||||
|
|
||||||
|
enums.push_back("enumi");
|
||||||
|
enums.push_back("enumii");
|
||||||
|
enums.push_back("enumiii");
|
||||||
|
enums.push_back("enumiv");
|
||||||
|
|
||||||
|
// Biblio:
|
||||||
|
newCounter("bibitem");
|
||||||
|
|
||||||
|
// Float counters:
|
||||||
|
newCounter("Figure");
|
||||||
|
newCounter("Table");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -73,36 +113,37 @@ void Counters::newCounter(string const & newc)
|
|||||||
{
|
{
|
||||||
// First check if newc already exist
|
// First check if newc already exist
|
||||||
CounterList::iterator cit = counterList.find(newc);
|
CounterList::iterator cit = counterList.find(newc);
|
||||||
// if alrady exist give warning and return
|
// if already exist give warning and return
|
||||||
if (cit != counterList.end()) {
|
if (cit != counterList.end()) {
|
||||||
lyxerr << "The new counter already exist." << endl;
|
lyxerr << "The new counter already exists." << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
counterList[newc] = new Counter;
|
counterList[newc];
|
||||||
|
cit = counterList.find(newc);
|
||||||
|
cit->second.setMaster("");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Counters::newCounter(string const & newc, string const & oldc)
|
void Counters::newCounter(string const & newc, string const & masterc)
|
||||||
{
|
{
|
||||||
// First check if newc already exist
|
// First check if newc already exists
|
||||||
CounterList::iterator cit = counterList.find(newc);
|
CounterList::iterator cit = counterList.find(newc);
|
||||||
// if already existant give warning and return
|
// if already existant give warning and return
|
||||||
if (cit != counterList.end()) {
|
if (cit != counterList.end()) {
|
||||||
lyxerr << "The new counter already exist." << endl;
|
lyxerr << "The new counter already exists." << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// then check if oldc exist
|
// then check if masterc exists
|
||||||
CounterList::iterator it = counterList.find(oldc);
|
CounterList::iterator it = counterList.find(masterc);
|
||||||
// if not give warning and return
|
// if not give warning and return
|
||||||
if (it == counterList.end()) {
|
if (it == counterList.end()) {
|
||||||
lyxerr << "The old counter does not exist." << endl;
|
lyxerr << "The master counter does not exist." << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Counter * tmp = new Counter;
|
counterList[newc];
|
||||||
it->second->onstep.connect(SigC::slot(tmp,
|
cit = counterList.find(newc);
|
||||||
&Counter::reset));
|
cit->second.setMaster(masterc);
|
||||||
counterList[newc] = tmp;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -110,10 +151,10 @@ void Counters::set(string const & ctr, int val)
|
|||||||
{
|
{
|
||||||
CounterList::iterator it = counterList.find(ctr);
|
CounterList::iterator it = counterList.find(ctr);
|
||||||
if (it == counterList.end()) {
|
if (it == counterList.end()) {
|
||||||
lyxerr << "Counter does not exist." << endl;
|
lyxerr << "set: Counter does not exist: " << ctr << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
it->second->set(val);
|
it->second.set(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -121,10 +162,10 @@ void Counters::addto(string const & ctr, int val)
|
|||||||
{
|
{
|
||||||
CounterList::iterator it = counterList.find(ctr);
|
CounterList::iterator it = counterList.find(ctr);
|
||||||
if (it == counterList.end()) {
|
if (it == counterList.end()) {
|
||||||
lyxerr << "Counter does not exist." << endl;
|
lyxerr << "addto: Counter does not exist: " << ctr << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
it->second->addto(val);
|
it->second.addto(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -132,10 +173,10 @@ int Counters::value(string const & ctr) const
|
|||||||
{
|
{
|
||||||
CounterList::const_iterator cit = counterList.find(ctr);
|
CounterList::const_iterator cit = counterList.find(ctr);
|
||||||
if (cit == counterList.end()) {
|
if (cit == counterList.end()) {
|
||||||
lyxerr << "Counter does not exist." << endl;
|
lyxerr << "value: Counter does not exist: " << ctr << endl;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return cit->second->value();
|
return cit->second.value();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -143,8 +184,177 @@ void Counters::step(string const & ctr)
|
|||||||
{
|
{
|
||||||
CounterList::iterator it = counterList.find(ctr);
|
CounterList::iterator it = counterList.find(ctr);
|
||||||
if (it == counterList.end()) {
|
if (it == counterList.end()) {
|
||||||
lyxerr << "Counter does not exist." << endl;
|
lyxerr << "step: Counter does not exist: " << ctr << endl;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
it->second->step();
|
|
||||||
|
it->second.step();
|
||||||
|
it = counterList.begin();
|
||||||
|
CounterList::iterator end = counterList.end();
|
||||||
|
for (; it != end; ++it) {
|
||||||
|
if (it->second.master() == ctr) {
|
||||||
|
it->second.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Counters::reset(string const & match)
|
||||||
|
{
|
||||||
|
CounterList::iterator it = counterList.begin();
|
||||||
|
CounterList::iterator end = counterList.end();
|
||||||
|
for (; it != end; ++it) {
|
||||||
|
if (it->first.find(match) != string::npos || match == "")
|
||||||
|
it->second.reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Counters::copy(Counters & from, Counters & to, string const & match)
|
||||||
|
{
|
||||||
|
CounterList::iterator it = counterList.begin();
|
||||||
|
CounterList::iterator end = counterList.end();
|
||||||
|
for (; it != end; ++it) {
|
||||||
|
if (it->first.find(match) != string::npos || match == "") {
|
||||||
|
to.set(it->first, from.value(it->first));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
inline
|
||||||
|
char loweralphaCounter(int n)
|
||||||
|
{
|
||||||
|
if (n < 1 || n > 26)
|
||||||
|
return '?';
|
||||||
|
else
|
||||||
|
return 'a' + n - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
char alphaCounter(int n)
|
||||||
|
{
|
||||||
|
if (n < 1 || n > 26)
|
||||||
|
return '?';
|
||||||
|
else
|
||||||
|
return 'A' + n - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
char hebrewCounter(int n)
|
||||||
|
{
|
||||||
|
static const char hebrew[22] = {
|
||||||
|
'à', 'á', 'â', 'ã', 'ä', 'å', 'æ', 'ç', 'è',
|
||||||
|
'é', 'ë', 'ì', 'î', 'ð', 'ñ', 'ò', 'ô', 'ö',
|
||||||
|
'÷', 'ø', 'ù', 'ú'
|
||||||
|
};
|
||||||
|
if (n < 1 || n > 22)
|
||||||
|
return '?';
|
||||||
|
else
|
||||||
|
return hebrew[n-1];
|
||||||
|
}
|
||||||
|
|
||||||
|
inline
|
||||||
|
string const romanCounter(int n)
|
||||||
|
{
|
||||||
|
static char const * roman[20] = {
|
||||||
|
"i", "ii", "iii", "iv", "v",
|
||||||
|
"vi", "vii", "viii", "ix", "x",
|
||||||
|
"xi", "xii", "xiii", "xiv", "xv",
|
||||||
|
"xvi", "xvii", "xviii", "xix", "xx"
|
||||||
|
};
|
||||||
|
if (n < 1 || n > 20)
|
||||||
|
return "??";
|
||||||
|
else
|
||||||
|
return roman[n-1];
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace anon
|
||||||
|
|
||||||
|
string Counters::labelItem(string const & ctr,
|
||||||
|
string const & numbertype,
|
||||||
|
string const & langtype,
|
||||||
|
bool first)
|
||||||
|
{
|
||||||
|
ostringstream s, o;
|
||||||
|
CounterList::iterator it = counterList.find(ctr);
|
||||||
|
if (it == counterList.end()) {
|
||||||
|
lyxerr << "Counter does not exist." << endl;
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
string mstr = it->second.master();
|
||||||
|
if (!first) {
|
||||||
|
s << "." << value(ctr);
|
||||||
|
} else {
|
||||||
|
if (numbertype == "sectioning" || numbertype == "appendix") {
|
||||||
|
if (numbertype == "appendix") {
|
||||||
|
if (langtype == "hebrew") {
|
||||||
|
o << hebrewCounter(value(ctr));
|
||||||
|
} else {
|
||||||
|
o << alphaCounter(value(ctr));
|
||||||
|
}
|
||||||
|
} else o << value(ctr);
|
||||||
|
}
|
||||||
|
s << o.str();
|
||||||
|
}
|
||||||
|
return s.str();
|
||||||
|
}
|
||||||
|
|
||||||
|
string Counters::numberLabel(string const & ctr,
|
||||||
|
string const & numbertype,
|
||||||
|
string const & langtype,
|
||||||
|
int head)
|
||||||
|
{
|
||||||
|
ostringstream s, o;
|
||||||
|
if (numbertype == "sectioning" || numbertype == "appendix") {
|
||||||
|
if (ctr == "chapter" && head == 0) {
|
||||||
|
s << labelItem("chapter", numbertype, langtype, true);
|
||||||
|
} else if (ctr == "section" && head <= 1) {
|
||||||
|
s << numberLabel("chapter", numbertype, langtype, head)
|
||||||
|
<< labelItem("section", numbertype, langtype, head == 1);
|
||||||
|
} else if (ctr == "subsection" && head <= 2) {
|
||||||
|
s << numberLabel("section", numbertype, langtype, head)
|
||||||
|
<< labelItem("subsection", numbertype, langtype, head == 2);
|
||||||
|
} else if (ctr == "subsubsection" && head <= 3) {
|
||||||
|
s << numberLabel("subsection", numbertype, langtype, head)
|
||||||
|
<< labelItem("subsubsection", numbertype, langtype, head == 3);
|
||||||
|
} else if (ctr == "paragraph" && head <= 4) {
|
||||||
|
s << numberLabel("subsubsection", numbertype, langtype, head)
|
||||||
|
<< labelItem("paragraph", numbertype, langtype, head == 4);
|
||||||
|
} else if (ctr == "subparagraph" && head <= 5) {
|
||||||
|
s << numberLabel("paragraph", numbertype, langtype, head)
|
||||||
|
<< labelItem("subparagraph", numbertype, langtype, head == 5);
|
||||||
|
} else if (ctr == "Figure" || ctr == "Table") {
|
||||||
|
// figure, table, ...
|
||||||
|
lyxerr << "Counter:" << ctr << endl;
|
||||||
|
s << numberLabel("chapter", numbertype, langtype, head)
|
||||||
|
<< labelItem(ctr, numbertype, langtype, head == 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (numbertype == "enumeration") {
|
||||||
|
ostringstream ei, eii, eiii, eiv;
|
||||||
|
//string ei, eiii, eiv;
|
||||||
|
//char eii;
|
||||||
|
if (langtype == "hebrew") {
|
||||||
|
ei << '.' << value("enumi");
|
||||||
|
eii << '(' << hebrewCounter(value("enumii")) << ')';
|
||||||
|
eiii << '.' << romanCounter(value("enumiii"));
|
||||||
|
eiv << '.' << alphaCounter(value("enumiv"));
|
||||||
|
} else {
|
||||||
|
ei << value("enumi") << '.';
|
||||||
|
eii << '(' << loweralphaCounter(value("enumii")) << ')';
|
||||||
|
eiii << romanCounter(value("enumiii")) << '.';
|
||||||
|
eiv << alphaCounter(value("enumiv")) << '.';
|
||||||
|
}
|
||||||
|
if (ctr == "enumii") {
|
||||||
|
s << eii.str();
|
||||||
|
} else if (ctr == "enumi") {
|
||||||
|
s << ei.str();
|
||||||
|
} else if (ctr == "enumiii") {
|
||||||
|
s << eiii.str();
|
||||||
|
} else if (ctr == "enumiv") {
|
||||||
|
s << eiv.str();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return s.str();
|
||||||
}
|
}
|
||||||
|
@ -19,14 +19,11 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "LString.h"
|
#include "LString.h"
|
||||||
|
|
||||||
#include <boost/signals/signal0.hpp>
|
|
||||||
#include <boost/signals/trackable.hpp>
|
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
///
|
///
|
||||||
class Counter : public boost::trackable {
|
class Counter {
|
||||||
public:
|
public:
|
||||||
///
|
///
|
||||||
Counter();
|
Counter();
|
||||||
@ -41,10 +38,15 @@ public:
|
|||||||
///
|
///
|
||||||
void reset();
|
void reset();
|
||||||
///
|
///
|
||||||
boost::signal0<void> onstep;
|
string master() const;
|
||||||
private:
|
|
||||||
///
|
///
|
||||||
|
void setMaster(string const & m);
|
||||||
|
///
|
||||||
|
|
||||||
|
private:
|
||||||
int value_;
|
int value_;
|
||||||
|
///
|
||||||
|
string master_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -54,7 +56,9 @@ private:
|
|||||||
class Counters {
|
class Counters {
|
||||||
public:
|
public:
|
||||||
///
|
///
|
||||||
~Counters();
|
Counters();
|
||||||
|
///
|
||||||
|
//~Counters();
|
||||||
///
|
///
|
||||||
void newCounter(string const & newc);
|
void newCounter(string const & newc);
|
||||||
///
|
///
|
||||||
@ -67,12 +71,29 @@ public:
|
|||||||
int value(string const & ctr) const;
|
int value(string const & ctr) const;
|
||||||
///
|
///
|
||||||
void step(string const & ctr);
|
void step(string const & ctr);
|
||||||
// string refstep(string const & cou);
|
///
|
||||||
|
void reset(string const & match = "");
|
||||||
|
///
|
||||||
|
void copy(Counters & from, Counters & to, string const & match = "");
|
||||||
|
///
|
||||||
|
string labelItem(string const & ctr,
|
||||||
|
string const & labeltype,
|
||||||
|
string const & langtype = "latin",
|
||||||
|
bool first = false);
|
||||||
|
///
|
||||||
|
string numberLabel(string const & ctr,
|
||||||
|
string const & labeltype,
|
||||||
|
string const & langtype = "latin",
|
||||||
|
int head = 0);
|
||||||
|
///
|
||||||
|
std::vector<string> enums, sects;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
///
|
///
|
||||||
typedef std::map<string, Counter*> CounterList;
|
typedef std::map<string, Counter> CounterList;
|
||||||
///
|
///
|
||||||
CounterList counterList;
|
CounterList counterList;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -77,8 +77,6 @@ extern BufferView * current_view;
|
|||||||
Paragraph::Paragraph()
|
Paragraph::Paragraph()
|
||||||
: pimpl_(new Paragraph::Pimpl(this))
|
: pimpl_(new Paragraph::Pimpl(this))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 10; ++i)
|
|
||||||
setCounter(i, 0);
|
|
||||||
next_ = 0;
|
next_ = 0;
|
||||||
previous_ = 0;
|
previous_ = 0;
|
||||||
enumdepth = 0;
|
enumdepth = 0;
|
||||||
@ -92,8 +90,6 @@ Paragraph::Paragraph()
|
|||||||
Paragraph::Paragraph(Paragraph * par)
|
Paragraph::Paragraph(Paragraph * par)
|
||||||
: pimpl_(new Paragraph::Pimpl(this))
|
: pimpl_(new Paragraph::Pimpl(this))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 10; ++i)
|
|
||||||
setCounter(i, 0);
|
|
||||||
enumdepth = 0;
|
enumdepth = 0;
|
||||||
itemdepth = 0;
|
itemdepth = 0;
|
||||||
|
|
||||||
@ -113,8 +109,6 @@ Paragraph::Paragraph(Paragraph * par)
|
|||||||
Paragraph::Paragraph(Paragraph const & lp, bool same_ids)
|
Paragraph::Paragraph(Paragraph const & lp, bool same_ids)
|
||||||
: pimpl_(new Paragraph::Pimpl(*lp.pimpl_, this, same_ids))
|
: pimpl_(new Paragraph::Pimpl(*lp.pimpl_, this, same_ids))
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 10; ++i)
|
|
||||||
setCounter(i, 0);
|
|
||||||
enumdepth = 0;
|
enumdepth = 0;
|
||||||
itemdepth = 0;
|
itemdepth = 0;
|
||||||
next_ = 0;
|
next_ = 0;
|
||||||
@ -2154,25 +2148,6 @@ void Paragraph::clearContents()
|
|||||||
pimpl_->clear();
|
pimpl_->clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Paragraph::setCounter(int i, int v)
|
|
||||||
{
|
|
||||||
pimpl_->counter_[i] = v;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int Paragraph::getCounter(int i) const
|
|
||||||
{
|
|
||||||
return pimpl_->counter_[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Paragraph::incCounter(int i)
|
|
||||||
{
|
|
||||||
pimpl_->counter_[i]++;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void Paragraph::setChar(pos_type pos, value_type c)
|
void Paragraph::setChar(pos_type pos, value_type c)
|
||||||
{
|
{
|
||||||
pimpl_->setChar(pos, c);
|
pimpl_->setChar(pos, c);
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include "insets/inset.h" // Just for Inset::Code
|
#include "insets/inset.h" // Just for Inset::Code
|
||||||
#include "lyxfont.h" // Just for LyXFont::FONT_SIZE
|
#include "lyxfont.h" // Just for LyXFont::FONT_SIZE
|
||||||
#include "support/types.h"
|
#include "support/types.h"
|
||||||
|
#include "counters.h"
|
||||||
|
|
||||||
class ParagraphParameters;
|
class ParagraphParameters;
|
||||||
class BufferParams;
|
class BufferParams;
|
||||||
@ -169,13 +170,6 @@ public:
|
|||||||
///
|
///
|
||||||
void layout(LyXLayout_ptr const & new_layout);
|
void layout(LyXLayout_ptr const & new_layout);
|
||||||
|
|
||||||
///
|
|
||||||
void setCounter(int i, int v);
|
|
||||||
///
|
|
||||||
int getCounter(int i) const;
|
|
||||||
///
|
|
||||||
void incCounter(int i);
|
|
||||||
|
|
||||||
///
|
///
|
||||||
char enumdepth;
|
char enumdepth;
|
||||||
|
|
||||||
@ -401,6 +395,9 @@ public:
|
|||||||
/// returns inset iterator of the first inset at or after pos.
|
/// returns inset iterator of the first inset at or after pos.
|
||||||
inset_iterator InsetIterator(lyx::pos_type pos);
|
inset_iterator InsetIterator(lyx::pos_type pos);
|
||||||
|
|
||||||
|
///
|
||||||
|
Counters ctrs;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/// if anything uses this we don't want it to.
|
/// if anything uses this we don't want it to.
|
||||||
Paragraph(Paragraph const &);
|
Paragraph(Paragraph const &);
|
||||||
|
293
src/text2.C
293
src/text2.C
@ -32,6 +32,7 @@
|
|||||||
#include "FloatList.h"
|
#include "FloatList.h"
|
||||||
#include "language.h"
|
#include "language.h"
|
||||||
#include "ParagraphParameters.h"
|
#include "ParagraphParameters.h"
|
||||||
|
#include "counters.h"
|
||||||
|
|
||||||
#include "insets/inseterror.h"
|
#include "insets/inseterror.h"
|
||||||
#include "insets/insetbib.h"
|
#include "insets/insetbib.h"
|
||||||
@ -387,7 +388,7 @@ void LyXText::insertParagraph(BufferView * bview, Paragraph * par,
|
|||||||
Row * row) const
|
Row * row) const
|
||||||
{
|
{
|
||||||
insertRow(row, par, 0); /* insert a new row, starting
|
insertRow(row, par, 0); /* insert a new row, starting
|
||||||
* at postition 0 */
|
* at position 0 */
|
||||||
|
|
||||||
setCounter(bview->buffer(), par); // set the counters
|
setCounter(bview->buffer(), par); // set the counters
|
||||||
|
|
||||||
@ -1211,60 +1212,6 @@ void LyXText::setParagraph(BufferView * bview,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
char loweralphaCounter(int n)
|
|
||||||
{
|
|
||||||
if (n < 1 || n > 26)
|
|
||||||
return '?';
|
|
||||||
else
|
|
||||||
return 'a' + n - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
inline
|
|
||||||
char alphaCounter(int n)
|
|
||||||
{
|
|
||||||
if (n < 1 || n > 26)
|
|
||||||
return '?';
|
|
||||||
else
|
|
||||||
return 'A' + n - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline
|
|
||||||
char hebrewCounter(int n)
|
|
||||||
{
|
|
||||||
static const char hebrew[22] = {
|
|
||||||
'à', 'á', 'â', 'ã', 'ä', 'å', 'æ', 'ç', 'è',
|
|
||||||
'é', 'ë', 'ì', 'î', 'ð', 'ñ', 'ò', 'ô', 'ö',
|
|
||||||
'÷', 'ø', 'ù', 'ú'
|
|
||||||
};
|
|
||||||
if (n < 1 || n > 22)
|
|
||||||
return '?';
|
|
||||||
else
|
|
||||||
return hebrew[n-1];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline
|
|
||||||
string const romanCounter(int n)
|
|
||||||
{
|
|
||||||
static char const * roman[20] = {
|
|
||||||
"i", "ii", "iii", "iv", "v",
|
|
||||||
"vi", "vii", "viii", "ix", "x",
|
|
||||||
"xi", "xii", "xiii", "xiv", "xv",
|
|
||||||
"xvi", "xvii", "xviii", "xix", "xx"
|
|
||||||
};
|
|
||||||
if (n < 1 || n > 20)
|
|
||||||
return "??";
|
|
||||||
else
|
|
||||||
return roman[n-1];
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace anon
|
|
||||||
|
|
||||||
|
|
||||||
// set the counter of a paragraph. This includes the labels
|
// set the counter of a paragraph. This includes the labels
|
||||||
void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
||||||
{
|
{
|
||||||
@ -1274,22 +1221,18 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
// copy the prev-counters to this one,
|
// copy the prev-counters to this one,
|
||||||
// unless this is the first paragraph
|
// unless this is the first paragraph
|
||||||
if (par->previous()) {
|
if (par->previous()) {
|
||||||
for (int i = 0; i < 10; ++i) {
|
|
||||||
par->setCounter(i, par->previous()->getFirstCounter(i));
|
par->ctrs.copy(par->previous()->ctrs, par->ctrs, "");
|
||||||
}
|
|
||||||
par->params().appendix(par->previous()->params().appendix());
|
par->params().appendix(par->previous()->params().appendix());
|
||||||
if (!par->params().appendix() && par->params().startOfAppendix()) {
|
if (!par->params().appendix() && par->params().startOfAppendix()) {
|
||||||
par->params().appendix(true);
|
par->params().appendix(true);
|
||||||
for (int i = 0; i < 10; ++i) {
|
par->ctrs.reset("");
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
par->enumdepth = par->previous()->enumdepth;
|
par->enumdepth = par->previous()->enumdepth;
|
||||||
par->itemdepth = par->previous()->itemdepth;
|
par->itemdepth = par->previous()->itemdepth;
|
||||||
} else {
|
} else {
|
||||||
for (int i = 0; i < 10; ++i) {
|
par->ctrs.reset("");
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
|
||||||
par->params().appendix(par->params().startOfAppendix());
|
par->params().appendix(par->params().startOfAppendix());
|
||||||
par->enumdepth = 0;
|
par->enumdepth = 0;
|
||||||
par->itemdepth = 0;
|
par->itemdepth = 0;
|
||||||
@ -1315,11 +1258,8 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
&& par->previous()->getDepth() > par->getDepth()
|
&& par->previous()->getDepth() > par->getDepth()
|
||||||
&& layout->labeltype != LABEL_BIBLIO) {
|
&& layout->labeltype != LABEL_BIBLIO) {
|
||||||
par->enumdepth = par->depthHook(par->getDepth())->enumdepth;
|
par->enumdepth = par->depthHook(par->getDepth())->enumdepth;
|
||||||
par->setCounter(6 + par->enumdepth,
|
par->ctrs.set(par->ctrs.enums[par->enumdepth],
|
||||||
par->depthHook(par->getDepth())->getCounter(6 + par->enumdepth));
|
par->depthHook(par->getDepth())->ctrs.value(par->ctrs.enums[par->enumdepth]));
|
||||||
// reset the counters.A depth change is like a breaking layout
|
|
||||||
for (int i = 6 + par->enumdepth + 1; i < 10; ++i)
|
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!par->params().labelString().empty()) {
|
if (!par->params().labelString().empty()) {
|
||||||
@ -1333,13 +1273,17 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
} else {
|
} else {
|
||||||
par->setLabelWidthString(string());
|
par->setLabelWidthString(string());
|
||||||
}
|
}
|
||||||
|
|
||||||
// is it a layout that has an automatic label?
|
// is it a layout that has an automatic label?
|
||||||
if (layout->labeltype >= LABEL_COUNTER_CHAPTER) {
|
if (layout->labeltype >= LABEL_COUNTER_CHAPTER) {
|
||||||
|
|
||||||
int i = layout->labeltype - LABEL_COUNTER_CHAPTER;
|
int i = layout->labeltype - LABEL_COUNTER_CHAPTER;
|
||||||
|
string numbertype, langtype;
|
||||||
|
ostringstream s;
|
||||||
|
|
||||||
if (i >= 0 && i<= buf->params.secnumdepth) {
|
if (i >= 0 && i<= buf->params.secnumdepth) {
|
||||||
par->incCounter(i); // increment the counter
|
|
||||||
|
par->ctrs.step(par->ctrs.sects[i]);
|
||||||
|
|
||||||
// Is there a label? Useful for Chapter layout
|
// Is there a label? Useful for Chapter layout
|
||||||
if (!par->params().appendix()) {
|
if (!par->params().appendix()) {
|
||||||
@ -1354,195 +1298,40 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
par->params().labelString(string());
|
par->params().labelString(string());
|
||||||
}
|
}
|
||||||
|
|
||||||
ostringstream s;
|
// Use if an integer is here less than elegant. For now.
|
||||||
|
int head = textclass.maxcounter() - LABEL_COUNTER_CHAPTER;
|
||||||
if (!par->params().appendix()) {
|
if (!par->params().appendix()) {
|
||||||
switch (2 * LABEL_COUNTER_CHAPTER -
|
numbertype = "sectioning";
|
||||||
textclass.maxcounter() + i) {
|
} else {
|
||||||
case LABEL_COUNTER_CHAPTER:
|
numbertype = "appendix";
|
||||||
s << par->getCounter(i);
|
if (par->isRightToLeftPar(buf->params))
|
||||||
break;
|
langtype = "hebrew";
|
||||||
case LABEL_COUNTER_SECTION:
|
else
|
||||||
s << par->getCounter(i - 1) << '.'
|
langtype = "latin";
|
||||||
<< par->getCounter(i);
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBSECTION:
|
|
||||||
s << par->getCounter(i - 2) << '.'
|
|
||||||
<< par->getCounter(i - 1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBSUBSECTION:
|
|
||||||
s << par->getCounter(i - 3) << '.'
|
|
||||||
<< par->getCounter(i - 2) << '.'
|
|
||||||
<< par->getCounter(i - 1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_PARAGRAPH:
|
|
||||||
s << par->getCounter(i - 4) << '.'
|
|
||||||
<< par->getCounter(i - 3) << '.'
|
|
||||||
<< par->getCounter(i - 2) << '.'
|
|
||||||
<< par->getCounter(i - 1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBPARAGRAPH:
|
|
||||||
s << par->getCounter(i - 5) << '.'
|
|
||||||
<< par->getCounter(i - 4) << '.'
|
|
||||||
<< par->getCounter(i - 3) << '.'
|
|
||||||
<< par->getCounter(i - 2) << '.'
|
|
||||||
<< par->getCounter(i - 1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
// Can this ever be reached? And in the
|
|
||||||
// case it is, how can this be correct?
|
|
||||||
// (Lgb)
|
|
||||||
s << par->getCounter(i) << '.';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} else { // appendix
|
|
||||||
switch (2 * LABEL_COUNTER_CHAPTER - textclass.maxcounter() + i) {
|
|
||||||
case LABEL_COUNTER_CHAPTER:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i));
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SECTION:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i - 1));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i - 1));
|
|
||||||
|
|
||||||
s << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBSECTION:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i - 2));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i - 2));
|
|
||||||
|
|
||||||
s << '.'
|
|
||||||
<< par->getCounter(i-1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBSUBSECTION:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i-3));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i-3));
|
|
||||||
|
|
||||||
s << '.'
|
|
||||||
<< par->getCounter(i-2) << '.'
|
|
||||||
<< par->getCounter(i-1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_PARAGRAPH:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i-4));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i-4));
|
|
||||||
|
|
||||||
s << '.'
|
|
||||||
<< par->getCounter(i-3) << '.'
|
|
||||||
<< par->getCounter(i-2) << '.'
|
|
||||||
<< par->getCounter(i-1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
case LABEL_COUNTER_SUBPARAGRAPH:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << hebrewCounter(par->getCounter(i-5));
|
|
||||||
else
|
|
||||||
s << alphaCounter(par->getCounter(i-5));
|
|
||||||
|
|
||||||
s << '.'
|
|
||||||
<< par->getCounter(i-4) << '.'
|
|
||||||
<< par->getCounter(i-3) << '.'
|
|
||||||
<< par->getCounter(i-2) << '.'
|
|
||||||
<< par->getCounter(i-1) << '.'
|
|
||||||
<< par->getCounter(i);
|
|
||||||
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
// Can this ever be reached? And in the
|
|
||||||
// case it is, how can this be correct?
|
|
||||||
// (Lgb)
|
|
||||||
s << par->getCounter(i) << '.';
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
s << par->ctrs.numberLabel(par->ctrs.sects[i],
|
||||||
|
numbertype, langtype, head);
|
||||||
|
|
||||||
par->params().labelString(par->params().labelString() +s.str().c_str());
|
par->params().labelString(par->params().labelString() +s.str().c_str());
|
||||||
// We really want to remove the c_str as soon as
|
// We really want to remove the c_str as soon as
|
||||||
// possible...
|
// possible...
|
||||||
|
|
||||||
for (i++; i < 10; ++i) {
|
// reset enum counters
|
||||||
// reset the following counters
|
par->ctrs.reset("enum");
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
|
||||||
} else if (layout->labeltype < LABEL_COUNTER_ENUMI) {
|
} else if (layout->labeltype < LABEL_COUNTER_ENUMI) {
|
||||||
for (i++; i < 10; ++i) {
|
par->ctrs.reset("enum");
|
||||||
// reset the following counters
|
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
|
||||||
} else if (layout->labeltype == LABEL_COUNTER_ENUMI) {
|
} else if (layout->labeltype == LABEL_COUNTER_ENUMI) {
|
||||||
par->incCounter(i + par->enumdepth);
|
par->ctrs.step(par->ctrs.enums[par->enumdepth]);
|
||||||
int number = par->getCounter(i + par->enumdepth);
|
|
||||||
|
|
||||||
ostringstream s;
|
|
||||||
|
|
||||||
switch (par->enumdepth) {
|
|
||||||
case 1:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << '('
|
|
||||||
<< hebrewCounter(number)
|
|
||||||
<< ')';
|
|
||||||
else
|
|
||||||
s << '('
|
|
||||||
<< loweralphaCounter(number)
|
|
||||||
<< ')';
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << '.' << romanCounter(number);
|
|
||||||
else
|
|
||||||
s << romanCounter(number) << '.';
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << '.'
|
|
||||||
<< alphaCounter(number);
|
|
||||||
else
|
|
||||||
s << alphaCounter(number)
|
|
||||||
<< '.';
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if (par->isRightToLeftPar(buf->params))
|
|
||||||
s << '.' << number;
|
|
||||||
else
|
|
||||||
s << number << '.';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
s << par->ctrs.numberLabel(par->ctrs.enums[par->enumdepth],
|
||||||
|
"enumeration", langtype);
|
||||||
par->params().labelString(s.str().c_str());
|
par->params().labelString(s.str().c_str());
|
||||||
|
|
||||||
for (i += par->enumdepth + 1; i < 10; ++i) {
|
|
||||||
// reset the following counters
|
|
||||||
par->setCounter(i, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
} else if (layout->labeltype == LABEL_BIBLIO) {// ale970302
|
} else if (layout->labeltype == LABEL_BIBLIO) {// ale970302
|
||||||
int i = LABEL_COUNTER_ENUMI - LABEL_COUNTER_CHAPTER + par->enumdepth;
|
par->ctrs.step("bibitem");
|
||||||
par->incCounter(i);
|
int number = par->ctrs.value("bibitem");
|
||||||
int number = par->getCounter(i);
|
|
||||||
if (!par->bibkey) {
|
if (!par->bibkey) {
|
||||||
InsetCommandParams p("bibitem" );
|
InsetCommandParams p("bibitem" );
|
||||||
par->bibkey = new InsetBibKey(p);
|
par->bibkey = new InsetBibKey(p);
|
||||||
@ -1563,8 +1352,13 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
InsetFloat * tmp = static_cast<InsetFloat*>(par->inInset()->owner());
|
InsetFloat * tmp = static_cast<InsetFloat*>(par->inInset()->owner());
|
||||||
Floating const & fl
|
Floating const & fl
|
||||||
= floatList.getType(tmp->type());
|
= floatList.getType(tmp->type());
|
||||||
|
|
||||||
|
// Why doesn't it work? -- MV
|
||||||
|
par->ctrs.step(fl.name());
|
||||||
// We should get the correct number here too.
|
// We should get the correct number here too.
|
||||||
s = fl.name() + " #:";
|
ostringstream o;
|
||||||
|
o << fl.name() << " " << par->ctrs.value(fl.name()) << ":";
|
||||||
|
s = o.str();
|
||||||
} else {
|
} else {
|
||||||
/* par->SetLayout(0);
|
/* par->SetLayout(0);
|
||||||
s = layout->labelstring; */
|
s = layout->labelstring; */
|
||||||
@ -1576,8 +1370,9 @@ void LyXText::setCounter(Buffer const * buf, Paragraph * par) const
|
|||||||
|
|
||||||
/* reset the enumeration counter. They are always resetted
|
/* reset the enumeration counter. They are always resetted
|
||||||
* when there is any other layout between */
|
* when there is any other layout between */
|
||||||
for (int i = 6 + par->enumdepth; i < 10; ++i)
|
for (int i = par->enumdepth + 1; i < 4; i++) {
|
||||||
par->setCounter(i, 0);
|
par->ctrs.set(par->ctrs.enums[i], 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user