zsh-users
 help / color / mirror / code / Atom feed
From: Sebastian Gniazdowski <sgniazdowski@gmail.com>
To: Bart Schaefer <schaefer@brasslantern.com>
Cc: Zsh Users <zsh-users@zsh.org>
Subject: Re: Nice in-word incremental history word searcher
Date: Thu, 21 Jan 2016 10:11:34 +0100	[thread overview]
Message-ID: <CAKc7PVAEP+HCizGzEZQiAXUhkxKrSd4TO6qetO6in3BoZ2O67Q@mail.gmail.com> (raw)
In-Reply-To: <160120213253.ZM22536@torch.brasslantern.com>

On 21 January 2016 at 06:32, Bart Schaefer <schaefer@brasslantern.com> wrote:
>     --- 8< --- snip --- 8< ---
> 19  local buf="$1"
> 20  local cursor="$CURSOR"
> 21  [ -n "$2" ] && cursor="$2"
> 22
> 23  ZEW_PB_WORDS=( "${(Z+n+)BUFFER}" )
>     --- 8< --- snip --- 8< ---
>
> You could replace lines 20 and 21 with
>
>     local cursor="${2:-$CURSOR}"

Thanks, done that

> Shouldn't line 23 say
>
>     ZEW_PB_WORDS=( "${(Z+n+)buf}" )
>
> ??

True, corrected that, thanks

> And therefore why is line 19 not
>
>     local buf="${1:-$BUFFER}"
>
> ??

Nice idea to have $1 and $2 all optional, done that

> This on line 72:
>
>   [[ "$ZEW_PB_SELECTED_WORD" -eq "-1" && "$char_count" -gt "$cursor" ]]
>
> Could be this:
>
>   (( ZEW_PB_SELECTED_WORD == -1 && char_count > cursor ))

Recently I started to introduce (( )) to conditional expressions,
could replace this to, but comments can nicely refer to "-gt", "-ge"
so I'll leave them as they are

> On line 81, this:
>
>     char_count=char_count+"$#buf"
>
> depends on the zsh semantics of assignment to an declared integer.  It
> might be better to explicitly use math context:
>
>     (( char_count = char_count + $#buf ))
>

I like utilizing integer declaration and then the semantics, rarely
use (( )), if I do then mostly as "integer i=$(( ))" when I need to
assign a value computed with use of parenthesis – "integer i=(a-b)*c"
will return error, doing "0+..." trick doesn't help (it helps when not
declaring but using already declared integer), so I do "integer i=$((
(a-b)*c )). Also, like the *SELECTED_WORD variable, I don't declare
globals as integers, so in such case if computation is needed I use ((
)). This makes some distinctions in code, allows to quickly
differentiate between integers and normal variables / globals. It's
not what I truly planned and I still experiment, but it rather works.

> First, you used the old [ ... ] test everywhere instead of [[ ... ]].
> Any particular reason?

Rather not, I just didn't want to depart from sh too much too fast. I
might switch to [[ ]] after year of testing what pitfalls [ ] can have
(and there are rather none), but on other hand, using [[ ]] only when
it's needed helps reading the code, user can expect simplicity in [ ]
and sophistication in [[ ]]. Is there a reason to always use [[ ?

> Second, I think you've partly missed the point of custom keymaps.  I
> imagine you copied the caps-lock example from the recursive-edit doc,
> but there's actually a better way now (that example could be redone):
>
> Instead of overriding self-insert et al. in the main keymap and then
> restoring them, you can do the same thing as with the zhcw keymap:
> Create (once) a copy of the main keymap, install your new bindings
> for self-insert etc., in that copy, and then when you want to use the
> new keymap, switch to it with "zle -K".

Saw your next email, seems that I could bind backspace and delete, and
leave self-insert as it is.

Best regards,
Sebastian Gniazdowski


      parent reply	other threads:[~2016-01-21  9:12 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-01-20 20:14 Sebastian Gniazdowski
2016-01-21  5:32 ` Bart Schaefer
2016-01-21  7:03   ` Bart Schaefer
2016-01-21  9:11   ` Sebastian Gniazdowski [this message]

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=CAKc7PVAEP+HCizGzEZQiAXUhkxKrSd4TO6qetO6in3BoZ2O67Q@mail.gmail.com \
    --to=sgniazdowski@gmail.com \
    --cc=schaefer@brasslantern.com \
    --cc=zsh-users@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).