Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
Re: Any way to have ".sh" be optional?
- X-seq: zsh-users 18009
- From: TJ Luoma <luomat@xxxxxxxxx>
- To: Micah Elliott <mde@xxxxxxxxxxxxxxxx>
- Subject: Re: Any way to have ".sh" be optional?
- Date: Thu, 26 Sep 2013 19:35:21 -0400
- Cc: Zsh-Users List <zsh-users@xxxxxxx>
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-type:content-transfer-encoding; bh=4cxTfRUPvb+u4KBh61qPMjryjcUH1QRzqrDU168qFU0=; b=r23XATGWSZgjD67fQH38H6W5HdfznbbS/5Rts4pRJQXSF7wo3AZk9ihgfkdkbPrgsP DqT8aMkS06HrZ9BhI2s0qM4UbEsVbtjM2lXsxnvGEuvBpli2+C8yvEFJ9U0/m0ay95Uc E7mjKk0B2N6KdRTC5wL9YSg+zVdHNueyHb4ALT6jgTyxN9LtZav3goczzB8VnrXYPdOc 6YcYDiMUFmHIPx6UGPdBnCWUvb4ByCZtfTrwVNM8oQawcBw3dBq1Fk6nX8pLPHp8rHyl CtCL7QIm+o+kGBtTxwCp2j25P0q+KYpaNfi3gCTFCz+9AVgbh+fv7pET0CNeLQrmft/q QZdA==
- In-reply-to: <CAELbujqMfX7Sgrr=JtJ8HZey6N4TwfyvS44J1XPvJJ3sOFs4=w@mail.gmail.com>
- List-help: <mailto:zsh-users-help@zsh.org>
- List-id: Zsh Users List <zsh-users.zsh.org>
- List-post: <mailto:zsh-users@zsh.org>
- Mailing-list: contact zsh-users-help@xxxxxxx; run by ezmlm
- References: <CADjGqHsrd8K=rW6dyDxwddYMu-iG6tmNMMj0HtJZ6SVQksWmCw@mail.gmail.com> <CAELbujqMfX7Sgrr=JtJ8HZey6N4TwfyvS44J1XPvJJ3sOFs4=w@mail.gmail.com>
On Thu, Sep 26, 2013 at 5:27 PM, Micah Elliott <mde@xxxxxxxxxxxxxxxx> wrote:
>
> On Thu, Sep 26, 2013 at 1:12 PM, TJ Luoma <luomat@xxxxxxxxx> wrote:
> >
> > I tend to name all of my Zsh scripts to end with '.sh' so I can easily
> > `fgrep -i Whatever *.sh` when I'm looking for something.
>
> Cool, I tend to use .zsh, but mostly so I know they're not system scripts.
Mine are all in ~/Dropbox/bin/ (which I've added to $PATH) so I know
they aren't system scripts, and since my Dropbox only syncs between
Macs I don't have to worry about cross platform script compatibility
but I always have all of my scripts on all of my Macs :-)
> > However, I would rather not have to type the ".sh" if not necessary. (Yes, I
> > am that lazy.)
>
> Leaving out the .«tab» saves a little bit of typing. But you might have
> already fully tab-completed a couple chars in.
Yup, I use 'tab' whenever possible to autocomplete. The problem is
that I have recently converted some functions (which did not have
".sh" suffix) to scripts, mostly so I can call them from other scripts
without putting them into .zsh(rc|env) but 'muscle memory' keeps me
typing them the old way.
> > is there a way to tell zsh "If I use the command 'foo' and there is no 'foo'
> > but there is 'foo.sh' then I want to use 'foo.sh'?
>
> You could tie into the command_not_found_hook (briefly mentioned in
> zshmisc(1)). Something like this:
>
> command_not_found_handler() {
> actual=$@[1].sh
> print "Proxying for actual: $actual"
> for p in $path; do
> if [[ -x $p/$actual ]]; then
> $actual $@[2,-1]
> break
> fi
> done
> }
FYI this worked perfectly for me, and I love the touch of having it
remind me that this is catching me when I type something incorrectly,
which is more likely to help me remember to do it correctly in the
future. I think. Theoretically. I definitely like what it does,
regardless of its actual effect on my habits.
> * I don't actually do this, but maybe I'll try; the func is not really
> tested
Worked as expected for me.
> * zsh syntax highlighting
> (https://github.com/zsh-users/zsh-syntax-highlighting) won't match foo
I don't use that but now I'm going to head over and see what else is there :-)
> * running in cwd as ./foo isn't handled
It is extremely unlikely that I would ever do `./foo` anyway.
> * not sure if looping over path is best approach; would something with
> hash work?
It was certainly fast enough for me that I wouldn't spend time trying
to optimize it. Even if it was slow it would be another way that maybe
it would push me towards correcting my habit of mistyping.
Thanks again.
Tj
Messages sorted by:
Reverse Date,
Date,
Thread,
Author