X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ffactory.C;h=03a285a3c3e0e007b6eea7644f1f28878602148c;hb=37e82a546392d43f787826b85481a11f2a27af15;hp=b0f443fdab9ed8ea3a06f3662e6510cce9fe6d71;hpb=1eaa3eb913b16f4e6f5991b9c53b0b9ab3f84948;p=lyx.git diff --git a/src/factory.C b/src/factory.C index b0f443fdab..03a285a3c3 100644 --- a/src/factory.C +++ b/src/factory.C @@ -53,17 +53,18 @@ #include "insets/insetvspace.h" #include "insets/insetwrap.h" -#include "mathed/formulamacro.h" +#include "mathed/math_macrotemplate.h" #include "mathed/math_hullinset.h" #include "frontends/Dialogs.h" #include "frontends/LyXView.h" #include "support/lstrings.h" -#include "support/std_sstream.h" #include +#include + using lyx::support::compare_ascii_no_case; using std::auto_ptr; @@ -154,7 +155,7 @@ InsetBase * createInset(BufferView * bv, FuncRequest const & cmd) // Try and generate a valid index entry. InsetCommandParams icp("index"); string const contents = cmd.argument.empty() ? - bv->getLyXText()->getStringToIndex() : + bv->getLyXText()->getStringToIndex(bv->cursor()) : cmd.argument; icp.setContents(contents); @@ -182,13 +183,11 @@ InsetBase * createInset(BufferView * bv, FuncRequest const & cmd) return 0; case LFUN_INSET_CAPTION: { - UpdatableInset * up = bv->cursor().inset() - ? bv->cursor().inset()->asUpdatableInset() : 0; + UpdatableInset * up = bv->cursor().inset().asUpdatableInset(); if (!up) { auto_ptr inset(new InsetCaption(params)); - inset->setOwner(up); inset->setAutoBreakRows(true); - inset->setDrawFrame(InsetText::LOCKED); + inset->setDrawFrame(true); inset->setFrameColor(LColor::captionframe); return inset.release(); } @@ -343,7 +342,7 @@ InsetBase * readInset(LyXLex & lex, Buffer const & buf) auto_ptr inset; LyXTextClass tclass = buf.params().getLyXTextClass(); - + lex.next(); string tmptok = lex.getString(); @@ -405,7 +404,7 @@ InsetBase * readInset(LyXLex & lex, Buffer const & buf) } else if (tmptok == "External") { inset.reset(new InsetExternal); } else if (tmptok == "FormulaMacro") { - inset.reset(new InsetFormulaMacro); + inset.reset(new MathMacroTemplate); } else if (tmptok == "Formula") { inset.reset(new MathHullInset); } else if (tmptok == "Graphics") { @@ -471,6 +470,17 @@ InsetBase * readInset(LyXLex & lex, Buffer const & buf) } inset->read(buf, lex); + +#ifdef WITH_WARNINGS +#warning hack.. +#endif + if (inset->lyxCode() == InsetBase::MATHMACRO_CODE) { + MathMacroTemplate const * tmpl = + static_cast(inset.get()); + MacroTable::globalMacros().insert + (tmpl->name(), tmpl->asMacroData()); + lyxerr << "creating local macro " << tmpl->name() << endl; + } } return inset.release();