*
* LyX, The Document Processor
*
- * Copyright (C) 1995 Matthias Ettrich
- * Copyright (C) 1995-1998 The LyX Team.
+ * Copyright 1995 Matthias Ettrich
+ * Copyright 1995-1999 The LyX Team.
*
- *======================================================*/
+ * ====================================================== */
#include <config.h>
#include "insetcommand.h"
#include "lyxdraw.h"
-#include "error.h"
-
-// $Id: insetcommand.C,v 1.1 1999/09/27 18:44:38 larsbj Exp $
-
-#if !defined(lint) && !defined(WITH_WARNINGS)
-static char vcid[] = "$Id: insetcommand.C,v 1.1 1999/09/27 18:44:38 larsbj Exp $";
-#endif /* lint */
-
+#include "debug.h"
InsetCommand::InsetCommand()
{
}
-InsetCommand::InsetCommand(LString const & cmd, LString const & arg,
- LString const & opt)
+InsetCommand::InsetCommand(string const & cmd, string const & arg,
+ string const & opt)
: command(cmd), options(opt), contents(arg)
{
}
-InsetCommand::~InsetCommand()
-{
-}
-
-
-int InsetCommand::Ascent(LyXFont const&font) const
+int InsetCommand::Ascent(LyXFont const & font) const
{
LyXFont f = font;
f.decSize();
}
-int InsetCommand::Descent(LyXFont const&font) const
+int InsetCommand::Descent(LyXFont const & font) const
{
LyXFont f = font;
f.decSize();
}
-int InsetCommand::Width(LyXFont const&font) const
+int InsetCommand::Width(LyXFont const & font) const
{
LyXFont f = font;
f.decSize();
- LString s = getScreenLabel();
+ string s = getScreenLabel();
return 10 + f.stringWidth(s);
}
-void InsetCommand::Draw(LyXFont font, LyXScreen &scr,
- int baseline, float &x)
+void InsetCommand::Draw(LyXFont font, LyXScreen & scr,
+ int baseline, float & x)
{
// Draw it as a box with the LaTeX text
x += 3;
- //scr.drawFilledRectangle(int(x), baseline - Ascent(font) + 1,
- // Width(font) - 2, Ascent(font) + Descent(font)-2,
- // FL_GRAY80);
scr.fillRectangle(gc_lighted,
int(x), baseline - Ascent(font) + 1,
Width(font) - 6,
h = (Ascent(font)+Descent(font)-2);
scr.drawFrame(FL_UP_FRAME, int(x), y, w, h, FL_BLACK, -1);
} else {
- //scr.drawRectangle(int(x), baseline - Ascent(font)+1,
- // Width(font)-2, Ascent(font)+Descent(font)-2,
- // FL_BLACK);
scr.drawRectangle(gc_note_frame,
int(x), baseline - Ascent(font)+1,
Width(font)-6,
Ascent(font)+Descent(font)-2);
}
- LString s = getScreenLabel();
+ string s = getScreenLabel();
LyXFont f = font;
f.decSize();
f.setColor(LyXFont::NONE);
// In lyxf3 this will be just LaTeX
-void InsetCommand::Write(FILE *file)
+void InsetCommand::Write(ostream & os)
{
- fprintf(file, "LatexCommand %s\n", getCommand().c_str());
+ os << "LatexCommand " << getCommand() << "\n";
}
-void InsetCommand::scanCommand(LString const &cmd)
+void InsetCommand::scanCommand(string const & cmd)
{
- LString tcommand, toptions, tcontents;
+ string tcommand, toptions, tcontents;
if (cmd.empty()) return;
// Used to handle things like \command[foo[bar]]{foo{bar}}
int nestdepth = 0;
- for (int i=0; i<cmd.length(); i++) {
+ for (string::size_type i = 0; i < cmd.length(); ++i) {
char c = cmd[i];
- if ((state==Command && c == ' ') ||
- (state==Command && c == '[') ||
- (state==Command && c == '{')) {
+ if ((state == Command && c == ' ') ||
+ (state == Command && c == '[') ||
+ (state == Command && c == '{')) {
state = WS;
}
- if ((state==Option && c == ']') ||
- (state==Content && c == '}')) {
- if (nestdepth==0) {
+ if ((state == Option && c == ']') ||
+ (state == Content && c == '}')) {
+ if (nestdepth == 0) {
state = WS;
} else {
- nestdepth--;
+ --nestdepth;
}
}
- if ((state==Option && c == '[') ||
- (state==Content && c == '{')) {
- nestdepth++;
+ if ((state == Option && c == '[') ||
+ (state == Content && c == '{')) {
+ ++nestdepth;
}
switch (state) {
case Command: tcommand += c; break;
if (!tcontents.empty()) setContents(tcontents);
// setContents is overloaded in InsetInclude
- if (lyxerr.debugging(Error::LEX_PARSER))
- lyxerr.print("Command <" + cmd
- + "> == <" + getCommand()
- + "> == <" + getCmdName()
- + '|' + getContents()
- + '|' + getOptions() +'>');
+ if (lyxerr.debugging(Debug::PARSER))
+ lyxerr << "Command <" << cmd
+ << "> == <" << getCommand()
+ << "> == <" << getCmdName()
+ << '|' << getContents()
+ << '|' << getOptions() << '>' << endl;
}
// This function will not be necessary when lyx3
-void InsetCommand::Read(LyXLex &lex)
+void InsetCommand::Read(LyXLex & lex)
{
if (lex.EatLine()) {
- LString t = lex.GetString();
+ string t = lex.GetString();
scanCommand(t);
} else
lex.printError("InsetCommand: Parse error: `$$Token'");
}
-int InsetCommand::Latex(FILE *file, signed char /*fragile*/)
+int InsetCommand::Latex(ostream & os, signed char /*fragile*/)
{
- fprintf(file, "%s", getCommand().c_str());
+ os << getCommand();
return 0;
}
-int InsetCommand::Latex(LString &file, signed char /*fragile*/)
+int InsetCommand::Latex(string & file, signed char /*fragile*/)
{
file += getCommand();
return 0;
}
-int InsetCommand::Linuxdoc(LString &/*file*/)
+int InsetCommand::Linuxdoc(string &/*file*/)
{
return 0;
}
-int InsetCommand::DocBook(LString &/*file*/)
+int InsetCommand::DocBook(string &/*file*/)
{
return 0;
}
-Inset* InsetCommand::Clone()
+Inset * InsetCommand::Clone() const
{
- InsetCommand *result = new InsetCommand(command, contents, options);
- return result;
+ return new InsetCommand(command, contents, options);
}
-LString InsetCommand::getCommand() const
+string InsetCommand::getCommand() const
{
- LString s;
+ string s;
if (!command.empty()) s += "\\"+command;
if (!options.empty()) s += "["+options+']';
s += "{"+contents+'}';