X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FCounters.cpp;h=4960eed5be87c10617f53695f4ea27be359741ff;hb=edc94a578f3e43c036842f91f25cf2eea42eb6cf;hp=c8e82ca39350832861d6c858be68629d26cdcf1f;hpb=4dd9a8acf17b13b38de5a03722e6cb1f6c43b7be;p=lyx.git diff --git a/src/Counters.cpp b/src/Counters.cpp index c8e82ca393..4960eed5be 100644 --- a/src/Counters.cpp +++ b/src/Counters.cpp @@ -145,6 +145,15 @@ docstring const & Counter::master() const } +bool Counter::checkAndRemoveMaster(docstring const & cnt) +{ + if (master_ != cnt) + return false; + master_ = docstring(); + return true; +} + + docstring const & Counter::labelString(bool in_appendix) const { return in_appendix ? labelstringappendix_ : labelstring_; @@ -157,6 +166,13 @@ Counter::StringMap & Counter::flatLabelStrings(bool in_appendix) const } +Counters::Counters() : appendix_(false), subfloat_(false) +{ + layout_stack_.push_back(0); + counter_stack_.push_back(from_ascii("")); +} + + void Counters::newCounter(docstring const & newc, docstring const & masterc, docstring const & ls, @@ -269,6 +285,7 @@ void Counters::reset() it->second.reset(); counter_stack_.clear(); counter_stack_.push_back(from_ascii("")); + layout_stack_.clear(); layout_stack_.push_back(0); } @@ -286,6 +303,22 @@ void Counters::reset(docstring const & match) } +bool Counters::remove(docstring const & cnt) +{ + bool retval = counterList_.erase(cnt); + if (!retval) + return false; + CounterList::iterator it = counterList_.begin(); + CounterList::iterator end = counterList_.end(); + for (; it != end; ++it) { + if (it->second.checkAndRemoveMaster(cnt)) + LYXERR(Debug::TCLASS, "Removed master counter `" + + to_utf8(cnt) + "' from counter: " + to_utf8(it->first)); + } + return retval; +} + + void Counters::copy(Counters & from, Counters & to, docstring const & match) { CounterList::iterator it = counterList_.begin(); @@ -436,7 +469,7 @@ docstring Counters::theCounter(docstring const & counter, { CounterList::const_iterator it = counterList_.find(counter); if (it == counterList_.end()) - return from_ascii("??"); + return from_ascii("#"); Counter const & ctr = it->second; Counter::StringMap & sm = ctr.flatLabelStrings(appendix()); Counter::StringMap::iterator smit = sm.find(lang); @@ -468,7 +501,7 @@ docstring Counters::flattenLabelString(docstring const & counter, CounterList::const_iterator it = counterList_.find(counter); if (it == counterList_.end()) - return from_ascii("??"); + return from_ascii("#"); Counter const & c = it->second; docstring ls = translateIfPossible(c.labelString(in_appendix), lang); @@ -545,21 +578,19 @@ docstring Counters::counterLabel(docstring const & format, } -docstring Counters::prettyCounter(docstring const & counter, +docstring Counters::prettyCounter(docstring const & name, string const & lang) const { - CounterList::const_iterator it = counterList_.find(counter); + CounterList::const_iterator it = counterList_.find(name); if (it == counterList_.end()) - return from_ascii("??"); + return from_ascii("#"); Counter const & ctr = it->second; + + docstring const value = theCounter(name, lang); docstring const & format = ctr.prettyFormat(); - // FIXME We need to "flatten" the format to get proper output, - // but doing so will take a bit of work. - if (true || format.empty()) { - docstring cntrname = translateIfPossible(counter, lang); - return cntrname + " " + theCounter(counter, lang); - } - return counterLabel(format, lang); + if (format.empty()) + return value; + return subst(format, from_ascii("##"), value); } @@ -600,14 +631,7 @@ void Counters::setActiveLayout(Layout const & lay) void Counters::beginEnvironment() { - docstring cnt = counter_stack_.back(); - counter_stack_.push_back(cnt); - deque::const_iterator it = counter_stack_.begin(); - deque::const_iterator en = counter_stack_.end(); -// docstring d; -// for (; it != en; ++it) -// d += " --> " + *it; -// LYXERR0(counter_stack_.size() << ": " << d); + counter_stack_.push_back(counter_stack_.back()); } @@ -615,12 +639,6 @@ void Counters::endEnvironment() { LASSERT(!counter_stack_.empty(), return); counter_stack_.pop_back(); - deque::const_iterator it = counter_stack_.begin(); - deque::const_iterator en = counter_stack_.end(); -// docstring d; -// for (; it != en; ++it) -// d += " --> " + *it; -// LYXERR0(counter_stack_.size() << ": " << d); }