Versioning policy
CKEditor 5 consists of multiple npm packages (over 50, at the moment of writing this guide). When releasing them, we use the following rules:
- We use the
MAJOR.MINOR.PATCH
version identifiers. - All packages are always in the same version.
- A major release of CKEditor 5 (i.e. of all its packages) is published when at least one of its packages must have a major release.
- A minor version of CKEditor 5 (i.e. of all its packages) is published when at least one of its packages must have a minor release and none of them require a major release.
- A package must have a major release when it contains a major breaking change.
- If none of the packages contain any major breaking change, the following rules are used to determine the new version of each package:
- If a package contains a minor breaking change, a
MINOR
version is increased. - If a package contains a new feature, a
MINOR
version is increased. - If a package contains only bug fixes, unrelated changes (e.g. updated translations), documentation or other internal changes, a
PATCH
version is increased.
- If a package contains a minor breaking change, a
- In order to ensure that all packages are in the same version, some releases of certain packages may be empty (no changes).
# Major and minor breaking changes
The ecosystem of CKEditor 5 consists of multiple layers. Our approach to breaking changes and their effect depends on which layer is affected.
- The integration layer. This is the most commonly used API which is used to integrate and customize existing builds or editors built from source. It also includes their setup (whose features are included and their default configuration).
- Breaking changes frequency: as rarely as possible. Therefore, changes to this layer are usually done in a backward compatible way.
- A breaking change in this layer is understood as a major breaking change.
- The plugin development API layer. This is the API exposed by packages such as
@ckeditor/ckeditor5-engine
or@ckeditor/ckeditor5-core
, which is commonly used by plugin developers.- Breaking changes frequency: rarely. This layer is still frequently used by developers, therefore, we try to limit breaking changes. However, to avoid increasing the technical debt, from time to time we will introduce breaking changes to one or more packages. We also try to “batch” them in order to have as many breaking changes done in one release as possible, to reduce the frequency of major releases.
- A breaking change in this layer is understood as a major breaking change.
- The low-level customizability API layer. This is the part of package APIs that allows tweaking the behavior of existing features, their UI, etc. and building other features on top of the existing ones or by using their helpers.
- Breaking changes frequency: frequent. This layer, while exposed by CKEditor 5 Framework, is often closely connected to the architecture of a certain feature and may expose some implementation details. We want this layer to be public as it increases the ability to reuse the code, however, we cannot guarantee its stability on the same level as in the two previous layers.
- A breaking change in this layer is understood as a minor breaking change.
# Why not semantic versioning?
Prior to version 15.0.0 each package was versioned independently and followed the semantic versioning (semver). Following semver as close as possible was useful as it allowed to quickly identify what changed in each release of a certain package. However, it lead to problems with building old versions of the editor.
Therefore, we switched to a more commonly used practice for an ecosystem of packages, which is to treat a single breaking change as a major release of all packages. It automatically fixed the aforementioned problem in all projects that use caret ranges in their package.json
files. Later on, we decided that it will be even more convenient for integrators if all packages are in the exact same version, which is also not uncommon (e.g. Angular follows this practice).
Every day, we work hard to keep our documentation complete. Have you spotted an outdated information? Is something missing? Please report it via our issue tracker.