Remove target_eol and small code cleanups
This commit is contained in:
parent
d28dbd0918
commit
7f9fe32f2d
|
@ -2057,7 +2057,8 @@ void move_cursor(Context& context, NormalParams params)
|
||||||
|
|
||||||
void select_whole_buffer(Context& context, NormalParams)
|
void select_whole_buffer(Context& context, NormalParams)
|
||||||
{
|
{
|
||||||
select_buffer(context.selections());
|
auto& buffer = context.buffer();
|
||||||
|
context.selections_write_only() = SelectionList{buffer, {{0,0}, {buffer.back_coord(), max_column}}};
|
||||||
}
|
}
|
||||||
|
|
||||||
void keep_selection(Context& context, NormalParams p)
|
void keep_selection(Context& context, NormalParams p)
|
||||||
|
|
|
@ -8,6 +8,8 @@ namespace Kakoune
|
||||||
|
|
||||||
using CaptureList = Vector<String, MemoryDomain::Selections>;
|
using CaptureList = Vector<String, MemoryDomain::Selections>;
|
||||||
|
|
||||||
|
constexpr ColumnCount max_column{std::numeric_limits<int>::max()};
|
||||||
|
|
||||||
// A selection is a Selection, associated with a CaptureList
|
// A selection is a Selection, associated with a CaptureList
|
||||||
struct Selection
|
struct Selection
|
||||||
{
|
{
|
||||||
|
@ -15,7 +17,7 @@ struct Selection
|
||||||
|
|
||||||
Selection() = default;
|
Selection() = default;
|
||||||
Selection(BufferCoord pos) : Selection(pos,pos) {}
|
Selection(BufferCoord pos) : Selection(pos,pos) {}
|
||||||
Selection(BufferCoord anchor, BufferCoord cursor,
|
Selection(BufferCoord anchor, BufferCoordAndTarget cursor,
|
||||||
CaptureList captures = {})
|
CaptureList captures = {})
|
||||||
: m_anchor{anchor}, m_cursor{cursor},
|
: m_anchor{anchor}, m_cursor{cursor},
|
||||||
m_captures(std::move(captures)) {}
|
m_captures(std::move(captures)) {}
|
||||||
|
|
|
@ -21,12 +21,6 @@ using Utf8Iterator = utf8::iterator<BufferIterator>;
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
|
|
||||||
Selection target_eol(Selection sel)
|
|
||||||
{
|
|
||||||
sel.cursor().target = INT_MAX;
|
|
||||||
return sel;
|
|
||||||
}
|
|
||||||
|
|
||||||
Selection utf8_range(const BufferIterator& first, const BufferIterator& last)
|
Selection utf8_range(const BufferIterator& first, const BufferIterator& last)
|
||||||
{
|
{
|
||||||
return {first.coord(), last.coord()};
|
return {first.coord(), last.coord()};
|
||||||
|
@ -183,7 +177,7 @@ select_line(const Context& context, const Selection& selection)
|
||||||
selection.cursor() == BufferCoord{line, buffer[line].length() - 1} and
|
selection.cursor() == BufferCoord{line, buffer[line].length() - 1} and
|
||||||
line != buffer.line_count() - 1)
|
line != buffer.line_count() - 1)
|
||||||
++line;
|
++line;
|
||||||
return target_eol({{line, 0_byte}, {line, buffer[line].length() - 1}});
|
return Selection{{line, 0_byte}, {line, buffer[line].length() - 1, max_column}};
|
||||||
}
|
}
|
||||||
|
|
||||||
template<bool only_move>
|
template<bool only_move>
|
||||||
|
@ -197,7 +191,7 @@ select_to_line_end(const Context& context, const Selection& selection)
|
||||||
buffer.iterator_at(line)).coord();
|
buffer.iterator_at(line)).coord();
|
||||||
if (end < begin) // Do not go backward when cursor is on eol
|
if (end < begin) // Do not go backward when cursor is on eol
|
||||||
end = begin;
|
end = begin;
|
||||||
return target_eol({only_move ? end : begin, end});
|
return Selection{only_move ? end : begin, {end, max_column}};
|
||||||
}
|
}
|
||||||
template Optional<Selection> select_to_line_end<false>(const Context&, const Selection&);
|
template Optional<Selection> select_to_line_end<false>(const Context&, const Selection&);
|
||||||
template Optional<Selection> select_to_line_end<true>(const Context&, const Selection&);
|
template Optional<Selection> select_to_line_end<true>(const Context&, const Selection&);
|
||||||
|
@ -823,7 +817,7 @@ select_lines(const Context& context, const Selection& selection)
|
||||||
to_line_start.column = 0;
|
to_line_start.column = 0;
|
||||||
to_line_end.column = buffer[to_line_end.line].length()-1;
|
to_line_end.column = buffer[to_line_end.line].length()-1;
|
||||||
|
|
||||||
return target_eol({anchor, cursor});
|
return Selection{anchor, {cursor, max_column}};
|
||||||
}
|
}
|
||||||
|
|
||||||
Optional<Selection>
|
Optional<Selection>
|
||||||
|
@ -849,13 +843,7 @@ trim_partial_lines(const Context& context, const Selection& selection)
|
||||||
if (to_line_start > to_line_end)
|
if (to_line_start > to_line_end)
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
return target_eol({anchor, cursor});
|
return Selection{anchor, {cursor, max_column}};
|
||||||
}
|
|
||||||
|
|
||||||
void select_buffer(SelectionList& selections)
|
|
||||||
{
|
|
||||||
auto& buffer = selections.buffer();
|
|
||||||
selections = SelectionList{ buffer, target_eol({{0,0}, buffer.back_coord()}) };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static RegexExecFlags
|
static RegexExecFlags
|
||||||
|
|
|
@ -97,8 +97,6 @@ select_lines(const Context& context, const Selection& selection);
|
||||||
Optional<Selection>
|
Optional<Selection>
|
||||||
trim_partial_lines(const Context& context, const Selection& selection);
|
trim_partial_lines(const Context& context, const Selection& selection);
|
||||||
|
|
||||||
void select_buffer(SelectionList& selections);
|
|
||||||
|
|
||||||
enum class RegexMode;
|
enum class RegexMode;
|
||||||
|
|
||||||
template<RegexMode mode>
|
template<RegexMode mode>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user