git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
* [Proposal] git am --check
@ 2019-06-02 17:37 Drew DeVault
  2019-06-03  9:28 ` Christian Couder
  0 siblings, 1 reply; 4+ messages in thread
From: Drew DeVault @ 2019-06-02 17:37 UTC (permalink / raw)
  To: git

This flag would behave similarly to git apply --check, or in other words
would exit with a nonzero status if the patch is not applicable without
actually applying the patch otherwise.

Rationale: I'm working on an email client which has some git
integration, and when you scroll over a patch I want to quickly test its
applicability and show an indication of the result.

Thoughts on the approach are welcome; my initial naive patch just tried
to add --check to the apply flags but that didn't work as I had hoped.
Will take another crack at a patch soon(ish).

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [Proposal] git am --check
  2019-06-02 17:37 [Proposal] git am --check Drew DeVault
@ 2019-06-03  9:28 ` Christian Couder
  2019-06-03  9:35   ` Duy Nguyen
  0 siblings, 1 reply; 4+ messages in thread
From: Christian Couder @ 2019-06-03  9:28 UTC (permalink / raw)
  To: Drew DeVault; +Cc: git

On Sun, Jun 2, 2019 at 7:38 PM Drew DeVault <sir@cmpwn.com> wrote:
>
> This flag would behave similarly to git apply --check, or in other words
> would exit with a nonzero status if the patch is not applicable without
> actually applying the patch otherwise.

`git am` uses the same code as `git apply` to apply patches, so there
should be no difference between `git am --check` and `git apply
--check`.

> Rationale: I'm working on an email client which has some git
> integration, and when you scroll over a patch I want to quickly test its
> applicability and show an indication of the result.
>
> Thoughts on the approach are welcome; my initial naive patch just tried
> to add --check to the apply flags but that didn't work as I had hoped.
> Will take another crack at a patch soon(ish).

Could you tell us about what didn't work as you hoped? And how `git am
--check` would be different from `git apply --check`?

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [Proposal] git am --check
  2019-06-03  9:28 ` Christian Couder
@ 2019-06-03  9:35   ` Duy Nguyen
  2019-06-03 18:16     ` Junio C Hamano
  0 siblings, 1 reply; 4+ messages in thread
From: Duy Nguyen @ 2019-06-03  9:35 UTC (permalink / raw)
  To: Christian Couder; +Cc: Drew DeVault, git

On Mon, Jun 3, 2019 at 4:29 PM Christian Couder
<christian.couder@gmail.com> wrote:
>
> On Sun, Jun 2, 2019 at 7:38 PM Drew DeVault <sir@cmpwn.com> wrote:
> >
> > This flag would behave similarly to git apply --check, or in other words
> > would exit with a nonzero status if the patch is not applicable without
> > actually applying the patch otherwise.
>
> `git am` uses the same code as `git apply` to apply patches, so there
> should be no difference between `git am --check` and `git apply
> --check`.

One difference (that still annoys me) is "git apply" must be run at
topdir. "git am" can be run anywhere and it will automatically find
topdir.

"git am" can also consume multiple patches, so it's some extra work if
we just use "git apply" directly, although I don't think that's a very
good argument for "am --check".
-- 
Duy

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [Proposal] git am --check
  2019-06-03  9:35   ` Duy Nguyen
@ 2019-06-03 18:16     ` Junio C Hamano
  0 siblings, 0 replies; 4+ messages in thread
From: Junio C Hamano @ 2019-06-03 18:16 UTC (permalink / raw)
  To: Duy Nguyen; +Cc: Christian Couder, Drew DeVault, git

Duy Nguyen <pclouds@gmail.com> writes:

> On Mon, Jun 3, 2019 at 4:29 PM Christian Couder
> <christian.couder@gmail.com> wrote:
>>
>> On Sun, Jun 2, 2019 at 7:38 PM Drew DeVault <sir@cmpwn.com> wrote:
>> >
>> > This flag would behave similarly to git apply --check, or in other words
>> > would exit with a nonzero status if the patch is not applicable without
>> > actually applying the patch otherwise.
>>
>> `git am` uses the same code as `git apply` to apply patches, so there
>> should be no difference between `git am --check` and `git apply
>> --check`.
>
> One difference (that still annoys me) is "git apply" must be run at
> topdir. "git am" can be run anywhere and it will automatically find
> topdir.
>
> "git am" can also consume multiple patches, so it's some extra work if
> we just use "git apply" directly, although I don't think that's a very
> good argument for "am --check".

Another is that "am" has preprocessing phase performed by mailsplit
that deals with MIME garbage, which "apply" will totally choke on
without even attempting to cope with.

I haven't carefully read the "proposal" or any rfc patches yet, but
would/should the command make a commit if the patch cleanly applies?

I wonder if a "--dry-run" option is more useful (i.e. checks and
reports with the exit status *if* the command without "--dry-run"
would cleanly succeed, but never makes a commit or touches the index
or the working tree), given the motivating use case is a Git aware
MUA that helps the user by saying "if you are busy you could perhaps
skip this message as the patch would not apply to your tree anyway".

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2019-06-03 18:16 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-06-02 17:37 [Proposal] git am --check Drew DeVault
2019-06-03  9:28 ` Christian Couder
2019-06-03  9:35   ` Duy Nguyen
2019-06-03 18:16     ` Junio C Hamano

Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).