定制 hershel-theodore-layton/printf-state-machine 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Hack

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-22