maidmaid / flag
位字段标志管理器/调试器
v0.2.1
2017-04-30 11:37 UTC
Requires
- php: >=5.6.0
- psr/log: ^1.0
Requires (Dev)
- phpunit/phpunit: ^5.7
- symfony/console: ^3.1
Suggests
- symfony/console: For debugging flags using the debug:flag command
This package is not auto-updated.
Last update: 2024-09-25 01:43:09 UTC
README
二进制标志不易理解,使用如位运算符、位掩码或位字段的概念。此外,这些标志不易调试;找到隐藏在整数字段背后的标志非常烦人。此库提供了一个流畅的API来处理位字段,并通过调试工具来提高开发者的体验。
安装
使用 Composer 在项目中安装 Flag
composer require "maidmaid/flag"
概述
例如,以下是处理 Yaml
标志 的方法
use Maidmaid\Flag\Flag; use Symfony\Component\Yaml\Yaml; $flag = Flag::create(Yaml::class) ->add(Yaml::DUMP_OBJECT) // logs '[debug] bitfield changed Yaml [bin: 1] [dec: 1] [flags: DUMP_OBJECT]' ->add(Yaml::PARSE_DATETIME) // logs '[debug] bitfield changed Yaml [bin: 100001] [dec: 33] [flags: DUMP_OBJECT | PARSE_DATETIME]' ->remove(Yaml::DUMP_OBJECT) // logs '[debug] bitfield changed Yaml [bin: 100000] [dec: 32] [flags: PARSE_DATETIME]' ; $flag->has(Yaml::DUMP_OBJECT); // returns false $flag->has(Yaml::PARSE_DATETIME); // returns true $flag->get(); // returns 288 $flag->set(100); // logs '[debug] bitfield changed Yaml [bin: 1100100] [dec: 100] [flags: PARSE_OBJECT | PARSE_DATETIME | DUMP_OBJECT_AS_MAP]' foreach ($flag as $k => $v) { echo "$k => $v "; // writes '4 => PARSE_OBJECT 32 => PARSE_DATETIME 64 => DUMP_OBJECT_AS_MAP ' }
前缀标志
如在 Caster::EXCLUDE_*
情况 中,可以处理带有前缀的标志。
use Maidmaid\Flag\Flag; use Symfony\Component\VarDumper\Caster\Caster; $flag = Flag::create(Caster::class, 'EXCLUDE_') ->add(Caster::EXCLUDE_EMPTY) // logs '[debug] bitfield changed Caster::EXCLUDE_* [bin: 10000000] [dec: 128] [EXCLUDE_*: EMPTY]' ->add(Caster::EXCLUDE_PRIVATE) // logs '[debug] bitfield changed Caster::EXCLUDE_* [bin: 10100000] [dec: 160] [EXCLUDE_*: PRIVATE | EMPTY]' ->add(Caster::EXCLUDE_NOT_IMPORTANT) // logs '[debug] bitfield changed Caster::EXCLUDE_* [bin: 110100000] [dec: 416] [EXCLUDE_*: PRIVATE | EMPTY | NOT_IMPORTANT]' ;
分层标志
如在 Output::VERBOSITY_*
情况 中,标志是分层的,如下所示
VERBOSITY_VERY_VERBOSE
└── VERBOSITY_VERBOSE
└── VERBOSITY_NORMAL
这意味着如果设置了 VERBOSITY_VERY_VERBOSE
标志,则也会隐式设置 VERBOSITY_VERBOSE
和 VERBOSITY_NORMAL
。
use Symfony\Component\Console\Output\Output; use Maidmaid\Flag\Flag; $flag = Flag::create(Output::class, 'VERBOSITY_', $hierachical = true) ->add(Output::VERBOSITY_VERBOSE) // logs '[debug] bitfield changed Output::VERBOSITY_* [bin: 1000000] [dec: 64] [VERBOSITY_*: QUIET | NORMAL | VERBOSE]' ->add(Output::VERBOSITY_DEBUG) // logs '[debug] bitfield changed Output::VERBOSITY_* [bin: 101000000] [dec: 320] [VERBOSITY_*: QUIET | NORMAL | VERBOSE | VERY_VERBOSE | DEBUG]' ;
全局标志
可以处理全局空间中的标志,如使用 E_*
错误标志。
use Maidmaid\Flag\Flag; $flag = Flag::create(null, 'E_') ->add(E_ALL) // logs '[debug] bitfield changed E_* [bin: 111111111111111] [dec: 32767] [E_*: ERROR | RECOVERABLE_ERROR | WARNING | PARSE | NOTICE | STRICT | DEPRECATED | CORE_ERROR | CORE_WARNING | COMPILE_ERROR | COMPILE_WARNING | USER_ERROR | USER_WARNING | USER_NOTICE | USER_DEPRECATED | ALL]' ->set(0) // logs '[debug] bitfield changed E_* [bin: 0] [dec: 0] [E_*: ]' ->add(E_USER_ERROR) // logs '[debug] bitfield changed E_* [bin: 100000000] [dec: 256] [E_*: USER_ERROR]' ->add(E_USER_DEPRECATED) // logs '[debug] bitfield changed E_* [bin: 100000100000000] [dec: 16640] [E_*: USER_ERROR | USER_DEPRECATED]' ;
无整数标志
如在 Request::METHOD_*
情况 中,值标志不是整数而是字符串。例如,METHOD_GET
有 GET
字符串作为值。这些字符串值在内部被二进制化。
use Symfony\Component\HttpFoundation\Request; use Maidmaid\Flag\Flag; $flag = Flag::create(Request::class, 'METHOD_') ->add(Request::METHOD_GET) // logs '[debug] bitfield changed Request::METHOD_* [bin: 10] [dec: 2] [METHOD_*: GET]' ->add(Request::METHOD_POST) // logs '[debug] bitfield changed Request::METHOD_* [bin: 110] [dec: 6] [METHOD_*: GET | POST]' ->add(Request::METHOD_PUT) // logs '[debug] bitfield changed Request::METHOD_* [bin: 1110] [dec: 14] [METHOD_*: GET | POST | PUT]' ;
独立标志
也可以处理无常量标志。
use Maidmaid\Flag\Flag; $flag = Flag::create() ->add('a') // logs '[debug] bitfield changed [bin: 1] [dec: 1] [flags: a]' ->add('b') // logs '[debug] bitfield changed [bin: 11] [dec: 3] [flags: a | b]' ; $flag = (new Flag()) ->add(8) // logs '[debug] bitfield changed [bin: 1000] [dec: 8] [flags: 8]' ->add(32) // logs '[debug] bitfield changed [bin: 101000] [dec: 40] [flags: 8 | 32]' ;
调试
如果您添加了 symfony/console
推荐的软件包,您可以使用 debug:flag
命令来调试您的标志。运行 php bin/flag --help
获取详细信息。
许可
Flag 在 MIT 许可下授权 - 详细信息请参阅LICENSE 文件。