diff options
| author | Maxime Coste <frrrwww@gmail.com> | 2014-09-10 19:06:53 +0100 |
|---|---|---|
| committer | Maxime Coste <frrrwww@gmail.com> | 2014-09-10 19:06:53 +0100 |
| commit | 827a77539af80d7ffa314d13c4cc4e7927709a55 (patch) | |
| tree | 59333a1c4e70711aee72acc239b84569bdf3ee16 /src/input_handler.cc | |
| parent | c18e2ac90ee575338234986d41e7773bed00b0a6 (diff) | |
Add some color to mode specific mode line info
Diffstat (limited to 'src/input_handler.cc')
| -rw-r--r-- | src/input_handler.cc | 33 |
1 files changed, 19 insertions, 14 deletions
diff --git a/src/input_handler.cc b/src/input_handler.cc index 97858e49..b0aff794 100644 --- a/src/input_handler.cc +++ b/src/input_handler.cc @@ -30,7 +30,7 @@ public: virtual void on_disabled() {} Context& context() const { return m_input_handler.context(); } - virtual String description() const = 0; + virtual DisplayLine mode_line() const = 0; virtual KeymapMode keymap_mode() const = 0; @@ -128,10 +128,15 @@ public: m_idle_timer.set_next_date(Clock::now() + idle_timeout); } - String description() const override + DisplayLine mode_line() const override { - return to_string(context().selections().size()) + - (m_count != 0 ? " sel; param=" + to_string(m_count) : " sel"); + AtomList atoms = { { to_string(context().selections().size()) + " sel", Face(Colors::Blue) } }; + if (m_count != 0) + { + atoms.push_back({ "; param=", Face(Colors::Yellow) }); + atoms.push_back({ to_string(m_count), Face(Colors::Green) }); + } + return atoms; } KeymapMode keymap_mode() const override { return KeymapMode::Normal; } @@ -407,9 +412,9 @@ public: } } - String description() const override + DisplayLine mode_line() const override { - return "menu"; + return { "menu", Face(Colors::Yellow) }; } KeymapMode keymap_mode() const override { return KeymapMode::Menu; } @@ -657,9 +662,9 @@ public: } } - String description() const override + DisplayLine mode_line() const override { - return "prompt"; + return { "prompt", Face(Colors::Yellow) }; } KeymapMode keymap_mode() const override { return KeymapMode::Prompt; } @@ -734,9 +739,9 @@ public: m_callback(key, context()); } - String description() const override + DisplayLine mode_line() const override { - return "enter key"; + return { "enter key", Face(Colors::Yellow) }; } KeymapMode keymap_mode() const override { return KeymapMode::None; } @@ -879,9 +884,9 @@ public: context().hooks().run_hook("InsertMove", key_to_str(key), context()); } - String description() const override + DisplayLine mode_line() const override { - return "insert"; + return { "insert", Face(Colors::Green) }; } KeymapMode keymap_mode() const override { return KeymapMode::Insert; } @@ -1130,9 +1135,9 @@ void InputHandler::reset_normal_mode() change_input_mode(new InputModes::Normal(*this)); } -String InputHandler::mode_string() const +DisplayLine InputHandler::mode_line() const { - return m_mode->description(); + return m_mode->mode_line(); } void InputHandler::clear_mode_trash() |
