spryker/decimal-object

PHP decimal handling as value object

Maintainers

👁 spryker-bot

Package info

github.com/spryker/decimal-object

pkg:composer/spryker/decimal-object

Statistics

Installs: 3 015 018

Dependents: 39

Suggesters: 1

Stars: 23

Open Issues: 4

1.2.1 2026-02-20 11:25 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT b0e7245379eab01d6b10645a6549d8664b24e8be

This package is auto-updated.

Last update: 2026-06-27 06:58:25 UTC


README

👁 Build Status
👁 codecov
👁 Latest Stable Version
👁 Minimum PHP Version
👁 PHPStan
👁 License

Decimal value object for PHP.

Background

When working with monetary values, normal data types like int or float are not suitable for exact arithmetic. Try out the following in PHP:

var_dump(0.1 + 0.2); // float(0.3)
var_dump(0.1 + 0.2 - 0.3); // float(5.5511151231258E-17)

Handling them as string is a workaround, but as value object you can more easily encapsulate some of the logic.

Alternatives

Solutions like https://php-decimal.io require a PHP extension (would make it faster, but also more difficult for some servers to be available). For details see the wiki.

Features

  • Super strict on precision/scale. Does not lose significant digits on its own. You need to trim() for this manually.
  • Speaking API (no le, gt methods).
  • Basic math operations and checks supported.
  • Immutability.
  • Handle very large and very small numbers.

Installation

Requirements

  • bcmath PHP extension enabled

Composer (preferred)

composer require spryker/decimal-object

Usage

See Documentation for more details.

Implementations

The following libraries are using the Decimal value object: