///
class LyXTabular {
public:
- // Are the values of these enums important? (Lgb)
+ ///
enum {
+ ///
APPEND_ROW = 0,
+ ///
APPEND_COLUMN,
+ ///
DELETE_ROW,
+ ///
DELETE_COLUMN,
+ ///
TOGGLE_LINE_TOP,
+ ///
TOGGLE_LINE_BOTTOM,
+ ///
TOGGLE_LINE_LEFT,
+ ///
TOGGLE_LINE_RIGHT,
- ALIGN_LEFT, // what are these alignment enums used for?
+ ///
+ ALIGN_LEFT,
+ ///
ALIGN_RIGHT,
+ ///
ALIGN_CENTER,
+ ///
+ VALIGN_TOP,
+ ///
+ VALIGN_BOTTOM,
+ ///
+ VALIGN_CENTER,
+ ///
+ M_TOGGLE_LINE_TOP,
+ ///
+ M_TOGGLE_LINE_BOTTOM,
+ ///
+ M_TOGGLE_LINE_LEFT,
+ ///
+ M_TOGGLE_LINE_RIGHT,
+ ///
+ M_ALIGN_LEFT,
+ ///
+ M_ALIGN_RIGHT,
+ ///
+ M_ALIGN_CENTER,
+ ///
+ M_VALIGN_TOP,
+ ///
+ M_VALIGN_BOTTOM,
+ ///
+ M_VALIGN_CENTER,
+ ///
DELETE_TABULAR,
+ ///
MULTICOLUMN,
+ ///
SET_ALL_LINES,
+ ///
UNSET_ALL_LINES,
+ ///
SET_LONGTABULAR,
+ ///
UNSET_LONGTABULAR,
+ ///
SET_PWIDTH,
+ ///
+ SET_MPWIDTH,
+ ///
SET_ROTATE_TABULAR,
+ ///
UNSET_ROTATE_TABULAR,
+ ///
SET_ROTATE_CELL,
+ ///
UNSET_ROTATE_CELL,
- SET_LINEBREAKS,
+ ///
+ SET_USEBOX,
+ ///
SET_LTHEAD,
+ ///
SET_LTFIRSTHEAD,
+ ///
SET_LTFOOT,
+ ///
SET_LTLASTFOOT,
+ ///
SET_LTNEWPAGE,
+ ///
SET_SPECIAL_COLUMN,
- SET_SPECIAL_MULTI
+ ///
+ SET_SPECIAL_MULTI,
+ ///
+ LAST_ACTION
};
-
+ ///
enum {
+ ///
CELL_NORMAL = 0,
+ ///
CELL_BEGIN_OF_MULTICOLUMN,
+ ///
CELL_PART_OF_MULTICOLUMN
};
+
+ ///
+ enum VAlignment {
+ ///
+ LYX_VALIGN_TOP = 0,
+ ///
+ LYX_VALIGN_BOTTOM = 1,
+ ///
+ LYX_VALIGN_CENTER = 2
+ };
+
/* konstruktor */
///
LyXTabular(InsetTabular *, int columns_arg, int rows_arg);
///
- ///
LyXTabular(InsetTabular *, LyXTabular const &);
///
explicit
LyXTabular * Clone(InsetTabular *);
/// Returns true if there is a topline, returns false if not
- bool TopLine(int cell) const;
+ bool TopLine(int cell, bool onlycolumn=false) const;
/// Returns true if there is a topline, returns false if not
- bool BottomLine(int cell) const;
+ bool BottomLine(int cell, bool onlycolumn=false) const;
/// Returns true if there is a topline, returns false if not
- bool LeftLine(int cell) const;
+ bool LeftLine(int cell, bool onlycolumn=false) const;
/// Returns true if there is a topline, returns false if not
- bool RightLine(int cell) const;
+ bool RightLine(int cell, bool onlycolumn=false) const;
///
bool TopAlreadyDrawed(int cell) const;
/// 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 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 SetBottomLine(int cell, bool line);
+ bool SetLeftLine(int cell, bool line, bool onlycolumn=false);
/// Returns true if a complete update is necessary, otherwise false
- bool SetLeftLine(int cell, bool line);
+ bool SetRightLine(int cell, bool line, bool onlycolumn=false);
/// Returns true if a complete update is necessary, otherwise false
- bool SetRightLine(int cell, bool line);
+ bool SetAlignment(int cell, char align, bool onlycolumn = false);
/// Returns true if a complete update is necessary, otherwise false
- bool SetAlignment(int cell, char align);
+ bool SetVAlignment(int cell, char align, bool onlycolumn = false);
///
- bool SetPWidth(int cell, string const & width);
+ bool SetColumnPWidth(int cell, string const & width);
+ ///
+ bool SetMColumnPWidth(int cell, string const & width);
///
bool SetAlignSpecial(int cell, string const & special, int what);
///
- char GetAlignment(int cell) const; // add approp. signedness
+ char GetAlignment(int cell, bool onlycolumn = false) const;
+ ///
+ char GetVAlignment(int cell, bool onlycolumn = false) const;
///
string GetPWidth(int cell) const;
///
+ string GetColumnPWidth(int cell) const;
+ ///
+ string GetMColumnPWidth(int cell) const;
+ ///
string GetAlignSpecial(int cell, int what) const;
///
int GetWidthOfCell(int cell) const;
void Read(Buffer const *, LyXLex &);
///
void OldFormatRead(LyXLex &, string const &);
- ///
- /// helper function for Latex returns number of newlines
+ //
+ // helper function for Latex returns number of newlines
///
int TeXTopHLine(std::ostream &, int row) const;
+ ///
int TeXBottomHLine(std::ostream &, int row) const;
+ ///
int TeXCellPreamble(std::ostream &, int cell) const;
+ ///
int TeXCellPostamble(std::ostream &, int cell) const;
///
int Latex(Buffer const *, std::ostream &, bool, bool) const;
char const * GetDocBookAlign(int cell, bool isColumn = false) const;
///
- bool IsMultiColumn(int cell) const;
+ bool IsMultiColumn(int cell, bool real = false) const;
///
void SetMultiColumn(int cell, int number);
///
///
int GetCellNumber(int row, int column) const;
///
- void SetLinebreaks(int cell, bool what);
- ///
- bool GetLinebreaks(int cell) const;
+ void SetUsebox(int cell, int what);
///
- /// Long Tabular Options
+ int GetUsebox(int cell) const;
+ //
+ // Long Tabular Options
///
void SetLTHead(int cell, bool first);
///
- bool GetRowOfLTHead(int cell) const;
+ bool GetRowOfLTHead(int cell, int & row) const;
///
- bool GetRowOfLTFirstHead(int cell) const;
+ bool GetRowOfLTFirstHead(int cell, int & row) const;
///
void SetLTFoot(int cell, bool last);
///
- bool GetRowOfLTFoot(int cell) const;
+ bool GetRowOfLTFoot(int cell, int & row) const;
///
- bool GetRowOfLTLastFoot(int cell) const;
+ bool GetRowOfLTLastFoot(int cell, int & row) const;
///
void SetLTNewPage(int cell, bool what);
///
struct cellstruct {
///
cellstruct();
- ///
#ifdef INSET_POINTER
- ~cellstruct();
///
+ ~cellstruct();
+ //
cellstruct(cellstruct const &);
///
cellstruct & operator=(cellstruct const &);
///
int width_of_cell;
///
- int multicolumn; // add approp. signedness
+ int multicolumn;
///
- int alignment; // add approp. signedness
+ int alignment;
+ ///
+ int valignment;
///
bool top_line;
///
bool left_line;
///
bool right_line;
- ///
- bool linebreaks;
+ /**
+ 0 ... don't use a box
+ 1 ... use a parbox
+ 2 ... use a minipage
+ This should be made into an enum (Lgb)
+ */
+ int usebox;
///
int rotate;
///
///
InsetText inset;
};
+ ///
typedef std::vector<cellstruct> cell_vector;
+ ///
typedef std::vector<cell_vector> cell_vvector;
///
struct rowstruct {
///
rowstruct();
- ///
+ //
//~rowstruct();
- ///
+ //
// rowstruct & operator=(rowstruct const &);
///
bool top_line;
+ ///
bool bottom_line;
+ ///
int ascent_of_row;
+ ///
int descent_of_row;
/// This are for longtabulars only
bool newpage;
};
+ ///
typedef std::vector<rowstruct> row_vector;
///
struct columnstruct {
///
columnstruct();
- ///
+ //
//~columnstruct();
- ///
+ //
//columnstruct & operator=(columnstruct const &);
///
- int alignment; // add approp. signedness
+ int alignment;
+ ///
+ int valignment;
+ ///
bool left_line;
+ ///
bool right_line;
+ ///
int width_of_column;
+ ///
string p_width;
+ ///
string align_special;
};
+ ///
typedef std::vector<columnstruct> column_vector;
///
///
int width_of_tabular;
///
- /// for long tabulars
+ int rotate;
+ //
+ // for long tabulars
///
- int endhead; // row of endhead
- int endfirsthead; // row of endfirsthead
- int endfoot; // row of endfoot
- int endlastfoot; // row of endlastfoot
+ int is_long_tabular;
+ /// row of endhead
+ int endhead;
+ /// row of endfirsthead
+ int endfirsthead;
+ /// row of endfoot
+ int endfoot;
+ /// row of endlastfoot
+ int endlastfoot;
///
InsetTabular * owner_;
void recalculateMulticolCells(int cell, int new_width);
/// Returns true if change
bool calculate_width_of_column(int column);
+ ///
bool calculate_width_of_column_NMC(int 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;
///
- int is_long_tabular;
- ///
- int rotate;
+ bool UseParbox(int cell) const;
};
#endif