X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetcommand.h;h=6428e667fd006611b40e9b12438cebb3777e6f71;hb=4a5b7a5952ad2381fcdf4830511293e184c7c5a1;hp=68c82a945eca708174b4cfc9f0a0132804757da1;hpb=8ed9dbabde30b31a6a14e032fa42f682a196ef7a;p=lyx.git diff --git a/src/insets/insetcommand.h b/src/insets/insetcommand.h index 68c82a945e..6428e667fd 100644 --- a/src/insets/insetcommand.h +++ b/src/insets/insetcommand.h @@ -5,7 +5,7 @@ * LyX, The Document Processor * * Copyright 1995 Matthias Ettrich - * Copyright 1995-2000 The LyX Team. + * Copyright 1995-2001 The LyX Team. * * ====================================================== */ @@ -17,6 +17,8 @@ #endif #include "insetbutton.h" +#include +#include // Created by Alejandro 970222 /** Used to insert a LaTeX command automatically @@ -24,86 +26,104 @@ * Similar to InsetLaTeX but having control of the basic structure of a * LaTeX command: \name[options]{contents}. */ -class InsetCommand : public InsetButton { +class InsetCommandParams { public: /// - InsetCommand(); + InsetCommandParams(); /// explicit - InsetCommand(string const & name, string const & arg = string(), - string const & opt = string()); + InsetCommandParams(string const & n, + string const & c = string(), + string const & o = string()); /// - void Write(Buffer const *, std::ostream &) const; + bool operator==(InsetCommandParams const &) const; + /// + bool operator!=(InsetCommandParams const &) const; + /// + void read(LyXLex &); + /// Parse the command + void scanCommand(string const &); + /// + void write(std::ostream &) const; + /// Build the complete LaTeX command + string const getCommand() const; + /// + string const & getCmdName() const { return cmdname; } + /// + string const & getOptions() const { return options; } + /// + string const & getContents() const { return contents; } + /// + void setCmdName(string const & n) { cmdname = n; } + /// + void setOptions(string const & o) { options = o; } + /// + void setContents(string const & c) { contents = c; } + /// + string const getAsString() const; + /// + void setFromString(string const &); +private: + /// + string cmdname; + /// + string contents; + /// + string options; +}; + - /// Parse the command. - void scanCommand(string const & cmd); +/// +class InsetCommand : public InsetButton, boost::noncopyable { +public: + /// + explicit + InsetCommand(InsetCommandParams const &, bool same_id = false); /// - virtual void Read(Buffer const *, LyXLex & lex); + virtual ~InsetCommand() { hideDialog(); } + /// + void write(Buffer const *, std::ostream & os) const + { p_.write(os); } + /// + virtual void read(Buffer const *, LyXLex & lex) + { p_.read(lex); } + /// Can remove one InsetBibKey is modified + void scanCommand(string const & c) { p_.scanCommand(c); }; /// - virtual int Latex(Buffer const *, std::ostream &, + virtual int latex(Buffer const *, std::ostream &, bool fragile, bool free_spc) const; /// - int Ascii(Buffer const *, std::ostream &) const; + int ascii(Buffer const *, std::ostream &, int linelen) const; /// - virtual int Linuxdoc(Buffer const *, std::ostream &) const; + virtual int linuxdoc(Buffer const *, std::ostream &) const; /// - virtual int DocBook(Buffer const *, std::ostream &) const; + virtual int docbook(Buffer const *, std::ostream &) const; /// - Inset * Clone() const; - /// - Inset::Code LyxCode() const - { - return Inset::NO_CODE; - } + Inset::Code lyxCode() const { return Inset::NO_CODE; } - /** Get the label that appears at screen. - - I thought it was enough to eliminate the argument to avoid - confusion with lyxinset::getLabel(int), but I've seen that - it wasn't. I hope you never confuse again both methods. (ale) - */ - virtual string getScreenLabel() const - { - return getCommand(); - } - - /// Build the complete LaTeX command - string getCommand() const; /// - string const & getCmdName() const { - return cmdname; - } + string const getCommand() const { return p_.getCommand(); } + /// + string const & getCmdName() const { return p_.getCmdName(); } /// - string const & getOptions() const { - return options; - } + string const & getOptions() const { return p_.getOptions(); } /// - string const & getContents() const { - return contents; - } + string const & getContents() const { return p_.getContents(); } /// - void setCmdName(string const & n) { - cmdname = n; - } + void setCmdName(string const & n) { p_.setCmdName(n); } /// - void setOptions(string const & o) { - options = o; - } + void setOptions(string const & o) { p_.setOptions(o); } /// - virtual void setContents(string const & c) { - contents = c; - } + void setContents(string const & c) { p_.setContents(c); } /// - void addContents(string const & c) { - contents += c; - } + InsetCommandParams const & params() const { return p_; } + /// + void setParams(InsetCommandParams const &); + /// + SigC::Signal0 hideDialog; private: - /// - string cmdname; - /// - string options; - /// - string contents; + /// + InsetCommandParams p_; }; #endif