2 /* This file is part of*
3 * ======================================================
5 * LyX, The Document Processor
7 * Copyright (C) 1995 Matthias Ettrich
8 * Copyright (C) 1996-1999 The LyX Team.
10 * ====================================================== */
12 #ifndef INSET_LATEXCOMMAND_H
13 #define INSET_LATEXCOMMAND_H
22 // Created by Alejandro 970222
23 /** Used to insert a LaTeX command automatically
25 * Similar to InsetLaTeX but having control of the basic structure of a
26 * LaTeX command: \name[options]{contents}.
28 class InsetCommand: public Inset {
33 InsetCommand(string const & name, string const & arg = string(),
34 string const & opt = string());
36 int Ascent(LyXFont const & font) const;
38 int Descent(LyXFont const & font) const;
40 int Width(LyXFont const & font) const;
42 void Draw(LyXFont, LyXScreen & scr, int baseline, float & x);
44 void Write(ostream &);
45 /// Parse the command.
46 void scanCommand(string const & cmd);
47 /// Will not be used when lyxf3
48 void Read(LyXLex & lex);
50 virtual int Latex(ostream &, signed char fragile);
52 virtual int Latex(string & file, signed char fragile);
54 virtual int Linuxdoc(string & file);
56 virtual int DocBook(string & file);
58 Inset * Clone() const;
60 Inset::Code LyxCode() const
62 return Inset::NO_CODE;
65 /** Get the label that appears at screen.
67 I thought it was enough to eliminate the argument to avoid
68 confusion with lyxinset::getLabel(int), but I've seen that
69 it wasn't. I hope you never confuse again both methods. (ale)
71 virtual string getScreenLabel() const
76 /// Build the complete LaTeX command
77 string getCommand() const;
79 string const & getCmdName() const {
83 string const & getOptions() const {
87 string const & getContents() const {
91 void setCmdName(string const & n) {
95 void setOptions(string const & o) {
99 virtual void setContents(string const & c) {