* [PATCH] git-subtree: Avoid using echo -n even indirectly @ 2013-10-09 3:57 Paolo G. Giarrusso 2013-10-09 10:20 ` Tay Ray Chuan 0 siblings, 1 reply; 10+ messages in thread From: Paolo G. Giarrusso @ 2013-10-09 3:57 UTC (permalink / raw) To: git; +Cc: Paolo G. Giarrusso Since say uses echo, this uses echo -n, which is not portable - see 19c3c5fdcb35b66b792534c5dc4e8d87a3952d2a. Without this commit, the output looks like: ... -n 1891/ 1936 (1883) -n 1892/ 1936 (1884) -n 1893/ 1936 (1885) ... Signed-off-by: Paolo G. Giarrusso <p.giarrusso@gmail.com> --- Please CC me on replies, as I am not subscribed to this mailing list. I am tracking this submission via https://github.com/git/git/pull/61, which I'll duly close myself when the discussion is resolved. contrib/subtree/git-subtree.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/contrib/subtree/git-subtree.sh b/contrib/subtree/git-subtree.sh index 7d7af03..ebfb78f 100755 --- a/contrib/subtree/git-subtree.sh +++ b/contrib/subtree/git-subtree.sh @@ -592,7 +592,9 @@ cmd_split() eval "$grl" | while read rev parents; do revcount=$(($revcount + 1)) - say -n "$revcount/$revmax ($createcount) " + if [ -z "$quiet" ]; then + printf "%s" "$revcount/$revmax ($createcount) " >&2 + fi debug "Processing commit: $rev" exists=$(cache_get $rev) if [ -n "$exists" ]; then -- 1.8.4 ^ permalink raw reply related [flat|nested] 10+ messages in thread
* Re: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 3:57 [PATCH] git-subtree: Avoid using echo -n even indirectly Paolo G. Giarrusso @ 2013-10-09 10:20 ` Tay Ray Chuan [not found] ` <CAAcnjCT1bdR+9kDW=q_326OhiSMm3_j-yOh0-ayTkObK3bZ3bQ@mail.gmail.com> 0 siblings, 1 reply; 10+ messages in thread From: Tay Ray Chuan @ 2013-10-09 10:20 UTC (permalink / raw) To: Paolo G. Giarrusso; +Cc: Git Mailing List On Wed, Oct 9, 2013 at 11:57 AM, Paolo G. Giarrusso <p.giarrusso@gmail.com> wrote: > diff --git a/contrib/subtree/git-subtree.sh b/contrib/subtree/git-subtree.sh > index 7d7af03..ebfb78f 100755 > --- a/contrib/subtree/git-subtree.sh > +++ b/contrib/subtree/git-subtree.sh > @@ -592,7 +592,9 @@ cmd_split() > eval "$grl" | > while read rev parents; do > revcount=$(($revcount + 1)) > - say -n "$revcount/$revmax ($createcount) > " > + if [ -z "$quiet" ]; then > + printf "%s" "$revcount/$revmax ($createcount) > " >&2 > + fi Reviewers might wish to know that "say" in git-subtree is defined as say() { if [ -z "$quiet" ]; then echo "$@" >&2 fi } Hence the "if" and the redirect. -- Cheers, Ray Chuan ^ permalink raw reply [flat|nested] 10+ messages in thread
[parent not found: <CAAcnjCT1bdR+9kDW=q_326OhiSMm3_j-yOh0-ayTkObK3bZ3bQ@mail.gmail.com>]
* Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly [not found] ` <CAAcnjCT1bdR+9kDW=q_326OhiSMm3_j-yOh0-ayTkObK3bZ3bQ@mail.gmail.com> @ 2013-10-09 10:32 ` Paolo Giarrusso 2013-10-09 10:46 ` Johannes Sixt ` (2 more replies) 0 siblings, 3 replies; 10+ messages in thread From: Paolo Giarrusso @ 2013-10-09 10:32 UTC (permalink / raw) To: Tay Ray Chuan; +Cc: Git Mailing List (Resending without HTML). On Wed, Oct 9, 2013 at 12:20 PM, Tay Ray Chuan <rctay89@gmail.com> wrote: > > On Wed, Oct 9, 2013 at 11:57 AM, Paolo G. Giarrusso > <p.giarrusso@gmail.com> wrote: > > diff --git a/contrib/subtree/git-subtree.sh b/contrib/subtree/git-subtree.sh > > index 7d7af03..ebfb78f 100755 > > --- a/contrib/subtree/git-subtree.sh > > +++ b/contrib/subtree/git-subtree.sh > > @@ -592,7 +592,9 @@ cmd_split() > > eval "$grl" | > > while read rev parents; do > > revcount=$(($revcount + 1)) > > - say -n "$revcount/$revmax ($createcount) > > " > > + if [ -z "$quiet" ]; then > > + printf "%s" "$revcount/$revmax ($createcount) > > " >&2 An additional note for reviewers and appliers: the original and the patched codeboth embed a literal ^M, not a new line, go to back to the beginning of the line and overwrite it, so the above is not a consequence of line-wrap. I used git-format-patch and git-send-email, and the ^M is visible in Vim in the exported patch (that's why I didn't remark on it). Seeing the email, I wonder whether there's hope something like that can be preserved in an email, and whether the code should use some escape sequence instead. > > + fi > > Reviewers might wish to know that "say" in git-subtree is defined as > > say() > { > if [ -z "$quiet" ]; then > echo "$@" >&2 > fi > } > > Hence the "if" and the redirect. Indeed. I considered having a variant of `say` instead of inlining and customizing it, but for once I decided to keep this simple, since this variant of `say` is currently used only once. Otherwise, one could change say to use printf, but that's more invasive. Cheers, -- Paolo G. Giarrusso - Ph.D. Student, Philipps-University Marburg http://www.informatik.uni-marburg.de/~pgiarrusso/ ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 10:32 ` Fwd: " Paolo Giarrusso @ 2013-10-09 10:46 ` Johannes Sixt 2013-10-09 11:26 ` Matthieu Moy 2013-10-09 21:11 ` Jonathan Nieder 2 siblings, 0 replies; 10+ messages in thread From: Johannes Sixt @ 2013-10-09 10:46 UTC (permalink / raw) To: Paolo Giarrusso; +Cc: Tay Ray Chuan, Git Mailing List Am 10/9/2013 12:32, schrieb Paolo Giarrusso: > On Wed, Oct 9, 2013 at 12:20 PM, Tay Ray Chuan <rctay89@gmail.com> wrote: >> On Wed, Oct 9, 2013 at 11:57 AM, Paolo G. Giarrusso >> <p.giarrusso@gmail.com> wrote: >>> diff --git a/contrib/subtree/git-subtree.sh b/contrib/subtree/git-subtree.sh >>> index 7d7af03..ebfb78f 100755 >>> --- a/contrib/subtree/git-subtree.sh >>> +++ b/contrib/subtree/git-subtree.sh >>> @@ -592,7 +592,9 @@ cmd_split() >>> eval "$grl" | >>> while read rev parents; do >>> revcount=$(($revcount + 1)) >>> - say -n "$revcount/$revmax ($createcount) >>> " >>> + if [ -z "$quiet" ]; then >>> + printf "%s" "$revcount/$revmax ($createcount) >>> " >&2 > > An additional note for reviewers and appliers: the original and the > patched codeboth embed a literal ^M, >... > whether the code should use some > escape sequence instead. As you are using printf, you can easily do: printf '%s\r' "..." without using ^M. -- Hannes ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 10:32 ` Fwd: " Paolo Giarrusso 2013-10-09 10:46 ` Johannes Sixt @ 2013-10-09 11:26 ` Matthieu Moy 2013-10-09 12:03 ` Paolo Giarrusso 2013-10-09 21:11 ` Jonathan Nieder 2 siblings, 1 reply; 10+ messages in thread From: Matthieu Moy @ 2013-10-09 11:26 UTC (permalink / raw) To: Paolo Giarrusso; +Cc: Tay Ray Chuan, Git Mailing List Paolo Giarrusso <p.giarrusso@gmail.com> writes: > Otherwise, one could > change say to use printf, but that's more invasive. "invasive" in the sense that it impacts indirectly more callers, but are there really cases where "echo" is needed when calling "say"? Aren't there other potential bugs when arbitrary strings are passed to "say", that would be fixed by using printf once and for all? The patch would look like the one I did in 89b0230a20 (Wed Aug 7 2013, die_with_status: use "printf '%s\n'", not "echo"). -- Matthieu Moy http://www-verimag.imag.fr/~moy/ ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 11:26 ` Matthieu Moy @ 2013-10-09 12:03 ` Paolo Giarrusso 2013-10-09 19:48 ` Jeff King 0 siblings, 1 reply; 10+ messages in thread From: Paolo Giarrusso @ 2013-10-09 12:03 UTC (permalink / raw) To: Matthieu Moy; +Cc: Tay Ray Chuan, Git Mailing List On Wed, Oct 9, 2013 at 1:26 PM, Matthieu Moy <Matthieu.Moy@grenoble-inp.fr> wrote: > Paolo Giarrusso <p.giarrusso@gmail.com> writes: > >> Otherwise, one could >> change say to use printf, but that's more invasive. > > "invasive" in the sense that it impacts indirectly more callers, but are > there really cases where "echo" is needed when calling "say"? Aren't > there other potential bugs when arbitrary strings are passed to "say", > that would be fixed by using printf once and for all? (1) Changing the implementation of say to use printf "%s\n" would be trivial, and I think would address your concerns. But I was concerned about code duplication; one could additionally make say reusable in this single call site, instead of inlining and customizing it by replacing the "\n" with "\r". But for that, you need to either (2) add an explicit \n to all callers (invasive & error prone), or (3) make `say` parse the `-n` option and conditionally add "\n" to the format string or to a final argument, if -n is not specified; this would affect no current caller, but complicate the implementation of say. Doing that for just one call site has too much potential for breakage, so I'm not sure I'd do it. (I'm not even sure on what should `say` do when `-n` is not the first argument). Options (1), (2) and (3) are mutually alternative; my favorite is (1). I can see your points about opportunity, especially after looking at the commit message of the patch of yours you linked. > The patch would look like the one I did in 89b0230a20 (Wed Aug 7 2013, > die_with_status: use "printf '%s\n'", not "echo"). I see your point. But note that using printf like in die_with_status after that commit wouldn't be reusable here in all call sites, because it always prints a newline. Cheers, -- Paolo G. Giarrusso - Ph.D. Student, Philipps-University Marburg http://www.informatik.uni-marburg.de/~pgiarrusso/ ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 12:03 ` Paolo Giarrusso @ 2013-10-09 19:48 ` Jeff King 0 siblings, 0 replies; 10+ messages in thread From: Jeff King @ 2013-10-09 19:48 UTC (permalink / raw) To: Paolo Giarrusso; +Cc: Matthieu Moy, Tay Ray Chuan, Git Mailing List On Wed, Oct 09, 2013 at 02:03:24PM +0200, Paolo Giarrusso wrote: > On Wed, Oct 9, 2013 at 1:26 PM, Matthieu Moy > <Matthieu.Moy@grenoble-inp.fr> wrote: > > Paolo Giarrusso <p.giarrusso@gmail.com> writes: > > > >> Otherwise, one could > >> change say to use printf, but that's more invasive. > > > > "invasive" in the sense that it impacts indirectly more callers, but are > > there really cases where "echo" is needed when calling "say"? Aren't > > there other potential bugs when arbitrary strings are passed to "say", > > that would be fixed by using printf once and for all? > > (1) Changing the implementation of say to use printf "%s\n" would be > trivial, and I think would address your concerns. Yeah, I think we should do that. I had the same thought as Matthieu when I read your initial patch; there are real portability bugs caused by using "echo" that would be fixed. However, that is somewhat orthogonal to the bug you are fixing. For handling this one site, I think it would be fine to just convert it to use printf, as your patch did. As you noted, the alternatives: > (2) add an explicit \n to all callers (invasive & error prone), or > (3) make `say` parse the `-n` option and conditionally add "\n" to the > format string or to a final argument, if -n is not specified; this > would affect no current caller, but complicate the implementation of > say. Doing that for just one call site has too much potential for > breakage, so I'm not sure I'd do it. (I'm not even sure on what should > `say` do when `-n` is not the first argument). ...are either annoying or complicated (and in particular, parsing "-n" means that callers need to be aware that 'say "$foo"' might accidentally trigger "-n" if $foo comes from the user). So the sanest interface is probably "say_nonl" or something similar. But since there would only be one caller, I don't see much point in factoring it out. > Options (1), (2) and (3) are mutually alternative; my favorite is (1). Me too. :) -Peff ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 10:32 ` Fwd: " Paolo Giarrusso 2013-10-09 10:46 ` Johannes Sixt 2013-10-09 11:26 ` Matthieu Moy @ 2013-10-09 21:11 ` Jonathan Nieder 2013-10-11 9:32 ` Paolo Giarrusso 2 siblings, 1 reply; 10+ messages in thread From: Jonathan Nieder @ 2013-10-09 21:11 UTC (permalink / raw) To: Paolo Giarrusso; +Cc: Tay Ray Chuan, Git Mailing List, David A. Greene Paolo Giarrusso wrote: > Seeing the email, I wonder whether there's hope something like that > can be preserved in an email, and whether the code should use some > escape sequence instead. Yes, please. Mind if I amend it to printf "%s\r" "$revcount/$revmax ($createcount)" >&2 ? [...] >> say() >> { >> if [ -z "$quiet" ]; then >> echo "$@" >&2 >> fi >> } I agree with the other reviewers that this should be fixed to use printf, too, but that's another topic. Thanks, Jonathan ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly 2013-10-09 21:11 ` Jonathan Nieder @ 2013-10-11 9:32 ` Paolo Giarrusso 0 siblings, 0 replies; 10+ messages in thread From: Paolo Giarrusso @ 2013-10-11 9:32 UTC (permalink / raw) To: Jonathan Nieder; +Cc: Tay Ray Chuan, Git Mailing List, David A. Greene On Wed, Oct 9, 2013 at 11:11 PM, Jonathan Nieder <jrnieder@gmail.com> wrote: > Paolo Giarrusso wrote: > >> Seeing the email, I wonder whether there's hope something like that >> can be preserved in an email, and whether the code should use some >> escape sequence instead. > > Yes, please. Mind if I amend it to > > printf "%s\r" "$revcount/$revmax ($createcount)" >&2 > > ? Please do go ahead, by all means (arguably as a different commit, but those are minor details). > [...] >>> say() >>> { >>> if [ -z "$quiet" ]; then >>> echo "$@" >&2 >>> fi >>> } > > I agree with the other reviewers that this should be fixed to use > printf, too, but that's another topic. Seconded. -- Paolo G. Giarrusso - Ph.D. Student, Philipps-University Marburg http://www.informatik.uni-marburg.de/~pgiarrusso/ ^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Fwd: [PATCH] git-subtree: Avoid using echo -n even indirectly @ 2013-10-28 14:04 Paolo Giarrusso 0 siblings, 0 replies; 10+ messages in thread From: Paolo Giarrusso @ 2013-10-28 14:04 UTC (permalink / raw) To: Jonathan Nieder; +Cc: Tay Ray Chuan, Git Mailing List, David A. Greene (Resending without HTML, so that it reaches the ML). On Fri, Oct 11, 2013 at 11:32 AM, Paolo Giarrusso <p.giarrusso@gmail.com> wrote: > > On Wed, Oct 9, 2013 at 11:11 PM, Jonathan Nieder <jrnieder@gmail.com> wrote: > > Paolo Giarrusso wrote: > > > >> Seeing the email, I wonder whether there's hope something like that > >> can be preserved in an email, and whether the code should use some > >> escape sequence instead. > > > > Yes, please. Mind if I amend it to > > > > printf "%s\r" "$revcount/$revmax ($createcount)" >&2 > > > > ? > > Please do go ahead, by all means (arguably as a different commit, but > those are minor details). What happened? Did you go ahead, as you wrote? Is the patch somewhere? Arguably it should go into the maint branch, but I think it didn't — otherwise https://github.com/git/git/pull/61 should have stopped being mergeable. This also makes me wonder whether you use any tracker at all — but unless there is one that I missed, that's a separate discussion. > > [...] > >>> say() > >>> { > >>> if [ -z "$quiet" ]; then > >>> echo "$@" >&2 > >>> fi > >>> } > > > > I agree with the other reviewers that this should be fixed to use > > printf, too, but that's another topic. > Seconded. -- Paolo G. Giarrusso - Ph.D. Student, Philipps-University Marburg http://www.informatik.uni-marburg.de/~pgiarrusso/ ^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2013-10-28 14:04 UTC | newest] Thread overview: 10+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2013-10-09 3:57 [PATCH] git-subtree: Avoid using echo -n even indirectly Paolo G. Giarrusso 2013-10-09 10:20 ` Tay Ray Chuan [not found] ` <CAAcnjCT1bdR+9kDW=q_326OhiSMm3_j-yOh0-ayTkObK3bZ3bQ@mail.gmail.com> 2013-10-09 10:32 ` Fwd: " Paolo Giarrusso 2013-10-09 10:46 ` Johannes Sixt 2013-10-09 11:26 ` Matthieu Moy 2013-10-09 12:03 ` Paolo Giarrusso 2013-10-09 19:48 ` Jeff King 2013-10-09 21:11 ` Jonathan Nieder 2013-10-11 9:32 ` Paolo Giarrusso -- strict thread matches above, loose matches on Subject: below -- 2013-10-28 14:04 Paolo Giarrusso
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).