-
-
Notifications
You must be signed in to change notification settings - Fork 356
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature Req: Directive to make parser skip over lines. #960
Comments
You seem to be taking advantage of the fact that bash does lazy parsing. The part after On one hand, if a shell script parses and works in Bash, I generally want it to parse without errors with our parser. On the other hand, I have to draw a line in the sand somewhere. Bash's parser is fairly lazy and forgiving, and our parser wouldn't be very useful if it did the same :) I wonder if #120 would be a solution for you. If you use a script which mixes bash and zsh, and presumably zsh's syntax has more features than bash's, then perhaps you should parse and format in a future zsh mode rather than bash. I imagine zsh is not actually a superset of bash syntax-wise, but since you're writing a script that is somewhere between the two, I imagine parsing in a zsh mode would be good enough. |
Hi, And yes, a zsh mode would prbly(!) parse the whole script but I guess there are bash constructs which zsh does NOT support. Not sure, I use zsh only for the REPL, like most of us. Reading #120, I see you really want to support zsh. My gut feeling tells me, that in the process you'll prbly want to support an "ignore this/next line" directive anyways ;-) |
Let's close this in favor of #120. I may be proven wrong about not needing a "skip this line" directive, but I really want to exhaust all options. As a solution, it would feel like a very hacky workaround. |
Ok, happy coding - for zsh you'll need endurance. For my specific problem I think the way to go is not set a script (with 95% bash code but sourceable also in zsh) to zsh syntax, looking at this (good) list of differences here: https://hyperpolyglot.org/unix-shells - there will be incompatibilites. The way to go is to find out the dir of the script with code which is bash compatible but works in zsh as well (i.e. the $0, not the % syntax) - and then source a zsh specific helper script when zsh is it, and zsh specific syntax is required: if [ -n "$ZSH_VERSION" ]; then . "$here/zsh_funcs"; fi It's an additional file but one death we have to die, mixing 2 languages in one file is also not exactly nice. Thanks again! |
Hi,
first of all thanks for your work!
in #680 you write:
and I wanted to further motivate the idea:
I have a script which can be sourced OR run. When sourced it just does a few simple things which work in zsh OR bash, so I'd like to have it work in both shells.
Problem: To find the script location when sourced I need an assignment which violates bash (but works in zsh):
And that makes shfmt deny formatting the whole file.
Edit: Yes
$0
would work outside of functions in zsh and that would be compatible with bash syntax, still the above one has some advantages, I assume there are other such crazies.-> An ignore directive would, imho, have some use cases.
The text was updated successfully, but these errors were encountered: