Re: [PATCH 3/4] git-push: make git push --porcelain print "Done"

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

 



Hi,

On Sat, Feb 27, 2010 at 11:59 AM, Larry D'Anna <larry@xxxxxxxxxxxxxx> wrote:
> diff --git a/transport.c b/transport.c
> index 32885f7..5b880d7 100644
> --- a/transport.c
> +++ b/transport.c
> [snip]

This hunk:

> @@ -1055,8 +1056,6 @@ int transport_push(struct transport *transport,
>                ret = transport->push_refs(transport, remote_refs, flags);
>                err = push_had_errors(remote_refs);
>
> -               ret |= err;
> -
>                if (!quiet || err)
>                        print_push_status(transport->url, remote_refs,
>                                        verbose | porcelain, porcelain,

and this hunk:

> @@ -1071,9 +1070,15 @@ int transport_push(struct transport *transport,
>                                update_tracking_ref(transport->remote, ref, verbose);
>                }
>
> -               if (!quiet && !ret && !refs_pushed(remote_refs))
> -                       fprintf(stderr, "Everything up-to-date\n");
> -               return ret;
> +
> +               if (porcelain) {
> +                       if (ret==0)
> +                               fprintf (stdout, "Done\n");
> +               } else
> +                       if (!quiet && !ret && !refs_pushed(remote_refs))
> +                               fprintf(stderr, "Everything up-to-date\n");
> +
> +               return ret | err;
>        }
>        return 1;
>  }

slightly changes the conditions under which "Everything up-to-date" is
printed, since you did away with "ret |= err". I guess you can
mitigate this by adding "!err" to the list of operands:

  if (!quiet && !ret && !err && !refs_pushed(remote_refs))
      ....

Even better, create yet another temporary variable:

  push_ret = transport->push_refs(transport, remote_refs, flags);
  err = push_had_errors(remote_refs);

  ret = push_ret | err;

That way, you can access transport->push_refs() status (what you
want), without messing with the other parts of the code and their
assumptions.

One last thing: could the if statements towards the end be "flattened"?

  if (porcelain && ret == 0)
      fprintf(stdout, "Done\n");
  else if (!quiet && !ret && !refs_pushed(remote_refs))
      fprintf(stderr, "Everything up-to-date\n");

(sorry about the lack of tabs, gmail doesn't let me type those easily.)

-- 
Cheers,
Ray Chuan
--
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]