zsh-users
 help / color / mirror / code / Atom feed
From: Bart Schaefer <schaefer@brasslantern.com>
To: zsh-users@zsh.org
Subject: Re: priority problem of ":|" and ":*"
Date: Wed, 26 Dec 2012 01:10:19 -0800	[thread overview]
Message-ID: <121226011019.ZM32249@torch.brasslantern.com> (raw)
In-Reply-To: <20121225231133.GA8145@localhost.localdomain>

On Dec 26,  7:11am, Han Pingtian wrote:
}
} >     % a1=(a b c);a2=('a b c');print "${#a1:|a2}"
} >     3
} > 
} > in this, the priority should be "5 Double-quoted joining" first, then "7
} > modifiers", then "9 length". So 'print "${#a1:|a2}"' should output 0 I
} > think. And the ":*" has the same problem. 

Hmm.

% a1=(a b c); print "${#a1}" :"${a1}":
3 :a b c:

Plainly if length were applied after double-quoted joining, the above
should print 5 rather than 3.  As I'm pretty sure this hasn't changed
*ever*, it must be that the documentation is wrong, not that :| has the
wrong priority.

And in fact poring through the code it appears that rule 5 double-quoted
joining is explicitly SKIPPED when the length is requested:

    if (isarr) {
        if (nojoin)
            isarr = -1;
        if (qt && !getlen && isarr > 0) {
            val = sepjoin(aval, sep, 1);
            isarr = 0;
        }
    }

"qt" there means double-quoted, but "getlen" means the "#" was seen.  So
when evaluating length, we do not remove arrayness.

} For the ":*", we have this result:
} 
}     % a1=(a b c);a2=(a b c);print "${#a1:*a2}"
}     3

This is consistent with the above.

I admit that this is not intuitive when applying operations to the members
of the array, but it's the way #, ##, %, %%, and :# have always worked, so
it's a bit late to change it and arguably worse to make it different for
:| and :*.  (My sympathies if anyone's mail reader is too clever by half
and renders a lot of that as emoticons.)


  reply	other threads:[~2012-12-26  9:10 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-12-24 10:52 Han Pingtian
2012-12-25 23:11 ` Han Pingtian
2012-12-26  9:10   ` Bart Schaefer [this message]
2012-12-26 10:09     ` Han Pingtian
2012-12-27  6:24       ` Bart Schaefer
2012-12-27  9:06         ` Han Pingtian
2012-12-26 16:44     ` Ray Andrews

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=121226011019.ZM32249@torch.brasslantern.com \
    --to=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).