On Fri, Sep 16, 2016 at 05:49:22PM -0700, Jeff King wrote:
> On Fri, Sep 16, 2016 at 10:27:45AM -0700, Josh Triplett wrote:
>
> > By far, the most common subject-prefix I've seen other than "PATCH" is
> > "RFC PATCH" (or occasionally "PATCH RFC"). Seems worth optimizing for
> > the common case, to avoid having to spell it out the long way as
> > --subject-prefix='RFC PATCH'.
>
> "RFC" is the most common one for me, too. And if it ends here, I'm OK
> with it. But I'm a little worried with ending up with a proliferation of
> options.
I haven't seen a significant number of variations on subject prefixes; I
can't think of any other prefix I've seen often enough to suggest an
option.
> If we had a short-option for --subject-prefix, then:
>
> -P RFC
>
> is not so bad compared to "--rfc". But if you want to spell it as "RFC
> PATCH" that's getting a bit longer. We could have a short option for
> "tag this in the subject prefix _in addition_ to writing PATCH". And
> then you could do:
>
> -T RFC
>
> I dunno. One other thing to consider is that format-patch takes
> arbitrary diff options, so we'd want to avoid stomping on them with any
> short options (which is why I used "-T" instead of "-t", though I find
> it unlikely that many people use the latter with format-patch). That's a
> point in favor of --rfc, I think.
I agree; the short option space seems more contentious. And in any
case, I find --rfc more ergonomic than "-T RFC". :)
> > builtin/log.c | 10 ++++++++++
> > t/t4014-format-patch.sh | 9 +++++++++
> > 2 files changed, 19 insertions(+), 0 deletions(-)
>
> Documentation?
Oops, thanks. I'll send v2 shortly.
> > +static int rfc_callback(const struct option *opt, const char *arg, int
> > unset)
> > +{
> > + subject_prefix = 1;
> > + ((struct rev_info *)opt->value)->subject_prefix = xstrdup("RFC PATCH");
> > + return 0;
> > +}
>
> I was going to complain that you don't free() the previous value, but
> actually the other callers do not xstrdup() in the first place (and we
> do not need to do so here, either, as it's a string literal). We
> actually _do_ allocate a new copy when reading the value from config,
> but it's probably not a big deal in practice to leak that.
>
> I also wonder if you could implement this as just:
>
> return subject_prefix_callback(opt, "RFC PATCH", unset);
>
> And then if you write the documentation as:
>
> --rfc::
> Behave as if --subject-prefix="RFC PATCH" was specified.
>
> then it will be trivially correct. :)
Nice idea; will do.
> > +cat >expect <<'EOF'
> > +Subject: [RFC PATCH 1/1] header with . in it
> > +EOF
> > +test_expect_success '--rfc' '
> > + git format-patch -n -1 --stdout --rfc >patch &&
> > + grep ^Subject: patch >actual &&
> > + test_cmp expect actual
> > +'
>
> Our usual style these days is to set up expectations inside the test
> blocks (and use "<<-" to get nice indentation; we also typically use
> "\EOF" but that's purely style).
I copied this from a test immediately above it. :)
I can change it easily enough, though.
- Josh Triplett