Codeline Management
The Cassini project is developed and released based on Yocto’s release branch process. This strategy allows us to make Major, Minor and Point/Patch Releases based on upstream stable branches, reducing the risk of having build and runtime issues.
Yocto Release Process Overview
 
The diagram above gives an overview of the Yocto branch and release process:
- Development happens primarily in the main (or master) branch. 
- The project has a major release roughly every 6 months where a stable release branch is created. 
- Each major release has a codename which is also used to name the stable release branch (e.g. kirkstone, scarthgap). 
- Once a stable branch is created and released, it only receives bug fixes with minor (point) releases on an unscheduled basis. 
- The goal is for users and 3rd parties layers to use these codenamed branches as a means to be compatible with each other. 
For a complete description of the Yocto release process, support schedule and other details, see the Yocto Release Process documentation.
Cassini Branch and Release Process
 
Cassini’s branch and release process is based on the Yocto release process. The following sub-sections describe in more details the branch strategy for Cassini’s development and release process.
Cassini main branch
- Represented by the green line on the diagram above. 
- The repository’s - mainbranch is meant to be compatible with- masteror- mainbranches from Poky and 3rd party layers.
- meta-cassiniis actively developed on this- mainbranch.
Cassini release branches
- Represented by the blue line on the diagram above. 
- A new release branch in Cassini is setup for each new Yocto release using the Yocto codename the branch targets. 
- Hot fixes in the main branch are back ported to the release branch if it is relevant and applicable. 
- Release branches are currently maintained not much longer than a Yocto release period (~7 months).