所以,我觉得这是可能的,但我没有把它拼凑起来.我有查找表(ID和名称字段).我有枚举,我与查找保持同步.我想要的是创建一个SQL表列表,并让roslyn在编译期间/之前创建枚举.通过这种方式,我知道我的枚举总是同步的,而且这是我的另一件事.
有人可以告诉我这样,或者告诉我为什么这会是一个坏主意?我觉得解决方案并不是真的很多代码......
谢谢!
这是你用roslyn创建枚举的方法;
class Program
{
static void Main(string[] args)
{
var member1 = Syntax.EnumMemberDeclaration(
identifier: Syntax.Identifier("Member1")
);
var declaration = Syntax.EnumDeclaration(
identifier: Syntax.Identifier("MyEnum"),
modifiers: Syntax.TokenList(Syntax.Token(SyntaxKind.PublicKeyword)),
members: Syntax.SeparatedList(member1)
);
Console.WriteLine(declaration.Format());
Console.ReadLine();
}
}
Run Code Online (Sandbox Code Playgroud)
这会返回:
public enum MyEnum
{
Member1
}
Run Code Online (Sandbox Code Playgroud)
现在问题,我不知道这是否是你真正需要的.
首先,我认为在预编译时还没有任何内置功能可以执行此操作,因此您需要创建一个控制台exe并在预建事件中调用它.
因此,在这一点上,通过代码生成手动执行此操作可能更好,而不是每次构建都是如此,除非这些表经常更改.
在这种情况下,你真的不需要roslyn为你做这件事,你可以用任何代码生成软件吐出来,或者自己动手......