X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ftabular.h;h=163f33a2b746aa364181e4bd20f9b6f967078b52;hb=d4f8fe124906af839a02d1ad3b7894e14fb69a37;hp=09e0faa1f73a318a1786b295a97a988cfa35d250;hpb=1dc25c472f3001b5e558f6dc4d471d8c4401fb1d;p=lyx.git diff --git a/src/tabular.h b/src/tabular.h index 09e0faa1f7..163f33a2b7 100644 --- a/src/tabular.h +++ b/src/tabular.h @@ -1,35 +1,34 @@ // -*- C++ -*- -/* This file is part of - * ====================================================== +/** + * \file tabular.h + * This file is part of LyX, the document processor. + * Licence details can be found in the file COPYING. * - * LyX, The Document Processor + * \author Lars Gullik Bjønnes + * \author Matthias Ettrich + * \author André Pönitz + * \author Jürgen Vigna * - * Copyright 2000-2001 The LyX Team. - * - * @author: Jürgen Vigna - * - * ====================================================== */ + * Full author contact details are available in file CREDITS. + */ + #ifndef TABULAR_H #define TABULAR_H -#ifdef __GNUG__ -#pragma interface -#endif - -#include "layout.h" -#include "LString.h" #include "lyxlength.h" - #include "insets/insettext.h" +#include + #include #include + +namespace lyx { + class InsetTabular; -class BufferParams; -class LaTeXFeatures; -class Buffer; -class LyXLex; +class LCursor; +class OutputParams; /* The features the text class offers for tables */ @@ -47,6 +46,10 @@ public: /// DELETE_COLUMN, /// + COPY_ROW, + /// + COPY_COLUMN, + /// TOGGLE_LINE_TOP, /// TOGGLE_LINE_BOTTOM, @@ -61,11 +64,13 @@ public: /// ALIGN_CENTER, /// + ALIGN_BLOCK, + /// VALIGN_TOP, /// VALIGN_BOTTOM, /// - VALIGN_CENTER, + VALIGN_MIDDLE, /// M_TOGGLE_LINE_TOP, /// @@ -85,7 +90,7 @@ public: /// M_VALIGN_BOTTOM, /// - M_VALIGN_CENTER, + M_VALIGN_MIDDLE, /// MULTICOLUMN, /// @@ -129,6 +134,16 @@ public: /// SET_SPECIAL_MULTI, /// + SET_BOOKTABS, + /// + UNSET_BOOKTABS, + /// + SET_TOP_SPACE, + /// + SET_BOTTOM_SPACE, + /// + SET_INTERLINE_SPACE, + /// LAST_ACTION }; /// @@ -148,7 +163,7 @@ public: /// LYX_VALIGN_BOTTOM = 1, /// - LYX_VALIGN_CENTER = 2 + LYX_VALIGN_MIDDLE = 2 }; enum BoxType { @@ -160,10 +175,11 @@ public: BOX_MINIPAGE = 2 }; - struct lttype { + class ltType { + public: // constructor - lttype(); - // we have this header type (is set in the GetLT... functions) + ltType(); + // we have this header type (is set in the getLT... functions) bool set; // double borders on top bool topDL; @@ -174,198 +190,207 @@ public: // ignored in the output and it is set to be empty! bool empty; }; - /// - typedef struct lttype ltType; - /* konstruktor */ - /// - LyXTabular(BufferParams const &, - InsetTabular *, int columns_arg, int rows_arg); - /// - LyXTabular(BufferParams const &, - InsetTabular *, LyXTabular const &, bool same_id = false); - /// - explicit - LyXTabular(Buffer const *, InsetTabular *, LyXLex & lex); - /// - LyXTabular & operator=(LyXTabular const &); - /// - LyXTabular * clone(BufferParams const &, - InsetTabular *, bool same_id = false); + /// type for row numbers + typedef size_t row_type; + /// type for column numbers + typedef size_t col_type; + /// type for cell indices + typedef size_t idx_type; + /// index indicating an invalid position + static const idx_type npos = static_cast(-1); + + /// constructor + LyXTabular(BufferParams const &, col_type columns_arg, + row_type rows_arg); /// Returns true if there is a topline, returns false if not - bool TopLine(int cell, bool onlycolumn = false) const; + bool topLine(idx_type cell, bool wholerow = false) const; /// Returns true if there is a topline, returns false if not - bool BottomLine(int cell, bool onlycolumn = false) const; + bool bottomLine(idx_type cell, bool wholerow = false) const; /// Returns true if there is a topline, returns false if not - bool LeftLine(int cell, bool onlycolumn = false) const; + bool leftLine(idx_type cell, bool wholecolumn = false) const; /// Returns true if there is a topline, returns false if not - bool RightLine(int cell, bool onlycolumn = false) const; + bool rightLine(idx_type cell, bool wholecolumn = false) const; /// - bool TopAlreadyDrawed(int cell) const; + bool topAlreadyDrawn(idx_type cell) const; /// - bool LeftAlreadyDrawed(int cell) const; + bool leftAlreadyDrawn(idx_type cell) const; /// - bool IsLastRow(int cell) const; + bool isLastRow(idx_type cell) const; + /// return space occupied by the second horizontal line and + /// interline space above row \p row in pixels + int getAdditionalHeight(row_type row) const; /// - int GetAdditionalHeight(int row) const; - /// - int GetAdditionalWidth(int cell) const; + int getAdditionalWidth(idx_type cell) const; /* returns the maximum over all rows */ /// - int GetWidthOfColumn(int cell) const; + int getWidthOfColumn(idx_type cell) const; /// - int GetWidthOfTabular() const; + int getWidthOfTabular() const; /// - int GetAscentOfRow(int row) const; + int getAscentOfRow(row_type row) const; /// - int GetDescentOfRow(int row) const; + int getDescentOfRow(row_type row) const; /// - int GetHeightOfTabular() const; - /// Returns true if a complete update is necessary, otherwise false - bool SetAscentOfRow(int row, int height); - /// Returns true if a complete update is necessary, otherwise false - bool SetDescentOfRow(int row, int height); - /// Returns true if a complete update is necessary, otherwise false - bool SetWidthOfCell(int cell, int new_width); - /// Returns true if a complete update is necessary, otherwise false - bool SetAllLines(int cell, bool line); - /// Returns true if a complete update is necessary, otherwise false - bool SetTopLine(int cell, bool line, bool onlycolumn = false); - /// Returns true if a complete update is necessary, otherwise false - bool SetBottomLine(int cell, bool line, bool onlycolumn = false); - /// Returns true if a complete update is necessary, otherwise false - bool SetLeftLine(int cell, bool line, bool onlycolumn = false); - /// Returns true if a complete update is necessary, otherwise false - bool SetRightLine(int cell, bool line, bool onlycolumn = false); - /// Returns true if a complete update is necessary, otherwise false - bool SetAlignment(int cell, LyXAlignment align, + int getHeightOfTabular() const; + /// + void setAscentOfRow(row_type row, int height); + /// + void setDescentOfRow(row_type row, int height); + /// + void setWidthOfCell(idx_type cell, int new_width); + /// + void setAllLines(idx_type cell, bool line); + /// + void setTopLine(idx_type cell, bool line, bool wholerow = false); + /// + void setBottomLine(idx_type cell, bool line, bool wholerow = false); + /// + void setLeftLine(idx_type cell, bool line, bool wholecolumn = false); + /// + void setRightLine(idx_type cell, bool line, bool wholecolumn = false); + /// + void setAlignment(idx_type cell, LyXAlignment align, bool onlycolumn = false); - /// Returns true if a complete update is necessary, otherwise false - bool SetVAlignment(int cell, VAlignment align, + /// + void setVAlignment(idx_type cell, VAlignment align, bool onlycolumn = false); /// - bool SetColumnPWidth(int cell, LyXLength const & width); + void setColumnPWidth(LCursor &, idx_type, LyXLength const &); /// - bool SetMColumnPWidth(int cell, LyXLength const & width); + bool setMColumnPWidth(LCursor &, idx_type, LyXLength const &); /// - bool SetAlignSpecial(int cell, string const & special, Feature what); + void setAlignSpecial(idx_type cell, docstring const & special, + Feature what); /// - LyXAlignment GetAlignment(int cell, bool onlycolumn = false) const; + LyXAlignment getAlignment(idx_type cell, + bool onlycolumn = false) const; /// - VAlignment GetVAlignment(int cell, bool onlycolumn = false) const; + VAlignment getVAlignment(idx_type cell, + bool onlycolumn = false) const; /// - LyXLength const GetPWidth(int cell) const; + LyXLength const getPWidth(idx_type cell) const; /// - LyXLength const GetColumnPWidth(int cell) const; + LyXLength const getColumnPWidth(idx_type cell) const; /// - LyXLength const GetMColumnPWidth(int cell) const; + LyXLength const getMColumnPWidth(idx_type cell) const; /// - string const GetAlignSpecial(int cell, int what) const; + docstring const getAlignSpecial(idx_type cell, int what) const; /// - int GetWidthOfCell(int cell) const; + int getWidthOfCell(idx_type cell) const; /// - int GetBeginningOfTextInCell(int cell) const; + int getBeginningOfTextInCell(idx_type cell) const; /// - void AppendRow(BufferParams const &, int cell); + void appendRow(BufferParams const &, idx_type cell); /// - void DeleteRow(int row); + void deleteRow(row_type row); /// - void AppendColumn(BufferParams const &, int cell); + void copyRow(BufferParams const &, row_type); /// - void DeleteColumn(int column); + void appendColumn(BufferParams const &, idx_type cell); /// - bool IsFirstCellInRow(int cell) const; + void deleteColumn(col_type column); /// - int GetFirstCellInRow(int row) const; + void copyColumn(BufferParams const &, col_type); /// - bool IsLastCellInRow(int cell) const; + bool isFirstCellInRow(idx_type cell) const; /// - int GetLastCellInRow(int row) const; + idx_type getFirstCellInRow(row_type row) const; /// - int GetNumberOfCells() const; + bool isLastCellInRow(idx_type cell) const; /// - int NumberOfCellsInRow(int cell) const; + idx_type getLastCellInRow(row_type row) const; /// - void Write(Buffer const *, std::ostream &) const; + idx_type getNumberOfCells() const; /// - void Read(Buffer const *, LyXLex &); + idx_type numberOfCellsInRow(idx_type cell) const; /// - void OldFormatRead(BufferParams const &, LyXLex &, string const &); + void write(Buffer const &, std::ostream &) const; /// - int latex(Buffer const *, std::ostream &, bool, bool) const; + void read(Buffer const &, LyXLex &); /// - int docbook(Buffer const * buf, std::ostream & os, bool mixcont) const; + int latex(Buffer const &, odocstream &, OutputParams const &) const; + // + int docbook(Buffer const & buf, odocstream & os, OutputParams const &) const; /// - int ascii(Buffer const *, std::ostream &, int const depth, + int plaintext(Buffer const &, odocstream &, + OutputParams const & runparams, + int const depth, bool onlydata, unsigned char delim) const; /// - bool IsMultiColumn(int cell, bool real = false) const; + bool isMultiColumn(idx_type cell) const; + /// + bool isMultiColumnReal(idx_type cell) const; /// - void SetMultiColumn(Buffer const *, int cell, int number); + void setMultiColumn(Buffer *, idx_type cell, idx_type number); /// - int UnsetMultiColumn(int cell); // returns number of new cells + idx_type unsetMultiColumn(idx_type cell); // returns number of new cells /// - bool IsPartOfMultiColumn(int row, int column) const; + bool isPartOfMultiColumn(row_type row, col_type column) const; /// - int row_of_cell(int cell) const; + row_type row_of_cell(idx_type cell) const; /// - int column_of_cell(int cell) const; + col_type column_of_cell(idx_type cell) const; /// - int right_column_of_cell(int cell) const; + col_type right_column_of_cell(idx_type cell) const; /// - void SetLongTabular(bool); + void setBookTabs(bool); /// - bool IsLongTabular() const; + bool useBookTabs() const; /// - void SetRotateTabular(bool); + void setLongTabular(bool); /// - bool GetRotateTabular() const; + bool isLongTabular() const; /// - void SetRotateCell(int cell, bool); + void setRotateTabular(bool); /// - bool GetRotateCell(int cell) const; + bool getRotateTabular() const; /// - bool NeedRotating() const; + void setRotateCell(idx_type cell, bool); /// - bool IsLastCell(int cell) const; + bool getRotateCell(idx_type cell) const; /// - int GetCellAbove(int cell) const; + bool needRotating() const; /// - int GetCellBelow(int cell) const; + bool isLastCell(idx_type cell) const; /// - int GetLastCellAbove(int cell) const; + idx_type getCellAbove(idx_type cell) const; /// - int GetLastCellBelow(int cell) const; + idx_type getCellBelow(idx_type cell) const; /// - int GetCellNumber(int row, int column) const; + idx_type getLastCellAbove(idx_type cell) const; /// - void SetUsebox(int cell, BoxType); + idx_type getLastCellBelow(idx_type cell) const; /// - BoxType GetUsebox(int cell) const; + idx_type getCellNumber(row_type row, col_type column) const; + /// + void setUsebox(idx_type cell, BoxType); + /// + BoxType getUsebox(idx_type cell) const; // // Long Tabular Options support functions /// - bool checkLTType(int row, ltType const &) const; + bool checkLTType(row_type row, ltType const &) const; /// - void SetLTHead(int row, bool flag, ltType const &, bool first); + void setLTHead(row_type row, bool flag, ltType const &, bool first); /// - bool GetRowOfLTHead(int row, ltType &) const; + bool getRowOfLTHead(row_type row, ltType &) const; /// - bool GetRowOfLTFirstHead(int row, ltType &) const; + bool getRowOfLTFirstHead(row_type row, ltType &) const; /// - void SetLTFoot(int row, bool flag, ltType const &, bool last); + void setLTFoot(row_type row, bool flag, ltType const &, bool last); /// - bool GetRowOfLTFoot(int row, ltType &) const; + bool getRowOfLTFoot(row_type row, ltType &) const; /// - bool GetRowOfLTLastFoot(int row, ltType &) const; + bool getRowOfLTLastFoot(row_type row, ltType &) const; /// - void SetLTNewPage(int row, bool what); + void setLTNewPage(row_type row, bool what); /// - bool GetLTNewPage(int row) const; + bool getLTNewPage(row_type row) const; /// bool haveLTHead() const; /// @@ -377,34 +402,37 @@ public: /// // end longtable support /// - InsetText * GetCellInset(int cell) const; - /// - InsetText * GetCellInset(int row, int column) const; - /// Search for \param inset in the tabular, with the - /// additional hint that it could be at \param maybe_cell - int GetCellFromInset(Inset const * inset, int maybe_cell = -1) const; + boost::shared_ptr getCellInset(idx_type cell) const; /// - int rows() const { return rows_; } + boost::shared_ptr getCellInset(row_type row, + col_type column) const; /// - int columns() const { return columns_;} + void setCellInset(row_type row, col_type column, + boost::shared_ptr) const; + /// Search for \param inset in the tabular, with the /// - InsetTabular * owner() const { return owner_; } + idx_type getCellFromInset(InsetBase const * inset) const; /// - void Validate(LaTeXFeatures &) const; + row_type rows() const { return rows_; } /// - std::vector const getLabelList() const; + col_type columns() const { return columns_;} /// - /// recalculate the widths/heights only! - void reinit(); + void validate(LaTeXFeatures &) const; /// - mutable int cur_cell; -private: +//private: /// - struct cellstruct { + class cellstruct { + public: /// cellstruct(BufferParams const &); /// - int cellno; + cellstruct(cellstruct const &); + /// + cellstruct & operator=(cellstruct); + /// + void swap(cellstruct & rhs); + /// + idx_type cellno; /// int width_of_cell; /// @@ -426,19 +454,21 @@ private: /// bool rotate; /// - string align_special; + docstring align_special; /// LyXLength p_width; // this is only set for multicolumn!!! /// - InsetText inset; + boost::shared_ptr inset; }; + cellstruct & cellinfo_of_cell(idx_type cell) const; /// typedef std::vector cell_vector; /// typedef std::vector cell_vvector; /// - struct rowstruct { + class rowstruct { + public: /// rowstruct(); /// @@ -449,6 +479,18 @@ private: bool top_line; /// bool bottom_line; + /// Extra space between the top line and this row + LyXLength top_space; + /// Ignore top_space if true and use the default top space + bool top_space_default; + /// Extra space between this row and the bottom line + LyXLength bottom_space; + /// 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 + LyXLength interline_space; + /// 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; @@ -465,7 +507,8 @@ private: typedef std::vector row_vector; /// - struct columnstruct { + class columnstruct { + public: /// columnstruct(); /// @@ -481,27 +524,21 @@ private: /// LyXLength p_width; /// - string align_special; + docstring align_special; }; /// typedef std::vector column_vector; /// - void ReadNew(Buffer const * buf, std::istream & is, - LyXLex & lex, string const & l, int const version); + row_type rows_; /// - void ReadOld(Buffer const * buf, std::istream & is, - LyXLex & lex, string const & l); + col_type columns_; /// - int rows_; + idx_type numberofcells; /// - int columns_; + std::vector rowofcell; /// - int numberofcells; - /// - std::vector rowofcell; - /// - std::vector columnofcell; + std::vector columnofcell; /// row_vector row_info; /// @@ -511,6 +548,8 @@ private: /// int width_of_tabular; /// + bool use_booktabs; + /// bool rotate; // // for long tabulars @@ -524,70 +563,70 @@ private: ltType endfoot; /// endlastfoot data ltType endlastfoot; - // - /// - InsetTabular * owner_; /// - void Init(BufferParams const &, - int columns_arg, int rows_arg, LyXTabular const * lt = 0); - /// - void Reinit(bool reset_widths = true); + void init(BufferParams const &, row_type rows_arg, + col_type columns_arg); /// - void set_row_column_number_info(bool oldformat = false); + void set_row_column_number_info(); /// Returns true if a complete update is necessary, otherwise false - bool SetWidthOfMulticolCell(int cell, int new_width); + bool setWidthOfMulticolCell(idx_type cell, int new_width); /// - void recalculateMulticolumnsOfColumn(int column); + void recalculateMulticolumnsOfColumn(col_type column); /// Returns true if change - bool calculate_width_of_column(int column); + void calculate_width_of_column(col_type column); /// - bool calculate_width_of_column_NMC(int column); // no multi cells + bool calculate_width_of_column_NMC(col_type column); // no multi cells /// void calculate_width_of_tabular(); /// - cellstruct * cellinfo_of_cell(int cell) const; - /// - void delete_column(int column); - /// - int cells_in_multicolumn(int cell) const; + void delete_column(col_type column); /// - BoxType UseParbox(int cell) const; + idx_type cells_in_multicolumn(idx_type cell) const; /// - void setHeaderFooterRows(int header, int fheader, int footer, int lfooter); + BoxType useParbox(idx_type cell) const; /// // helper function for Latex returns number of newlines /// - int TeXTopHLine(std::ostream &, int row) const; + int TeXTopHLine(odocstream &, row_type row) const; /// - int TeXBottomHLine(std::ostream &, int row) const; + int TeXBottomHLine(odocstream &, row_type row) const; /// - int TeXCellPreamble(std::ostream &, int cell) const; + int TeXCellPreamble(odocstream &, idx_type cell) const; /// - int TeXCellPostamble(std::ostream &, int cell) const; + int TeXCellPostamble(odocstream &, idx_type cell) const; /// - int TeXLongtableHeaderFooter(std::ostream &, Buffer const * buf, - bool fragile, bool fp) const; + int TeXLongtableHeaderFooter(odocstream &, Buffer const & buf, + OutputParams const &) const; /// - bool isValidRow(int const row) const; + bool isValidRow(row_type const row) const; /// - int TeXRow(std::ostream &, int const row, Buffer const * buf, - bool fragile, bool fp) const; + int TeXRow(odocstream &, row_type const row, Buffer const & buf, + OutputParams const &) const; /// - // helper function for ASCII returns number of newlines + // helper functions for plain text return number of newlines /// - int asciiTopHLine(std::ostream &, int row, - std::vector const &) const; + int plaintextTopHLine(odocstream &, row_type row, + std::vector const &) const; /// - int asciiBottomHLine(std::ostream &, int row, - std::vector const &) const; + int plaintextBottomHLine(odocstream &, row_type row, + std::vector const &) const; /// - int asciiPrintCell(Buffer const *, std::ostream &, - int cell, int row, int column, - std::vector const &, + int plaintextPrintCell(Buffer const &, odocstream &, + OutputParams const &, + idx_type cell, row_type row, col_type column, + std::vector const &, bool onlydata) const; /// auxiliary function for docbook - int docbookRow(Buffer const * buf, std::ostream & os, int row) const; + int docbookRow(Buffer const & buf, odocstream & os, row_type, + OutputParams const &) const; + +private: + /// renumber cells after structural changes + void fixCellNums(); }; + +} // namespace lyx + #endif