// -*- C++ -*-
-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The LyX Team.
+/**
+ * \file lyxrow.h
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * ====================================================== */
+ * \author unknown
+ *
+ * Full author contact details are available in file CREDITS
+ *
+ * Metrics for an on-screen text row.
+ */
#ifndef LYXROW_H
#define LYXROW_H
-#include "lyxparagraph.h"
+#include "support/types.h"
+
+class Paragraph;
///
-struct Row {
+class Row {
+public:
+ ///
+ Row();
+
+ ///
+ void par(Paragraph * p);
+ ///
+ Paragraph * par();
+ ///
+ Paragraph * par() const;
+ ///
+ void pos(lyx::pos_type p);
+ ///
+ lyx::pos_type pos() const;
+ ///
+ void fill(int f);
+ ///
+ int fill() const;
+ ///
+ void height(unsigned short h);
+ ///
+ unsigned short height() const;
+ ///
+ void width(unsigned int w);
+ ///
+ unsigned int width() const;
+ ///
+ void ascent_of_text(unsigned short a);
+ ///
+ unsigned short ascent_of_text() const;
+ ///
+ void top_of_text(unsigned int top);
+ ///
+ unsigned int top_of_text() const;
+ ///
+ void baseline(unsigned int b);
///
- Row()
- : par(0), pos(0), baseline(0), fill(0), height(0),
- ascent_of_text(0), next(0), previous(0)
- {}
+ unsigned int baseline() const;
///
- LyXParagraph * par;
+ void next(Row * r);
///
- LyXParagraph::size_type pos;
+ Row * next() const;
///
- unsigned short baseline;
+ void previous(Row * r);
+ ///
+ Row * previous() const;
+
+ /// return true if this row is the start of a paragraph
+ bool isParStart() const;
+
+ /// return true if this row is the end of a paragraph
+ bool isParEnd() const;
+
+ /// return the position of the last character in this row
+ lyx::pos_type lastPos() const;
+ /// return the position of the last normal, printable character in this row
+ lyx::pos_type lastPrintablePos() const;
+
+ /**
+ * Returns the number of separators.
+ * The separator on the very last column doesnt count.
+ */
+ int numberOfSeparators() const;
+
+ /**
+ * Returns the number of hfills. It works like a LaTeX \hfill:
+ * the hfills at the beginning and at the end are ignored.
+ * This is much more useful than not to ignore!
+ */
+ int numberOfHfills() const;
+
+ /// Returns the number of hfills in the manual label. See numberOfHfills().
+ int numberOfLabelHfills() const;
+
+ /**
+ * Returns true if a expansion is needed at the given position.
+ * Rules are given by LaTeX
+ */
+ bool hfillExpansion(lyx::pos_type pos) const;
+
+private:
+ ///
+ Paragraph * par_;
+ ///
+ lyx::pos_type pos_;
/** what is missing to a full row can be negative.
Needed for hfills, flushright, block etc. */
- mutable int fill;
+ mutable int fill_;
+ ///
+ unsigned short height_;
///
- unsigned short height;
+ unsigned int width_;
+ /// ascent from baseline including prelude space
+ unsigned short ascent_of_text_;
+ /// the top of the real text in the row
+ unsigned int top_of_text_;
///
- unsigned short ascent_of_text;
-
+ unsigned int baseline_;
///
- Row * next;
+ Row * next_;
///
- Row * previous;
+ Row * previous_;
};
+
+inline
+Paragraph * Row::par()
+{
+ return par_;
+}
+
+
+inline
+Paragraph * Row::par() const
+{
+ return par_;
+}
+
+
+inline
+unsigned short Row::height() const
+{
+ return height_;
+}
+
+
+inline
+Row * Row::next() const
+{
+ return next_;
+}
+
#endif