On Sat, Sep 21, 2024, at 17:08, Ruffalo Lavoisier wrote: > if fseek() is success, return value is 0 > > Signed-off-by: Ruffalo Lavoisier <RuffaloLavoisier@xxxxxxxxx> > --- > builtin/am.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/builtin/am.c b/builtin/am.c > index d8875ad402..a7727fd4ea 100644 > --- a/builtin/am.c > +++ b/builtin/am.c > @@ -589,7 +589,7 @@ static int is_mail(FILE *fp) > regex_t regex; > int ret = 1; > > - if (fseek(fp, 0L, SEEK_SET)) > + if (!fseek(fp, 0L, SEEK_SET)) > die_errno(_("fseek failed")); > > if (regcomp(®ex, header_regex, REG_NOSUB | REG_EXTENDED)) > -- > 2.46.1 I don’t get this change? The function returns false on success. true if it fails (not zero). You want the program to die if it returns non-zero. It’s hard to wrap my head around… “false must mean “no errors” ” If the original code has a bug then I don’t see how git-am(1) could work considering it presumably always checks ‘is_mail’. -- Kristoffer