Hi Dennis,

On Thu, 1 Sep 2016, Dennis Kaarsemaker wrote:

> On wo, 2016-08-31 at 10:56 +0200, Johannes Schindelin wrote:
> > diff --git a/sequencer.c b/sequencer.c
> > index 51c2f76..4c902e5 100644
> > --- a/sequencer.c
> > +++ b/sequencer.c
> > @@ -763,7 +763,8 @@ enum todo_command {
> >         TODO_SQUASH,
> >         TODO_EXEC,
> >         TODO_NOOP,
> > -       TODO_DROP
> > +       TODO_DROP,
> > +       TODO_COMMENT
> >  };
> 
> (picking a random commit that touches this enum)
> 
> In a few places you now make comparisons like "< TODO_NOOP", so I think
> it would be good to have a comment near the definition of this enum
> that says that ordering matters and why, so people don't attempt to add
> a new TODO_FOOBAR at the end.

True.

It does not seem that we have a precedent for that. The closest is what I
had in an early iteration of the fsck message IDs, and subsequently things
were refactored so that it is not the order, but a flag, that determines
what the command does.

Not sure how to do this elegantly. Maybe like this?

        enum todo_command {
                TODO_PICK_COMMANDS = 0,
                TODO_PICK = TODO_PICK_COMMANDS,
                TODO_SQUASH,

                TODO_NON_PICK_COMMANDS,
                TODO_EXEC = TODO_NON_PICK_COMMANDS,

                TODO_NOOP_COMMANDS,
                TODO_NOOP = TODO_NOOP_COMMANDS,
                TODO_DROP
                TODO_DROP,

                TODO_LAST_COMMAND,
                TODO_COMMENT = TODO_LAST_COMMAND
        };

But that is so god-awful to read.

Still unsure,
Dscho

Reply via email to