hershel-theodore-layton/printf-state-machine
最新稳定版本:v0.2.1
Composer 安装命令:
composer require hershel-theodore-layton/printf-state-machine
包简介
Generate HH\FormatString<T> state machines
README 文档
README
Generate HH\FormatString<T> state machines.
This package uses a code generator to create state machines that process
HH\FormatString<T> with their arguments and the accompanying typesafety
interfaces. This is a --dev dependency. You don't need this generator in
production to use the state machines.
Usage
You can chain together your own format string DSL in little to no time.
Start with PrintfStateMachine\Factory::create() and chain ->with... methods.
Once your DSL is ready, invoke
|> PrintfStateMachine\codegen($$, PrintfStateMachine\ENGINE_TEMPLATE). You will
get Entities, which are "just code". Put this code somewhere in a namespace
it won't conflict with any other engines. Then create a typesafe caller.
function your_format_function( \HH\FormatString<\YourNamespace\YourType> $format, mixed ... $args )[]: (string, vec<mixed>) { return \YourNamespace\engine($format, $args); }
This will transform your format and arguments according to the rules you've set out in your factory.
Use case
HH\Lib\SQL\Query has support for these specifiers:
| Specifier | Effect |
|---|---|
%d %f %s |
nullable int, float, and string |
%=d %=f %=s |
equality for int, float, and string |
%C %T |
column and table names |
%Ld %Lf %Ls %LC |
list of int, float, string, and column |
%K |
/* comments */ |
%Q |
nested Query objects |
You may very well want to add a strongly typed %N for TableAndColumnName
to make sure that you never accidentally switch around a column name and a
user supplied value. Short of patching the Hack typechecker, or building a
very difficult to write linter that depends on type information, you'd need
a tool like this. Write a definition for 12 (excluding %C and %T) specifiers
and add ->withRewrite<TableAndColumnName>('N', 'C'). The format and args were
typechecked by Hack.
A library will be published with these implementations.
统计信息
- 总下载量: 208
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-06-22