我正在尝试在程序中使用optparse-applicative库,该程序应根据参数的数量执行不同的操作。
例如,计算周长的程序的参数解析:
module TestOpts where
import Options.Applicative
type Length = Double
data PerimeterCommand
= GeneralQuadranglePerimeter Length Length Length Length
| RectanglePerimeter Length Length
parsePerimeterCommand :: Parser PerimeterCommand
parsePerimeterCommand = parseQuadPerimeter <|> parseRectPerimeter
parseQuadPerimeter = GeneralQuadranglePerimeter <$>
parseLength "SIDE1" <*>
parseLength "SIDE2" <*>
parseLength "SIDE3" <*>
parseLength "SIDE4"
parseRectPerimeter = RectanglePerimeter <$>
parseLength "WIDTH" <*> parseLength "HEIGHT"
parseLength name = argument auto (metavar name)
只有第一个参数才能<|>
成功解析。我认为需要某种参数回溯,类似于 Parsec 的try
组合器。
关于如何解析替代参数集的任何想法,当第一个替代方案可能会消耗下一个替代方案的一些参数时?