#ifndef selectors_hh_INCLUDED #define selectors_hh_INCLUDED #include "selection.hh" namespace Kakoune { class Regex; class Context; inline Selection keep_direction(Selection res, const Selection& ref) { if ((res.cursor() < res.anchor()) != (ref.cursor() < ref.anchor())) std::swap<BufferCoord>(res.cursor(), res.anchor()); return res; } template<WordType word_type> Optional<Selection> select_to_next_word(const Context& context, const Selection& selection); template<WordType word_type> Optional<Selection> select_to_next_word_end(const Context& context, const Selection& selection); template<WordType word_type> Optional<Selection> select_to_previous_word(const Context& context, const Selection& selection); Optional<Selection> select_line(const Context& context, const Selection& selection); Optional<Selection> select_matching(const Context& context, const Selection& selection); Optional<Selection> select_to(const Context& context, const Selection& selection, Codepoint c, int count, bool inclusive); Optional<Selection> select_to_reverse(const Context& context, const Selection& selection, Codepoint c, int count, bool inclusive); template<bool only_move> Optional<Selection> select_to_line_end(const Context& context, const Selection& selection); template<bool only_move> Optional<Selection> select_to_line_begin(const Context& context, const Selection& selection); Optional<Selection> select_to_first_non_blank(const Context& context, const Selection& selection); enum class ObjectFlags { ToBegin = 1, ToEnd = 2, Inner = 4 }; constexpr bool with_bit_ops(Meta::Type<ObjectFlags>) { return true; } template<WordType word_type> Optional<Selection> select_word(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_number(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_sentence(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_paragraph(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_whitespaces(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_indent(const Context& context, const Selection& selection, int count, ObjectFlags flags); Optional<Selection> select_argument(const Context& context, const Selection& selection, int level, ObjectFlags flags); Optional<Selection> select_lines(const Context& context, const Selection& selection); Optional<Selection> trim_partial_lines(const Context& context, const Selection& selection); void select_buffer(SelectionList& selections); enum class MatchDirection; template<MatchDirection direction> Selection find_next_match(const Context& context, const Selection& sel, const Regex& regex, bool& wrapped); void select_all_matches(SelectionList& selections, const Regex& regex, int capture = 0); void split_selections(SelectionList& selections, const Regex& regex, int capture = 0); Optional<Selection> select_surrounding(const Context& context, const Selection& selection, const Regex& opening, const Regex& closing, int level, ObjectFlags flags); } #endif // selectors_hh_INCLUDED