Make inset-select-all select all cells only in tables

inset-select-all has 3 levels
1. select current cell
2. select all cells
3. select inset from outside.

The second level makes sense for tables (text and math), but not for things like a math fraction.

Introduce a new method Inset::isTable() that allows to detect this case properly and skip level 2.

(cherry picked from commit 5de28b9ac6736c791146a1a3ebe7f4826c22a9b7)
This commit is contained in:
Jean-Marc Lasgouttes 2016-03-14 11:46:28 +01:00
parent 1a836459fb
commit 1f2d7bf7e6
5 changed files with 22 additions and 9 deletions

View File

@ -1771,21 +1771,25 @@ void BufferView::dispatch(FuncRequest const & cmd, DispatchResult & dr)
}
case LFUN_INSET_SELECT_ALL:
if (cur.depth() > 1
case LFUN_INSET_SELECT_ALL: {
// true if all cells are selected
bool const all_selected = cur.depth() > 1
&& cur.selBegin().at_begin()
&& cur.selEnd().at_end()) {
// All the contents of the inset if selected.
&& cur.selEnd().at_end();
// true if some cells are selected
bool const cells_selected = cur.depth() > 1
&& cur.selBegin().at_cell_begin()
&& cur.selEnd().at_cell_end();
if (all_selected || (cells_selected && !cur.inset().isTable())) {
// All the contents of the inset if selected, or only at
// least one cell but inset is not a table.
// Select the inset from outside.
cur.pop();
cur.resetAnchor();
cur.setSelection(true);
cur.posForward();
} else if (cur.selBegin().idx() != cur.selEnd().idx()
|| (cur.depth() > 1
&& cur.selBegin().at_cell_begin()
&& cur.selEnd().at_cell_end())) {
// At least one complete cell is selected.
} else if (cells_selected) {
// At least one complete cell is selected and inset is a table.
// Select all cells
cur.idx() = 0;
cur.pos() = 0;
@ -1805,6 +1809,7 @@ void BufferView::dispatch(FuncRequest const & cmd, DispatchResult & dr)
cur.setCurrentFont();
dr.screenUpdate(Update::Force);
break;
}
// This would be in Buffer class if only Cursor did not

View File

@ -347,6 +347,8 @@ public:
virtual bool clickable(BufferView const &, int, int) const { return false; }
/// Move one cell backwards
virtual bool allowsCaptionVariation(std::string const &) const { return false; }
// true for insets that have a table structure (InsetMathGrid, InsetTabular)
virtual bool isTable() const { return false; }
/// does this contain text that can be change track marked in DVI?
virtual bool canTrackChanges() const { return false; }

View File

@ -881,6 +881,8 @@ public:
bool inheritFont() const { return false; }
///
bool allowsCaptionVariation(std::string const &) const;
//
bool isTable() const { return true; }
///
DisplayType display() const;
///

View File

@ -154,6 +154,8 @@ public:
InsetMathGrid * asGridInset() { return this; }
/// identifies GridInset
InsetMathGrid const * asGridInset() const { return this; }
//
bool isTable() const { return true; }
///
col_type ncols() const;
///

View File

@ -27,6 +27,8 @@ What's new
- Change mouse cursor to indicate row/column selection in tabulars.
- Make inset-select-all select all cells only in tables.
- Automatically show the review toolbar if the document has tracked changes
(bug 8738), and related UI imrovements.