[yocto] Idea for bbappend / layer organization and naming convention

Bruce Ashfield bruce.ashfield at windriver.com
Mon Aug 14 20:02:14 PDT 2017


On 2017-08-14 3:36 PM, Gunnar Andersson wrote:
> 
> Yocto community,
> 
> Triggered by the previous email request to yocto@ about best practices for
> layer organization I'm finally firing off this email for (hopefully) some
> feedback on an idea we first kicked around, discussed for rough consensus
> and then decided to implement in the Yocto based GDP project [1].  You can
> see it as a trial, anything can be changed, but so far so good...
> 
> We adopted a somewhat novel (but actually not really unique, see inside)
> naming convention [2] for all modifications to components that belong to
> other layers.
> 

I've been using a similar naming/sorting mechanism in layers that
I maintain for several years now. When you have a single layer that
is carrying bbappends to many other layers, I find that it really
helps keep everything separated and aids finding the original
recipe.

(that being said, recent work with layer index, etc, make it
easier to locate the original recipe and any bbappends .. but that
doesn't preclude keeping things organized in a layer).

Cheers,

Bruce

> This convention shows what layers are being modified by the .bbappends by
> actually naming the layer it is (intending to**) modify.  The initiative
> also aims to highlight and separate .bbappends (modifications) from uniquely
> added components in our project (new .bb files) in GDP.
> 
> **Note that we are well aware this does NOT control bitbake behavior (as
> neither does the recipe-xxx/ directory convention), and is therefore just a
> guide.  If the project is misconfigured, bitbake could do something
> different than the naming convention implies and it could even be
> misleading, but at least the *programmer intent* is shown clearly.
> 
> I think it also makes .bbappends more explicitly visible and might trigger
> the idea:   Do we really need this?  Are we really modifying *that* adopted
> layer, and if so, why?
> 
> To Russel who wrote the previous request for guidance - feel free to
> consider, but I won't recommend this directly since it's by no means an
> agreed best practice in all of the community.  I'm rather asking for other
> experienced OE developers to consider and comment on the idea.
> 
> For oldtimers it's probably easy to find this odd and just be negative
> against it since well, "standard practice", inertia, NIH and all that, but
> I'll stick my neck out anyway because it seems to solve some issues of
> organization and understanding at least for us (and I'm a sucker for some
> flamebait ;)
> 
> If the intro is too formal and long, just look at the final examples.  I
> think you'll get it.  Feel free to ask.
> 
> 
> - Gunnar
> 
> -- 
> Gunnar Andersson <gandersson at genivi.org>
> Development Lead
> GENIVI Alliance
> 
> [1] https://github.com/GENIVI/genivi-dev-platform
> [2] Naming strategy for bitbake extension layers:			
> https://at.projects.genivi.org/wiki/x/w4Xk
> 
> 
> 




More information about the yocto mailing list