f#获取可能的歧视联合项目列表

abh*_*hek 5 f#

我正在创建一个带有多个受歧视联盟(DU)的简单DSL.有积木DU和较高的DU建立在较低的顶部之上.

现在我想创建UI,用户可以在其中构建与我的DSL匹配的文本.到UI我不想表达我的完整语法,但只显示可以执行的操作.所以我需要一种方法来从我的层次结构DU中找出用户可以做的其他可能状态.

示例输入文本 (1 + (2 * 3))

type Expression =
   | Constant of int
   | Add of Expression * Expression
   | Mul of expression * Expression
Run Code Online (Sandbox Code Playgroud)

所以当用户启动时,我必须返回一个只能Constant使用的列表.当用户将(常量)作为当前状态传递时,我必须告诉你可以add/Mul(这是表达式)等等.

我想用一种类型安全的方式表示一种结构,它表示当前状态和可能的状态.有没有办法在f#中解决这类问题

Sea*_*ron 1

我想你正在寻找FSharpType.GetUnionCases。您可以按如下方式使用它:

open System
open Microsoft.FSharp.Collections
open Microsoft.FSharp.Reflection

type Expression =
   | Constant of int
   | Add of Expression * Expression
   | Mul of Expression * Expression

typeof<Expression> |> FSharpType.GetUnionCases|> Dump |> ignore
Run Code Online (Sandbox Code Playgroud)

以上内容的 LinqPad在这里