From 266cdca115c7e9b14f734da478d04a8ce0c2cb69 Mon Sep 17 00:00:00 2001 From: Robin Haberkorn Date: Tue, 4 Dec 2012 04:46:13 +0100 Subject: search-kill command (FK) * like the other search-related commands the operation (delete, kill, replace) is not performed until the search pattern string argument is terminated (simplifies implementation and has visual advantages) --- parser.cpp | 1 + search.cpp | 25 +++++++++++++++++++++++++ search.h | 6 ++++++ 3 files changed, 32 insertions(+) diff --git a/parser.cpp b/parser.cpp index 10c0ea3..bb05d66 100644 --- a/parser.cpp +++ b/parser.cpp @@ -1015,6 +1015,7 @@ StateStart::custom(gchar chr) throw (Error) StateFCommand::StateFCommand() : State() { transitions['\0'] = this; + transitions['K'] = &States::searchkill; transitions['D'] = &States::searchdelete; transitions['S'] = &States::replace; transitions['R'] = &States::replacedefault; diff --git a/search.cpp b/search.cpp index ea0613a..f27e744 100644 --- a/search.cpp +++ b/search.cpp @@ -13,6 +13,7 @@ namespace States { StateSearch search; StateSearchAll searchall; + StateSearchKill searchkill; StateSearchDelete searchdelete; StateReplace replace; StateReplace_insert replace_insert; @@ -494,6 +495,30 @@ StateSearchAll::done(const gchar *str) throw (Error) return &States::start; } +State * +StateSearchKill::done(const gchar *str) throw (Error) +{ + gint anchor; + + BEGIN_EXEC(&States::start); + + StateSearch::done(str); + + undo.push_msg(SCI_GOTOPOS, interface.ssm(SCI_GETCURRENTPOS)); + anchor = interface.ssm(SCI_GETANCHOR); + interface.ssm(SCI_GOTOPOS, anchor); + + interface.ssm(SCI_BEGINUNDOACTION); + interface.ssm(SCI_DELETERANGE, + parameters.dot, anchor - parameters.dot); + interface.ssm(SCI_ENDUNDOACTION); + ring.dirtify(); + + undo.push_msg(SCI_UNDO); + + return &States::start; +} + State * StateSearchDelete::done(const gchar *str) throw (Error) { diff --git a/search.h b/search.h index 8a23ac6..12b95db 100644 --- a/search.h +++ b/search.h @@ -48,6 +48,11 @@ private: State *done(const gchar *str) throw (Error); }; +class StateSearchKill : public StateSearch { +private: + State *done(const gchar *str) throw (Error); +}; + class StateSearchDelete : public StateSearch { public: StateSearchDelete(bool last = true) : StateSearch(last) {} @@ -86,6 +91,7 @@ private: namespace States { extern StateSearch search; extern StateSearchAll searchall; + extern StateSearchKill searchkill; extern StateSearchDelete searchdelete; extern StateReplace replace; extern StateReplace_insert replace_insert; -- cgit v1.2.3