2000-04-19 14:42:19 +00:00
|
|
|
// -*- C++ -*-
|
2002-09-25 14:26:13 +00:00
|
|
|
/**
|
2007-04-25 01:24:38 +00:00
|
|
|
* \file InsetTabular.h
|
2002-09-25 14:26:13 +00:00
|
|
|
* This file is part of LyX, the document processor.
|
|
|
|
* Licence details can be found in the file COPYING.
|
2002-03-21 17:09:55 +00:00
|
|
|
*
|
2008-11-14 15:58:50 +00:00
|
|
|
* \author Lars Gullik Bjønnes
|
2007-04-26 12:54:21 +00:00
|
|
|
* \author Matthias Ettrich
|
2008-11-14 15:58:50 +00:00
|
|
|
* \author André Pönitz
|
|
|
|
* \author Jürgen Vigna
|
2010-02-11 01:47:06 +00:00
|
|
|
* \author Edwin Leuven
|
|
|
|
* \author Uwe Stöhr
|
2012-12-24 05:51:28 -05:00
|
|
|
* \author Scott Kostyshak
|
2000-04-19 14:42:19 +00:00
|
|
|
*
|
2003-08-23 00:17:00 +00:00
|
|
|
* Full author contact details are available in file CREDITS.
|
2000-04-19 14:42:19 +00:00
|
|
|
*/
|
|
|
|
|
2004-02-16 11:58:51 +00:00
|
|
|
// Things to think of when designing the new tabular support:
|
2000-04-19 14:42:19 +00:00
|
|
|
// - color support (colortbl, color)
|
|
|
|
// - decimal alignment (dcloumn)
|
|
|
|
// - custom lines (hhline)
|
|
|
|
// - column styles
|
|
|
|
|
2008-03-27 22:26:24 +00:00
|
|
|
#ifndef INSET_TABULAR_H
|
|
|
|
#define INSET_TABULAR_H
|
2000-04-19 14:42:19 +00:00
|
|
|
|
2022-04-01 04:12:14 +02:00
|
|
|
#include "BufferParams.h"
|
2020-11-30 01:03:35 +02:00
|
|
|
#include "Changes.h"
|
2007-04-26 12:54:21 +00:00
|
|
|
#include "InsetText.h"
|
2020-08-03 14:15:09 +02:00
|
|
|
|
|
|
|
#include "support/Length.h"
|
2020-11-21 00:06:05 +02:00
|
|
|
#include "support/types.h"
|
2007-04-26 12:54:21 +00:00
|
|
|
|
2013-03-08 14:52:18 -05:00
|
|
|
#include <climits>
|
2007-04-26 12:54:21 +00:00
|
|
|
#include <iosfwd>
|
2016-06-02 18:13:55 +01:00
|
|
|
#include <memory>
|
2007-04-26 12:54:21 +00:00
|
|
|
#include <vector>
|
2006-10-21 00:16:43 +00:00
|
|
|
|
2016-06-02 18:13:55 +01:00
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
namespace lyx {
|
2004-01-08 18:30:14 +00:00
|
|
|
|
2000-04-19 14:42:19 +00:00
|
|
|
class Buffer;
|
2008-03-21 17:45:14 +00:00
|
|
|
class BufferView;
|
2008-03-15 12:22:28 +00:00
|
|
|
class CompletionList;
|
2010-09-02 10:26:34 +00:00
|
|
|
class Cursor;
|
2004-01-08 18:30:14 +00:00
|
|
|
class CursorSlice;
|
2008-03-21 17:45:14 +00:00
|
|
|
class FuncStatus;
|
|
|
|
class Lexer;
|
2010-09-02 10:26:34 +00:00
|
|
|
class OutputParams;
|
2019-05-10 01:35:40 +02:00
|
|
|
class XMLStream;
|
2004-01-08 18:30:14 +00:00
|
|
|
|
2000-04-19 14:42:19 +00:00
|
|
|
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
|
|
|
class InsetTableCell : public InsetText
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
///
|
2019-09-17 23:06:18 +02:00
|
|
|
explicit InsetTableCell(Buffer * buf);
|
2020-10-05 13:11:48 -04:00
|
|
|
/// We need this since generation of the default is deprecated
|
2020-10-06 20:31:11 -04:00
|
|
|
/// (since we declare the assignment constuctor below).
|
|
|
|
InsetTableCell(InsetTableCell const & in) = default;
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
InsetCode lyxCode() const override { return CELL_CODE; }
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
2023-07-22 23:27:09 +02:00
|
|
|
docstring layoutName() const override { return from_ascii("Tabular:Cell"); }
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
Inset * clone() const override { return new InsetTableCell(*this); }
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
|
|
|
bool getStatus(Cursor & cur, FuncRequest const & cmd,
|
2020-10-01 10:42:11 +03:00
|
|
|
FuncStatus & status) const override;
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
|
|
|
void toggleFixedWidth(bool fw) { isFixedWidth = fw; }
|
|
|
|
///
|
2021-01-23 15:22:09 +01:00
|
|
|
void toggleVarWidth(bool vw) { isVarwidth = vw; }
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
void toggleMultiCol(bool m) { isMultiColumn = m; }
|
|
|
|
///
|
|
|
|
void toggleMultiRow(bool m) { isMultiRow = m; }
|
|
|
|
///
|
2024-01-28 12:13:27 +01:00
|
|
|
void toggleCaptionRow(bool m) { isCaptionRow = m; }
|
|
|
|
///
|
2021-01-29 15:46:46 +01:00
|
|
|
void setContentAlignment(LyXAlignment al) { contentAlign = al; }
|
2010-09-02 10:26:34 +00:00
|
|
|
/// writes the contents of the cell as a string, optionally
|
|
|
|
/// descending into insets
|
|
|
|
docstring asString(bool intoInsets = true);
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
docstring xhtml(XMLStream &, OutputParams const &) const override;
|
2014-02-24 14:36:13 -05:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void docbook(XMLStream &, OutputParams const &) const override;
|
2020-06-08 23:27:49 +02:00
|
|
|
///
|
2015-09-27 07:05:00 +01:00
|
|
|
void addToToc(DocIterator const & di, bool output_active,
|
2020-10-01 10:42:11 +03:00
|
|
|
UpdateType utype, TocBackend & backend) const override;
|
2018-07-01 19:18:38 +02:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void metrics(MetricsInfo &, Dimension &) const override;
|
2020-08-12 16:25:35 +02:00
|
|
|
/// Can the cell contain several paragraphs?
|
2020-10-01 10:42:11 +03:00
|
|
|
bool allowMultiPar() const override { return !isMultiRow && (!isMultiColumn || isFixedWidth); }
|
2021-01-21 09:04:29 +01:00
|
|
|
///
|
|
|
|
bool canPaintChange(BufferView const &) const override { return false; }
|
2021-01-29 15:45:54 +01:00
|
|
|
/// This assures we never output \maketitle in table cells
|
|
|
|
bool isInTitle() const override { return true; }
|
2010-09-02 10:26:34 +00:00
|
|
|
private:
|
2020-10-07 11:05:54 -04:00
|
|
|
///
|
|
|
|
InsetTableCell() = delete;
|
|
|
|
///
|
|
|
|
void operator=(InsetTableCell const &) = delete;
|
2010-09-02 10:26:34 +00:00
|
|
|
// FIXME
|
2018-07-01 19:18:38 +02:00
|
|
|
// These booleans are supposed to track whether the cell has had its
|
|
|
|
// width explicitly set and whether it is part of a multicolumn, respectively.
|
|
|
|
// We need to know this to determine whether
|
2010-09-02 10:26:34 +00:00
|
|
|
// layout changes and paragraph customization are allowed---that is,
|
2014-07-26 16:29:23 +02:00
|
|
|
// we need it in forcePlainLayout() and allowParagraphCustomization().
|
|
|
|
// Unfortunately, that information is not readily available in
|
2010-09-02 10:26:34 +00:00
|
|
|
// InsetTableCell. In the case of multicolumn cells, it is present
|
|
|
|
// in CellData, and so would be available here if CellData were to
|
|
|
|
// become a member of InsetTableCell. But in the other case, it isn't
|
|
|
|
// even available there, but is held in Tabular::ColumnData.
|
|
|
|
// So, the present solution uses this boolean to track the information
|
|
|
|
// we need to track, and tries to keep it updated. This is not ideal,
|
|
|
|
// but the other solutions are no better. These are:
|
|
|
|
// (i) Keep a pointer in InsetTableCell to the table;
|
|
|
|
// (ii) Find the table by iterating over the Buffer's insets.
|
2014-07-26 16:29:23 +02:00
|
|
|
// Solution (i) raises the problem of updating the pointer when an
|
2010-09-02 10:26:34 +00:00
|
|
|
// InsetTableCell is copied, and we'd therefore need a copy constructor
|
2014-07-26 16:29:23 +02:00
|
|
|
// in InsetTabular and then in Tabular, which seems messy, given how
|
|
|
|
// complicated those classes are. Solution (ii) involves a lot of
|
2010-09-02 10:26:34 +00:00
|
|
|
// iterating, since this information is needed quite often, and so may
|
|
|
|
// be quite slow.
|
|
|
|
// So, well, if someone can do better, please do!
|
2020-10-05 13:11:48 -04:00
|
|
|
// --rkh
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
|
|
|
bool isFixedWidth;
|
2018-07-01 19:18:38 +02:00
|
|
|
///
|
2021-01-23 15:22:09 +01:00
|
|
|
bool isVarwidth;
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
bool isMultiColumn;
|
|
|
|
///
|
|
|
|
bool isMultiRow;
|
2024-01-28 12:13:27 +01:00
|
|
|
// FIXME: For the next two items the thoughts from the comment above also apply.
|
|
|
|
///
|
|
|
|
bool isCaptionRow;
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
|
|
|
LyXAlignment contentAlign;
|
Run codespell on src/insets
Command was
codespell -w -i 3 -S Makefile.in -L mathed,afe,tthe,ue,fro,uint,larg,alph,te,thes,alle,Claus,pres,pass-thru src/insets/
2020-06-25 23:46:16 +02:00
|
|
|
/// should paragraph indentation be omitted in any case?
|
2020-10-01 10:42:11 +03:00
|
|
|
bool neverIndent() const override { return true; }
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
LyXAlignment contentAlignment() const override { return contentAlign; }
|
2010-09-02 10:26:34 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool usePlainLayout() const override { return true; }
|
2014-07-26 16:29:23 +02:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool allowParagraphCustomization(idx_type = 0) const override;
|
2015-04-04 11:59:01 +02:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool forceLocalFontSwitch() const override;
|
2010-09-02 10:26:34 +00:00
|
|
|
/// Is the width forced to some value?
|
2020-10-01 10:42:11 +03:00
|
|
|
bool hasFixedWidth() const override { return isFixedWidth; }
|
2024-01-28 12:13:27 +01:00
|
|
|
///
|
|
|
|
bool insetAllowed(InsetCode code) const override;
|
2010-09-02 10:26:34 +00:00
|
|
|
};
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// A helper struct for tables
|
2007-05-28 22:27:45 +00:00
|
|
|
//
|
2007-10-06 09:19:53 +00:00
|
|
|
class Tabular {
|
2007-04-26 12:54:21 +00:00
|
|
|
public:
|
|
|
|
///
|
|
|
|
enum Feature {
|
|
|
|
///
|
|
|
|
APPEND_ROW = 0,
|
|
|
|
///
|
|
|
|
APPEND_COLUMN,
|
|
|
|
///
|
|
|
|
DELETE_ROW,
|
|
|
|
///
|
|
|
|
DELETE_COLUMN,
|
|
|
|
///
|
|
|
|
COPY_ROW,
|
|
|
|
///
|
|
|
|
COPY_COLUMN,
|
|
|
|
///
|
2012-12-24 05:51:28 -05:00
|
|
|
MOVE_COLUMN_RIGHT,
|
|
|
|
///
|
|
|
|
MOVE_COLUMN_LEFT,
|
|
|
|
///
|
|
|
|
MOVE_ROW_DOWN,
|
|
|
|
///
|
|
|
|
MOVE_ROW_UP,
|
|
|
|
///
|
2010-02-19 10:03:03 +00:00
|
|
|
SET_LINE_TOP,
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-19 10:03:03 +00:00
|
|
|
SET_LINE_BOTTOM,
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-19 10:03:03 +00:00
|
|
|
SET_LINE_LEFT,
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-19 10:03:03 +00:00
|
|
|
SET_LINE_RIGHT,
|
|
|
|
///FIXME: remove
|
|
|
|
TOGGLE_LINE_TOP,
|
|
|
|
///FIXME: remove
|
|
|
|
TOGGLE_LINE_BOTTOM,
|
|
|
|
///FIXME: remove
|
|
|
|
TOGGLE_LINE_LEFT,
|
|
|
|
///FIXME: remove
|
2007-04-26 12:54:21 +00:00
|
|
|
TOGGLE_LINE_RIGHT,
|
|
|
|
///
|
2019-04-03 07:59:52 +02:00
|
|
|
SET_LTRIM_TOP,
|
|
|
|
///
|
|
|
|
SET_RTRIM_TOP,
|
|
|
|
///
|
|
|
|
SET_LTRIM_BOTTOM,
|
|
|
|
///
|
|
|
|
SET_RTRIM_BOTTOM,
|
|
|
|
///
|
|
|
|
TOGGLE_LTRIM_TOP,
|
|
|
|
///
|
|
|
|
TOGGLE_RTRIM_TOP,
|
|
|
|
///
|
|
|
|
TOGGLE_LTRIM_BOTTOM,
|
|
|
|
///
|
|
|
|
TOGGLE_RTRIM_BOTTOM,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
ALIGN_LEFT,
|
|
|
|
///
|
|
|
|
ALIGN_RIGHT,
|
|
|
|
///
|
|
|
|
ALIGN_CENTER,
|
|
|
|
///
|
|
|
|
ALIGN_BLOCK,
|
|
|
|
///
|
2010-06-05 07:44:44 +00:00
|
|
|
ALIGN_DECIMAL,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
VALIGN_TOP,
|
|
|
|
///
|
|
|
|
VALIGN_BOTTOM,
|
|
|
|
///
|
|
|
|
VALIGN_MIDDLE,
|
|
|
|
///
|
|
|
|
M_ALIGN_LEFT,
|
|
|
|
///
|
|
|
|
M_ALIGN_RIGHT,
|
|
|
|
///
|
|
|
|
M_ALIGN_CENTER,
|
|
|
|
///
|
|
|
|
M_VALIGN_TOP,
|
|
|
|
///
|
|
|
|
M_VALIGN_BOTTOM,
|
|
|
|
///
|
|
|
|
M_VALIGN_MIDDLE,
|
|
|
|
///
|
|
|
|
MULTICOLUMN,
|
|
|
|
///
|
2010-10-29 04:09:49 +00:00
|
|
|
SET_MULTICOLUMN,
|
|
|
|
///
|
|
|
|
UNSET_MULTICOLUMN,
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
MULTIROW,
|
|
|
|
///
|
2010-10-29 04:09:49 +00:00
|
|
|
SET_MULTIROW,
|
|
|
|
///
|
|
|
|
UNSET_MULTIROW,
|
|
|
|
///
|
2010-11-07 05:32:28 +00:00
|
|
|
SET_MROFFSET,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_ALL_LINES,
|
|
|
|
///
|
2019-04-01 07:08:13 +02:00
|
|
|
RESET_FORMAL_DEFAULT,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
UNSET_ALL_LINES,
|
|
|
|
///
|
2015-11-13 14:09:04 +01:00
|
|
|
TOGGLE_LONGTABULAR,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_LONGTABULAR,
|
|
|
|
///
|
|
|
|
UNSET_LONGTABULAR,
|
|
|
|
///
|
|
|
|
SET_PWIDTH,
|
|
|
|
///
|
|
|
|
SET_MPWIDTH,
|
|
|
|
///
|
2018-06-24 10:05:15 +02:00
|
|
|
TOGGLE_VARWIDTH_COLUMN,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_ROTATE_TABULAR,
|
|
|
|
///
|
|
|
|
UNSET_ROTATE_TABULAR,
|
|
|
|
///
|
2007-05-12 20:59:21 +00:00
|
|
|
TOGGLE_ROTATE_TABULAR,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_ROTATE_CELL,
|
|
|
|
///
|
|
|
|
UNSET_ROTATE_CELL,
|
|
|
|
///
|
2007-05-12 20:59:21 +00:00
|
|
|
TOGGLE_ROTATE_CELL,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_USEBOX,
|
|
|
|
///
|
|
|
|
SET_LTHEAD,
|
|
|
|
UNSET_LTHEAD,
|
|
|
|
///
|
|
|
|
SET_LTFIRSTHEAD,
|
|
|
|
UNSET_LTFIRSTHEAD,
|
|
|
|
///
|
|
|
|
SET_LTFOOT,
|
|
|
|
UNSET_LTFOOT,
|
|
|
|
///
|
|
|
|
SET_LTLASTFOOT,
|
|
|
|
UNSET_LTLASTFOOT,
|
|
|
|
///
|
|
|
|
SET_LTNEWPAGE,
|
2012-05-31 13:56:07 +02:00
|
|
|
UNSET_LTNEWPAGE,
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-05-04 07:51:50 +00:00
|
|
|
TOGGLE_LTCAPTION,
|
|
|
|
///
|
2010-10-29 04:09:49 +00:00
|
|
|
SET_LTCAPTION,
|
|
|
|
///
|
|
|
|
UNSET_LTCAPTION,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_SPECIAL_COLUMN,
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
SET_SPECIAL_MULTICOLUMN,
|
|
|
|
///
|
2015-11-13 14:09:04 +01:00
|
|
|
TOGGLE_BOOKTABS,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
SET_BOOKTABS,
|
|
|
|
///
|
|
|
|
UNSET_BOOKTABS,
|
|
|
|
///
|
|
|
|
SET_TOP_SPACE,
|
|
|
|
///
|
|
|
|
SET_BOTTOM_SPACE,
|
|
|
|
///
|
|
|
|
SET_INTERLINE_SPACE,
|
|
|
|
///
|
2008-03-20 08:45:40 +00:00
|
|
|
SET_BORDER_LINES,
|
|
|
|
///
|
2009-01-03 18:33:09 +00:00
|
|
|
TABULAR_VALIGN_TOP,
|
|
|
|
///
|
|
|
|
TABULAR_VALIGN_MIDDLE,
|
|
|
|
///
|
|
|
|
TABULAR_VALIGN_BOTTOM,
|
|
|
|
///
|
2009-07-11 13:09:45 +00:00
|
|
|
LONGTABULAR_ALIGN_LEFT,
|
|
|
|
///
|
|
|
|
LONGTABULAR_ALIGN_CENTER,
|
|
|
|
///
|
|
|
|
LONGTABULAR_ALIGN_RIGHT,
|
|
|
|
///
|
2010-06-05 07:44:44 +00:00
|
|
|
SET_DECIMAL_POINT,
|
|
|
|
///
|
2011-02-03 23:11:26 +00:00
|
|
|
SET_TABULAR_WIDTH,
|
|
|
|
///
|
2018-12-28 10:11:42 +01:00
|
|
|
SET_INNER_LINES,
|
|
|
|
///
|
2022-03-13 08:57:49 +01:00
|
|
|
TOGGLE_INNER_LINES,
|
|
|
|
///
|
|
|
|
TOGGLE_BORDER_LINES,
|
|
|
|
///
|
|
|
|
TOGGLE_ALL_LINES,
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
LAST_ACTION
|
|
|
|
};
|
|
|
|
///
|
|
|
|
enum {
|
|
|
|
///
|
|
|
|
CELL_NORMAL = 0,
|
|
|
|
///
|
|
|
|
CELL_BEGIN_OF_MULTICOLUMN,
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
CELL_PART_OF_MULTICOLUMN,
|
|
|
|
///
|
|
|
|
CELL_BEGIN_OF_MULTIROW,
|
|
|
|
///
|
|
|
|
CELL_PART_OF_MULTIROW
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
///
|
|
|
|
enum VAlignment {
|
|
|
|
///
|
|
|
|
LYX_VALIGN_TOP = 0,
|
|
|
|
///
|
2009-07-11 14:33:05 +00:00
|
|
|
LYX_VALIGN_MIDDLE = 1,
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2009-07-11 14:33:05 +00:00
|
|
|
LYX_VALIGN_BOTTOM = 2
|
2014-07-26 16:29:23 +02:00
|
|
|
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
2009-07-11 13:09:45 +00:00
|
|
|
///
|
|
|
|
enum HAlignment {
|
|
|
|
///
|
|
|
|
LYX_LONGTABULAR_ALIGN_LEFT = 0,
|
|
|
|
///
|
|
|
|
LYX_LONGTABULAR_ALIGN_CENTER = 1,
|
|
|
|
///
|
|
|
|
LYX_LONGTABULAR_ALIGN_RIGHT = 2
|
|
|
|
};
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
enum BoxType {
|
|
|
|
///
|
|
|
|
BOX_NONE = 0,
|
|
|
|
///
|
|
|
|
BOX_PARBOX = 1,
|
|
|
|
///
|
2018-06-30 14:32:27 +02:00
|
|
|
BOX_MINIPAGE = 2,
|
|
|
|
///
|
|
|
|
BOX_VARWIDTH = 3
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
|
|
|
|
2011-12-18 21:27:17 +00:00
|
|
|
enum CaptionType {
|
|
|
|
///
|
|
|
|
CAPTION_FIRSTHEAD,
|
|
|
|
///
|
|
|
|
CAPTION_HEAD,
|
|
|
|
///
|
|
|
|
CAPTION_FOOT,
|
|
|
|
///
|
|
|
|
CAPTION_LASTFOOT,
|
|
|
|
///
|
|
|
|
CAPTION_ANY
|
|
|
|
};
|
|
|
|
|
2012-12-24 05:51:28 -05:00
|
|
|
enum RowDirection {
|
|
|
|
UP,
|
|
|
|
DOWN
|
|
|
|
};
|
|
|
|
|
|
|
|
enum ColDirection {
|
|
|
|
RIGHT,
|
|
|
|
LEFT
|
|
|
|
};
|
|
|
|
|
2007-04-26 12:54:21 +00:00
|
|
|
class ltType {
|
|
|
|
public:
|
|
|
|
// constructor
|
|
|
|
ltType();
|
|
|
|
// we have this header type (is set in the getLT... functions)
|
|
|
|
bool set;
|
|
|
|
// double borders on top
|
|
|
|
bool topDL;
|
|
|
|
// double borders on bottom
|
|
|
|
bool bottomDL;
|
|
|
|
// used for FirstHeader & LastFooter and if this is true
|
|
|
|
// all the rows marked as FirstHeader or LastFooter are
|
|
|
|
// ignored in the output and it is set to be empty!
|
|
|
|
bool empty;
|
|
|
|
};
|
|
|
|
|
|
|
|
/// index indicating an invalid position
|
|
|
|
static const idx_type npos = static_cast<idx_type>(-1);
|
|
|
|
|
|
|
|
/// constructor
|
2009-11-08 15:53:21 +00:00
|
|
|
Tabular(Buffer * buf, col_type columns_arg, row_type rows_arg);
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
/// Returns true if there is a topline, returns false if not
|
2008-03-18 18:08:32 +00:00
|
|
|
bool topLine(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Returns true if there is a topline, returns false if not
|
2008-03-18 18:08:32 +00:00
|
|
|
bool bottomLine(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Returns true if there is a topline, returns false if not
|
2019-04-01 09:26:09 +02:00
|
|
|
/// If \p ignore_bt is true, we return the state as if booktabs was
|
|
|
|
/// not used
|
|
|
|
bool leftLine(idx_type cell, bool const ignore_bt = false) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Returns true if there is a topline, returns false if not
|
2019-04-01 09:26:09 +02:00
|
|
|
/// If \p ignore_bt is true, we return the state as if booktabs was
|
|
|
|
/// not used
|
|
|
|
bool rightLine(idx_type cell, bool const ignore_bt = false) const;
|
2022-03-13 08:57:49 +01:00
|
|
|
/// Returns true if there is an outside border around the selection
|
|
|
|
bool outsideBorders(row_type sel_row_start, row_type sel_row_end,
|
|
|
|
col_type sel_col_start, col_type sel_col_end) const;
|
|
|
|
/// Returns true if there are inside lines in the selection
|
|
|
|
bool innerBorders(row_type sel_row_start, row_type sel_row_end,
|
|
|
|
col_type sel_col_start, col_type sel_col_end) const;
|
|
|
|
/// Sets the grid lines in the selection
|
|
|
|
/// if \p setLinesInnerOnly is true, outside borders are excluded
|
|
|
|
/// if \p setLines is true the lines are set otherwise they are unset
|
|
|
|
void setLines(row_type const sel_row_start, row_type const sel_row_end,
|
|
|
|
col_type const sel_col_start, col_type const sel_col_end,
|
|
|
|
bool setLinesInnerOnly, bool setLines);
|
2019-04-03 07:59:52 +02:00
|
|
|
/// Returns whether the top line is trimmed left and/or right
|
|
|
|
std::pair<bool, bool> topLineTrim(idx_type const cell) const;
|
|
|
|
/// Returns whether the bottom line is trimmed left and/or right
|
|
|
|
std::pair<bool, bool> bottomLineTrim(idx_type const cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
/// return space occupied by the second horizontal line and
|
|
|
|
/// interline space above row \p row in pixels
|
2010-02-11 01:07:54 +00:00
|
|
|
int interRowSpace(row_type row) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
int interColumnSpace(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
/* returns the maximum over all rows */
|
|
|
|
///
|
2010-06-14 10:42:42 +00:00
|
|
|
int cellWidth(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-03-16 21:42:16 +00:00
|
|
|
int cellHeight(idx_type cell) const;
|
2010-02-11 01:07:54 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int width() const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int height() const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-03-05 18:10:34 +00:00
|
|
|
row_type nrows() const {return row_info.size();}
|
|
|
|
///
|
|
|
|
col_type ncols() const {return column_info.size();}
|
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int rowAscent(row_type row) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int rowDescent(row_type row) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
void setRowAscent(row_type row, int height);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
void setRowDescent(row_type row, int height);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
void setTopLine(idx_type cell, bool line);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
void setBottomLine(idx_type cell, bool line);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2019-04-03 07:59:52 +02:00
|
|
|
void setTopLineLTrim(idx_type cell, bool val);
|
|
|
|
///
|
|
|
|
void setBottomLineLTrim(idx_type cell, bool val);
|
|
|
|
///
|
|
|
|
void setTopLineRTrim(idx_type cell, bool val);
|
|
|
|
///
|
|
|
|
void setBottomLineRTrim(idx_type cell, bool val);
|
|
|
|
///
|
|
|
|
void setTopLineTrim(idx_type cell, std::pair<bool, bool>);
|
|
|
|
///
|
|
|
|
void setBottomLineTrim(idx_type cell, std::pair<bool, bool>);
|
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
void setLeftLine(idx_type cell, bool line);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
void setRightLine(idx_type cell, bool line);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
bool rowTopLine(row_type row) const;
|
|
|
|
///
|
|
|
|
bool rowBottomLine(row_type row) const;
|
|
|
|
///
|
|
|
|
bool columnLeftLine(col_type column) const;
|
|
|
|
///
|
|
|
|
bool columnRightLine(col_type column) const;
|
|
|
|
|
2007-04-26 12:54:21 +00:00
|
|
|
void setAlignment(idx_type cell, LyXAlignment align,
|
|
|
|
bool onlycolumn = false);
|
|
|
|
///
|
|
|
|
void setVAlignment(idx_type cell, VAlignment align,
|
|
|
|
bool onlycolumn = false);
|
|
|
|
///
|
2011-02-03 23:11:26 +00:00
|
|
|
void setTabularWidth(Length const & l) { tabular_width = l; }
|
|
|
|
///
|
|
|
|
Length tabularWidth() const { return tabular_width; }
|
|
|
|
///
|
2007-04-28 12:58:49 +00:00
|
|
|
void setColumnPWidth(Cursor &, idx_type, Length const &);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-04-28 12:58:49 +00:00
|
|
|
bool setMColumnPWidth(Cursor &, idx_type, Length const &);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2018-06-24 10:05:15 +02:00
|
|
|
bool toggleVarwidth(idx_type, bool const);
|
|
|
|
///
|
2010-11-07 05:32:28 +00:00
|
|
|
bool setMROffset(Cursor &, idx_type, Length const &);
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
void setAlignSpecial(idx_type cell, docstring const & special,
|
|
|
|
Feature what);
|
|
|
|
///
|
|
|
|
LyXAlignment getAlignment(idx_type cell,
|
|
|
|
bool onlycolumn = false) const;
|
|
|
|
///
|
|
|
|
VAlignment getVAlignment(idx_type cell,
|
|
|
|
bool onlycolumn = false) const;
|
2016-07-18 12:37:14 +02:00
|
|
|
/// The vertical offset of the table due to the vertical
|
|
|
|
/// alignment with respect to the baseline.
|
|
|
|
int offsetVAlignment() const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-04-28 12:58:49 +00:00
|
|
|
Length const getPWidth(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-11-07 05:32:28 +00:00
|
|
|
Length const getMROffset(idx_type cell) const;
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
int textHOffset(idx_type cell) const;
|
|
|
|
///
|
|
|
|
int textVOffset(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2012-01-22 22:15:25 +00:00
|
|
|
void appendRow(row_type row);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2020-01-11 16:17:04 +01:00
|
|
|
void deleteRow(row_type row, bool const force = false);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2012-01-22 22:16:03 +00:00
|
|
|
void copyRow(row_type row);
|
2014-07-26 16:29:23 +02:00
|
|
|
///
|
2012-01-22 22:16:03 +00:00
|
|
|
void insertRow(row_type row, bool copy);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2021-01-25 19:00:50 +01:00
|
|
|
void moveColumn(col_type col_start, col_type col_end,
|
|
|
|
ColDirection direction);
|
2012-12-24 05:51:28 -05:00
|
|
|
///
|
2021-01-25 19:00:50 +01:00
|
|
|
void moveRow(row_type row_start, row_type row_end,
|
|
|
|
RowDirection direction);
|
2012-12-24 05:51:28 -05:00
|
|
|
///
|
2012-01-22 22:15:25 +00:00
|
|
|
void appendColumn(col_type column);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2020-01-11 16:17:04 +01:00
|
|
|
void deleteColumn(col_type column, bool const force = false);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2012-01-22 22:16:03 +00:00
|
|
|
void copyColumn(col_type column);
|
|
|
|
///
|
|
|
|
void insertColumn(col_type column, bool copy);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2020-01-14 13:03:12 +01:00
|
|
|
idx_type getFirstCellInRow(row_type row, bool const ct = false) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2020-01-14 13:03:12 +01:00
|
|
|
idx_type getLastCellInRow(row_type row, bool const ct = false) const;
|
|
|
|
///
|
|
|
|
idx_type getFirstRow(bool const ct = false) const;
|
|
|
|
///
|
|
|
|
idx_type getLastRow(bool const ct = false) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-12 18:36:20 +00:00
|
|
|
idx_type numberOfCellsInRow(row_type row) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-02-27 20:43:16 +00:00
|
|
|
void write(std::ostream &) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-02-27 20:43:16 +00:00
|
|
|
void read(Lexer &);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-02-10 20:02:48 +00:00
|
|
|
void latex(otexstream &, OutputParams const &) const;
|
2020-07-13 03:31:48 +02:00
|
|
|
/// serialise the table in DocBook, according to buffer parameters
|
2020-07-08 12:15:34 -04:00
|
|
|
void docbook(XMLStream &, OutputParams const &) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2019-05-10 01:35:40 +02:00
|
|
|
docstring xhtml(XMLStream &, OutputParams const &) const;
|
2009-12-14 15:39:13 +00:00
|
|
|
///
|
2013-03-08 14:52:18 -05:00
|
|
|
void plaintext(odocstringstream &,
|
2007-05-28 22:27:45 +00:00
|
|
|
OutputParams const & runparams, int const depth,
|
2013-03-08 14:52:18 -05:00
|
|
|
bool onlydata, char_type delim, size_t max_length = INT_MAX) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
bool isMultiColumn(idx_type cell) const;
|
|
|
|
///
|
2012-12-24 05:51:28 -05:00
|
|
|
bool hasMultiColumn(col_type cell) const;
|
|
|
|
///
|
2018-06-24 10:05:15 +02:00
|
|
|
bool hasVarwidthColumn() const;
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
bool isVTypeColumn(col_type cell) const;
|
|
|
|
///
|
|
|
|
idx_type setMultiColumn(Cursor & cur, idx_type cell, idx_type number,
|
2011-09-25 06:50:03 +00:00
|
|
|
bool const right_border);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
void unsetMultiColumn(idx_type cell);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
bool isPartOfMultiColumn(row_type row, col_type column) const;
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
bool isPartOfMultiRow(row_type row, col_type column) const;
|
|
|
|
///
|
|
|
|
bool isMultiRow(idx_type cell) const;
|
|
|
|
///
|
2012-12-24 05:51:28 -05:00
|
|
|
bool hasMultiRow(row_type r) const;
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
idx_type setMultiRow(Cursor & cur, idx_type cell, idx_type number,
|
2014-02-13 21:17:20 -05:00
|
|
|
bool const bottom_border,
|
|
|
|
LyXAlignment const halign);
|
2010-02-11 01:07:54 +00:00
|
|
|
///
|
|
|
|
void unsetMultiRow(idx_type cell);
|
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
row_type cellRow(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
col_type cellColumn(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2012-03-16 02:29:37 +01:00
|
|
|
void setRotateCell(idx_type cell, int);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2012-03-16 02:29:37 +01:00
|
|
|
int getRotateCell(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
bool needRotating() const;
|
|
|
|
///
|
|
|
|
bool isLastCell(idx_type cell) const;
|
|
|
|
///
|
2008-03-25 13:32:38 +00:00
|
|
|
idx_type cellAbove(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-25 13:32:38 +00:00
|
|
|
idx_type cellBelow(idx_type cell) const;
|
2014-08-09 13:13:10 -04:00
|
|
|
/// \return the index of the VISIBLE cell at row, column
|
|
|
|
/// this will be the same as the cell in the previous row,
|
|
|
|
/// e.g., if the cell is part of a multirow
|
2007-09-04 10:52:08 +00:00
|
|
|
idx_type cellIndex(row_type row, col_type column) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
void setUsebox(idx_type cell, BoxType);
|
|
|
|
///
|
|
|
|
BoxType getUsebox(idx_type cell) const;
|
|
|
|
//
|
|
|
|
// Long Tabular Options support functions
|
|
|
|
///
|
|
|
|
void setLTHead(row_type row, bool flag, ltType const &, bool first);
|
|
|
|
///
|
|
|
|
bool getRowOfLTHead(row_type row, ltType &) const;
|
|
|
|
///
|
|
|
|
bool getRowOfLTFirstHead(row_type row, ltType &) const;
|
|
|
|
///
|
|
|
|
void setLTFoot(row_type row, bool flag, ltType const &, bool last);
|
|
|
|
///
|
|
|
|
bool getRowOfLTFoot(row_type row, ltType &) const;
|
|
|
|
///
|
|
|
|
bool getRowOfLTLastFoot(row_type row, ltType &) const;
|
|
|
|
///
|
|
|
|
void setLTNewPage(row_type row, bool what);
|
|
|
|
///
|
|
|
|
bool getLTNewPage(row_type row) const;
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
idx_type setLTCaption(Cursor & cur, row_type row, bool what);
|
2008-05-04 07:51:50 +00:00
|
|
|
///
|
|
|
|
bool ltCaption(row_type row) const;
|
|
|
|
///
|
2011-12-18 21:27:17 +00:00
|
|
|
bool haveLTHead(bool withcaptions = true) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-12-18 21:27:17 +00:00
|
|
|
bool haveLTFirstHead(bool withcaptions = true) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-12-18 21:27:17 +00:00
|
|
|
bool haveLTFoot(bool withcaptions = true) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-12-18 21:27:17 +00:00
|
|
|
bool haveLTLastFoot(bool withcaptions = true) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-12-18 21:27:17 +00:00
|
|
|
bool haveLTCaption(CaptionType captiontype = CAPTION_ANY) const;
|
2009-02-10 18:08:09 +00:00
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
// end longtable support
|
2014-08-09 13:13:10 -04:00
|
|
|
|
|
|
|
//@{
|
|
|
|
/// there is a subtle difference between these two methods.
|
|
|
|
/// cellInset(r,c);
|
|
|
|
/// and
|
|
|
|
/// cellInset(cellIndex(r,c));
|
|
|
|
/// can return different things. this is because cellIndex(r,c)
|
|
|
|
/// returns the VISIBLE cell at r,c, which may be the same as the
|
|
|
|
/// cell at the previous row or column, if we're dealing with some
|
2022-09-02 01:30:25 +02:00
|
|
|
/// multirow or multicolumn.
|
2016-06-26 18:22:59 +02:00
|
|
|
std::shared_ptr<InsetTableCell> cellInset(idx_type cell);
|
|
|
|
std::shared_ptr<InsetTableCell> cellInset(row_type row, col_type column);
|
2016-06-20 22:00:05 +02:00
|
|
|
InsetTableCell const * cellInset(idx_type cell) const;
|
2014-08-09 13:13:10 -04:00
|
|
|
//@}
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
void setCellInset(row_type row, col_type column,
|
2016-06-26 18:22:59 +02:00
|
|
|
std::shared_ptr<InsetTableCell>);
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Search for \param inset in the tabular, with the
|
|
|
|
///
|
|
|
|
void validate(LaTeXFeatures &) const;
|
2014-08-09 13:13:10 -04:00
|
|
|
|
|
|
|
//private:
|
|
|
|
// FIXME Now that cells have an InsetTableCell as their insets, rather
|
|
|
|
// than an InsetText, it'd be possible to reverse the relationship here,
|
|
|
|
// so that cell_vector was a vector<InsetTableCell> rather than a
|
|
|
|
// vector<CellData>, and an InsetTableCell had a CellData as a member,
|
|
|
|
// or perhaps just had its members as members.
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
class CellData {
|
2007-04-26 12:54:21 +00:00
|
|
|
public:
|
|
|
|
///
|
2019-09-17 23:06:18 +02:00
|
|
|
explicit CellData(Buffer *);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
CellData(CellData const &);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2014-07-05 11:44:13 +02:00
|
|
|
CellData & operator=(CellData const &);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
idx_type cellno;
|
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int width;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
int multicolumn;
|
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
int multirow;
|
|
|
|
///
|
2010-11-07 05:32:28 +00:00
|
|
|
Length mroffset;
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
LyXAlignment alignment;
|
|
|
|
///
|
|
|
|
VAlignment valignment;
|
2010-06-05 07:44:44 +00:00
|
|
|
/// width of the part before the decimal
|
|
|
|
int decimal_hoffset;
|
|
|
|
/// width of the decimal part
|
|
|
|
int decimal_width;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-03-19 09:41:31 +00:00
|
|
|
int voffset;
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
bool top_line;
|
|
|
|
///
|
|
|
|
bool bottom_line;
|
|
|
|
///
|
|
|
|
bool left_line;
|
|
|
|
///
|
|
|
|
bool right_line;
|
|
|
|
///
|
2019-04-03 07:59:52 +02:00
|
|
|
bool top_line_rtrimmed;
|
|
|
|
///
|
|
|
|
bool top_line_ltrimmed;
|
|
|
|
///
|
|
|
|
bool bottom_line_rtrimmed;
|
|
|
|
///
|
|
|
|
bool bottom_line_ltrimmed;
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
BoxType usebox;
|
|
|
|
///
|
2012-03-16 02:29:37 +01:00
|
|
|
int rotate;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
docstring align_special;
|
|
|
|
///
|
2007-04-28 12:58:49 +00:00
|
|
|
Length p_width; // this is only set for multicolumn!!!
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2016-06-26 18:22:59 +02:00
|
|
|
std::shared_ptr<InsetTableCell> inset;
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
2016-06-21 21:09:50 +02:00
|
|
|
///
|
|
|
|
CellData const & cellInfo(idx_type cell) const;
|
|
|
|
///
|
|
|
|
CellData & cellInfo(idx_type cell);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
typedef std::vector<CellData> cell_vector;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
typedef std::vector<cell_vector> cell_vvector;
|
|
|
|
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
class RowData {
|
2007-04-26 12:54:21 +00:00
|
|
|
public:
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
RowData();
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int ascent;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int descent;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Extra space between the top line and this row
|
2007-04-28 12:58:49 +00:00
|
|
|
Length top_space;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Ignore top_space if true and use the default top space
|
|
|
|
bool top_space_default;
|
|
|
|
/// Extra space between this row and the bottom line
|
2007-04-28 12:58:49 +00:00
|
|
|
Length bottom_space;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Ignore bottom_space if true and use the default bottom space
|
|
|
|
bool bottom_space_default;
|
|
|
|
/// Extra space between the bottom line and the next top line
|
2007-04-28 12:58:49 +00:00
|
|
|
Length interline_space;
|
2007-04-26 12:54:21 +00:00
|
|
|
/// Ignore interline_space if true and use the default interline space
|
|
|
|
bool interline_space_default;
|
|
|
|
/// This are for longtabulars only
|
|
|
|
/// a row of endhead
|
|
|
|
bool endhead;
|
|
|
|
/// a row of endfirsthead
|
|
|
|
bool endfirsthead;
|
|
|
|
/// a row of endfoot
|
|
|
|
bool endfoot;
|
|
|
|
/// row of endlastfoot
|
|
|
|
bool endlastfoot;
|
2007-11-23 02:10:00 +00:00
|
|
|
/// row for a newpage
|
2007-04-26 12:54:21 +00:00
|
|
|
bool newpage;
|
2008-05-04 07:51:50 +00:00
|
|
|
/// caption
|
|
|
|
bool caption;
|
2020-01-11 16:17:04 +01:00
|
|
|
///
|
2020-01-14 09:28:36 +01:00
|
|
|
Change change;
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
typedef std::vector<RowData> row_vector;
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
class ColumnData {
|
2007-04-26 12:54:21 +00:00
|
|
|
public:
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
ColumnData();
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
LyXAlignment alignment;
|
|
|
|
///
|
|
|
|
VAlignment valignment;
|
|
|
|
///
|
2007-09-04 10:52:08 +00:00
|
|
|
int width;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2007-04-28 12:58:49 +00:00
|
|
|
Length p_width;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
docstring align_special;
|
2010-06-05 07:44:44 +00:00
|
|
|
///
|
|
|
|
docstring decimal_point;
|
2018-06-24 10:05:15 +02:00
|
|
|
///
|
|
|
|
bool varwidth;
|
2020-01-11 16:17:04 +01:00
|
|
|
///
|
2020-01-14 09:28:36 +01:00
|
|
|
Change change;
|
2007-04-26 12:54:21 +00:00
|
|
|
};
|
|
|
|
///
|
2008-02-27 20:59:44 +00:00
|
|
|
typedef std::vector<ColumnData> column_vector;
|
2007-04-26 12:54:21 +00:00
|
|
|
|
2022-04-01 21:15:13 +02:00
|
|
|
private:
|
|
|
|
// Determines the style of borders, per row.
|
|
|
|
class XmlRowWiseBorders {
|
|
|
|
public:
|
|
|
|
// Whether to draw double bottom line.
|
|
|
|
bool completeBorder = true;
|
|
|
|
|
|
|
|
// Whether to draw booktabs' thicker lines.
|
|
|
|
bool completeBorderAbove = true;
|
|
|
|
bool completeBorderBelow = true;
|
|
|
|
|
|
|
|
// Size of the borders.
|
|
|
|
double borderBottomWidth = 1.0;
|
|
|
|
double borderBottomWidthComplete = 3.0;
|
|
|
|
double borderTopWidth = 1.0;
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
|
|
|
idx_type numberofcells;
|
|
|
|
///
|
|
|
|
std::vector<row_type> rowofcell;
|
|
|
|
///
|
|
|
|
std::vector<col_type> columnofcell;
|
|
|
|
///
|
|
|
|
row_vector row_info;
|
|
|
|
///
|
|
|
|
column_vector column_info;
|
|
|
|
///
|
2016-07-18 14:34:08 +02:00
|
|
|
cell_vvector cell_info;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2011-02-03 23:11:26 +00:00
|
|
|
Length tabular_width;
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
bool use_booktabs;
|
|
|
|
///
|
2012-03-19 01:21:26 +01:00
|
|
|
int rotate;
|
2009-01-03 18:33:09 +00:00
|
|
|
///
|
|
|
|
VAlignment tabular_valignment;
|
2007-04-26 12:54:21 +00:00
|
|
|
//
|
|
|
|
// for long tabulars
|
2009-07-11 13:09:45 +00:00
|
|
|
///
|
|
|
|
HAlignment longtabular_alignment;
|
2007-04-26 12:54:21 +00:00
|
|
|
//
|
|
|
|
bool is_long_tabular;
|
|
|
|
/// endhead data
|
|
|
|
ltType endhead;
|
|
|
|
/// endfirsthead data
|
|
|
|
ltType endfirsthead;
|
|
|
|
/// endfoot data
|
|
|
|
ltType endfoot;
|
|
|
|
/// endlastfoot data
|
|
|
|
ltType endlastfoot;
|
|
|
|
|
|
|
|
///
|
2009-11-08 15:53:21 +00:00
|
|
|
void init(Buffer *, row_type rows_arg,
|
2007-04-26 12:54:21 +00:00
|
|
|
col_type columns_arg);
|
|
|
|
///
|
2007-09-04 18:13:19 +00:00
|
|
|
void updateIndexes();
|
2008-07-21 02:07:54 +00:00
|
|
|
///
|
|
|
|
bool setFixedWidth(row_type r, col_type c);
|
2008-03-24 14:03:00 +00:00
|
|
|
/// return true of update is needed
|
2018-07-02 17:05:46 +02:00
|
|
|
bool updateColumnWidths(MetricsInfo & mi);
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2008-03-18 18:08:32 +00:00
|
|
|
idx_type columnSpan(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2010-02-11 01:07:54 +00:00
|
|
|
idx_type rowSpan(idx_type cell) const;
|
|
|
|
///
|
2018-07-01 19:18:38 +02:00
|
|
|
BoxType useBox(idx_type cell) const;
|
2007-04-26 12:54:21 +00:00
|
|
|
///
|
2022-10-11 16:01:29 +02:00
|
|
|
bool hasNewlines(idx_type cell) const;
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
bool isValidRow(row_type const row) const;
|
|
|
|
///
|
2024-01-12 12:16:31 +01:00
|
|
|
void TeXRow(otexstream &, row_type const row, OutputParams const &,
|
|
|
|
std::list<col_type> const &, std::list<col_type> const &) const;
|
2022-04-01 03:51:24 +02:00
|
|
|
|
2008-02-27 20:43:16 +00:00
|
|
|
/// change associated Buffer
|
2008-07-23 12:13:41 +00:00
|
|
|
void setBuffer(Buffer & buffer);
|
2008-02-27 20:43:16 +00:00
|
|
|
/// retrieve associated Buffer
|
2016-06-21 21:09:50 +02:00
|
|
|
Buffer const & buffer() const { return *buffer_; }
|
|
|
|
/// retrieve associated Buffer
|
|
|
|
Buffer & buffer() { return *buffer_; }
|
2007-04-26 12:54:21 +00:00
|
|
|
|
|
|
|
private:
|
2008-07-23 12:13:41 +00:00
|
|
|
Buffer * buffer_;
|
2008-02-27 20:43:16 +00:00
|
|
|
|
2022-09-02 01:29:19 +02:00
|
|
|
///
|
|
|
|
// helper function for DocBook
|
|
|
|
///
|
2022-09-02 01:26:20 +02:00
|
|
|
/// Determines whether the tabular item should be generated as DocBook or XHTML.
|
|
|
|
enum class XmlOutputFormat : bool {
|
|
|
|
XHTML = true,
|
|
|
|
DOCBOOK = false
|
|
|
|
};
|
|
|
|
|
2023-01-09 01:50:05 +01:00
|
|
|
/// Transforms the vertical alignment of the given cell as prebaked CSS (for HTML tables in HTML output).
|
|
|
|
std::string getHAlignAsXmlAttribute(idx_type cell) const;
|
|
|
|
/// Transforms the vertical alignment of the given cell as a prebaked XML attribute (for CALS or HTML tables in DocBook).
|
|
|
|
std::string getHAlignAsCssAttribute(idx_type cell) const;
|
|
|
|
/// Transforms the vertical alignment of the given cell as prebaked CSS (for HTML tables in HTML output).
|
|
|
|
std::string getVAlignAsCssAttribute(idx_type cell) const;
|
|
|
|
/// Transforms the vertical alignment of the given cell as a prebaked XML attribute (for CALS or HTML tables in DocBook).
|
2022-09-01 23:35:52 +02:00
|
|
|
std::string getVAlignAsXmlAttribute(idx_type cell) const;
|
|
|
|
|
|
|
|
/// Helpers for XML tables (XHTML or DocBook).
|
|
|
|
docstring xmlRow(XMLStream & xs, row_type row, OutputParams const &,
|
2022-09-02 01:26:20 +02:00
|
|
|
bool header, XmlOutputFormat output_format,
|
2022-09-01 23:35:52 +02:00
|
|
|
BufferParams::TableOutput docbook_table_output = BufferParams::TableOutput::HTMLTable) const;
|
2022-09-02 01:26:20 +02:00
|
|
|
void xmlHeader(XMLStream & xs, OutputParams const &, XmlOutputFormat output_format) const;
|
|
|
|
void xmlFooter(XMLStream & xs, OutputParams const &, XmlOutputFormat output_format) const;
|
|
|
|
void xmlBody(XMLStream & xs, OutputParams const &, XmlOutputFormat output_format) const;
|
2022-09-01 23:35:52 +02:00
|
|
|
XmlRowWiseBorders computeXmlBorders(row_type row) const;
|
|
|
|
std::vector<std::string> computeCssStylePerCell(row_type row, col_type col, idx_type cell) const;
|
|
|
|
|
2022-09-02 01:29:19 +02:00
|
|
|
///
|
|
|
|
// helper functions for plain text
|
|
|
|
///
|
|
|
|
bool plaintextTopHLine(odocstringstream &, row_type row,
|
|
|
|
std::vector<unsigned int> const &) const;
|
|
|
|
///
|
|
|
|
bool plaintextBottomHLine(odocstringstream &, row_type row,
|
|
|
|
std::vector<unsigned int> const &) const;
|
|
|
|
///
|
|
|
|
void plaintextPrintCell(odocstringstream &,
|
|
|
|
OutputParams const &,
|
|
|
|
idx_type cell, row_type row, col_type column,
|
|
|
|
std::vector<unsigned int> const &,
|
|
|
|
bool onlydata, size_t max_length) const;
|
|
|
|
|
|
|
|
///
|
|
|
|
// helper function for LaTeX
|
|
|
|
///
|
2024-01-12 12:16:31 +01:00
|
|
|
void TeXTopHLine(otexstream &, row_type row, std::list<col_type> const &,
|
|
|
|
std::list<col_type> const &) const;
|
2022-09-02 01:29:19 +02:00
|
|
|
///
|
2024-01-12 12:16:31 +01:00
|
|
|
void TeXBottomHLine(otexstream &, row_type row, std::list<col_type> const &,
|
|
|
|
std::list<col_type> const &) const;
|
2022-09-02 01:29:19 +02:00
|
|
|
///
|
|
|
|
void TeXCellPreamble(otexstream &, idx_type cell, bool & ismulticol, bool & ismultirow,
|
|
|
|
bool const bidi) const;
|
|
|
|
///
|
|
|
|
void TeXCellPostamble(otexstream &, idx_type cell, bool ismulticol, bool ismultirow) const;
|
|
|
|
///
|
2024-01-12 12:16:31 +01:00
|
|
|
void TeXLongtableHeaderFooter(otexstream &, OutputParams const &, std::list<col_type> const &,
|
|
|
|
std::list<col_type> const &) const;
|
2022-09-02 01:29:19 +02:00
|
|
|
|
2008-03-21 17:45:14 +00:00
|
|
|
}; // Tabular
|
|
|
|
|
2007-04-26 12:54:21 +00:00
|
|
|
|
2008-03-27 22:26:24 +00:00
|
|
|
class InsetTabular : public Inset
|
|
|
|
{
|
2000-04-19 14:42:19 +00:00
|
|
|
public:
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2009-11-08 15:53:21 +00:00
|
|
|
InsetTabular(Buffer *, row_type rows = 1,
|
2006-04-05 23:56:29 +00:00
|
|
|
col_type columns = 1);
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
|
|
|
~InsetTabular();
|
2008-07-23 13:25:03 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void setBuffer(Buffer & buffer) override;
|
2008-07-23 13:25:03 +00:00
|
|
|
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2008-03-27 22:26:24 +00:00
|
|
|
static void string2params(std::string const &, InsetTabular &);
|
|
|
|
///
|
|
|
|
static std::string params2string(InsetTabular const &);
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void read(Lexer &) override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void write(std::ostream &) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void metrics(MetricsInfo &, Dimension &) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void draw(PainterInfo & pi, int x, int y) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void drawSelection(PainterInfo & pi, int x, int y) const override;
|
2004-11-30 01:59:49 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void drawBackground(PainterInfo & pi, int x, int y) const override;
|
2010-11-25 13:08:26 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool editable() const override { return true; }
|
2009-04-22 20:55:13 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool hasSettings() const override { return true; }
|
2005-07-15 22:10:25 +00:00
|
|
|
///
|
2024-02-08 09:00:57 +01:00
|
|
|
bool insetAllowed(InsetCode code) const override;
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool allowSpellCheck() const override { return true; }
|
2006-07-07 10:18:33 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool canTrackChanges() const override { return true; }
|
2016-05-22 22:48:28 +01:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool canPaintChange(BufferView const &) const override { return true; }
|
2021-04-13 10:33:42 +02:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool allowMultiPar() const override;
|
2020-08-12 16:25:35 +02:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool allowsCaptionVariation(std::string const &) const override;
|
2016-03-14 11:46:28 +01:00
|
|
|
//
|
2020-10-01 10:42:11 +03:00
|
|
|
bool isTable() const override { return true; }
|
2013-03-22 22:23:38 +01:00
|
|
|
///
|
2021-07-12 00:07:59 +02:00
|
|
|
int rowFlags() const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void latex(otexstream &, OutputParams const &) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2013-03-08 14:52:18 -05:00
|
|
|
int plaintext(odocstringstream & ods, OutputParams const & op,
|
2020-10-01 10:42:11 +03:00
|
|
|
size_t max_length = INT_MAX) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void docbook(XMLStream &, OutputParams const &) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
docstring xhtml(XMLStream &, OutputParams const &) const override;
|
2009-12-14 15:39:13 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void validate(LaTeXFeatures & features) const override;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
InsetCode lyxCode() const override { return TABULAR_CODE; }
|
2008-03-28 18:50:33 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
std::string contextMenu(BufferView const &, int, int) const override;
|
2010-11-29 23:21:52 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
std::string contextMenuName() const override;
|
2004-11-30 01:59:49 +00:00
|
|
|
/// get offset of this cursor slice relative to our upper left corner
|
2006-10-17 16:23:27 +00:00
|
|
|
void cursorPos(BufferView const & bv, CursorSlice const & sl,
|
2020-10-01 10:42:11 +03:00
|
|
|
bool boundary, int & x, int & y) const override;
|
2016-02-08 18:19:24 +01:00
|
|
|
/// Executes a space-separated sequence of tabular-features requests
|
2015-12-11 02:15:52 +00:00
|
|
|
void tabularFeatures(Cursor & cur, std::string const & what);
|
2016-02-08 18:19:24 +01:00
|
|
|
/// Change a single tabular feature; does not handle undo.
|
2007-04-26 14:56:30 +00:00
|
|
|
void tabularFeatures(Cursor & cur, Tabular::Feature feature,
|
2003-10-06 15:43:21 +00:00
|
|
|
std::string const & val = std::string());
|
2004-02-16 11:58:51 +00:00
|
|
|
/// number of cells
|
2020-10-01 10:42:11 +03:00
|
|
|
size_t nargs() const override { return tabular.numberofcells; }
|
2001-04-27 14:03:25 +00:00
|
|
|
///
|
2016-06-26 18:22:59 +02:00
|
|
|
std::shared_ptr<InsetTableCell const> cell(idx_type) const;
|
2004-02-16 11:58:51 +00:00
|
|
|
///
|
2016-06-26 18:22:59 +02:00
|
|
|
std::shared_ptr<InsetTableCell> cell(idx_type);
|
2003-11-01 09:56:18 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
Text * getText(int) const override;
|
2003-02-08 19:18:01 +00:00
|
|
|
|
2020-01-13 16:34:38 +01:00
|
|
|
/// does the inset contain changes ?
|
2020-10-01 10:42:11 +03:00
|
|
|
bool isChanged() const override;
|
2006-10-20 09:29:19 +00:00
|
|
|
/// set the change for the entire inset
|
2020-10-01 10:42:11 +03:00
|
|
|
void setChange(Change const & change) override;
|
2006-10-24 06:11:45 +00:00
|
|
|
/// accept the changes within the inset
|
2020-10-01 10:42:11 +03:00
|
|
|
void acceptChanges() override;
|
2006-10-24 21:38:47 +00:00
|
|
|
/// reject the changes within the inset
|
2020-10-01 10:42:11 +03:00
|
|
|
void rejectChanges() override;
|
2003-02-08 19:18:01 +00:00
|
|
|
|
2005-11-17 08:41:56 +00:00
|
|
|
// this should return true if we have a "normal" cell, otherwise false.
|
2002-01-08 14:24:49 +00:00
|
|
|
// "normal" means without width set!
|
2005-11-17 08:41:56 +00:00
|
|
|
/// should all paragraphs be output with "Standard" layout?
|
2020-10-04 17:56:53 +03:00
|
|
|
bool allowParagraphCustomization(idx_type cell = 0) const override;
|
Fix bug 4037 and related problems. The patch has been cleaned up a bit
from the one posted to the list.
The basic idea has two parts. First, we hard code an "empty layout"
(called PlainLayout, for want of a better name) in TextClass and read it
before doing anything else. It can therefore be customized by classes,
if they want---say, to make it left-aligned. Second, InsetText's are
divided into three types: (i) normal ones, that use the "default" layout
defined by the text class; (ii) highly restrictive ones, such as ERT and
(not quite an inset) table cells, which demand the empty layout; (iii)
middling ones, which default to an empty layout and use the empty layout
in place of the default. (This is so we don't get the same problem we
had with ERT in e.g. footnotes.) The type of inset is signaled by new
methods InsetText::forceEmptyLayout() and InsetText::useEmptyLayout().
(The latter might better be called: useEmptyLayoutInsteadOfDefault(),
but that's silly.) The old InsetText::forceDefaultParagraphs() has been
split into these, plus a new method InsetText::allowParagraphCustomization().
A lot of the changes just adapt to this change.
The other big change is in GuiToolbar: We want to show LyXDefault and
the "default" layout only when they're active.
There are a handful of places where I'm not entirely sure whether we
should be using forceEmptyLayout or !allowParagraphCustomization() or
both. The InsetCaption is one of these. These places, and some others,
are marked with FIXMEs, so I'd appreciate it if people would search
through the patch and let me know whether these need changing. If they
don't, the FIXMEs can be deleted.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@22966 a592a061-630c-0410-9148-cb99ea01b6c8
2008-02-12 17:31:07 +00:00
|
|
|
///
|
2009-11-22 20:50:35 +00:00
|
|
|
void addPreview(DocIterator const & inset_pos,
|
2020-10-01 10:42:11 +03:00
|
|
|
graphics::PreviewLoader &) const override;
|
2002-08-02 16:39:43 +00:00
|
|
|
|
2003-11-04 12:36:59 +00:00
|
|
|
/// lock cell with given index
|
2020-10-01 10:42:11 +03:00
|
|
|
void edit(Cursor & cur, bool front, EntryDirection entry_from) override;
|
2008-03-18 18:08:32 +00:00
|
|
|
/// get table row from x coordinate
|
|
|
|
int rowFromY(Cursor & cur, int y) const;
|
|
|
|
/// get table column from y coordinate
|
|
|
|
int columnFromX(Cursor & cur, int x) const;
|
2003-11-04 12:36:59 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
Inset * editXY(Cursor & cur, int x, int y) override;
|
2003-11-17 12:53:44 +00:00
|
|
|
/// can we go further down on mouse click?
|
2020-10-01 10:42:11 +03:00
|
|
|
bool descendable(BufferView const &) const override { return true; }
|
2010-01-28 08:33:14 +00:00
|
|
|
/// Update the counters of this inset and of its contents
|
2020-10-01 10:42:11 +03:00
|
|
|
void updateBuffer(ParIterator const &, UpdateType, bool const deleted = false) override;
|
2010-01-28 08:33:14 +00:00
|
|
|
///
|
2015-09-27 07:05:00 +01:00
|
|
|
void addToToc(DocIterator const & di, bool output_active,
|
2020-10-01 10:42:11 +03:00
|
|
|
UpdateType utype, TocBackend & backend) const override;
|
2003-12-10 09:45:32 +00:00
|
|
|
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool completionSupported(Cursor const &) const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool inlineCompletionSupported(Cursor const & cur) const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool automaticInlineCompletion() const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool automaticPopupCompletion() const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool showCompletionCursor() const override;
|
2008-03-16 17:07:10 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
CompletionList const * createCompletionList(Cursor const & cur) const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
docstring completionPrefix(Cursor const & cur) const override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2022-10-04 15:11:36 +02:00
|
|
|
bool insertCompletion(Cursor & cur, docstring const & s, bool /*finished*/) override;
|
2008-03-15 12:22:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const override;
|
2008-08-08 16:19:28 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool usePlainLayout() const override { return true; }
|
2016-07-30 19:41:51 -04:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
docstring layoutName() const override { return from_ascii("Tabular"); }
|
2016-07-30 19:41:51 -04:00
|
|
|
|
2008-03-15 12:22:28 +00:00
|
|
|
|
2008-04-11 12:02:10 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
InsetTabular * asInsetTabular() override { return this; }
|
2008-04-11 12:02:10 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
InsetTabular const * asInsetTabular() const override { return this; }
|
2008-04-11 12:02:10 +00:00
|
|
|
///
|
|
|
|
bool isRightToLeft(Cursor & cur) const;
|
2008-08-08 21:26:18 +00:00
|
|
|
/// writes the cells between stidx and enidx as a string, optionally
|
|
|
|
/// descending into the insets
|
|
|
|
docstring asString(idx_type stidx, idx_type enidx, bool intoInsets = true);
|
2020-06-29 15:13:45 +02:00
|
|
|
///
|
|
|
|
ParagraphList asParList(idx_type stidx, idx_type enidx);
|
2023-03-15 23:24:30 -04:00
|
|
|
///
|
|
|
|
bool confirmDeletion() const override { return true; }
|
2008-10-25 10:47:38 +00:00
|
|
|
/// Returns whether the cell in the specified row and column is selected.
|
|
|
|
bool isCellSelected(Cursor & cur, row_type row, col_type col) const;
|
Possible fix for the mystery crash, which is bug #9049.
Investigation of bug #9236 showed that crash to be due to a Paragraph's
holding a dangling pointer to an old and deleted Layout after the
DocumentClass was reset. Since the backtraces look almost identical, it
seems likely that we have the same problem here.
Since this crash seems almost always to involve tables, I looked at the
code in switchBetweenClasses() and found that the Paragraphs that belong
to "hidden" table cells are not seen by the initial recursion using a
ParIterator: It skips right over them. This was confirmed by test code
suggested by Enrico, with results reported in Trac.
The present patch attempts to deal with this problem in the second
recursion, over Insets. When we see an InsetTabular, we call a new
routine that recurses through the cells, looking for hidden ones. If it
finds a hidden one, it then resets the Layout for the cell's Paragraphs
(there should be only one, but we do not make any assumptions) to the
PlainLayout that belongs to the new DocumentClass. This is good enough,
since such cells never have content.
There is extensive discussion of the patch here:
https://www.mail-archive.com/lyx-devel@lists.lyx.org/msg185095.html
Additional testing by Enrico and me confirmed the existence of the
dangling pointer.
2014-08-07 15:00:35 -04:00
|
|
|
///
|
|
|
|
void setLayoutForHiddenCells(DocumentClass const & dc);
|
2003-12-10 09:45:32 +00:00
|
|
|
//
|
|
|
|
// Public structures and variables
|
|
|
|
///
|
2007-04-26 12:54:21 +00:00
|
|
|
mutable Tabular tabular;
|
2003-12-10 09:45:32 +00:00
|
|
|
|
2008-03-05 00:21:05 +00:00
|
|
|
private:
|
2005-07-15 22:10:25 +00:00
|
|
|
///
|
2004-11-23 23:04:52 +00:00
|
|
|
InsetTabular(InsetTabular const &);
|
2005-07-15 22:10:25 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
void doDispatch(Cursor & cur, FuncRequest & cmd) override;
|
2004-03-18 13:57:20 +00:00
|
|
|
///
|
2015-12-11 02:15:52 +00:00
|
|
|
bool getFeatureStatus(Cursor & cur, std::string const & s,
|
|
|
|
std::string const & argument, FuncStatus & status) const;
|
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const override;
|
2005-07-17 01:13:36 +00:00
|
|
|
///
|
2020-10-01 10:42:11 +03:00
|
|
|
Inset * clone() const override { return new InsetTabular(*this); }
|
2004-11-23 23:04:52 +00:00
|
|
|
|
2016-02-02 17:07:29 +01:00
|
|
|
///
|
|
|
|
bool hitSelectRow(BufferView const & bv, int x) const;
|
|
|
|
///
|
|
|
|
bool hitSelectColumn(BufferView const & bv, int y) const;
|
2016-04-19 13:53:47 +02:00
|
|
|
/// Returns true if coordinates are on row/column selection zones
|
2020-10-01 10:42:11 +03:00
|
|
|
bool clickable(BufferView const &, int x, int y) const override;
|
2016-02-02 17:07:29 +01:00
|
|
|
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2010-09-02 12:13:54 +00:00
|
|
|
void drawCellLines(PainterInfo &, int x, int y, row_type row,
|
|
|
|
idx_type cell) const;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2007-04-26 14:56:30 +00:00
|
|
|
void setCursorFromCoordinates(Cursor & cur, int x, int y) const;
|
2003-12-15 15:33:15 +00:00
|
|
|
|
|
|
|
///
|
2014-07-26 16:29:23 +02:00
|
|
|
void moveNextCell(Cursor & cur,
|
2008-04-11 12:02:10 +00:00
|
|
|
EntryDirection entry_from = ENTRY_DIRECTION_IGNORE);
|
2003-12-15 15:33:15 +00:00
|
|
|
///
|
2008-04-11 12:02:10 +00:00
|
|
|
void movePrevCell(Cursor & cur,
|
|
|
|
EntryDirection entry_from = ENTRY_DIRECTION_IGNORE);
|
2001-07-24 22:08:49 +00:00
|
|
|
///
|
2008-03-25 13:32:38 +00:00
|
|
|
int cellXPos(idx_type cell) const;
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2010-11-25 13:22:04 +00:00
|
|
|
int cellYPos(idx_type cell) const;
|
|
|
|
///
|
2007-04-26 14:56:30 +00:00
|
|
|
bool copySelection(Cursor & cur);
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2007-04-26 14:56:30 +00:00
|
|
|
bool pasteClipboard(Cursor & cur);
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2007-04-26 14:56:30 +00:00
|
|
|
void cutSelection(Cursor & cur);
|
2001-04-04 09:42:56 +00:00
|
|
|
///
|
2007-04-26 14:56:30 +00:00
|
|
|
void getSelection(Cursor & cur, row_type & rs, row_type & re,
|
2006-04-05 23:56:29 +00:00
|
|
|
col_type & cs, col_type & ce) const;
|
2001-07-17 15:39:12 +00:00
|
|
|
///
|
2007-01-15 22:49:14 +00:00
|
|
|
bool insertPlaintextString(BufferView &, docstring const & buf, bool usePaste);
|
2004-02-13 16:22:53 +00:00
|
|
|
|
2005-06-27 12:53:35 +00:00
|
|
|
/// return the "Manhattan distance" to nearest corner
|
2006-10-13 16:44:44 +00:00
|
|
|
int dist(BufferView &, idx_type cell, int x, int y) const;
|
2005-03-21 18:21:13 +00:00
|
|
|
/// return the cell nearest to x, y
|
2006-10-13 16:44:44 +00:00
|
|
|
idx_type getNearestCell(BufferView &, int x, int y) const;
|
2005-04-26 11:12:20 +00:00
|
|
|
|
2016-07-18 16:24:06 +02:00
|
|
|
/// test the rotation state of the given cell range.
|
2007-05-12 20:59:21 +00:00
|
|
|
bool oneCellHasRotationState(bool rotated,
|
2007-05-28 22:27:45 +00:00
|
|
|
row_type row_start, row_type row_end,
|
2007-05-12 20:59:21 +00:00
|
|
|
col_type col_start, col_type col_end) const;
|
2016-07-18 16:24:06 +02:00
|
|
|
|
2008-03-25 21:26:03 +00:00
|
|
|
/// true when selecting rows with the mouse
|
|
|
|
bool rowselect_;
|
|
|
|
/// true when selecting columns with the mouse
|
|
|
|
bool colselect_;
|
2000-04-19 14:42:19 +00:00
|
|
|
};
|
2003-03-09 18:11:57 +00:00
|
|
|
|
2007-04-26 12:54:21 +00:00
|
|
|
std::string const featureAsString(Tabular::Feature feature);
|
2003-03-09 18:11:57 +00:00
|
|
|
|
2010-06-05 07:44:44 +00:00
|
|
|
/// Split cell on decimal symbol
|
2014-07-05 19:13:10 +02:00
|
|
|
InsetTableCell splitCell(InsetTableCell & head, docstring const & decimal_sym, bool & hassep);
|
2010-06-05 07:44:44 +00:00
|
|
|
|
2006-10-21 00:16:43 +00:00
|
|
|
} // namespace lyx
|
|
|
|
|
2008-03-27 22:26:24 +00:00
|
|
|
#endif // INSET_TABULAR_H
|