Skip to content

Composer Versioning

Identifier

composer

References

Ranges/Constraints

✅ Ranges are supported.

Valid rangeStrategy values are: bump, widen, pin, replace, update-lockfile

Description

Composer uses Semver-like versioning, but some package authors may use versions that are not completely valid, e.g. 1.2 instead of 1.2.0.

Composer supports ranges in a similar manner to npm, but not identical. The main difference is with tilde ranges.

Tilde ranges with "short" versions are different to npm. e.g.

~4 is equivalent to ^4 in npm ~4.1 is equivalent to ^4.1 in npm ~0.4 is equivalent to >=0.4 <1 in npm

Composer supports patches in the version numbers, which are considered stable. E.g., 1.2.3-p1 is recognized by npm as unstable, Renovate implements additional logic to support correct sorting and stability checks on composer patch versions syntax.


Open items

The below list of features and bugs were current when this page was generated on January 21, 2025.

Feature requests

  • Composer versioning: widening of range should use | instead of || if already in use #28299
  • Composer: support non-semver (four part) versions #28297

Bug reports

  • Composer: unsupported value if != constraint used #31504
  • Composer: unsupported value if version number contains leading zero #26861
  • Composer versioning uses stability modifiers incorrectly #24993
  • composer-versioning is not respecting major.minor ranges #11027