Heiko Voigt <hvoigt@xxxxxxxxxx> writes: > How about I update CodingGuidelines according to the rules you > suggested? Then other people know how we prefer bash functions and if > statements to look like. OK. I was hoping that "imitate surrounding code" was sufficient, but it seems many parts of the codebase have deteriorated enough to make that rule no longer easy to follow. >> Style: >> >> if test -z "$sm_path" >> then >> exit 1 > > See above. If you agree I would add this style to the guidelines. Likewise. >> I know module_list would have said "error: pathspec 'no-such' did >> not match any file(s) known to git. Did you forget to git add" >> already, but because that comes at the very end of the input to the >> filter written in perl (and with the way the filter is coded, it >> will stay at the end), I am not sure if the user would notice it if >> we exit like this. By the time we hit this exit, we would have seen >> "Entering $sm_path..." followed by whatever message given while in >> the submodule for all the submodules that comes out of module_list, >> no? >> >> How about doing it this way to avoid that issue, to make sure we die >> immediately after the typo is diagnosed without touching anything? > > I like it, your approach combines the atomicity of my first patch with > the efficiency of not calling ls-files twice. I was hesitant to change > to much code just to get the exit code right, but your approach looks > good to me. > > Should I send an updated patch? Or do you just want to squash this in. > Since now only the tests are from me what should we do with the > ownership? That is your itch and the idea and the bulk of the changes remains to be yours in any case, methinks. By the way, there is no reason for my patch to be unshifting the "#unmatch" token into the array and spewing the array out, if the readers are always going to stop upon seeing "#unmatch" without touching any submodule that is named correctly on the command line. In other words, the following should suffice: while (<>) { ... accumulate in @out ... } if ($unmatched) { print "#unmatched\n"; } else { print for (@out); } -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html