Re: [PATCH] branch.c: simplify chain of if statements

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Thanks for the submission. Comments below to give you a taste of the
Git review process...

On Sun, Mar 16, 2014 at 5:22 PM, Dragos Foianu <dragos.foianu@xxxxxxxxx> wrote:
> This patch uses a table-driven approach in order to make the code
> cleaner.

In fact, this change is not table-driven (emphasis on *driven*). It
merely moves the strings into a table, but all the logic is still in
the code. To be table-driven, the logic would be encoded in the table
as well, and that logic would *drive* the code.

This is not to say that the code must be table-driven. The GSoC
microproject merely asks if doing so would make sense. Whether it
would is for you to decide, and then to explain to reviewers the
reason(s) why you did or did not make it so.

> Although not necessary, it helps code reability by not
> forcing the user to read the print message when trying to
> understand what the code does.

The if-chain is just sufficiently complex that the print messages may
actually help the reader understand the logic of the code, so this
argument seems specious.

> The rebase check has been moved to
> the verbose if statement to avoid making the same check in each of
> the four if statements.
>
> Signed-off-by: Dragos Foianu <dragos.foianu@xxxxxxxxx>
> ---

Overall, the patch appears to be properly constructed and you seem to
have digested Documentation/SubmittingPatches. Good.

>  branch.c | 32 ++++++++++++++++----------------
>  1 file changed, 16 insertions(+), 16 deletions(-)
>
> diff --git a/branch.c b/branch.c
> index 723a36b..e2fe455 100644
> --- a/branch.c
> +++ b/branch.c
> @@ -54,6 +54,14 @@ void install_branch_config(int flag, const char *local, const char *origin, cons
>         struct strbuf key = STRBUF_INIT;
>         int rebasing = should_setup_rebase(origin);
>
> +       const char *verbose_prints[4] = {

No need to hard-code 4. 'const char *verbose_prints[]' is sufficient.

On this project, it is preferred (though not consistent) to name
arrays using singular form, such as verbose_print[], so that accessing
a single element, such as verbose_print[42], reads more grammatically
correct.

verbose_prints[] is not as descriptive as it could be. Perhaps
something like verbose_messages[] would be more informative (though
awfully long; maybe just messages[]).

> +               "Branch %s set up to track remote branch %s from %s%s",

Even though you are correctly accessing these strings via _() in the
printf_ln() invocation, you still need to mark them translatable here
with N_(). See section 4.7 [1] of the gettext manual.

[1]: http://www.gnu.org/software/gettext/manual/gettext.html#Special-cases

> +               "Branch %s set up to track local branch %s%s",
> +               "Branch %s set up to track remote ref %s%s",
> +               "Branch %s set up to track local ref %s%s"
> +       };
> +       char *verbose_rebasing = rebasing ? " by rebasing." : ".";

This should be 'const char *'.

Matthieu already mentioned [2] that this sort of "lego" string
construction is not internationalization-friendly. See section 4.3 [3]
of the gettext manual for details.

[2]: http://thread.gmane.org/gmane.comp.version-control.git/244210/focus=244226
[3]: http://www.gnu.org/software/gettext/manual/gettext.html#Preparing-Strings

>         if (remote_is_branch
>             && !strcmp(local, shortname)
>             && !origin) {
> @@ -78,25 +86,17 @@ void install_branch_config(int flag, const char *local, const char *origin, cons
>
>         if (flag & BRANCH_CONFIG_VERBOSE) {
>                 if (remote_is_branch && origin)
> -                       printf_ln(rebasing ?
> -                                 _("Branch %s set up to track remote branch %s from %s by rebasing.") :
> -                                 _("Branch %s set up to track remote branch %s from %s."),
> -                                 local, shortname, origin);
> +                       printf_ln(_(verbose_prints[0]),
> +                               local, shortname, origin, verbose_rebasing);
>                 else if (remote_is_branch && !origin)
> -                       printf_ln(rebasing ?
> -                                 _("Branch %s set up to track local branch %s by rebasing.") :
> -                                 _("Branch %s set up to track local branch %s."),
> -                                 local, shortname);
> +                       printf_ln(_(verbose_prints[1]),
> +                               local, shortname, verbose_rebasing);
>                 else if (!remote_is_branch && origin)
> -                       printf_ln(rebasing ?
> -                                 _("Branch %s set up to track remote ref %s by rebasing.") :
> -                                 _("Branch %s set up to track remote ref %s."),
> -                                 local, remote);
> +                       printf_ln(_(verbose_prints[2]),
> +                               local, remote, verbose_rebasing);
>                 else if (!remote_is_branch && !origin)
> -                       printf_ln(rebasing ?
> -                                 _("Branch %s set up to track local ref %s by rebasing.") :
> -                                 _("Branch %s set up to track local ref %s."),
> -                                 local, remote);
> +                       printf_ln(_(verbose_prints[3]),
> +                               local, remote, verbose_rebasing);

These hard-coded indexing constants (0, 1, 2, 3) are fragile and
convey little meaning to the reader. Try to consider how to compute
the index into verbose_prints[] based upon the values of
'remote_is_branch' and 'origin'. What are the different ways you could
do so?

>                 else
>                         die("BUG: impossible combination of %d and %p",
>                             remote_is_branch, origin);
> --
> 1.8.3.2
--
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




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]