]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetLine.cpp
Squash warning
[lyx.git] / src / insets / InsetLine.cpp
index d90c285bc185b67bb6edb12de03d2959d30f7b73..be05fe14234b2e4201733cb6742e6d55306c5210 100644 (file)
@@ -3,7 +3,8 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * \author André Pönitz
+ * \author André Pönitz
+ * \author Uwe Stöhr
  *
  * Full author contact details are available in file CREDITS.
  */
 
 #include "InsetLine.h"
 
+#include "Buffer.h"
 #include "Dimension.h"
-#include "Font.h"
-#include "MetricsInfo.h"
+#include "DispatchResult.h"
+#include "FuncRequest.h"
+#include "FuncStatus.h"
 #include "LaTeXFeatures.h"
+#include "Length.h"
+#include "MetricsInfo.h"
 #include "OutputParams.h"
+#include "output_xhtml.h"
 #include "Text.h"
 
+#include "frontends/FontMetrics.h"
 #include "frontends/Painter.h"
 
 #include "support/debug.h"
 #include "support/docstream.h"
-
-
+#include "support/gettext.h"
+#include "support/lstrings.h"
 
 using namespace std;
 
@@ -33,24 +40,88 @@ namespace lyx {
 using frontend::Painter;
 
 
-void InsetLine::read(Lexer &)
+InsetLine::InsetLine(Buffer * buf, InsetCommandParams const & p)
+       : InsetCommand(buf, p, "line")
+{}
+
+
+ParamInfo const & InsetLine::findInfo(string const & /* cmdName */)
+{
+       static ParamInfo param_info_;
+       if (param_info_.empty()) {
+               param_info_.add("offset", ParamInfo::LYX_INTERNAL);
+               param_info_.add("width", ParamInfo::LYX_INTERNAL);
+               param_info_.add("height", ParamInfo::LYX_INTERNAL);
+       }
+       return param_info_;
+}
+
+
+docstring InsetLine::screenLabel() const
+{
+       return _("Horizontal line");
+}
+
+
+void InsetLine::doDispatch(Cursor & cur, FuncRequest & cmd)
 {
-       /* Nothing to read */
+       switch (cmd.action()) {
+
+       case LFUN_INSET_MODIFY: {
+               InsetCommandParams p(LINE_CODE);
+               // FIXME UNICODE
+               InsetCommand::string2params("line",
+                       to_utf8(cmd.argument()), p);
+               if (p.getCmdName().empty()) {
+                       cur.noScreenUpdate();
+                       break;
+               }
+               setParams(p);
+               break;
+       }
+
+       default:
+               InsetCommand::doDispatch(cur, cmd);
+               break;
+       }
 }
 
 
-void InsetLine::write(ostream & os) const
+bool InsetLine::getStatus(Cursor & cur, FuncRequest const & cmd,
+       FuncStatus & status) const
 {
-       os << "\n\\lyxline\n";
+       switch (cmd.action()) {
+       case LFUN_INSET_DIALOG_UPDATE:
+       case LFUN_INSET_MODIFY:
+               status.setEnabled(true);
+               return true;
+       default:
+               return InsetCommand::getStatus(cur, cmd, status);
+       }
 }
 
 
 void InsetLine::metrics(MetricsInfo & mi, Dimension & dim) const
 {
-       dim.asc = 3;
-       dim.des = 3;
-       dim.wid = mi.base.textwidth;
-       // Cache the inset dimension. 
+       frontend::FontMetrics const & fm = theFontMetrics(mi.base.font);
+       dim.asc = fm.maxAscent();
+       dim.des = fm.maxDescent();
+       
+       Length width = Length(to_ascii(getParam("width")));
+       int w = 
+               width.inPixels(mi.base.textwidth,
+               fm.width(char_type('M')));
+
+       // assure that the line inset is not outside of the window
+       // check that it doesn't exceed the outer boundary
+       if (w > mi.base.textwidth)
+               w = mi.base.textwidth;
+
+       // set a minimal width
+       int const minw = (w < 0) ? 3 * 8 : 4;
+       dim.wid = max(minw, abs(w));
+
+       // Cache the inset dimension
        setDimCache(mi, dim);
 }
 
@@ -58,15 +129,61 @@ void InsetLine::metrics(MetricsInfo & mi, Dimension & dim) const
 void InsetLine::draw(PainterInfo & pi, int x, int y) const
 {
        Dimension const dim = dimension(*pi.base.bv);
-       pi.pain.line(x, y, x + dim.wid, y, Color_topline,
-               Painter::line_solid, Painter::line_thick);
+
+       frontend::FontMetrics const & fm = theFontMetrics(pi.base.font);
+
+       // get the length of the parameters in pixels
+       Length offset = Length(to_ascii(getParam("offset")));
+       int o = 
+               offset.inPixels(pi.base.textwidth,
+               fm.width(char_type('M')));
+       Length width = Length(to_ascii(getParam("width")));
+       int w = 
+               width.inPixels(pi.base.textwidth,
+               fm.width(char_type('M')));
+       Length height = Length(to_ascii(getParam("height")));
+       int h = 
+               height.inPixels(pi.base.textwidth,
+               fm.width(char_type('M')));
+
+       // get the surrounding text color
+       FontInfo f = pi.base.font;
+       Color Line_color = f.realColor();
+
+       // assure that the drawn line is not outside of the window
+       // check that it doesn't exceed the outer boundary
+       if (x + w - h/2 - 2 > pi.base.textwidth)
+               w = pi.base.textwidth - x + h/2 + 2;
+       // check that it doesn't exceed the upper boundary
+       if (y - o - h/2 < 0)
+               o = y - h/2 - 2;
+
+       // the offset is a vertical one
+       pi.pain.line(x + h/2 + 1, y - o - h/2, x + w - h/2 - 2, y - o - h/2,
+               Line_color, Painter::line_solid, float(h));
 }
 
 
-int InsetLine::latex(odocstream & os, OutputParams const & runparams) const
+int InsetLine::latex(odocstream & os, OutputParams const &) const
 {
-       os << "\\lyxline{\\"
-          << from_ascii(runparams.local_font->latexSize()) << '}';
+       bool have_offset = true;
+       Length offset_len = Length(to_ascii(getParam("offset")));
+       if (offset_len.value() == 0)
+               have_offset = false;
+
+       string const offset =
+               Length(to_ascii(getParam("offset"))).asLatexString();
+       string const width =
+               Length(to_ascii(getParam("width"))).asLatexString();
+       string const height =
+               Length(to_ascii(getParam("height"))).asLatexString();
+
+       os << "\\rule";
+       // only output the optional parameter if the offset is not 0
+       if (have_offset)
+               os      << "[" << from_ascii(offset) << "]";
+       os << "{" << from_ascii(width) << "}{" << from_ascii(height) << '}';
+
        return 0;
 }
 
@@ -85,9 +202,11 @@ int InsetLine::docbook(odocstream & os, OutputParams const &) const
 }
 
 
-void InsetLine::validate(LaTeXFeatures & features) const
+docstring InsetLine::xhtml(XHTMLStream & xs, OutputParams const &) const
 {
-       features.require("lyxline");
+       xs << html::CompTag("hr");
+       xs.cr();
+       return docstring();
 }