mfonte / bitmask
Bitmask class helps you to use all might of bit masks and don't care about what bitwise operations are. It represents a high-level abstraction that looks like simple and manageable object and behaves like collection.
Installs: 19
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/mfonte/bitmask
Requires
- php: >=7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.4
- orchestra/testbench: ^3.5.6
- php-coveralls/php-coveralls: ^2.5.3
- phpstan/phpstan: ^1.9
- phpunit/phpunit: ^8
README
Bitmask class helps you to use all might of bit masks and don't care about what bitwise operations are. It represents a high-level abstraction that looks like simple and manageable object and behaves like collection.
Installation
Add the following dependency to your composer.json file.
{
    "require": {
        "mfonte/bitmask": "^1.0"
    }
}
Example usage
For example we have User class that can have different roles.
use Mfonte\Bit\Mask; class User { const ROLE_ADMIN = Mask::FLAG_1; const ROLE_MANAGER = Mask::FLAG_2; const ROLE_CUSTOMER = Mask::FLAG_3; /** * @var Mask */ private $roles; public function __construct() { $this->roles = new Mask(); } public function becomeAdmin() { $this->roles->add(self::ROLE_ADMIN); } public function isAdmin() { return $this->roles->has(self::ROLE_ADMIN); } ... public function isCustomer() { return $this->roles->has(self::ROLE_CUSTOMER); } ... }
Now we are able to create a user.
$user = new User(); $user->becomeAdmin(); // User now has admin role $user->becomeAdmin(); // Throws MaskException because role has been already set // and mask is in strict mode $user->isAdmin(); // Returns true $user->isCustomer(); // Returns false