]> git.lyx.org Git - lyx.git/blobdiff - src/mathed/math_dotsinset.C
more IU
[lyx.git] / src / mathed / math_dotsinset.C
index 8251356cf7a589ba0202e0e1ce1437d5ee6ed858..c08c31a443c2327066278b51e498d15fe2ad1934 100644 (file)
@@ -1,50 +1,66 @@
-#include <config.h>
+/**
+ * \file math_dotsinset.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
+ *
+ * \author Alejandro Aguilar Sierra
+ * \author André Pönitz
+ *
+ * Full author contact details are available in file CREDITS.
+ */
 
+#include <config.h>
 
 #include "math_dotsinset.h"
 #include "math_mathmlstream.h"
-#include "math_streamstr.h"
 #include "math_support.h"
 #include "math_parser.h"
 
 
+using std::string;
+using std::auto_ptr;
+
+
 MathDotsInset::MathDotsInset(latexkeys const * key)
        : key_(key)
 {}
 
 
-MathInset * MathDotsInset::clone() const
+auto_ptr<InsetBase> MathDotsInset::clone() const
 {
-       return new MathDotsInset(*this);
+       return auto_ptr<InsetBase>(new MathDotsInset(*this));
 }
 
 
-void MathDotsInset::metrics(MathMetricsInfo & mi) const
+void MathDotsInset::metrics(MetricsInfo & mi, Dimension & dim) const
 {
        mathed_char_dim(mi.base.font, 'M', dim_);
        dh_ = 0;
        if (key_->name == "cdots" || key_->name == "dotsb"
                        || key_->name == "dotsm" || key_->name == "dotsi")
-               dh_ = ascent() / 2;
+               dh_ = dim_.asc / 2;
        else if (key_->name == "dotsc")
-               dh_ = ascent() / 4;
+               dh_ = dim_.asc / 4;
        else if (key_->name == "vdots") {
-               dim_.w = (dim_.w / 2) + 1;
-               dh_ = ascent();
+               dim_.wid = (dim_.wid / 2) + 1;
+               dh_ = dim_.asc;
        }
        else if (key_->name == "ddots")
-               dh_ = ascent();
+               dh_ = dim_.asc;
+       dim = dim_;
 }
 
 
-void MathDotsInset::draw(MathPainterInfo & pain, int x, int y) const
+void MathDotsInset::draw(PainterInfo & pain, int x, int y) const
 {
-       mathed_draw_deco(pain, x + 2, y - dh_, width() - 2, ascent(), key_->name);
+       mathed_draw_deco(pain, x + 2, y - dh_, dim_.width() - 2, dim_.ascent(),
+               key_->name);
        if (key_->name == "vdots" || key_->name == "ddots")
                ++x;
        if (key_->name != "vdots")
                --y;
-       mathed_draw_deco(pain, x + 2, y - dh_, width() - 2, ascent(), key_->name);
+       mathed_draw_deco(pain, x + 2, y - dh_, dim_.width() - 2, dim_.ascent(),
+               key_->name);
 }