On Wed, Apr 12, 2017 at 06:21:06AM +0800, Jin Yao wrote:

SNIP

> +static int branch_type_str(struct branch_type_stat *stat,
> +                        char *bf, int bfsize)
> +{
> +     int i, j = 0, printed = 0;
> +     u64 total = 0;
> +
> +     for (i = 0; i < PERF_BR_MAX; i++)
> +             total += stat->counts[i];
> +
> +     if (total == 0)
> +             return 0;
> +
> +     printed += scnprintf(bf + printed, bfsize - printed, " (");
> +
> +     if (stat->jcc_fwd > 0) {
> +             j++;
> +             printed += scnprintf(bf + printed, bfsize - printed,
> +                                  "JCC forward");
> +     }
> +
> +     if (stat->jcc_bwd > 0) {
> +             if (j++)
> +                     printed += scnprintf(bf + printed, bfsize - printed,
> +                                          " JCC backward");
> +             else
> +                     printed += scnprintf(bf + printed, bfsize - printed,
> +                                          "JCC backward");
> +     }
> +
> +     if (stat->cross_4k > 0) {
> +             if (j++)
> +                     printed += scnprintf(bf + printed, bfsize - printed,
> +                                          " CROSS_4K");
> +             else
> +                     printed += scnprintf(bf + printed, bfsize - printed,
> +                                          "CROSS_4K");
> +     }

could that 2 legs if be shortened to just one scnprintf like (untested):

   printed += scnprintf(bf + printed, bfsize - printed, "%s%s", j++ ? " " : "", 
"CROSS_4K");

I'd also probably use some kind of macro or function
with all that similar code, but I dont insist ;-)

thanks,
jirka

Reply via email to