zsh-workers
 help / color / mirror / code / Atom feed
From: Nikita Romanyuk <ufh8945@gmail.com>
To: Mikael Magnusson <mikachu@gmail.com>
Cc: zsh-workers@zsh.org
Subject: Re: [PATCH] correct: add support for colemak layout
Date: Fri, 10 Mar 2023 07:47:23 +0300	[thread overview]
Message-ID: <56087c9f-b450-1520-37d9-6209f681d960@gmail.com> (raw)
In-Reply-To: <CAHYJk3ShpoS_QbVYCVsejm9003ahcedE06Tc=-MirbmNTWM-wg@mail.gmail.com>

If I understood correctly, we shouldn't use setopt for changing keyboard 
layouts because it's not expandable. Better, there should be a separate 
builtin function. How should it be called? "setlayout"? "setkblayout"?


Thanks, I didn't put any brain activity into this enum.

> OPT_SIZE should always go last in this list.

I'm going to send another patch later, but with these options as builtins.


On 3/10/23 06:37, Mikael Magnusson wrote:
> On 3/9/23, Nikita Romanyuk <ufh8945@gmail.com> wrote:
>> Colemak is a modern alternative to the QWERTY and Dvorak layouts,
>> designed for efficient and ergonomic touch typing in English.
> It would be nice to not introduce another weird tri-state thing here,
> eg what should happen when both dvorak and colemak are set, why is
> qwerty not a named option, etc. Perhaps it would be nicer to just let
> the user set the layout in some special (namespaced?) parameter for
> scalability and deprecate the dvorak option. We could have some helper
> function in the distribution that sets this parameter for various
> known layouts.
>
>> Signed-off-by: Nikita Romanyuk <ufh8945@gmail.com>
>> ---
>>   Doc/Zsh/options.yo |  8 ++++++++
>>   Src/options.c      |  1 +
>>   Src/utils.c        | 14 ++++++++++++++
>>   Src/zsh.h          |  3 ++-
>>   4 files changed, 25 insertions(+), 1 deletion(-)
>>
>> diff --git a/Doc/Zsh/options.yo b/Doc/Zsh/options.yo
>> index 443676b..cda4b33 100644
>> --- a/Doc/Zsh/options.yo
>> +++ b/Doc/Zsh/options.yo
>> @@ -1235,6 +1235,14 @@ Use the Dvorak keyboard instead of the standard
>> qwerty keyboard as a basis
>>   for examining spelling mistakes for the tt(CORRECT) and tt(CORRECT_ALL)
>>   options and the tt(spell-word) editor command.
>>   )
>> +pindex(COLEMAK)
>> +pindex(NO_COLEMAK)
>> +pindex(NOCOLEMAK)
>> +item(tt(COLEMAK))(
>> +Use the Colemak keyboard instead of the standard qwerty keyboard as a
>> basis
>> +for examining spelling mistakes for the tt(CORRECT) and tt(CORRECT_ALL)
>> +options and the tt(spell-word) editor command.
>> +)
>>   pindex(FLOW_CONTROL)
>>   pindex(NO_FLOW_CONTROL)
>>   pindex(FLOWCONTROL)
>> diff --git a/Src/options.c b/Src/options.c
>> index a1fe918..8f9fe85 100644
>> --- a/Src/options.c
>> +++ b/Src/options.c
>> @@ -280,6 +280,7 @@ static struct optname optns[] = {
>>   {{NULL, "stdin",	      OPT_ALIAS}, /* ksh */	 SHINSTDIN},
>>   {{NULL, "trackall",	      OPT_ALIAS}, /* ksh */	 HASHCMDS},
>>   {{NULL, "dvorak",	      0},			 DVORAK},
>> +{{NULL, "colemak",	      0},			 COLEMAK},
>>   {{NULL, NULL, 0}, 0}
>>   };
>>
>> diff --git a/Src/utils.c b/Src/utils.c
>> index 62bd3e6..b3d09d7 100644
>> --- a/Src/utils.c
>> +++ b/Src/utils.c
>> @@ -4607,10 +4607,24 @@ spdist(char *s, char *t, int thresh)
>>   \t\"<>PYFGCRL?+\t\
>>   \tAOEUIDHTNS_\n\t\
>>   \t:QJKXBMWVZ\n\n\t\
>> +\n\n\n\n\n\n\n\n\n\n\n\n\n\n";
>> +    const char colemakkeymap[] =
>> +    "\n\n\n\n\n\n\n\n\n\n\n\n\n\n\
>> +\t1234567890-=\t\
>> +\tqwfpgjluy;[]\t\
>> +\tarstdhneio'\n\t\
>> +\tzxcvbkm,./\t\t\t\
>> +\n\n\n\n\n\n\n\n\n\n\n\n\n\n\
>> +\t!@#$%^&*()_+\t\
>> +\tQWFPGJLUY:{}\t\
>> +\tARSTDHNEIO\"\n\t\
>> +\tZXCVBKM<>?\n\n\t\
>>   \n\n\n\n\n\n\n\n\n\n\n\n\n\n";
>>       const char *keymap;
>>       if ( isset( DVORAK ) )
>>         keymap = dvorakkeymap;
>> +    else if ( isset( COLEMAK ) )
>> +      keymap = colemakkeymap;
>>       else
>>         keymap = qwertykeymap;
>>
>> diff --git a/Src/zsh.h b/Src/zsh.h
>> index 40f9ea5..93f3c8c 100644
>> --- a/Src/zsh.h
>> +++ b/Src/zsh.h
>> @@ -2547,7 +2547,8 @@ enum {
>>       XTRACE,
>>       USEZLE,
>>       DVORAK,
>> -    OPT_SIZE
>> +    OPT_SIZE,
>> +    COLEMAK
> OPT_SIZE should always go last in this list.
>
>>   };
>>
>>   /*
>> --
>> 2.39.2
>>
>>
>>
>


  reply	other threads:[~2023-03-10  4:47 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-03-09 17:43 Nikita Romanyuk
2023-03-10  3:37 ` Mikael Magnusson
2023-03-10  4:47   ` Nikita Romanyuk [this message]
2023-03-10  5:13     ` Bart Schaefer
2023-03-10  5:18       ` Kelvium
2023-03-11 23:17         ` Bart Schaefer
2023-03-12  6:47           ` Nikita Romanyuk
2023-03-10  5:07   ` Bart Schaefer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=56087c9f-b450-1520-37d9-6209f681d960@gmail.com \
    --to=ufh8945@gmail.com \
    --cc=mikachu@gmail.com \
    --cc=zsh-workers@zsh.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/zsh/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).