#pragma interface
#endif
-#include "lyxinset.h"
-#include "LString.h"
+#include "insetbutton.h"
+#include <sigc++/signal_system.h>
+#include <boost/utility.hpp>
+
+#ifdef SIGC_CXX_NAMESPACES
+using SigC::Signal0;
+#endif
// 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}.
*/
-class InsetCommand: public Inset {
+class InsetCommandParams {
public:
///
- InsetCommand();
+ InsetCommandParams();
///
- InsetCommand(string const & name, string const & arg = string(),
- string const & opt = string());
+ explicit
+ InsetCommandParams( string const & n,
+ string const & c = string(),
+ string const & o = string());
///
- int ascent(Painter &, LyXFont const &) const;
+ bool operator==(InsetCommandParams const &) const;
///
- int descent(Painter &, LyXFont const &) const;
+ bool operator!=(InsetCommandParams const &) const;
///
- int width(Painter &, LyXFont const &) const;
+ void Read(LyXLex &);
+ /// Parse the command
+ void scanCommand(string const &);
///
- void draw(Painter &, LyXFont const &, int baseline, float & x) const;
+ void Write(std::ostream &) const;
+ /// Build the complete LaTeX command
+ string const getCommand() const;
///
- void Write(ostream &) const;
- /// Parse the command.
- void scanCommand(string const & cmd);
- /// Will not be used when lyxf3
- void Read(LyXLex & lex);
- ///
- virtual int Latex(ostream &, signed char fragile) const;
-#ifndef USE_OSTREAM_ONLY
+ string const & getCmdName() const { return cmdname; }
///
- virtual int Latex(string & file, signed char fragile) const;
+ string const & getOptions() const { return options; }
///
- virtual int Linuxdoc(string & file) const;
+ string const & getContents() const { return contents; }
///
- virtual int DocBook(string & file) const;
-#else
+ void setCmdName( string const & n) { cmdname = n; }
///
- virtual int Linuxdoc(ostream &) const;
+ void setOptions(string const & o) { options = o; }
///
- virtual int DocBook(ostream &) const;
-#endif
+ void setContents(string const & c) { contents = c; }
+ ///
+ string const getAsString() const;
+ ///
+ void setFromString( string const & );
+private:
+ ///
+ string cmdname;
+ ///
+ string contents;
+ ///
+ string options;
+};
+
+
+///
+class InsetCommand : public InsetButton, public noncopyable {
+public:
+ ///
+ explicit
+ InsetCommand(InsetCommandParams const &);
+ ///
+ virtual ~InsetCommand() { hideDialog(); }
///
- Inset * Clone() const;
- ///
- Inset::Code LyxCode() const
- {
- return Inset::NO_CODE;
- }
+ 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 &,
+ bool fragile, bool free_spc) const;
+ ///
+ int Ascii(Buffer const *, std::ostream &, int linelen) const;
+ ///
+ virtual int Linuxdoc(Buffer const *, std::ostream &) const;
+ ///
+ virtual int DocBook(Buffer const *, std::ostream &) const;
+ ///
+ Inset::Code LyxCode() const { return Inset::NO_CODE; }
/** Get the label that appears at screen.
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;
+ virtual string const getScreenLabel() const = 0;
///
- string const & getCmdName() const {
- return command;
- }
+ string const getCommand() const { return p_.getCommand(); }
///
- string const & getOptions() const {
- return options;
- }
+ string const & getCmdName() const { return p_.getCmdName(); }
///
- string const & getContents() const {
- return contents;
- }
+ string const & getOptions() const { return p_.getOptions(); }
///
- void setCmdName(string const & n) {
- command = n;
- }
+ string const & getContents() const { return p_.getContents(); }
///
- void setOptions(string const & o) {
- options = o;
- }
+ void setCmdName(string const & n) { p_.setCmdName(n); }
///
- virtual void setContents(string const & c) {
- contents = c;
- }
-protected:
- ///
- string command;
- ///
- string options;
- ///
- string contents;
+ void setOptions(string const & o) { p_.setOptions(o); }
+ ///
+ void setContents(string const & c) { p_.setContents(c); }
+ ///
+ InsetCommandParams const & params() const { return p_; }
+ ///
+ void setParams(InsetCommandParams const &);
+ ///
+ Signal0<void> hideDialog;
+private:
+ ///
+ InsetCommandParams p_;
};
#endif