* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
- * \author Lars Gullik Bjønnes
+ * \author Lars Gullik Bjønnes
*
* Full author contact details are available in file CREDITS.
*/
-#ifndef INSET_LATEXCOMMAND_H
-#define INSET_LATEXCOMMAND_H
+#ifndef INSETCOMMAND_H
+#define INSETCOMMAND_H
#include "Inset.h"
#include "InsetCommandParams.h"
#include "RenderButton.h"
-#include "MailInset.h"
-#include "Cursor.h"
namespace lyx {
+class Cursor;
+
+/////////////////////////////////////////////////////////////////////////
+//
+// InsetCommand
+//
+/////////////////////////////////////////////////////////////////////////
// Created by Alejandro 970222
-/** Used to insert a LaTeX command automatically
- *
- * Similar to InsetLaTeX but having control of the basic structure of a
- * LaTeX command: \name[options]{contents}.
- */
+// Used to insert a LaTeX command automatically.
-///
-class InsetCommand : public Inset {
+class InsetCommand : public Inset
+{
public:
///
- InsetCommand(InsetCommandParams const &, std::string const & mailer_name);
- ///
- ~InsetCommand();
- ///
- void metrics(MetricsInfo &, Dimension &) const;
+ InsetCommand(Buffer *, InsetCommandParams const &);
///
- Dimension const dimension(BufferView const &) const { return button_.dimension(); }
+ InsetCommand(InsetCommand const & rhs);
///
- void draw(PainterInfo & pi, int x, int y) const;
+ InsetCommand & operator=(InsetCommand const & rhs);
///
- void write(Buffer const &, std::ostream & os) const
- { p_.write(os); }
+ virtual ~InsetCommand();
///
- virtual void read(Buffer const &, Lexer & lex)
- { p_.read(lex); }
+ InsetCommand * asInsetCommand() override { return this; }
///
- int latex(Buffer const &, odocstream &, OutputParams const &) const;
- ///
- int plaintext(Buffer const &, odocstream &, OutputParams const &) const;
- ///
- int docbook(Buffer const &, odocstream &, OutputParams const & runparams) const;
- ///
- InsetCode lyxCode() const { return NO_CODE; }
+ InsetCommand const * asInsetCommand() const override { return this; }
+ /// \return true if params are successfully read
+ static bool string2params(std::string const & data,
+ InsetCommandParams &);
+ ///
+ static std::string params2string(InsetCommandParams const &);
///
InsetCommandParams const & params() const { return p_; }
- /// FIXME remove
- std::string const getContents() const { return p_.getContents(); }
-protected:
- /// FIXME remove
- void setContents(std::string const & c)
- {
- updateButtonLabel_ = true;
- p_.setContents(c);
- }
-public:
- /// tell that the button label should be recomputed.
- void refresh() { updateButtonLabel_ = true; }
///
- void setParam(std::string const & name, docstring const & value)
- {
- updateButtonLabel_ = true;
- p_[name] = value;
- }
+ void setParams(InsetCommandParams const &);
///
- docstring const & getParam(std::string const & name) const
- {
- return p_[name];
- }
+ docstring const & getParam(std::string const & name) const;
///
- void edit(Cursor & cur, bool left);
- /// FIXME remove
- virtual void replaceContents(std::string const & from, std::string const & to);
+ void setParam(std::string const & name, docstring const & value);
+ /// FIXME Remove
+ docstring const getFirstNonOptParam() const { return p_.getFirstNonOptParam(); }
///
- RenderButton & button() const { return button_; }
+ void setBroken(bool const b) const { broken_ = b; }
///
- bool setMouseHover(bool mouse_hover);
+ bool isBroken() const { return broken_; }
-protected:
+ /// \name Public functions inherited from Inset class
+ //@{
///
- virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
+ void write(std::ostream & os) const override { p_.write(os); }
///
- bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const;
+ void read(Lexer & lex) override { p_.Read(lex, &buffer()); }
///
- docstring const getCommand() const { return p_.getCommand(); }
+ void doDispatch(Cursor & cur, FuncRequest & cmd) override;
///
- std::string const & getCmdName() const { return p_.getCmdName(); }
+ bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const override;
///
- void setCmdName(std::string const & n)
- {
- updateButtonLabel_ = true;
- p_.setCmdName(n);
- }
+ void metrics(MetricsInfo &, Dimension &) const override;
///
- void setParams(InsetCommandParams const &);
- /// This should provide the text for the button
- virtual docstring const getScreenLabel(Buffer const &) const = 0;
-
-private:
+ void draw(PainterInfo & pi, int x, int y) const override;
///
- InsetCommandParams p_;
+ void drawBackground(PainterInfo &, int, int) const override {}
///
- std::string mailer_name_;
- /// changes color when mouse enters/leaves this inset
- bool mouse_hover_;
+ void latex(otexstream &, OutputParams const &) const override;
///
- mutable bool updateButtonLabel_;
+ int plaintext(odocstringstream & ods, OutputParams const & op,
+ size_t max_length = INT_MAX) const override;
///
- mutable RenderButton button_;
-};
-
-
-class InsetCommandMailer : public MailInset {
-public:
+ void docbook(XMLStream &, OutputParams const &) const override;
///
- InsetCommandMailer(std::string const & name, InsetCommand & inset);
+ void validate(LaTeXFeatures & features) const override;
///
- virtual Inset & inset() const { return inset_; }
+ bool setMouseHover(BufferView const * bv, bool mouse_hover) const override;
///
- virtual std::string const & name() const { return name_; }
+ bool clickable(BufferView const &, int, int) const override { return hasSettings(); }
+ //@}
+
+protected:
+ /// \name Methods relaying to the InsetCommandParams p_
+ //@{
///
- virtual std::string const inset2string(Buffer const &) const;
+ std::string contextMenuName() const override;
///
- static void string2params(std::string const &, std::string const & name,
- InsetCommandParams &);
+ bool showInsetDialog(BufferView * bv) const override;
+ //@}
+
+protected:
+ /// \name Functions relaying to the InsetCommandParams
+ //@{
+ /// Build the complete LaTeX command
+ /// \see InsetCommandParams::getCommand
+ docstring const getCommand(OutputParams const & rp) const
+ { return p_.getCommand(rp); }
+ /// Return the command name
+ /// \see InsetCommandParams::getCmdName
+ std::string const & getCmdName() const { return p_.getCmdName(); }
+ /// Set the name to \p n. This must be a known name. All parameters
+ /// are cleared except those that exist also in the new command.
+ /// What matters here is the parameter name, not position.
+ /// \see InsetCommandParams::setCmdName
+ void setCmdName(std::string const & n) { p_.setCmdName(n); }
///
- static std::string const params2string(std::string const & name,
- InsetCommandParams const &);
+ void changeCmdName(std::string const & new_name);
+ //@}
+
private:
+ /// This should provide the text for the button
+ virtual docstring screenLabel() const = 0;
+
+ /// \name Static public methods obligated for InsetCommand derived classes
+ //@{
+ /// Return parameter information for command cmdName.
+ /// Not implemented here. Must be implemented in derived class.
+ static ParamInfo const & findInfo(std::string const & cmdName);
+ /// Return default command for this inset.
+ /// Not implemented here. Must be implemented in derived class.
+ static std::string defaultCommand();
+ /// Whether this is a command this inset can represent.
+ /// Not implemented here. Must be implemented in derived class.
+ static bool isCompatibleCommand(std::string const & cmd);
+ //@}
+
///
- std::string const name_;
+ InsetCommandParams p_;
+ /// changes color when mouse enters/leaves this inset
+ mutable std::map<BufferView const *, bool> mouse_hover_;
///
- InsetCommand & inset_;
+ mutable RenderButton button_;
+ ///
+ mutable bool broken_;
};
-
+/// Decode InsetCommand considering Inset name and data.
+bool decodeInsetParam(std::string const & name, std::string & data,
+ Buffer const & buffer);
} // namespace lyx