Fix shift-key down on last line in TextEdit

This commit is contained in:
Bernhard Liebl 2017-12-26 07:53:16 +01:00
parent 37aab45091
commit 076a5f35fc
2 changed files with 29 additions and 2 deletions

View file

@ -2719,6 +2719,8 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
_scroll_lines_down();
break;
}
{
#else
if (k->get_command() && k->get_alt()) {
_scroll_lines_down();
@ -2727,9 +2729,15 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (k->get_command())
cursor_set_line(text.size() - 1, true, false);
else
else {
#endif
if (!is_last_visible_line(cursor.line)) {
cursor_set_line(cursor_get_line() + num_lines_from(CLAMP(cursor.line + 1, 0, text.size() - 1), 1), true, false);
} else {
cursor_set_line(text.size() - 1);
cursor_set_column(get_line(cursor.line).length(), true);
}
}
if (k->get_shift())
_post_shift_selection();
@ -4574,6 +4582,24 @@ int TextEdit::num_lines_from(int p_line_from, int unhidden_amount) const {
return num_total;
}
bool TextEdit::is_last_visible_line(int p_line) const {
ERR_FAIL_INDEX_V(p_line, text.size(), false);
if (p_line == text.size() - 1)
return true;
if (!is_hiding_enabled())
return false;
for (int i = p_line + 1; i < text.size(); i++) {
if (!is_line_hidden(i))
return false;
}
return true;
}
int TextEdit::get_indent_level(int p_line) const {
ERR_FAIL_INDEX_V(p_line, text.size(), 0);

View file

@ -433,6 +433,7 @@ public:
void fold_all_lines();
void unhide_all_lines();
int num_lines_from(int p_line_from, int unhidden_amount) const;
bool is_last_visible_line(int p_line) const;
bool can_fold(int p_line) const;
bool is_folded(int p_line) const;
void fold_line(int p_line);