From: Pierre Habouzit <madcoder@debian.org>
To: Junio C Hamano <gitster@pobox.com>
Cc: Git ML <git@vger.kernel.org>
Subject: Re: [PATCH] revisions: refactor init_revisions and setup_revisions.
Date: Mon, 10 Mar 2008 09:49:21 +0100 [thread overview]
Message-ID: <20080310084920.GA2798@artemis.madism.org> (raw)
In-Reply-To: <7v63vvkplm.fsf@gitster.siamese.dyndns.org>
[-- Attachment #1: Type: text/plain, Size: 4229 bytes --]
On Mon, Mar 10, 2008 at 07:25:25AM +0000, Junio C Hamano wrote:
> Pierre Habouzit <madcoder@debian.org> writes:
>
> struct rev_info gains two new fields:
>
> * .def to store --default argument;
> * .show_merge 1-bit field.
>
> The refactor consists of the following steps:
>
> * init_revisions now takes the --default argument to initialize .def
> properly, instead of getting it through setup_revisions.
>
> * setup_revisions has been split in two:
>
> - parse_revisions that does (almost) only argument parsing, to be more
> like what parse-options can do, and
>
> - setup_revisions that does the rest.
>
> Many places had no arguments to pass to setup_revisions, and those don't
> use parse_revisions at all.
>
> Conceptually, I like the split up into three, which are:
>
> - initializes the structure (init_revisions);
>
> - parses the user arguments (parse_revisions -- the naming could probably
> be improved, though);
Well, the goal is to replace that bit with a parse_options
structure/macro at some point, so the naming isn't really important.
> - prepares the derived/derivable fields for the real work
> (setup_revisions).
>
> Was there a particular reason you moved default to init_revisions() and
> not kept it with setup_revisions()? All the callers of cmd_log_init()
> needs to say "I want to default to HEAD" because of it, instead of letting
> cmd_log_init() say it at only one place. Also the caller needs to decide
> upfront before calling init_revisions() what the default should be.
Yes, because the revision parsing has side effects on that default
parameter (the --default command line switch).
We could of course have a .def member in the struct rev_info, and use
the one passed to setup_revisions then if it's still NULL, but it
doesn't really makes sense to me, and I don't really see a problem with
saying at init time that you'll default to "HEAD". Though if you really
dislike it that much, I squash a patch that does that on top of it.
> > Signed-off-by: Pierre Habouzit <madcoder@debian.org>
> > ---
> >
> > This is a required patch for revisions parse-optification that splits
> > the logic of revision arguments parsing in parsing, and post-processing.
> >
> > The aim is to replace parsing with parse-opt at some point.
> >
> > The final version (using parse-options) will probably need more rework
> > in revisions.[hc], but I'd like to avoid rebasing this patch over and
> > over, and I'd be glad if it's merged now, as it's not _that_
> > intrusive.
>
> > I've been using a git with this patch for a week without issues.
>
> .... which is a nice assuring comment ;-)
Well it has been even more since :)
> > @@ -892,8 +893,7 @@ static void add_grep(struct rev_info *revs, const char *ptn, enum grep_pat_token
> > opt->regflags = REG_NEWLINE;
> > revs->grep_filter = opt;
> > }
> > - append_grep_pattern(revs->grep_filter, ptn,
> > - "command line", 0, what);
> > + append_grep_pattern(revs->grep_filter, ptn, "command line", 0, what);
> > }
>
> Made me go "huh?".
Huh yeah, sorry, that's totally spurious indeed.
> But everything else looked pretty mechanical conversion, and in that sense
> it is not that intrusive.
>
> Applying this to 'master' and then merging 'pu' shows that there are a few
> topics that are cooking that would conflict with this change. Merging
> 'next' seems to go cleanly (I haven't checked the result), so it is not
> too bad for me to carrry this at this moment, if we were not this close to
> the rc freeze. I dunno.
Well I can wait longer, I'd just like to see it merged in a not too
far future, because I have to check for new places that would need
conversions at each reabase :) (though the init/setup_revisions
functions changed their number of arguments so I _think_ I should miss
none each time but …).
--
·O· Pierre Habouzit
··O madcoder@debian.org
OOO http://www.madism.org
[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
next prev parent reply other threads:[~2008-03-10 8:50 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-03-04 23:19 [PATCH] revisions: refactor init_revisions and setup_revisions Pierre Habouzit
2008-03-10 7:25 ` Junio C Hamano
2008-03-10 8:49 ` Pierre Habouzit [this message]
2008-03-10 19:36 ` Junio C Hamano
2008-03-10 20:44 ` Pierre Habouzit
-- strict thread matches above, loose matches on Subject: below --
2008-05-28 9:17 Pierre Habouzit
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20080310084920.GA2798@artemis.madism.org \
--to=madcoder@debian.org \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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 NNTP newsgroup(s).