-
-
Notifications
You must be signed in to change notification settings - Fork 426
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
postinstall incompatible with Windows #212
Closed
Comments
binki
added a commit
to binki/lint-staged
that referenced
this issue
Jul 14, 2017
Wow that's a detailed bug report. I wish all issues were like this one 💯 |
okonet
pushed a commit
that referenced
this issue
Jul 17, 2017
It kind of was a rant, sorry xD. Thanks for accepting the simple solution. |
This was referenced Oct 19, 2017
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
As you can see,
cmd
’sECHO
does not treat"
as a string delimiter in the same way thatsh
does. As a result, the"
is printed in the output and only the first line is displayed.Additionally,
&& exit 0
seems redundant.If you want to use an
echo
that behaves consistently cross-platform, should either remove the double-quotes and use two echo commands:or, if you really want to surround the content of your messages in double-quotes, then use shx’s
echo
(note that single-quotes around arguments do not work on Windows):Double Quotes Unnecessary/Wrong
You might wonder why the exclamation mark (
!
) doesn’t cause any problems forsh
(unix). That is because!
is only a special character in interactive shells where history expansion is enabled by default. Also, it only causes an error if there is no whitespace after it. So if you use!
that in a terminal, you will get an error. But not in a shellout:Also, double quotes are wrong on Windows because Windows passes the whole command line as a single string. This means that splitting a command’s parameters into separate arguments and globbing is performed by the invoked application. Which in turn means that different commands implement different string splitting/quoting rules.
ECHO
literally prints everything passed unless if nothing is passed, in which caseECHO is ON
orOFF
is printed (to print a blank line, you doECHO.
[sic]).Postinstall Pointless
Also, one could argue that if a developer installs this package, they could be expected to look up the documentation on how to use it without prompting. Note that
postinstall
runs even when the user just typesnpm install
, so thepostinstall
runs even for projects which already are configured or even when it is an indirect dependency. So is there even a point in apostinstall
step that prints stuff out like this? Maybe the best change to improve portability of the package by increasing the similarity of install behavior on different platforms would be to just remove thepostinstall
script.The text was updated successfully, but these errors were encountered: