diff options
author | Robin Haberkorn <robin.haberkorn@googlemail.com> | 2017-03-25 06:47:10 +0100 |
---|---|---|
committer | Robin Haberkorn <robin.haberkorn@googlemail.com> | 2017-03-25 06:57:17 +0100 |
commit | 90baf34034af9363ee4cfa1654a8cc72dfc8c62e (patch) | |
tree | b4b912e42c0246d735b33f1f0babb1475acba1ab /src | |
parent | 2491d5f30573d9e5e72b3c7d2eac8788bbe69dd4 (diff) | |
download | sciteco-90baf34034af9363ee4cfa1654a8cc72dfc8c62e.tar.gz |
0,8ED: Automatic case-folding of commands
* when enabled, it will automatically upper-case all
one or two letter commands (which are case insensitive).
* also affects the up-carret control commands, so they when inserted
they look more like real control commands.
* specifically does not affect case-insensitive Q-Register specifications
* the result are command lines that are better readable and conform
to the coding style used in SciTECO's standard library.
This eases reusing command lines as well.
* Consequently, string-building and pattern match characters should
be case-folded as well, but they aren't currently since
State::process_edit_cmd() does not have sufficient insight
into the MicroStateMachines. Also, it could not be delegated
to the MicroStateMachines.
Perhaps they should be abandoned in favour of embeddedable
regular state machines; or regular state machines with a stack
of return states?
Diffstat (limited to 'src')
-rw-r--r-- | src/cmdline.cpp | 11 | ||||
-rw-r--r-- | src/parser.cpp | 19 | ||||
-rw-r--r-- | src/parser.h | 24 | ||||
-rw-r--r-- | src/sciteco.h | 1 |
4 files changed, 44 insertions, 11 deletions
diff --git a/src/cmdline.cpp b/src/cmdline.cpp index f10da33..daf1a9b 100644 --- a/src/cmdline.cpp +++ b/src/cmdline.cpp @@ -614,6 +614,17 @@ State::process_edit_cmd(gchar key) } void +StateCaseInsensitive::process_edit_cmd(gchar key) +{ + if (Flags::ed & Flags::ED_AUTOCASEFOLD) + /* will not modify non-letter keys */ + key = g_ascii_islower(key) ? g_ascii_toupper(key) + : g_ascii_tolower(key); + + State::process_edit_cmd(key); +} + +void StateExpectString::process_edit_cmd(gchar key) { switch (key) { diff --git a/src/parser.cpp b/src/parser.cpp index 42c4c33..fe22560 100644 --- a/src/parser.cpp +++ b/src/parser.cpp @@ -672,7 +672,7 @@ StateExpectFile::done(const gchar *str) return next; } -StateStart::StateStart() : State() +StateStart::StateStart() { transitions['\0'] = this; init(" \f\r\n\v"); @@ -1648,7 +1648,7 @@ StateStart::custom(gchar chr) return this; } -StateFCommand::StateFCommand() : State() +StateFCommand::StateFCommand() { transitions['\0'] = this; transitions['K'] = &States::searchkill; @@ -1842,7 +1842,7 @@ StateChangeDir::got_file(const gchar *filename) return &States::start; } -StateCondCommand::StateCondCommand() : State() +StateCondCommand::StateCondCommand() { transitions['\0'] = this; } @@ -1948,7 +1948,7 @@ StateCondCommand::custom(gchar chr) return &States::start; } -StateControl::StateControl() : State() +StateControl::StateControl() { transitions['\0'] = this; transitions['I'] = &States::insert_indent; @@ -2183,7 +2183,7 @@ StateEscape::end_of_macro(void) expressions.discard_args(); } -StateECommand::StateECommand() : State() +StateECommand::StateECommand() { transitions['\0'] = this; transitions['%'] = &States::epctcommand; @@ -2256,6 +2256,15 @@ StateECommand::custom(gchar chr) * Without any argument ED returns the current flags. * * Currently, the following flags are used by \*(ST: + * - 8: Enable/disable automatic folding of case-insensitive + * command characters during interactive key translation. + * The case of letter keys is inverted, so one or two + * character commands will typically be inserted upper-case, + * but you can still press Shift to insert lower-case letters. + * Case-insensitive Q-Register specifications are not + * case folded. + * This is thought to improve the readability of the command + * line macro. * - 16: Enable/disable automatic translation of end of * line sequences to and from line feed. * - 32: Enable/Disable buffer editing hooks diff --git a/src/parser.h b/src/parser.h index 56e58c4..f61d335 100644 --- a/src/parser.h +++ b/src/parser.h @@ -124,6 +124,18 @@ public: } }; +/** + * Base class of states with case-insenstive input. + * + * This is meant for states accepting command characters + * that can possibly be case-folded. + */ +class StateCaseInsensitive : public State { +protected: + /* in cmdline.cpp */ + void process_edit_cmd(gchar key); +}; + template <typename Type> class MicroStateMachine : public Object { protected: @@ -252,7 +264,7 @@ protected: void process_edit_cmd(gchar key); }; -class StateStart : public State { +class StateStart : public StateCaseInsensitive { public: StateStart(); @@ -276,7 +288,7 @@ private: } }; -class StateControl : public State { +class StateControl : public StateCaseInsensitive { public: StateControl(); @@ -292,7 +304,7 @@ private: State *custom(gchar chr); }; -class StateEscape : public State { +class StateEscape : public StateCaseInsensitive { public: StateEscape(); @@ -312,7 +324,7 @@ private: } }; -class StateFCommand : public State { +class StateFCommand : public StateCaseInsensitive { public: StateFCommand(); @@ -344,7 +356,7 @@ private: State *got_file(const gchar *filename); }; -class StateCondCommand : public State { +class StateCondCommand : public StateCaseInsensitive { public: StateCondCommand(); @@ -352,7 +364,7 @@ private: State *custom(gchar chr); }; -class StateECommand : public State { +class StateECommand : public StateCaseInsensitive { public: StateECommand(); diff --git a/src/sciteco.h b/src/sciteco.h index bc2e58c..b856210 100644 --- a/src/sciteco.h +++ b/src/sciteco.h @@ -39,6 +39,7 @@ typedef tecoInt tecoBool; namespace Flags { enum { + ED_AUTOCASEFOLD = (1 << 3), ED_AUTOEOL = (1 << 4), ED_HOOKS = (1 << 5), ED_FNKEYS = (1 << 6), |