首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用CQLinq在单个查询中获取方法和字段的度量

如何使用CQLinq在单个查询中获取方法和字段的度量
EN

Stack Overflow用户
提问于 2016-05-07 02:35:23
回答 1查看 129关注 0票数 2

我正在用CQLinq在NDepend中计算标识符的平均长度,我希望得到类、字段和方法名称的长度。我浏览了CQlinq:http://www.ndepend.com/docs/cqlinq-syntax的这一页,代码如下:

代码语言:javascript
复制
let id_m = Methods.Select(m => new { m.SimpleName, m.SimpleName.Length })
let id_f = Fields.Select(f => new { f.Name, f.Name.Length })
select id_m.Union(id_f)

它不起作用,有一个错误说:

'System.Collections.Generic.IEnumerable‘不包含’Union‘的定义.

另一个是:

无法从“System.Collections.Generic.IEnumerable”转换为“System.Collections.Generic.HashSet”

但是,根据MSDN,IEnumerable接口定义了Union()和Concat()方法。

在我看来,我不能像Linq那样使用CQLinq。无论如何,是否有一种方法可以从单个查询中的类型、方法和字段域获取信息?

非常感谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-09 13:27:26

是否有方法从单个查询中的类型、方法和字段域获取信息?

目前还不能,因为CQLinq查询只能匹配类型序列、方法序列或字段序列,因此需要三个不同的代码查询。

对于下一个版本的CQLinq,将得到很大的改进,实际上,您将能够编写如下内容:

代码语言:javascript
复制
from codeElement in Application.TypesAndMembers 
select new { codeElement, codeElement.Name.Length }

下一个版本将在2016年年底前提供。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37083906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档