Use <esc> to exit on-key modes
This commit is contained in:
parent
42196b83cf
commit
a20ecf6b00
|
@ -260,15 +260,15 @@ public:
|
|||
{
|
||||
on_next_key_with_autoinfo(context(), KeymapMode::None,
|
||||
[this](Key key, Context& context) {
|
||||
if (auto cp = key.codepoint())
|
||||
{
|
||||
auto cp = key.codepoint();
|
||||
if (not cp or key == Key::Escape)
|
||||
return;
|
||||
if (*cp <= 127)
|
||||
m_params.reg = *cp;
|
||||
else
|
||||
context.print_status(
|
||||
{ format("invalid register '{}'", *cp),
|
||||
get_face("Error") });
|
||||
}
|
||||
}, "enter target register", register_doc);
|
||||
}
|
||||
else
|
||||
|
@ -755,14 +755,14 @@ public:
|
|||
{
|
||||
on_next_key_with_autoinfo(context(), KeymapMode::None,
|
||||
[this](Key key, Context&) {
|
||||
if (auto cp = key.codepoint())
|
||||
{
|
||||
auto cp = key.codepoint();
|
||||
if (not cp or key == Key::Escape)
|
||||
return;
|
||||
StringView reg = context().main_sel_register_value(String{*cp});
|
||||
m_line_editor.insert(reg);
|
||||
|
||||
display();
|
||||
m_line_changed = true;
|
||||
}
|
||||
}, "enter register name", register_doc);
|
||||
display();
|
||||
return;
|
||||
|
@ -1183,7 +1183,9 @@ public:
|
|||
{
|
||||
on_next_key_with_autoinfo(context(), KeymapMode::None,
|
||||
[this](Key key, Context&) {
|
||||
if (auto cp = key.codepoint())
|
||||
auto cp = key.codepoint();
|
||||
if (not cp or key == Key::Escape)
|
||||
return;
|
||||
insert(RegisterManager::instance()[*cp].get(context()));
|
||||
}, "enter register name", register_doc);
|
||||
update_completions = false;
|
||||
|
|
|
@ -185,7 +185,7 @@ void goto_commands(Context& context, NormalParams params)
|
|||
on_next_key_with_autoinfo(context, KeymapMode::Goto,
|
||||
[](Key key, Context& context) {
|
||||
auto cp = key.codepoint();
|
||||
if (not cp)
|
||||
if (not cp or key == Key::Escape)
|
||||
return;
|
||||
auto& buffer = context.buffer();
|
||||
switch (to_lower(*cp))
|
||||
|
@ -1119,7 +1119,7 @@ void select_object(Context& context, NormalParams params)
|
|||
on_next_key_with_autoinfo(context, KeymapMode::Object,
|
||||
[count](Key key, Context& context) {
|
||||
auto cp = key.codepoint().value_or((Codepoint)-1);
|
||||
if (cp == -1)
|
||||
if (cp == -1 or key == Key::Escape)
|
||||
return;
|
||||
|
||||
static constexpr struct ObjectType
|
||||
|
@ -1332,9 +1332,11 @@ void select_to_next_char(Context& context, NormalParams params)
|
|||
|
||||
on_next_key_with_autoinfo(context, KeymapMode::None,
|
||||
[params](Key key, Context& context) {
|
||||
auto cp = key.codepoint();
|
||||
if (not cp or key == Key::Escape)
|
||||
return;
|
||||
constexpr auto new_flags = flags & SelectFlags::Extend ? SelectMode::Extend
|
||||
: SelectMode::Replace;
|
||||
if (auto cp = key.codepoint())
|
||||
select_and_set_last<new_flags>(
|
||||
context,
|
||||
std::bind(flags & SelectFlags::Reverse ? select_to_reverse
|
||||
|
|
Loading…
Reference in New Issue
Block a user