galaxon / core
Core PHP utilities for floats, integers, arrays, types, and string conversion with IEEE-754 support.
Requires
- php: ^8.4
Requires (Dev)
- dealerdirect/phpcodesniffer-composer-installer: ^1.0
- galaxon/coding-standard: ^1.0
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0 || ^11.0 || ^12.0
- squizlabs/php_codesniffer: ^4.0
README
A general purpose library containing core utility classes and methods for use by other Galaxon PHP packages.
License | Changelog | Documentation
Description
This package provides a comprehensive set of utility classes for working with various PHP types and common operations. All utility classes are final with static methods and cannot be instantiated.
Development and Quality Assurance / AI Disclosure
Claude Chat and Claude Code were used in the development of this package. The core classes were designed, coded, and commented primarily by the author, with Claude providing substantial assistance with code review, suggesting improvements, debugging, and generating tests and documentation. All code was thoroughly reviewed by the author, and validated using industry-standard tools including PHP_Codesniffer, PHPStan (to level 9), and PHPUnit to ensure full compliance with PSR-12 coding standards and comprehensive unit testing with 100% code coverage. This collaborative approach resulted in a high-quality, thoroughly-tested, and well-documented package delivered in significantly less time than traditional development methods.
Requirements
- PHP ^8.4
Installation
composer require galaxon/core
Classes
Numbers
General number-related utility methods including sign operations.
Floats
Float-specific utilities for handling IEEE-754 special values (-0.0, ±INF, NAN), approximate comparison, float space navigation (next/previous), random generation, and IEEE-754 component assembly/disassembly.
Integers
Integer arithmetic operations with overflow checking (add, subtract, multiply, power), GCD calculation, and Unicode subscript/superscript conversion.
Arrays
Array utility methods including circular reference detection, value quoting, and first/last element extraction.
Types
Type checking and inspection utilities with methods for identifying numbers, unsigned integers, traits, and generating unique string keys.
Strings
String conversion and output utilities. Converts any value to a string, passing strings through as-is and using __toString() for Stringable objects.
Stringify
Advanced value-to-string conversion with pretty printing, supporting all PHP types with improved readability.
Functions
Functions
Convenience functions in the Galaxon\Core namespace, including println() for outputting strings and other values.
Traits
Comparison Traits
Equality and ordering comparison operations for custom types. See ComparisonTraits.md for the trait hierarchy and usage guide.
| Trait | Description |
|---|---|
| Equatable | Base trait for exact equality comparison via equal(). |
| Comparable | Extends Equatable with ordering: lessThan(), greaterThan(), etc. |
| ApproxEquatable | Extends Equatable with tolerance-based approxEqual(). |
| ApproxComparable | Combines Comparable and ApproxEquatable with approxCompare(). |
Assert Traits
Custom PHPUnit assertions for test cases. See TestingTraits.md for usage examples.
| Trait | Description |
|---|---|
| FloatAssertions | Provides assertApproxEqual() and assertApproxZero() with informative failure messages. |
Exceptions
IncomparableTypesException
Exception thrown when attempting to compare values of incompatible types. Used by the Comparable and ApproxComparable traits. Automatically generates descriptive error messages.
FormatException
Exception thrown when a string has an invalid format for the desired operation. Extends DomainException. Useful for parse methods or constructors that accept string arguments.
Testing
The library includes comprehensive test coverage:
# Run all tests vendor/bin/phpunit # Run specific test class vendor/bin/phpunit tests/NumbersTest.php # Run with coverage (generates HTML report and clover.xml) composer test
License
MIT License - see LICENSE for details
Support
- Issues: https://github.com/mossy2100/Galaxon-PHP-Core/issues
- Documentation: See docs/ directory for detailed class documentation
- Examples: See test files for comprehensive usage examples
For questions or suggestions, please open an issue.
Changelog
See CHANGELOG.md for version history and changes.
