]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetcommand.C
clear()->erase() ; lots of using directives for cxx
[lyx.git] / src / insets / insetcommand.C
index 1b0566ff05a9863baf56ab6d816120fab3836833..69322ae8905cc40caa50164553a0d2bf939f3760 100644 (file)
@@ -4,7 +4,7 @@
  *           LyX, The Document Processor
  *      
  *         Copyright 1995 Matthias Ettrich
- *          Copyright 1995-1999 The LyX Team.
+ *          Copyright 1995-2000 The LyX Team.
  *
  * ====================================================== */
 
 #endif
 
 #include "insetcommand.h"
-#include "lyxdraw.h"
 #include "debug.h"
 #include "Painter.h"
 
+using std::ostream;
+using std::endl;
+
+
 InsetCommand::InsetCommand()
 {
 }
@@ -31,130 +34,90 @@ InsetCommand::InsetCommand(string const & cmd, string const & arg,
 }
 
 
-#ifdef USE_PAINTER
-int InsetCommand::ascent(Painter &, LyXFont const & font) const
-{
-       LyXFont f = font;
-       f.decSize();
-       return f.maxAscent() + 3;
-}
-#else
-int InsetCommand::Ascent(LyXFont const & font) const
-{
-       LyXFont f = font;
-       f.decSize();
-       return f.maxAscent() + 3;
-}
-#endif
-
-
-#ifdef USE_PAINTER
-int InsetCommand::descent(Painter &, LyXFont const & font) const
+int InsetCommand::ascent(Painter & pain, LyXFont const &) const
 {
-       LyXFont f = font;
-       f.decSize();
-       return f.maxDescent() + 3;
-}
-#else
-int InsetCommand::Descent(LyXFont const & font) const
-{
-       LyXFont f = font;
-       f.decSize();
-       return f.maxDescent() + 3;
+       LyXFont font(LyXFont::ALL_SANE);
+       font.decSize();
+       
+       int width, ascent, descent;
+        string s = getScreenLabel();
+       
+        if (Editable()) {
+               pain.buttonText(0, 0, s, font,
+                               false, width, ascent, descent);
+       } else {
+               pain.rectText(0, 0, s, font,
+                             LColor::commandbg, LColor::commandframe,
+                             false, width, ascent, descent);
+       }
+       return ascent;
 }
-#endif
 
 
-#ifdef USE_PAINTER
-int InsetCommand::width(Painter &, LyXFont const & font) const
+int InsetCommand::descent(Painter & pain, LyXFont const &) const
 {
-       LyXFont f = font;
-       f.decSize();
-       string s = getScreenLabel();
-       return 10 + f.stringWidth(s);
-}
-#else
-int InsetCommand::Width(LyXFont const & font) const
-{
-       LyXFont f = font;
-       f.decSize();
-       string s = getScreenLabel();
-       return 10 + f.stringWidth(s);
+       LyXFont font(LyXFont::ALL_SANE);
+       font.decSize();
+       
+       int width, ascent, descent;
+        string s = getScreenLabel();
+       
+        if (Editable()) {
+               pain.buttonText(0, 0, s, font,
+                               false, width, ascent, descent);
+       } else {
+               pain.rectText(0, 0, s, font,
+                             LColor::commandbg, LColor::commandframe,
+                             false, width, ascent, descent);
+       }
+       return descent;
 }
