On Thu, 2012-09-13 at 03:39 -0700, Brian Harring wrote:
> Hola.
> 
> CC'ing pms since obviously they should comment, although the 
> discussion should be on -dev (aka, public, not an alias).
> 
> Sorry, this is a long email; condensing it down into a glep is viable, 
> just my time is limited (it's telling I started the gentoo stuff at 
> 2am, wrapping up likely at 4am).
> 
> The length of this email basically relates to the subtlety of this 
> proposal; at first glance it may appear as if I'm proposing a syntax 
> shuffle just for aesthetic reasons, but as elaborated in the tail end, 
> that subtle syntax change opens up a lot of possibilities.
> 
> 
> Either way, what I propose, is pretty simple.  Currently USE_EXPAND'd 
> groups are pushed into USE in the form ${use_group}_${setting}.
> 
> Thus VIDEO_CARDS="intel nvidia" becomes video_cards_intel 
> video_cards_nvidia.  This should be reasonably well known and 
> understood from the dev standpoint; from the PM side of things, this 
> actually seriously sucks ass; if we see video_cards_intel in an IUSE 
> somewhere, we don't know if it's a USE flag, or a use_expanded group; 
> to figure that out, we basically have to do a longest prefix matching 
> (or suffix tree).
> 
> There in is one of the subtle design flaws of it; two USE_EXPAND'd 
> targets, VIDEO_CARDS and VIDEO, can intersect in their namespace.  
> While we (devs) intentionally avoid this potential via careful name 
> choice, the fact the possibility exists is a bit of a sign that 
> USE_EXPAND was a bit of a hack.
> 
> What I propose is simple enough, and is for >=EAPI5:
> 
> 1) We disallow '@' in USE flags (yes, a use flag can actually have 
> '@' in it's name according to PMS; someone was hitting the crack 
> pipe pretty damn hard when they allowed that one).  This doesn't 
> impact anything in gentoo-x86, nor any tree I've ever seen.
> 
> 2) If <EAPI5, we continue exporting video_cards_nvidia 
> (${use_group}_${setting}).
> 
> 3) If >=EAPI5, we export ${use_group}_${setting}, *and* 
> ${use_group}@${setting}.  While there may be complaints about having 
> it exported in two fashions, the reason for this is simple- it makaes 
> transition way the fuck easier, meaning we don't make devs wrie pain 
> in the ass "if eapi x, else blah" code.  Basically, for eclass code, 
> the dev would do thus:
> 3.a) If the eclass supports <EAPI5, they check for the old form; 
> ${use_group}_${setting}.
> 3.b) If however that eclass is >=EAPI5, they should check for the new 
> form; ${use_group}@{setting}.
> 
> 4) At some point in the future, when either code involved has migrated 
> all to EAPI5, or we do something in a later EAPI that renders 
> supporting ${use_group}_${setting} untenuable, we stop exporting 
> ${use_group}_${setting} for those EAPIs.  Preferably with one EAPI 
> cycle w/ deprecation warnings.
> 
...
> ~harring
> 

+1

This would make things easier for PM consumer apps to process use flags
without specialized code to figure out if the flag was use_expanded or
just had an "_" in it's name...

-- 
Brian Dolbec <dol...@gentoo.org>

Attachment: signature.asc
Description: This is a digitally signed message part

Reply via email to