不可能从 IMethodSymbol可靠地获取 MethodInfo,因为您需要加载包含该方法所在类型的程序集,这可能是正在解析的脚本的情况,但可能不是代码的情况正在执行分析。
换句话说,您正在运行的脚本代码可能加载了程序集 X,其中包含类型 T,其中包含方法 M(因此脚本代码可以包含调用方法 M 的代码),但分析器可能没有加载程序集 X 并且因此它无法加载类型 T,因此无法获取方法 M 的 MethodInfo 实例。
但是,对于像 System 这样的程序集,您可以从分析器代码中访问它可能是一个相当安全的选择。
因此,您需要做的就是获取具有该方法的类型的名称空间和类型名称,并为其获取一个 TypeInfo 实例。然后使用 GetMethod - 将方法名称和参数类型传递给它以获取 MethodInfo。像这样的东西:
var invocation = (InvocationExpressionSyntax)context.Node;
var methodSymbol = (IMethodSymbol)context.SemanticModel.GetSymbolInfo(invocation).Symbol;
var declaringTypeName = string.Format(
"{0}.{1}",
methodSymbol.ContainingType.ContainingAssembly.Name,
methodSymbol.ContainingType.Name
);
var methodName = methodSymbol.Name;
var methodArgumentTypeNames = methodSymbol.Parameters.Select(
p => p.Type.ContainingNamespace.Name + "." + p.Type.Name
);
var methodInfo = Type.GetType(declaringTypeName).GetMethod(
methodName,
methodArgumentTypeNames.Select(typeName => Type.GetType(typeName)).ToArray()
);
值得注意的是,分析器通常是无法访问完整反射 API 的可移植类库(这意味着上面的代码将不起作用),但如果您只是在项目中使用 Roslyn 来分析一些脚本,那么您可能不必有这个限制。