-#endif
 
 
-#ifdef USE_PAINTER
-void InsetCommand::draw(Painter & pain, LyXFont const & font,
-                       int baseline, float & x) const
+int InsetCommand::width(Painter & pain, LyXFont const &) const
 {
-       // Draw it as a box with the LaTeX text
-       x += 3;
-
-       pain.fillRectangle(int(x), baseline - ascent(pain, font) + 1,
-                          width(pain, font) - 6,
-                          ascent(pain, font) + descent(pain, font) - 2,
-                          LColor::insetbg);
-        // Tell whether this slows down the drawing  (ale)
-       // lets draw editable and non-editable insets differently
+       LyXFont font(LyXFont::ALL_SANE);
+       font.decSize();
+       
+       int width, ascent, descent;
+        string s = getScreenLabel();
+       
         if (Editable()) {
-               int y = baseline - ascent(pain, font) + 1;
-               int w = width(pain, font) - 6;
-               int h = ascent(pain, font) + descent(pain, font) - 2;
-               pain.rectangle(int(x), y, w, h, LColor::insetframe);
+               pain.buttonText(0, 0, s, font,
+                               false, width, ascent, descent);
        } else {
-               
-               pain.rectangle(int(x), baseline - ascent(pain, font) + 1,
-                              width(pain, font) - 6,
-                              ascent(pain, font) + descent(pain, font) - 2,
-                              LColor::insetframe); 
+               pain.rectText(0, 0, s, font,
+                             LColor::commandbg, LColor::commandframe,
+                             false, width, ascent, descent);
        }
-        string s = getScreenLabel();
-               LyXFont f(font);
-       f.decSize();
-       f.setColor(LColor::none);
-       f.setLatex(LyXFont::OFF);
-       pain.text(int(x + 2), baseline, s, f);
-       
-       x +=  width(pain, font) - 3;
+       return width + 4;
 }
-#else
-void InsetCommand::Draw(LyXFont font, LyXScreen & scr,
-                     int baseline, float & x)
+
+
+void InsetCommand::draw(Painter & pain, LyXFont const &,
+                       int baseline, float & x) const
 {
        // Draw it as a box with the LaTeX text
-       x += 3;
-
-       scr.fillRectangle(gc_lighted,
-                         int(x), baseline - Ascent(font) + 1,
-                         Width(font) - 6,
-                         Ascent(font) + Descent(font)-2);
-        // Tell whether this slows down the drawing  (ale)
-       // lets draw editable and non-editable insets differently
-        if (Editable()) {
-               int y = baseline - Ascent(font)+1, w = Width(font)-6,
-                       h = (Ascent(font)+Descent(font)-2);
-               scr.drawFrame(FL_UP_FRAME, int(x), y, w, h, FL_BLACK, -1);
+       LyXFont font(LyXFont::ALL_SANE);
+       font.setColor(LColor::command).decSize();
+
+       int width;
+       string s = getScreenLabel();
+
+       if (Editable()) {
+               pain.buttonText(int(x)+2, baseline, s, font, true, width);
        } else {
-               scr.drawRectangle(gc_note_frame,
-                                 int(x), baseline - Ascent(font)+1,
-                                 Width(font)-6,
-                                 Ascent(font)+Descent(font)-2); 
+               pain.rectText(int(x)+2, baseline, s, font,
+                             LColor::commandbg, LColor::commandframe,
+                             true, width);
        }
-        string s = getScreenLabel();
-               LyXFont f = font;
-       f.decSize();
-       f.setColor(LyXFont::NONE);
-       f.setLatex(LyXFont::OFF);
-       scr.drawString(f, s, baseline, int(x+2));
 
-       x +=  Width(font) - 3;
+       x += width + 4;
 }
-#endif
 
 
 // In lyxf3 this will be just LaTeX
-void InsetCommand::Write(ostream & os)
+void InsetCommand::Write(ostream & os) const
 {
        os << "LatexCommand " << getCommand() << "\n";
 }
@@ -234,27 +197,26 @@ void InsetCommand::Read(LyXLex & lex)
 }
 
 
-int InsetCommand::Latex(ostream & os, signed char /*fragile*/)
+int InsetCommand::Latex(ostream & os, bool /*fragile*/, bool/*fs*/) const
 {
        os << getCommand();
        return 0;
 }
 
 
-int InsetCommand::Latex(string & file, signed char /*fragile*/)
+int InsetCommand::Ascii(ostream &) const
 {
-       file += getCommand();
        return 0;
 }
 
 
-int InsetCommand::Linuxdoc(string &/*file*/)
+int InsetCommand::Linuxdoc(ostream &) const
 {
        return 0;
 }
 
 
-int InsetCommand::DocBook(string &/*file*/)
+int InsetCommand::DocBook(ostream &) const
 {
        return 0;
 }