]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/math_deliminset.C
remove symbol_def.h
[lyx.git] / src / mathed / math_deliminset.C
index 9e4bbcaf3a160f4c9d811d0995f8a82d57c7a3ef..d42bbf79d393d86fe7ff3cd1a197873fbba46039 100644 (file)
@@ -1,90 +1,91 @@
 #include <config.h>
 
+#ifdef __GNUG__
+#pragma implementation
+#endif
+
 #include "math_deliminset.h"
-#include "math_iter.h"
 #include "math_parser.h"
-#include "LColor.h"
-#include "Painter.h"
 #include "mathed/support.h"
+#include "support/LOstream.h"
 
+using std::max;
 
-MathDelimInset::MathDelimInset(int l, int r, short st)
-       : MathParInset(st, "", LM_OT_DELIM), left(l), right(r) {}
+MathDelimInset::MathDelimInset(latexkeys const * l, latexkeys const * r)
+       : MathNestInset(1), left_(l), right_(r)
+{}
 
 
-MathedInset * MathDelimInset::Clone()
+MathInset * MathDelimInset::clone() const
 {   
-       MathDelimInset * p = new MathDelimInset(left, right, GetStyle());
-       MathedIter it(array);
-       p->SetData(it.Copy());
-       return p;
+       return new MathDelimInset(*this);
 }
 
 
-
-void MathDelimInset::Write(ostream & os, bool fragile)
+string MathDelimInset::latexName(latexkeys const * l)
 {
-       latexkeys * l = (left != '|') ? lm_get_key_by_id(left, LM_TK_SYM): 0;
-       latexkeys * r = (right != '|') ? lm_get_key_by_id(right, LM_TK_SYM): 0;
-       os << "\\left";
-       if (l) {
-               os << '\\' << l->name << ' ';
-       } else {
-               if (left == '{' || left == '}') {
-                       os << '\\' << char(left) << ' ';
-               } else {
-                       os << char(left) << ' ';
-               }
-       }
-       MathParInset::Write(os, fragile);
-       os << "\\right";
-       if (r) {
-               os << '\\' << r->name << ' ';
-       } else {
-               if (right == '{' || right == '}') {
-                       os << '\\' << char(right) << ' ';
-               } else {
-                       os << char(right) << ' ';
-               }
-       }
+       //static const string vdelim("(){}[]./|");
+       string name = l->name;
+       if (name == "(")
+               return name;
+       if (name == "[")
+               return name;
+       if (name == ".")
+               return name;
+       if (name == ")")
+               return name;
+       if (name == "]")
+               return name;
+       if (name == "/")
+               return name;
+       if (name == "|")
+               return name;
+       return "\\" + name + " ";
 }
 
 
+void MathDelimInset::write(std::ostream & os, bool fragile) const
+{
+       os << "\\left" << latexName(left_);
+       cell(0).write(os, fragile);
+       os << "\\right" << latexName(right_);
+}
+
 
-void
-MathDelimInset::draw(Painter & pain, int x, int y)
-{ 
-       xo = x;  yo = y; 
-       MathParInset::draw(pain, x + dw + 2, y - dh); 
-       
-       if (left == '.') {
-               pain.line(x + 4, yo - ascent,
-                         x + 4, yo + descent,
-                         LColor::mathcursor, Painter::line_onoffdash);
-       } else
-               mathed_draw_deco(pain, x, y - ascent, dw, Height(), left);
-       x += Width() - dw - 2;
-       if (right == '.') {
-               pain.line(x + 4, yo - ascent,
-                         x + 4, yo + descent,
-                         LColor::mathcursor, Painter::line_onoffdash);
-       } else
-               mathed_draw_deco(pain, x, y-ascent, dw, Height(), right);
+int MathDelimInset::dw() const
+{
+       int w = height() / 5;
+       if (w > 15)
+               w = 15;
+       if (w < 4)
+               w = 4;
+       return w;
 }
 
 
-void
-MathDelimInset::Metrics()
+void MathDelimInset::metrics(MathStyles st) const
 {
-   MathParInset::Metrics();
-   int d;
-   
-   mathed_char_height(LM_TC_CONST, size, 'I', d, dh);
-   dh /= 2;
-   ascent += 2 + dh;
-   descent += 2 - dh;
-   dw = Height()/5;
-   if (dw > 15) dw = 15;
-   if (dw<6) dw = 6;
-   width += 2*dw+4;
+       xcell(0).metrics(st);
+       size_    = st;
+       int a, d, w;
+       mathed_char_dim(LM_TC_VAR, st,'I', a, d, w);
+       int h0   = (a + d) / 2;
+       int a0   = std::max(xcell(0).ascent(), a)   - h0;
+       int d0   = std::max(xcell(0).descent(), d)  + h0;
+       ascent_  = max(a0, d0) + h0;
+       descent_ = max(a0, d0) - h0;
+       width_   = xcell(0).width() + 2 * dw() + 4;
+}
+
+
+void MathDelimInset::draw(Painter & pain, int x, int y) const
+{ 
+       xo(x);
+       yo(y); 
+
+       int const w = dw();
+       int const b = y - ascent_ - 2;
+       xcell(0).draw(pain, x + w + 2, y);
+       mathed_draw_deco(pain, x + 1, b, w, height() + 4, left_->name);
+       mathed_draw_deco(pain, x + width() - w - 1, b, w, height() + 4, right_->name);
 }