Join GitHub today
GitHub is home to over 28 million developers working together to host and review code, manage projects, and build software together.Sign up
better support for multi-valued configuration flags #394
For some packages one has to pick one of several mutually exclusive options. For example yi has a number of console or gui front ends.
That can be expressed in terms of boolean flags but it's a little clumsy. We should consider adding some syntactic sugar.
Currently it can be expressed by excluding the choice of picking none:
if flag(gtk) ... if flag(vty) ... if flag(coca) && os(osx) ... if ! ( flag(gtk) || flag(vty) || (flag(coca) && os(osx)) ) buildable: falseThat doesn't exclude the possibility of picking two options of course.
In some cases we would want the options to be mutually exclusive and in others we would want to simply force the choice of one option, but multiple options might be possible.
So the question is what kind of syntactic sugar would we like, how would it translate and how would it be exposed to package managers. eg:
flag gui values: gtk, vty, coca if flag(gui==gtk) ... etcand it'd translate into boolean choices that forced a choice of one flag being true and the others false.
Needs some thought.