X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetTabular.h;h=fd942049ba6d07c53d86acfb84610443196ca07b;hb=48b1e8a0aca2f3f3faa8f1f800568e47792ba9a0;hp=65cc2ae2e1d118999afa4ae5d07cd0af27b0dbdf;hpb=912704511b8c0fd443ab583c59ddfb6c34bc340d;p=lyx.git diff --git a/src/insets/InsetTabular.h b/src/insets/InsetTabular.h index 65cc2ae2e1..fd942049ba 100644 --- a/src/insets/InsetTabular.h +++ b/src/insets/InsetTabular.h @@ -25,7 +25,8 @@ #define INSET_TABULAR_H #include "InsetText.h" -#include "Length.h" + +#include "support/Length.h" #include #include @@ -44,7 +45,7 @@ class FuncStatus; class Lexer; class OutputParams; class Paragraph; -class XHTMLStream; +class XMLStream; /// @@ -72,12 +73,18 @@ public: /// descending into insets docstring asString(bool intoInsets = true); /// - docstring xhtml(XHTMLStream &, OutputParams const &) const; + docstring xhtml(XMLStream &, OutputParams const &) const; + /// + void docbook(XMLStream &, OutputParams const &) const; /// void addToToc(DocIterator const & di, bool output_active, UpdateType utype, TocBackend & backend) const; /// void metrics(MetricsInfo &, Dimension &) const; + /// Needs to be same as InsetTabular + bool inheritFont() const { return false; } + /// Can the cell contain several paragraphs? + bool allowMultiPar() const { return !isMultiRow && (!isMultiColumn || isFixedWidth); } private: /// unimplemented InsetTableCell(); @@ -116,7 +123,7 @@ private: // FIXME: Here the thoughts from the comment above also apply. /// LyXAlignment contentAlign; - /// should paragraph indendation be omitted in any case? + /// should paragraph indentation be omitted in any case? bool neverIndent() const { return true; } /// LyXAlignment contentAlignment() const { return contentAlign; } @@ -130,8 +137,6 @@ private: virtual bool forceLocalFontSwitch() const; /// Is the width forced to some value? bool hasFixedWidth() const { return isFixedWidth; } - /// Can the cell contain several paragraphs? - bool allowMultiPar() const { return !isMultiRow && (!isMultiColumn || isFixedWidth); } }; @@ -537,7 +542,7 @@ public: /// void appendRow(row_type row); /// - void deleteRow(row_type row); + void deleteRow(row_type row, bool const force = false); /// void copyRow(row_type row); /// @@ -549,15 +554,19 @@ public: /// void appendColumn(col_type column); /// - void deleteColumn(col_type column); + void deleteColumn(col_type column, bool const force = false); /// void copyColumn(col_type column); /// void insertColumn(col_type column, bool copy); /// - idx_type getFirstCellInRow(row_type row) const; + idx_type getFirstCellInRow(row_type row, bool const ct = false) const; + /// + idx_type getLastCellInRow(row_type row, bool const ct = false) const; /// - idx_type getLastCellInRow(row_type row) const; + idx_type getFirstRow(bool const ct = false) const; + /// + idx_type getLastRow(bool const ct = false) const; /// idx_type numberOfCellsInRow(row_type row) const; /// @@ -566,10 +575,10 @@ public: void read(Lexer &); /// void latex(otexstream &, OutputParams const &) const; + /// serialise the table in DocBook, according to buffer parameters + void docbook(XMLStream &, OutputParams const &) const; /// - int docbook(odocstream & os, OutputParams const &) const; - /// - docstring xhtml(XHTMLStream & os, OutputParams const &) const; + docstring xhtml(XMLStream &, OutputParams const &) const; /// void plaintext(odocstringstream &, OutputParams const & runparams, int const depth, @@ -785,6 +794,8 @@ public: bool newpage; /// caption bool caption; + /// + Change change; }; /// typedef std::vector row_vector; @@ -808,6 +819,8 @@ public: docstring decimal_point; /// bool varwidth; + /// + Change change; }; /// typedef std::vector column_vector; @@ -865,21 +878,24 @@ public: /// // helper function for Latex /// - void TeXTopHLine(otexstream &, row_type row, std::list) const; + void TeXTopHLine(otexstream &, row_type row, std::list, + std::list) const; /// - void TeXBottomHLine(otexstream &, row_type row, std::list) const; + void TeXBottomHLine(otexstream &, row_type row, std::list, + std::list) const; /// 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; /// - void TeXLongtableHeaderFooter(otexstream &, OutputParams const &, std::list) const; + void TeXLongtableHeaderFooter(otexstream &, OutputParams const &, std::list, + std::list) const; /// bool isValidRow(row_type const row) const; /// void TeXRow(otexstream &, row_type const row, - OutputParams const &, std::list) const; + OutputParams const &, std::list, std::list) const; /// // helper functions for plain text /// @@ -894,10 +910,16 @@ public: idx_type cell, row_type row, col_type column, std::vector const &, bool onlydata, size_t max_length) const; - /// auxiliary function for docbook - int docbookRow(odocstream & os, row_type, OutputParams const &) const; - /// - docstring xhtmlRow(XHTMLStream & xs, row_type, OutputParams const &, + /// auxiliary function for DocBook + void docbookRow(XMLStream &, row_type, OutputParams const &, + bool header = false) const; + /// auxiliary function for DocBook: export this row as HTML + void docbookRowAsHTML(XMLStream &, row_type, OutputParams const &, + bool header) const; + /// auxiliary function for DocBook: export this row as CALS + void docbookRowAsCALS(XMLStream &, row_type, OutputParams const &) const; + /// + docstring xhtmlRow(XMLStream & xs, row_type, OutputParams const &, bool header = false) const; /// change associated Buffer @@ -952,25 +974,27 @@ public: bool canTrackChanges() const { return true; } /// bool canPaintChange(BufferView const &) const { return true; } - /** returns false if, when outputing LaTeX, font changes should + /** returns false if, when outputting LaTeX, font changes should be closed before generating this inset. This is needed for insets that may contain several paragraphs */ bool inheritFont() const { return false; } /// + bool allowMultiPar() const; + /// bool allowsCaptionVariation(std::string const &) const; // bool isTable() const { return true; } /// - DisplayType display() const; + RowFlags rowFlags() const; /// void latex(otexstream &, OutputParams const &) const; /// int plaintext(odocstringstream & ods, OutputParams const & op, size_t max_length = INT_MAX) const; /// - int docbook(odocstream &, OutputParams const &) const; + void docbook(XMLStream &, OutputParams const &) const; /// - docstring xhtml(XHTMLStream &, OutputParams const &) const; + docstring xhtml(XMLStream &, OutputParams const &) const; /// void validate(LaTeXFeatures & features) const; /// @@ -996,6 +1020,8 @@ public: /// Text * getText(int) const; + /// does the inset contain changes ? + bool isChanged() const; /// set the change for the entire inset void setChange(Change const & change); /// accept the changes within the inset @@ -1024,7 +1050,7 @@ public: /// can we go further down on mouse click? bool descendable(BufferView const &) const { return true; } /// Update the counters of this inset and of its contents - void updateBuffer(ParIterator const &, UpdateType); + void updateBuffer(ParIterator const &, UpdateType, bool const deleted = false); /// void addToToc(DocIterator const & di, bool output_active, UpdateType utype, TocBackend & backend) const; @@ -1062,6 +1088,8 @@ public: /// 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); + /// + ParagraphList asParList(idx_type stidx, idx_type enidx); /// Returns whether the cell in the specified row and column is selected. bool isCellSelected(Cursor & cur, row_type row, col_type col) const;