]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetERT.cpp
Stupid bug fix.
[lyx.git] / src / insets / InsetERT.cpp
index ade0a22f49c6481f72be6a7b8a5e30d1856aadee..a25db23df222ad7eb32a94791560ae5f9f3c4ac3 100644 (file)
 #include "FuncStatus.h"
 #include "Language.h"
 #include "Layout.h"
-#include "LyXAction.h"
 #include "Lexer.h"
-#include "TextClass.h"
+#include "LyXAction.h"
 #include "MetricsInfo.h"
 #include "ParagraphParameters.h"
 #include "Paragraph.h"
+#include "TextClass.h"
 
 #include "frontends/alert.h"
+#include "frontends/Application.h"
 
 #include "support/debug.h"
 #include "support/gettext.h"
@@ -42,7 +43,6 @@ using namespace lyx::support;
 
 namespace lyx {
 
-
 InsetERT::InsetERT(Buffer const & buf, CollapseStatus status)
        : InsetCollapsable(buf, status)
 {}
@@ -50,7 +50,7 @@ InsetERT::InsetERT(Buffer const & buf, CollapseStatus status)
 
 InsetERT::~InsetERT()
 {
-       InsetERTMailer(*this).hideDialog();
+       hideDialogs("ert", this);
 }
 
 
@@ -114,9 +114,7 @@ void InsetERT::doDispatch(Cursor & cur, FuncRequest & cmd)
                break;
        }
        case LFUN_INSET_MODIFY: {
-               InsetCollapsable::CollapseStatus st;
-               InsetERTMailer::string2params(to_utf8(cmd.argument()), st);
-               setStatus(cur, st);
+               setStatus(cur, string2params(to_utf8(cmd.argument())));
                break;
        }
        default:
@@ -143,7 +141,7 @@ bool InsetERT::getStatus(Cursor & cur, FuncRequest const & cmd,
                case LFUN_PASTE:
                case LFUN_PRIMARY_SELECTION_PASTE:
                case LFUN_QUOTE_INSERT:
-                       status.enabled(true);
+                       status.setEnabled(true);
                        return true;
 
                // this one is difficult to get right. As a half-baked
@@ -186,52 +184,31 @@ void InsetERT::draw(PainterInfo & pi, int x, int y) const
 
 bool InsetERT::showInsetDialog(BufferView * bv) const
 {
-       InsetERTMailer(const_cast<InsetERT &>(*this)).showDialog(bv);
+       bv->showDialog("ert", params2string(status()), 
+               const_cast<InsetERT *>(this));
        return true;
 }
 
 
-string const InsetERTMailer::name_("ert");
-
-InsetERTMailer::InsetERTMailer(InsetERT & inset)
-       : inset_(inset)
-{}
-
-
-string const InsetERTMailer::inset2string(Buffer const &) const
-{
-       return params2string(inset_.status());
-}
-
-
-void InsetERTMailer::string2params(string const & in,
-                                  InsetCollapsable::CollapseStatus & status)
+InsetCollapsable::CollapseStatus InsetERT::string2params(string const & in)
 {
-       status = InsetCollapsable::Collapsed;
        if (in.empty())
-               return;
-
+               return Collapsed;
        istringstream data(in);
-       Lexer lex(0,0);
+       Lexer lex;
        lex.setStream(data);
-
-       string name;
-       lex >> name;
-       if (name != name_)
-               return print_mailer_error("InsetERTMailer", in, 1, name_);
-
+       lex.setContext("InsetERT::string2params");
+       lex >> "ert";
        int s;
        lex >> s;
-       if (lex)
-               status = static_cast<InsetCollapsable::CollapseStatus>(s);
+       return static_cast<CollapseStatus>(s);
 }
 
 
-string const
-InsetERTMailer::params2string(InsetCollapsable::CollapseStatus status)
+string InsetERT::params2string(CollapseStatus status)
 {
        ostringstream data;
-       data << name_ << ' ' << status;
+       data << "ert" << ' ' << status;
        return data.str();
 }