`go generate` 解析指令时仅支持空格分隔或双引号包裹的参数,单引号会被忽略,导致含空格的 `-data` 值被截断或丢失。
在 Go 的 //go:generate 指令中,参数解析由 go 工具自身完成,不经过 shell 解释器。这意味着它不支持 shell 特性(如单引号、变量展开、命令替换等),仅遵循其内置的简单词法解析规则:
✅ 支持:
❌ 不支持:
//go:generate myprog -someName thisname -data "Request: Typ \".\" callMe, Rsp: MyTyp \".\" close"
注意:双引号内的 . 需要写成 \. 以避免被 Go 工具误解析为特殊符号(尽管实际中 . 通常无害,但显式转义更安全);若字符串本身含双引号,则用 \" 转义:
//go:generate myprog -data "He said: \"Hello, world!\" and used a dot: \."

运行以下命令查看 go generate 实际调用的完整命令行:
go generate -n
输出类似:
run myprog -someName thisname -data 'Request: Typ "." callMe, Rsp: MyTyp "." close'
⚠️ 若看到单引号,说明你代码里写了单引号——这正是问题根源(go 工具不会保留单引号,而是将其当作字面量或引发解析错误)。
总之:永远用双引号包裹含空格的 flag 值,禁用单引号——这是 go generate 的硬性约定,而非 bug。