From 86c1053f51784c8ad7a479d6d86f299b889e46d5 Mon Sep 17 00:00:00 2001 From: Abdelrazak Younes Date: Tue, 17 Apr 2007 16:49:17 +0000 Subject: [PATCH] Revert to revision 17835: I applied the wrong tree! git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@17840 a592a061-630c-0410-9148-cb99ea01b6c8 --- src/mathed/InsetMath.h | 1 - src/mathed/InsetMathBrace.h | 7 +- src/mathed/InsetMathMacro.C | 89 +++++++------------------ src/mathed/InsetMathMacro.h | 22 +++--- src/mathed/MathData.C | 118 ++++++++++++--------------------- src/mathed/MathData.h | 5 +- src/mathed/MathFactory.C | 10 ++- src/mathed/MathMacroTable.C | 2 +- src/mathed/MathMacroTable.h | 19 ++---- src/mathed/MathMacroTemplate.C | 2 +- 10 files changed, 95 insertions(+), 180 deletions(-) diff --git a/src/mathed/InsetMath.h b/src/mathed/InsetMath.h index 508f9af95d..6602d98b9c 100644 --- a/src/mathed/InsetMath.h +++ b/src/mathed/InsetMath.h @@ -113,7 +113,6 @@ public: virtual InsetMathAMSArray const * asAMSArrayInset() const { return 0; } virtual InsetMathArray * asArrayInset() { return 0; } virtual InsetMathArray const * asArrayInset() const { return 0; } - virtual InsetMathBrace * asBraceInset() { return 0; } virtual InsetMathBrace const * asBraceInset() const { return 0; } virtual InsetMathChar const * asCharInset() const { return 0; } virtual InsetMathDelim * asDelimInset() { return 0; } diff --git a/src/mathed/InsetMathBrace.h b/src/mathed/InsetMathBrace.h index f7c399a9c7..3d581dc023 100644 --- a/src/mathed/InsetMathBrace.h +++ b/src/mathed/InsetMathBrace.h @@ -25,6 +25,8 @@ public: InsetMathBrace(); /// InsetMathBrace(MathArray const & ar); + /// + InsetMathBrace const * asBraceInset() const { return this; } /// we write extra braces in any case... bool extraBraces() const { return true; } /// @@ -45,11 +47,6 @@ public: void mathmlize(MathStream &) const; /// void infoize(odocstream & os) const; - - /// identifies brace insets - InsetMathBrace * asBraceInset() { return this; } - /// identifies brace insets - InsetMathBrace const * asBraceInset() const { return this; } private: virtual std::auto_ptr doClone() const; }; diff --git a/src/mathed/InsetMathMacro.C b/src/mathed/InsetMathMacro.C index 6db0b05e45..43cbed7c31 100644 --- a/src/mathed/InsetMathMacro.C +++ b/src/mathed/InsetMathMacro.C @@ -33,49 +33,8 @@ using std::endl; using std::vector; -/// This class is the value of a macro argument, technically -/// a wrapper of the cells of MathMacro. -class MathMacroArgumentValue : public InsetMathDim { -public: - /// - MathMacroArgumentValue(MathArray const * value) : value_(value) {} - /// - bool metrics(MetricsInfo & mi, Dimension & dim) const; - /// - void draw(PainterInfo &, int x, int y) const; - -private: - std::auto_ptr doClone() const; - MathArray const * value_; -}; - - -auto_ptr MathMacroArgumentValue::doClone() const -{ - return auto_ptr(new MathMacroArgumentValue(*this)); -} - - -bool MathMacroArgumentValue::metrics(MetricsInfo & mi, Dimension & dim) const -{ - value_->metrics(mi, dim); - metricsMarkers2(dim); - if (dim_ == dim) - return false; - dim_ = dim; - return true; -} - - -void MathMacroArgumentValue::draw(PainterInfo & pi, int x, int y) const -{ - value_->draw(pi, x, y); -} - - - -MathMacro::MathMacro(docstring const & name) - : InsetMathNest(0), name_(name) +MathMacro::MathMacro(docstring const & name, int numargs) + : InsetMathNest(numargs), name_(name) {} @@ -121,12 +80,7 @@ bool MathMacro::metrics(MetricsInfo & mi, Dimension & dim) const dim.des += c.height() + 10; } } else { - // create MathMacroArgumentValue object pointing to the cells of the macro - MacroData const & macro = MacroTable::globalMacros().get(name()); - vector values(nargs()); - for (size_t i = 0; i != nargs(); ++i) - values[i].insert(0, MathAtom(new MathMacroArgumentValue(&cells_[i]))); - macro.expand(values, expanded_); + MacroTable::globalMacros().get(name()).expand(cells_, expanded_); expanded_.metrics(mi, dim); } metricsMarkers2(dim); @@ -187,23 +141,18 @@ void MathMacro::validate(LaTeXFeatures & features) const InsetBase * MathMacro::editXY(LCursor & cur, int x, int y) { // We may have 0 arguments, but InsetMathNest requires at least one. - if (nargs() > 0) + if (nargs() > 0) { + // Prevent crash due to cold coordcache + // FIXME: This is only a workaround, the call of + // InsetMathNest::editXY is correct. The correct fix would + // ensure that the coordcache of the arguments is valid. + if (!editing(&cur.bv())) { + edit(cur, true); + return this; + } return InsetMathNest::editXY(cur, x, y); - else - return this; -} - - -void MathMacro::detachArguments(std::vector &args) -{ - args = cells_; - cells_ = std::vector(); -} - - -void MathMacro::attachArguments(std::vector const &args) -{ - cells_ = args; + } + return this; } @@ -230,22 +179,31 @@ bool MathMacro::notifyCursorLeaves(LCursor & cur) void MathMacro::maple(MapleStream & os) const { + updateExpansion(); lyx::maple(expanded_, os); } void MathMacro::mathmlize(MathStream & os) const { + updateExpansion(); lyx::mathmlize(expanded_, os); } void MathMacro::octave(OctaveStream & os) const { + updateExpansion(); lyx::octave(expanded_, os); } +void MathMacro::updateExpansion() const +{ + //expanded_.substitute(*this); +} + + void MathMacro::infoize(odocstream & os) const { os << "Macro: " << name(); @@ -255,6 +213,7 @@ void MathMacro::infoize(odocstream & os) const void MathMacro::infoize2(odocstream & os) const { os << "Macro: " << name(); + } diff --git a/src/mathed/InsetMathMacro.h b/src/mathed/InsetMathMacro.h index a1d1144922..cc2be0a014 100644 --- a/src/mathed/InsetMathMacro.h +++ b/src/mathed/InsetMathMacro.h @@ -26,11 +26,7 @@ namespace lyx { class MathMacro : public InsetMathNest { public: /// A macro can be built from an existing template - MathMacro(docstring const & name); - /// - virtual MathMacro * asMacro() { return this; } - /// - virtual MathMacro const * asMacro() const { return this; } + MathMacro(docstring const & name, int numargs); /// void draw(PainterInfo & pi, int x, int y) const; /// @@ -42,8 +38,6 @@ public: { drawMarkers2(pi, x, y); } /// bool metrics(MetricsInfo & mi, Dimension & dim) const; - /// - bool metricsExpanded(MetricsInfo & mi, Dimension & dim) const; /// get cursor position void cursorPos(BufferView const & bv, CursorSlice const & sl, bool boundary, int & x, int & y) const; @@ -58,10 +52,8 @@ public: /// docstring name() const; /// - void detachArguments(std::vector &args); - /// - void attachArguments(std::vector const &args); - + void setExpansion(MathArray const & exp, MathArray const & args) const; + /// void validate(LaTeXFeatures &) const; @@ -78,10 +70,14 @@ public: private: virtual std::auto_ptr doClone() const; - + /// + void updateExpansion() const; + /// + void expand() const; + /// name of macro docstring name_; - /// the macro template + /// the unexpanded macro defintition mutable MathArray tmpl_; /// the macro substituted with our args mutable MathArray expanded_; diff --git a/src/mathed/MathData.C b/src/mathed/MathData.C index 70a256c708..b2ef50fb97 100644 --- a/src/mathed/MathData.C +++ b/src/mathed/MathData.C @@ -14,7 +14,6 @@ #include "InsetMathFont.h" #include "InsetMathScript.h" #include "InsetMathMacro.h" -#include "InsetMathBrace.h" #include "MathMacroTable.h" #include "MathStream.h" #include "MathSupport.h" @@ -240,6 +239,7 @@ bool isInside(DocIterator const & it, MathArray const & ar, } + void MathArray::metrics(MetricsInfo & mi) const { frontend::FontMetrics const & fm = theFontMetrics(mi.base.font); @@ -256,16 +256,37 @@ void MathArray::metrics(MetricsInfo & mi) const if (empty()) return; - const_cast(this)->updateMacros( mi ); - dim_.asc = 0; dim_.wid = 0; - Dimension d; - for (size_t i = 0; i != size(); ++i) { + Dimension d; + //BufferView & bv = *mi.base.bv; + //Buffer const & buf = *bv.buffer(); + for (size_t i = 0, n = size(); i != n; ++i) { MathAtom const & at = operator[](i); +#if 0 + MathMacro const * mac = at->asMacro(); + if (mac && buf.hasMacro(mac->name())) { + MacroData const & tmpl = buf.getMacro(mac->name()); + int numargs = tmpl.numargs(); + if (i + numargs > n) + numargs = n - i - 1; + lyxerr << "metrics:found macro: " << mac->name() + << " numargs: " << numargs << endl; + if (!isInside(bv.cursor(), *this, i + 1, i + numargs + 1)) { + MathArray args(begin() + i + 1, begin() + i + numargs + 1); + MathArray exp; + tmpl.expand(args, exp); + mac->setExpansion(exp, args); + mac->metricsExpanded(mi, d); + dim_.wid += mac->widthExpanded(); + i += numargs; + continue; + } + } +#endif at->metrics(mi, d); dim_ += d; - if (i == size() - 1) + if (i == n - 1) kerning_ = at->kerning(); } } @@ -291,6 +312,23 @@ void MathArray::draw(PainterInfo & pi, int x, int y) const for (size_t i = 0, n = size(); i != n; ++i) { MathAtom const & at = operator[](i); +#if 0 + Buffer const & buf = bv.buffer(); + // special macro handling + MathMacro const * mac = at->asMacro(); + if (mac && buf.hasMacro(mac->name())) { + MacroData const & tmpl = buf.getMacro(mac->name()); + int numargs = tmpl.numargs(); + if (i + numargs > n) + numargs = n - i - 1; + if (!isInside(bv.cursor(), *this, i + 1, i + numargs + 1)) { + mac->drawExpanded(pi, x, y); + x += mac->widthExpanded(); + i += numargs; + continue; + } + } +#endif bv.coordCache().insets().add(at.nucleus(), x, y); at->drawSelection(pi, x, y); at->draw(pi, x, y); @@ -325,74 +363,6 @@ void MathArray::drawT(TextPainter & pain, int x, int y) const } -void MathArray::updateMacros(MetricsInfo & mi) { - Buffer *buf = mi.base.bv->buffer(); - - // go over the array and look for macros - for (size_t i = 0; i != size(); ++i) { - InsetMath * at = operator[](i).nucleus(); - MathMacro * macroInset = at->asMacro(); - if (macroInset) { - // get arity of macro or 0 if unknown - size_t numargs = 0; - if (buf->hasMacro(macroInset->name())) { - MacroData const & macro = buf->getMacro(macroInset->name()); - numargs = macro.numargs(); - } - - // arity of macro changed? - if (macroInset->nargs() != numargs) { - // detach all arguments - std::vector detachedArgs; - macroInset->detachArguments( detachedArgs ); - - // too many arguments in the macro inset? - if (detachedArgs.size() > numargs) { - // insert overlap back as braces - std::vector overlap(detachedArgs.begin()+numargs, detachedArgs.end()); - detachedArgs.erase(detachedArgs.begin()+numargs, detachedArgs.end()); - for (size_t j = 0; j < overlap.size(); ++j) { - MathArray const & arg = overlap[j]; - if (arg.size() == 1) - insert(i+j+1, MathAtom(new InsetMathBrace(arg))); - else - insert(i+j+1, arg[0]); - } - i += overlap.size(); - } else { - // insert some cells from the array into the macro inset - size_t missingArgs = numargs-detachedArgs.size(); - size_t j; - for (j = 0; j < missingArgs && i+1+j < size(); ++j) { - MathAtom & cell = operator[](i+1+j); - InsetMathBrace const * brace = cell->asBraceInset(); - if (brace) { - // found brace, convert into argument - detachedArgs.push_back(brace->cell(0)); - } else { - MathArray array; - array.insert(0, cell); - detachedArgs.push_back(array); - } - } - - // remove them from the array - erase(begin()+i+1, begin()+i+1+j); - - // enough for the macro inset now? - // Add some empty ones of necessary - for (; j < missingArgs; ++j) - detachedArgs.insert(detachedArgs.end(), MathArray()); - } - - // attach arguments back to macro inset - macroInset->attachArguments(detachedArgs); - } - } - } -} - - int MathArray::pos2x(size_type pos) const { return pos2x(pos, 0); diff --git a/src/mathed/MathData.h b/src/mathed/MathData.h index a2ea8c837e..d3c916c28e 100644 --- a/src/mathed/MathData.h +++ b/src/mathed/MathData.h @@ -161,7 +161,7 @@ public: int kerning() const { return kerning_; } /// void swap(MathArray & ar) { base_type::swap(ar); } - + protected: /// cached dimensions of cell mutable Dimension dim_; @@ -172,9 +172,6 @@ protected: mutable int sshift_; mutable int kerning_; - /// attach/detach brace inset to macros - void updateMacros(MetricsInfo & mi); - private: /// is this an exact match at this position? bool find1(MathArray const & ar, size_type pos) const; diff --git a/src/mathed/MathFactory.C b/src/mathed/MathFactory.C index 2be23f6915..62bcef30db 100644 --- a/src/mathed/MathFactory.C +++ b/src/mathed/MathFactory.C @@ -392,7 +392,15 @@ MathAtom createInsetMath(docstring const & s) if (s == "vphantom") return MathAtom(new InsetMathPhantom(InsetMathPhantom::vphantom)); - return MathAtom(new MathMacro(s)); + if (MacroTable::globalMacros().has(s)) + return MathAtom(new MathMacro(s, + MacroTable::globalMacros().get(s).numargs())); + //if (MacroTable::localMacros().has(s)) + // return MathAtom(new MathMacro(s, + // MacroTable::localMacros().get(s).numargs())); + + //lyxerr << "creating unknown inset '" << s << "'" << endl; + return MathAtom(new InsetMathUnknown(s)); } diff --git a/src/mathed/MathMacroTable.C b/src/mathed/MathMacroTable.C index 3e3dd8ff54..961235c2f2 100644 --- a/src/mathed/MathMacroTable.C +++ b/src/mathed/MathMacroTable.C @@ -41,7 +41,7 @@ MacroData::MacroData() MacroData::MacroData(docstring const & def, int numargs, docstring const & disp, string const & requires) - : def_(def), numargs_(numargs), disp_(disp), requires_(requires), lockCount_(0) + : def_(def), numargs_(numargs), disp_(disp), requires_(requires) {} diff --git a/src/mathed/MathMacroTable.h b/src/mathed/MathMacroTable.h index ac1a985314..f6e2db77aa 100644 --- a/src/mathed/MathMacroTable.h +++ b/src/mathed/MathMacroTable.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author AndrÈ Pˆnitz + * \author André Pönitz * * Full author contact details are available in file CREDITS. */ @@ -12,13 +12,11 @@ #ifndef MATH_MACROTABLE_H #define MATH_MACROTABLE_H -#include "support/docstring.h" - -#include - #include #include +#include "support/docstring.h" + namespace lyx { class MathArray; @@ -42,14 +40,7 @@ public: std::string requires() const { return requires_; } /// std::string & requires() { return requires_; } - - /// - int lock() { return ++lockCount_; } - /// - bool locked() const { return lockCount_ != 0; } - /// - void unlock() { --lockCount_; BOOST_ASSERT(lockCount_ >= 0); } - + private: /// docstring def_; @@ -59,8 +50,6 @@ private: docstring disp_; /// std::string requires_; - /// - int lockCount_; }; diff --git a/src/mathed/MathMacroTemplate.C b/src/mathed/MathMacroTemplate.C index 99e58e8e8c..2f6f8b4e79 100644 --- a/src/mathed/MathMacroTemplate.C +++ b/src/mathed/MathMacroTemplate.C @@ -105,7 +105,7 @@ docstring MathMacroTemplate::name() const docstring MathMacroTemplate::prefix() const { - return bformat(_(" Macro \\%1$s: "), name_); + return bformat(_(" Macro: %1$s: "), name_); }