On Mon, Mar 02, 2015 at 06:02:37PM +0600, Alexander Kuleshov wrote: > 'was_alias' variable does not need to store it's value on each > iteration in the loop, anyway this variable changes it's value with run_argv. > > 'done_help' variable does not need to be static variable too if we'll move it > out the loop. > > So these variables do not need to be static. Agreed, but... > diff --git a/git.c b/git.c > index 1780233..96723b8 100644 > --- a/git.c > +++ b/git.c > @@ -619,6 +619,7 @@ int main(int argc, char **av) > { > const char **argv = (const char **) av; > const char *cmd; > + int done_help, was_alias; Now done_help is not initialized, but we read from it before assigning it. And I think there is no need for was_alias to go outside the loop, right? > startup_info = &git_startup_info; > > @@ -681,8 +682,6 @@ int main(int argc, char **av) > setup_path(); > > while (1) { > - static int done_help = 0; > - static int was_alias = 0; > was_alias = run_argv(&argc, &argv); Dropping the initialization of was_alias is fine, since we always assign to it before reading. That becomes more obvious if we leave it in the loop, and we can even assign in its declaration. So all together, like: diff --git a/git.c b/git.c index acde36a..8dbe12f 100644 --- a/git.c +++ b/git.c @@ -635,6 +635,7 @@ int main(int argc, char **av) { const char **argv = (const char **) av; const char *cmd; + int done_help = 0; startup_info = &git_startup_info; @@ -697,9 +698,7 @@ int main(int argc, char **av) setup_path(); while (1) { - static int done_help = 0; - static int was_alias = 0; - was_alias = run_argv(&argc, &argv); + int was_alias = run_argv(&argc, &argv); if (errno != ENOENT) break; if (was_alias) { -- 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