mpyw/sharable-value-objects
最新稳定版本:v1.1.0
Composer 安装命令:
composer require mpyw/sharable-value-objects
包简介
Share value objects that contain the same primitive value as a singleton.
README 文档
README
Share value objects that contain the same primitive value as a singleton.
Important
Singleton objects are kept under WeakReference.
Tip
You can compare objects like primitives through === operator!
Value::create('one') === Value::create('one') // This should be true Value::create('one') === Value::create('two') // This should be false
Requirements
- PHP:
^8.2
Note
Older versions have outdated dependency requirements. If you cannot prepare the latest environment, please refer to past releases.
Installing
composer require mpyw/sharable-value-objects
Caution
PHP 8.3.2 is incompatible due to the bug in the PHP core.
Usage
class ScreenName { // 1. Mixin Sharable trait family use SharableString; // 2. Write your instantiation logic here public static function create(string $value): static { // Validation/Assertion if (!preg_match('/\A@\w{4,15}\z/', $value)) { throw new \InvalidArgumentException("invalid screen_name: $value"); } // ** Call static::acquire() to get instance ** return static::acquire($value); } // 3. Write your raw presentation logic here public function value(): string { // ** Call $this->getOriginalValue() to retrieve original value ** return $this->getOriginalValue(); } }
class ScreenNameTest extends TestCase { public function testSame(): void { // Same parameters yield the same instance $this->assertSame( ScreenName::create('@mpyw'), ScreenName::create('@mpyw'), ); } public function testDifferent(): void { // Different parameters yield different instances $this->assertNotSame( ScreenName::create('@mpyw'), ScreenName::create('@X'), ); } }
统计信息
- 总下载量: 84.64k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 7
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2021-11-11