niko9911 / bitwise-flags
使用位操作管理您的标志布尔值。
1.0.2
2021-04-08 11:02 UTC
Requires
- php: ^7.1|^8.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2
- phpunit/phpunit: ^7 || ^8
This package is auto-updated.
Last update: 2024-09-08 19:36:00 UTC
README
您可使用的标志数量受限于您的系统架构,例如:32位系统上32个标志或64位系统上64个标志。要在数据库中存储64位标志,您需要将其存储为MySQL中的UNSIGNED BIGINT。
安装
通过 composer
composer require niko9911/bitwise-flags
用法
以下是一些示例用法代码
<?php declare(strict_types=1); use Niko9911\Flags\Bits; use Niko9911\Flags\Flags; final class User extends Flags { public const BANNED = Bits::BIT_1; // 0x1 public const ADMIN = Bits::BIT_2; // 0x2 public const ACTIVATED = Bits::BIT_3; // 0x4 } /** @var User|Flags $entity */ $entity = new User(); /** Usage when using single flag. */ $entity->addFlag(User::BANNED); var_dump($entity->matchFlag(User::ADMIN)); // False var_dump($entity->matchFlag(User::BANNED)); // True $entity->removeFlag(User::BANNED); var_dump($entity->matchFlag(User::BAR)); // False /** Usage when using multiple flags. */ $entity->addFlag(User::ACTIVATED | User::ADMIN); var_dump($entity->matchFlag(User::ACTIVATED)); // True var_dump($entity->matchFlag(User::ACTIVATED | User::BANNED)); // False (Banned not set.) var_dump($entity->matchFlag(User::ACTIVATED | User::ADMIN)); // True (Both set) var_dump($entity->matchAnyFlag(User::ACTIVATED | User::BANNED)); // True. (One is set.) /** Usage with flag names. */ // Flag name is taken from constant name $entity = new User(); $entity->addFlag(User::BANNED | User::ADMIN | User::ACTIVATED); var_dump($entity->getFlagNames()); // [Banned, Admin, Activated] var_dump($entity->getFlagNames(User::ACTIVATED | User::BANNED)); // [Activated, Banned] /** Overriding automatically defined flag names. */ final class UserWCustomNames extends Flags { public const BANNED = Bits::BIT_1; public const ADMIN = Bits::BIT_2; public const ACTIVATED = Bits::BIT_3; // Implementing this specific function you can register // flags with custom naming. public static function registerFlags(): array { return [ static::BANNED => 'IsUserBanned', static::ADMIN => 'IsUserAdmin', static::ACTIVATED => 'IsUserActivated', ]; } } $entity = new UserWCustomNames(); $entity->addFlag( UserWCustomNames::BANNED | UserWCustomNames::ADMIN | UserWCustomNames::ACTIVATED ); var_dump($entity->getFlagNames()); // [ // 0 => IsUserBanned, // 1 => IsUserAdmin, // 2 => IsUserActivated, // ]