* [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe @ 2015-08-11 20:51 Johannes Sixt 2015-08-11 22:50 ` Eric Sunshine 2015-08-12 11:07 ` Johannes Schindelin 0 siblings, 2 replies; 12+ messages in thread From: Johannes Sixt @ 2015-08-11 20:51 UTC (permalink / raw) To: Git Mailing List, msysGit Invoking plink requires special treatment, and we have support and even test cases for the commands 'plink' and 'tortoiseplink'. We also support .exe variants for these two and there is a test for 'plink.exe'. On Windows, however, where support for plink.exe would be relevant, the test case fails because it is not possible to execute a file with a .exe extension that is actually not a binary executable---it is a shell script in our test. We have to disable the test case on Windows. Considering, that 'plink.exe' is irrelevant on non-Windows, let's just remove the test and assume that the code "just works". Signed-off-by: Johannes Sixt <j6t@kdbg.org> --- t/t5601-clone.sh | 6 ------ 1 file changed, 6 deletions(-) diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh index 9b34f3c..df69bf6 100755 --- a/t/t5601-clone.sh +++ b/t/t5601-clone.sh @@ -353,12 +353,6 @@ test_expect_success 'plink is treated specially (as putty)' ' expect_ssh "-P 123" myhost src ' -test_expect_success 'plink.exe is treated specially (as putty)' ' - copy_ssh_wrapper_as "$TRASH_DIRECTORY/plink.exe" && - git clone "[myhost:123]:src" ssh-bracket-clone-plink-1 && - expect_ssh "-P 123" myhost src -' - test_expect_success 'tortoiseplink is like putty, with extra arguments' ' copy_ssh_wrapper_as "$TRASH_DIRECTORY/tortoiseplink" && git clone "[myhost:123]:src" ssh-bracket-clone-plink-2 && -- 2.3.2.245.gb5bf9d3 -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-11 20:51 [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe Johannes Sixt @ 2015-08-11 22:50 ` Eric Sunshine 2015-08-11 22:53 ` Junio C Hamano 2015-08-11 22:56 ` [msysGit] " Junio C Hamano 2015-08-12 11:07 ` Johannes Schindelin 1 sibling, 2 replies; 12+ messages in thread From: Eric Sunshine @ 2015-08-11 22:50 UTC (permalink / raw) To: Johannes Sixt; +Cc: Git Mailing List, msysGit On Tue, Aug 11, 2015 at 4:51 PM, Johannes Sixt <j6t@kdbg.org> wrote: > Invoking plink requires special treatment, and we have support and even > test cases for the commands 'plink' and 'tortoiseplink'. We also support > .exe variants for these two and there is a test for 'plink.exe'. > > On Windows, however, where support for plink.exe would be relevant, the > test case fails because it is not possible to execute a file with a .exe > extension that is actually not a binary executable---it is a shell > script in our test. We have to disable the test case on Windows. > > Considering, that 'plink.exe' is irrelevant on non-Windows, let's just > remove the test and assume that the code "just works". putty and plink are used on Unix as well. A quick check of Mac OS X, Linux, and FreeBSD reveals that package managers on each platform have putty and plink packages available. > Signed-off-by: Johannes Sixt <j6t@kdbg.org> > --- > t/t5601-clone.sh | 6 ------ > 1 file changed, 6 deletions(-) > > diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh > index 9b34f3c..df69bf6 100755 > --- a/t/t5601-clone.sh > +++ b/t/t5601-clone.sh > @@ -353,12 +353,6 @@ test_expect_success 'plink is treated specially (as putty)' ' > expect_ssh "-P 123" myhost src > ' > > -test_expect_success 'plink.exe is treated specially (as putty)' ' > - copy_ssh_wrapper_as "$TRASH_DIRECTORY/plink.exe" && > - git clone "[myhost:123]:src" ssh-bracket-clone-plink-1 && > - expect_ssh "-P 123" myhost src > -' > - > test_expect_success 'tortoiseplink is like putty, with extra arguments' ' > copy_ssh_wrapper_as "$TRASH_DIRECTORY/tortoiseplink" && > git clone "[myhost:123]:src" ssh-bracket-clone-plink-2 && > -- > 2.3.2.245.gb5bf9d3 -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-11 22:50 ` Eric Sunshine @ 2015-08-11 22:53 ` Junio C Hamano 2015-08-11 22:56 ` [msysGit] " Junio C Hamano 1 sibling, 0 replies; 12+ messages in thread From: Junio C Hamano @ 2015-08-11 22:53 UTC (permalink / raw) To: Eric Sunshine; +Cc: Johannes Sixt, Git Mailing List, msysGit Eric Sunshine <sunshine@sunshineco.com> writes: > On Tue, Aug 11, 2015 at 4:51 PM, Johannes Sixt <j6t@kdbg.org> wrote: >> Invoking plink requires special treatment, and we have support and even >> test cases for the commands 'plink' and 'tortoiseplink'. We also support >> .exe variants for these two and there is a test for 'plink.exe'. >> >> On Windows, however, where support for plink.exe would be relevant, the >> test case fails because it is not possible to execute a file with a .exe >> extension that is actually not a binary executable---it is a shell >> script in our test. We have to disable the test case on Windows. >> >> Considering, that 'plink.exe' is irrelevant on non-Windows, let's just >> remove the test and assume that the code "just works". > > putty and plink are used on Unix as well. A quick check of Mac OS X, > Linux, and FreeBSD reveals that package managers on each platform have > putty and plink packages available. ... so we should do the same !MINGW prereq instead? > >> Signed-off-by: Johannes Sixt <j6t@kdbg.org> >> --- >> t/t5601-clone.sh | 6 ------ >> 1 file changed, 6 deletions(-) >> >> diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh >> index 9b34f3c..df69bf6 100755 >> --- a/t/t5601-clone.sh >> +++ b/t/t5601-clone.sh >> @@ -353,12 +353,6 @@ test_expect_success 'plink is treated specially (as putty)' ' >> expect_ssh "-P 123" myhost src >> ' >> >> -test_expect_success 'plink.exe is treated specially (as putty)' ' >> - copy_ssh_wrapper_as "$TRASH_DIRECTORY/plink.exe" && >> - git clone "[myhost:123]:src" ssh-bracket-clone-plink-1 && >> - expect_ssh "-P 123" myhost src >> -' >> - >> test_expect_success 'tortoiseplink is like putty, with extra arguments' ' >> copy_ssh_wrapper_as "$TRASH_DIRECTORY/tortoiseplink" && >> git clone "[myhost:123]:src" ssh-bracket-clone-plink-2 && >> -- >> 2.3.2.245.gb5bf9d3 > -- > To unsubscribe from this list: send the line "unsubscribe git" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [msysGit] [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-11 22:50 ` Eric Sunshine 2015-08-11 22:53 ` Junio C Hamano @ 2015-08-11 22:56 ` Junio C Hamano 2015-08-11 23:26 ` Eric Sunshine 1 sibling, 1 reply; 12+ messages in thread From: Junio C Hamano @ 2015-08-11 22:56 UTC (permalink / raw) To: Eric Sunshine; +Cc: Johannes Sixt, Git Mailing List, msysGit Eric Sunshine <sunshine@sunshineco.com> writes: > On Tue, Aug 11, 2015 at 4:51 PM, Johannes Sixt <j6t@kdbg.org> wrote: >> Invoking plink requires special treatment, and we have support and even >> test cases for the commands 'plink' and 'tortoiseplink'. We also support >> .exe variants for these two and there is a test for 'plink.exe'. >> >> On Windows, however, where support for plink.exe would be relevant, the >> test case fails because it is not possible to execute a file with a .exe >> extension that is actually not a binary executable---it is a shell >> script in our test. We have to disable the test case on Windows. >> >> Considering, that 'plink.exe' is irrelevant on non-Windows, let's just >> remove the test and assume that the code "just works". > > putty and plink are used on Unix as well. A quick check of Mac OS X, > Linux, and FreeBSD reveals that package managers on each platform have > putty and plink packages available. But they do not force their users to say "plink.exe", but instead let them invoke "plink", no? The test before the one that was removed is about "plink" (sans .exe), and what was removed is with ".exe", so I think J6t's patch is OK. Or am I still missing something? > >> Signed-off-by: Johannes Sixt <j6t@kdbg.org> >> --- >> t/t5601-clone.sh | 6 ------ >> 1 file changed, 6 deletions(-) >> >> diff --git a/t/t5601-clone.sh b/t/t5601-clone.sh >> index 9b34f3c..df69bf6 100755 >> --- a/t/t5601-clone.sh >> +++ b/t/t5601-clone.sh >> @@ -353,12 +353,6 @@ test_expect_success 'plink is treated specially (as putty)' ' >> expect_ssh "-P 123" myhost src >> ' >> >> -test_expect_success 'plink.exe is treated specially (as putty)' ' >> - copy_ssh_wrapper_as "$TRASH_DIRECTORY/plink.exe" && >> - git clone "[myhost:123]:src" ssh-bracket-clone-plink-1 && >> - expect_ssh "-P 123" myhost src >> -' >> - >> test_expect_success 'tortoiseplink is like putty, with extra arguments' ' >> copy_ssh_wrapper_as "$TRASH_DIRECTORY/tortoiseplink" && >> git clone "[myhost:123]:src" ssh-bracket-clone-plink-2 && >> -- >> 2.3.2.245.gb5bf9d3 > -- > To unsubscribe from this list: send the line "unsubscribe git" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-11 22:56 ` [msysGit] " Junio C Hamano @ 2015-08-11 23:26 ` Eric Sunshine 0 siblings, 0 replies; 12+ messages in thread From: Eric Sunshine @ 2015-08-11 23:26 UTC (permalink / raw) To: Junio C Hamano; +Cc: Johannes Sixt, Git Mailing List, msysGit On Tue, Aug 11, 2015 at 6:56 PM, Junio C Hamano <gitster@pobox.com> wrote: > Eric Sunshine <sunshine@sunshineco.com> writes: > >> On Tue, Aug 11, 2015 at 4:51 PM, Johannes Sixt <j6t@kdbg.org> wrote: >>> Invoking plink requires special treatment, and we have support and even >>> test cases for the commands 'plink' and 'tortoiseplink'. We also support >>> .exe variants for these two and there is a test for 'plink.exe'. >>> >>> On Windows, however, where support for plink.exe would be relevant, the >>> test case fails because it is not possible to execute a file with a .exe >>> extension that is actually not a binary executable---it is a shell >>> script in our test. We have to disable the test case on Windows. >>> >>> Considering, that 'plink.exe' is irrelevant on non-Windows, let's just >>> remove the test and assume that the code "just works". >> >> putty and plink are used on Unix as well. A quick check of Mac OS X, >> Linux, and FreeBSD reveals that package managers on each platform have >> putty and plink packages available. > > But they do not force their users to say "plink.exe", but instead > let them invoke "plink", no? > > The test before the one that was removed is about "plink" (sans .exe), > and what was removed is with ".exe", so I think J6t's patch is OK. Ah, you're correct. I overlooked the extra emphasis j6t's commit message placed on ".exe". -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-11 20:51 [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe Johannes Sixt 2015-08-11 22:50 ` Eric Sunshine @ 2015-08-12 11:07 ` Johannes Schindelin 2015-08-12 11:58 ` [msysGit] " Erik Faye-Lund 1 sibling, 1 reply; 12+ messages in thread From: Johannes Schindelin @ 2015-08-12 11:07 UTC (permalink / raw) To: Johannes Sixt; +Cc: Git Mailing List, msysGit Hi Johannes, On 2015-08-11 22:51, Johannes Sixt wrote: > Invoking plink requires special treatment, and we have support and even > test cases for the commands 'plink' and 'tortoiseplink'. We also support > .exe variants for these two and there is a test for 'plink.exe'. > > On Windows, however, where support for plink.exe would be relevant, the > test case fails because it is not possible to execute a file with a .exe > extension that is actually not a binary executable---it is a shell > script in our test. We have to disable the test case on Windows. Oh how would I wish you were working on Git for Windows even *just* a bit *with* me. At least I would wish for a more specific description of the development environment, because it sure as hell is not anything anybody can download and install as easily as Git for Windows' SDK. FWIW Git for Windows has this patch (that I wanted to contribute in due time, what with being busy with all those tickets) to solve the problem mentioned in your patch in a different way: https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 Please read this as my vote not to remove the test cases. Thanks, Johannes ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [msysGit] Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-12 11:07 ` Johannes Schindelin @ 2015-08-12 11:58 ` Erik Faye-Lund 2015-08-12 18:31 ` Johannes Sixt 2015-08-13 8:37 ` Johannes Schindelin 0 siblings, 2 replies; 12+ messages in thread From: Erik Faye-Lund @ 2015-08-12 11:58 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Johannes Sixt, Git Mailing List, msysGit On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin <johannes.schindelin@gmx.de> wrote: > Hi Johannes, > > On 2015-08-11 22:51, Johannes Sixt wrote: >> Invoking plink requires special treatment, and we have support and even >> test cases for the commands 'plink' and 'tortoiseplink'. We also support >> .exe variants for these two and there is a test for 'plink.exe'. >> >> On Windows, however, where support for plink.exe would be relevant, the >> test case fails because it is not possible to execute a file with a .exe >> extension that is actually not a binary executable---it is a shell >> script in our test. We have to disable the test case on Windows. > > Oh how would I wish you were working on Git for Windows even *just* a bit *with* me. At least I would wish for a more specific description of the development environment, because it sure as hell is not anything anybody can download and install as easily as Git for Windows' SDK. > > FWIW Git for Windows has this patch (that I wanted to contribute in due time, what with being busy with all those tickets) to solve the problem mentioned in your patch in a different way: > > https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 Yuck. On Windows, it's the extension of a file that dictates what kind of file it is (and if it's executable or not), not the contents. If we get a shell script written with the ".exe"-prefix, it's considered as an invalid executable by the system. We should consider it the same way, otherwise we're on the path to user-experience schizophrenia. I'm not sure I consider this commit a step in the right direction. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [msysGit] Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-12 11:58 ` [msysGit] " Erik Faye-Lund @ 2015-08-12 18:31 ` Johannes Sixt 2015-08-13 7:30 ` Johannes Schindelin 2015-08-13 8:37 ` Johannes Schindelin 1 sibling, 1 reply; 12+ messages in thread From: Johannes Sixt @ 2015-08-12 18:31 UTC (permalink / raw) To: kusmabite, Johannes Schindelin; +Cc: Git Mailing List, msysGit Am 12.08.2015 um 13:58 schrieb Erik Faye-Lund: > On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin > <johannes.schindelin@gmx.de> wrote: >> FWIW Git for Windows has this patch (that I wanted to contribute >> in due time, what with being busy with all those tickets) to solve the >> problem mentioned in your patch in a different way: >> >> https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 > > Yuck. On Windows, it's the extension of a file that dictates what kind > of file it is (and if it's executable or not), not the contents. If we > get a shell script written with the ".exe"-prefix, it's considered as > an invalid executable by the system. We should consider it the same > way, otherwise we're on the path to user-experience schizophrenia. > > I'm not sure I consider this commit a step in the right direction. I, too, think that it is a wrong decision to pessimize git for the sake of a single test case. -- Hannes ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-12 18:31 ` Johannes Sixt @ 2015-08-13 7:30 ` Johannes Schindelin 2015-08-13 18:07 ` [msysGit] " Johannes Sixt 0 siblings, 1 reply; 12+ messages in thread From: Johannes Schindelin @ 2015-08-13 7:30 UTC (permalink / raw) To: Johannes Sixt; +Cc: kusmabite, Git Mailing List, msysGit Hi Johannes, On 2015-08-12 20:31, Johannes Sixt wrote: > Am 12.08.2015 um 13:58 schrieb Erik Faye-Lund: >> On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin >> <johannes.schindelin@gmx.de> wrote: >>> FWIW Git for Windows has this patch (that I wanted to contribute >>> in due time, what with being busy with all those tickets) to solve the >>> problem mentioned in your patch in a different way: >>> >>> https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 >> >> Yuck. On Windows, it's the extension of a file that dictates what kind >> of file it is (and if it's executable or not), not the contents. If we >> get a shell script written with the ".exe"-prefix, it's considered as >> an invalid executable by the system. We should consider it the same >> way, otherwise we're on the path to user-experience schizophrenia. >> >> I'm not sure I consider this commit a step in the right direction. > > I, too, think that it is a wrong decision to pessimize git for the > sake of a single test case. Oh, you make it sound as if you believe that I had indeed weakened Git *just* for a single test case. That is quite a strong assumption, and could not be further from the truth, though, I have to point out. It is important to keep in mind that we (actually, IIRC it was you) taught Git to recognize shell scripts when executing external programs *because Windows does not do that for us*. So yes, we are deviating from the standard Windows way of things, and we do that quite intentionally so. Now, let's look at the test case for a moment and let's try to understand the technique it uses (that breaks the test case currently). It puts a script in place of an `.exe`, with the intention to execute the script instead of the original executable. This technique is an age-old technique on Unix, and it just works. There are a range of valid reasons, from debugging to slightly modifying the function of a particular `.exe` (possibly renaming the original `.exe` and calling it from the script) in the easiest way: by scripting on top of it. If we want to allow such a thing -- allowing users to use scripts to modify the behavior of executables -- then we *have* to allow `.exe` suffixes for scripts, because that happens to be the suffix of executables on Windows. I guess you would have had an easier time to understand my thinking if I had replaced the sentence So the assumption that the `.exe` extension implies that the file is *not* a shell script is now wrong. by So this is a strong indicator that it was wrong to assume that `.exe` extensions imply that the file is *not* a shell script. Further, I even looked at the performance impact, but that is at least well documented in the commit message. I also have to point out that the alternative "solution" presented by your patch -- to disable the test case -- is no solution at all: the very platform that is most likely to have plink users is Windows. And to *exclude* that platform from running that unit test is questionable at best. Ciao, Johannes -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [msysGit] Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-13 7:30 ` Johannes Schindelin @ 2015-08-13 18:07 ` Johannes Sixt 0 siblings, 0 replies; 12+ messages in thread From: Johannes Sixt @ 2015-08-13 18:07 UTC (permalink / raw) To: Johannes Schindelin; +Cc: kusmabite, Git Mailing List, msysGit Am 13.08.2015 um 09:30 schrieb Johannes Schindelin: > Hi Johannes, > > On 2015-08-12 20:31, Johannes Sixt wrote: >> Am 12.08.2015 um 13:58 schrieb Erik Faye-Lund: >>> On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin >>> <johannes.schindelin@gmx.de> wrote: >>>> FWIW Git for Windows has this patch (that I wanted to contribute >>>> in due time, what with being busy with all those tickets) to solve the >>>> problem mentioned in your patch in a different way: >>>> >>>> https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 >>> >>> Yuck. On Windows, it's the extension of a file that dictates what kind >>> of file it is (and if it's executable or not), not the contents. If we >>> get a shell script written with the ".exe"-prefix, it's considered as >>> an invalid executable by the system. We should consider it the same >>> way, otherwise we're on the path to user-experience schizophrenia. >>> >>> I'm not sure I consider this commit a step in the right direction. >> >> I, too, think that it is a wrong decision to pessimize git for the >> sake of a single test case. > > Oh, you make it sound as if you believe that I had indeed weakened > Git *just* for a single test case. Whatever. Since I do not have the time to provide hard numbers that prove my claim that your patch removes an optimization (and, furthermore, I do not want to reply to your arguments that I consider mostly philosophical rather than pragmatic), I bow out. Until this solution or that one is in upstream, I can help myself. Junio, please drop my patch. I do not have the nerves to support it. -- Hannes ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-12 11:58 ` [msysGit] " Erik Faye-Lund 2015-08-12 18:31 ` Johannes Sixt @ 2015-08-13 8:37 ` Johannes Schindelin 2015-08-13 8:56 ` [msysGit] " Erik Faye-Lund 1 sibling, 1 reply; 12+ messages in thread From: Johannes Schindelin @ 2015-08-13 8:37 UTC (permalink / raw) To: kusmabite; +Cc: Johannes Sixt, Git Mailing List, msysGit Hi kusma, On 2015-08-12 13:58, Erik Faye-Lund wrote: > On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin > <johannes.schindelin@gmx.de> wrote: >> >> On 2015-08-11 22:51, Johannes Sixt wrote: >>> Invoking plink requires special treatment, and we have support and even >>> test cases for the commands 'plink' and 'tortoiseplink'. We also support >>> .exe variants for these two and there is a test for 'plink.exe'. >>> >>> On Windows, however, where support for plink.exe would be relevant, the >>> test case fails because it is not possible to execute a file with a .exe >>> extension that is actually not a binary executable---it is a shell >>> script in our test. We have to disable the test case on Windows. >> >> Oh how would I wish you were working on Git for Windows even *just* a bit *with* me. At least I would wish for a more specific description of the development environment, because it sure as hell is not anything anybody can download and install as easily as Git for Windows' SDK. >> >> FWIW Git for Windows has this patch (that I wanted to contribute in due time, what with being busy with all those tickets) to solve the problem mentioned in your patch in a different way: >> >> https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 > > Yuck. On Windows, it's the extension of a file that dictates what kind > of file it is (and if it's executable or not), not the contents. Careful. If you continue along those lines, interactive rebase, `git add -p` and all those wonderful scripts Git has will have to stop working. Because those scripts completely disagree with what you just said about Windows if you think about it: *none* of them has an extension. I know that you do not mean this, of course, but that is the argument you were making... ;-) > If we get a shell script written with the ".exe"-prefix, it's considered as > an invalid executable by the system. And if we get a shell script without any `.exe` suffix, it is still considered as an invalid executable by the system. And even if we tack on an `.sh` suffix (which is *not* in line with the way Git works), it is *still* considered as an invalid executable by the system. Ciao, Dscho -- -- *** Please reply-to-all at all times *** *** (do not pretend to know who is subscribed and who is not) *** *** Please avoid top-posting. *** The msysGit Wiki is here: https://github.com/msysgit/msysgit/wiki - Github accounts are free. You received this message because you are subscribed to the Google Groups "msysGit" group. To post to this group, send email to msysgit@googlegroups.com To unsubscribe from this group, send email to msysgit+unsubscribe@googlegroups.com For more options, and view previous threads, visit this group at http://groups.google.com/group/msysgit?hl=en_US?hl=en --- You received this message because you are subscribed to the Google Groups "Git for Windows" group. To unsubscribe from this group and stop receiving emails from it, send an email to msysgit+unsubscribe@googlegroups.com. For more options, visit https://groups.google.com/d/optout. ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [msysGit] Re: [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe 2015-08-13 8:37 ` Johannes Schindelin @ 2015-08-13 8:56 ` Erik Faye-Lund 0 siblings, 0 replies; 12+ messages in thread From: Erik Faye-Lund @ 2015-08-13 8:56 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Johannes Sixt, Git Mailing List, msysGit On Thu, Aug 13, 2015 at 10:37 AM, Johannes Schindelin <johannes.schindelin@gmx.de> wrote: > Hi kusma, > > On 2015-08-12 13:58, Erik Faye-Lund wrote: >> On Wed, Aug 12, 2015 at 1:07 PM, Johannes Schindelin >> <johannes.schindelin@gmx.de> wrote: >>> >>> On 2015-08-11 22:51, Johannes Sixt wrote: >>>> Invoking plink requires special treatment, and we have support and even >>>> test cases for the commands 'plink' and 'tortoiseplink'. We also support >>>> .exe variants for these two and there is a test for 'plink.exe'. >>>> >>>> On Windows, however, where support for plink.exe would be relevant, the >>>> test case fails because it is not possible to execute a file with a .exe >>>> extension that is actually not a binary executable---it is a shell >>>> script in our test. We have to disable the test case on Windows. >>> >>> Oh how would I wish you were working on Git for Windows even *just* a bit *with* me. At least I would wish for a more specific description of the development environment, because it sure as hell is not anything anybody can download and install as easily as Git for Windows' SDK. >>> >>> FWIW Git for Windows has this patch (that I wanted to contribute in due time, what with being busy with all those tickets) to solve the problem mentioned in your patch in a different way: >>> >>> https://github.com/git-for-windows/git/commit/2fff4b54a0d4e5c5e2e4638c9b0739d3c1ff1e45 >> >> Yuck. On Windows, it's the extension of a file that dictates what kind >> of file it is (and if it's executable or not), not the contents. > > Careful. If you continue along those lines, interactive rebase, `git add -p` and all those wonderful scripts Git has will have to stop working. > > Because those scripts completely disagree with what you just said about Windows if you think about it: *none* of them has an extension. > > I know that you do not mean this, of course, but that is the argument you were making... ;-) > You should know better than to straw-man like that. I was not arguing to break any current functionality, but to not move further away from Windows' semantics. But if I would have, there's nothing that would stop us from renaming those scrips to *.sh, and let the filename dictate how to execute them. Or provide batch-files to wrap them. >> If we get a shell script written with the ".exe"-prefix, it's considered as >> an invalid executable by the system. > > And if we get a shell script without any `.exe` suffix, it is still considered as an invalid executable by the system. Nope, it's considered an unknown file, not an executable at all. > And even if we tack on an `.sh` suffix (which is *not* in line with the way Git works), it is *still* considered as an invalid executable by the system. That's not necessarily true; the Git for Windows installer (optionally, but on by default) registers /bin/sh as a file-handler for .sh files. Windows knows just fine how to execute them, unless the user opts out. But again, I was not arguing to patch git to not parse the shebang. ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2015-08-13 18:07 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-08-11 20:51 [PATCH bc/connect-plink] t5601-clone: remove broken and pointless check for plink.exe Johannes Sixt 2015-08-11 22:50 ` Eric Sunshine 2015-08-11 22:53 ` Junio C Hamano 2015-08-11 22:56 ` [msysGit] " Junio C Hamano 2015-08-11 23:26 ` Eric Sunshine 2015-08-12 11:07 ` Johannes Schindelin 2015-08-12 11:58 ` [msysGit] " Erik Faye-Lund 2015-08-12 18:31 ` Johannes Sixt 2015-08-13 7:30 ` Johannes Schindelin 2015-08-13 18:07 ` [msysGit] " Johannes Sixt 2015-08-13 8:37 ` Johannes Schindelin 2015-08-13 8:56 ` [msysGit] " Erik Faye-Lund
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).