当前位置: 首页>>代码示例>>C#>>正文


C# SelectOrGroupClauseSyntax类代码示例

本文整理汇总了C#中SelectOrGroupClauseSyntax的典型用法代码示例。如果您正苦于以下问题:C# SelectOrGroupClauseSyntax类的具体用法?C# SelectOrGroupClauseSyntax怎么用?C# SelectOrGroupClauseSyntax使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


SelectOrGroupClauseSyntax类属于命名空间,在下文中一共展示了SelectOrGroupClauseSyntax类的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetTypeInfo

 public override TypeInfo GetTypeInfo(SelectOrGroupClauseSyntax node, CancellationToken cancellationToken = default(CancellationToken))
 {
     var bound = GetBoundQueryClause(node);
     return GetTypeInfoForQuery(bound);
 }
开发者ID:orthoxerox,项目名称:roslyn,代码行数:5,代码来源:MemberSemanticModel.cs

示例2: GetTypeInfo

 public override TypeInfo GetTypeInfo(SelectOrGroupClauseSyntax node, CancellationToken cancellationToken = default(CancellationToken))
 {
     CheckSyntaxNode(node);
     var model = this.GetMemberModel(node);
     return (model == null) ? default(TypeInfo) : model.GetTypeInfo(node, cancellationToken);
 }
开发者ID:nileshjagtap,项目名称:roslyn,代码行数:6,代码来源:SyntaxTreeSemanticModel.cs

示例3: HandleSelectOrGroup

 private static void HandleSelectOrGroup(SelectOrGroupClauseSyntax selectOrGroup, List<SyntaxToken> tokensToCheck)
 {
     switch (selectOrGroup.Kind())
     {
     case SyntaxKind.SelectClause:
         var selectClause = (SelectClauseSyntax)selectOrGroup;
         tokensToCheck.Add(selectClause.SelectKeyword);
         break;
     case SyntaxKind.GroupClause:
         var groupClause = (GroupClauseSyntax)selectOrGroup;
         tokensToCheck.Add(groupClause.GroupKeyword);
         break;
     }
 }
开发者ID:EdwinEngelen,项目名称:StyleCopAnalyzers,代码行数:14,代码来源:SA110xQueryClauses.cs

示例4: IsReducedSelectOrGroupByClause

        /// <summary>
        /// When queries are translated into expressions select and group-by expressions such that
        /// 1) select/group-by expression is the same identifier as the "source" identifier and
        /// 2) at least one Where or OrderBy clause but no other clause is present in the contained query body or
        ///    the expression in question is a group-by expression and the body has no clause
        /// 
        /// do not translate into lambdas.
        /// By "source" identifier we mean the identifier specified in the from clause that initiates the query or the query continuation that includes the body.
        /// 
        /// The above condition can be derived from the language specification (chapter 7.16.2) as follows:
        /// - In order for 7.16.2.5 "Select clauses" to be applicable the following conditions must hold:
        ///   - There has to be at least one clause in the body, otherwise the query is reduced into a final form by 7.16.2.3 "Degenerate query expressions".
        ///   - Only where and order-by clauses may be present in the query body, otherwise a transformation in 7.16.2.4 "From, let, where, join and orderby clauses"
        ///     produces pattern that doesn't match the requirements of 7.16.2.5.
        ///   
        /// - In order for 7.16.2.6 "Groupby clauses" to be applicable the following conditions must hold:
        ///   - Only where and order-by clauses may be present in the query body, otherwise a transformation in 7.16.2.4 "From, let, where, join and orderby clauses"
        ///     produces pattern that doesn't match the requirements of 7.16.2.5.
        /// </summary>
        private static bool IsReducedSelectOrGroupByClause(SelectOrGroupClauseSyntax selectOrGroupClause, ExpressionSyntax selectOrGroupExpression)
        {
            if (!selectOrGroupExpression.IsKind(SyntaxKind.IdentifierName))
            {
                return false;
            }

            var selectorIdentifier = ((IdentifierNameSyntax)selectOrGroupExpression).Identifier;

            SyntaxToken sourceIdentifier;
            QueryBodySyntax containingBody;

            var containingQueryOrContinuation = selectOrGroupClause.Parent.Parent;
            if (containingQueryOrContinuation.IsKind(SyntaxKind.QueryExpression))
            {
                var containingQuery = (QueryExpressionSyntax)containingQueryOrContinuation;
                containingBody = containingQuery.Body;
                sourceIdentifier = containingQuery.FromClause.Identifier;
            }
            else
            {
                var containingContinuation = (QueryContinuationSyntax)containingQueryOrContinuation;
                sourceIdentifier = containingContinuation.Identifier;
                containingBody = containingContinuation.Body;
            }

            if (!SyntaxFactory.AreEquivalent(sourceIdentifier, selectorIdentifier))
            {
                return false;
            }

            if (selectOrGroupClause.IsKind(SyntaxKind.SelectClause) && containingBody.Clauses.Count == 0)
            {
                return false;
            }

            foreach (var clause in containingBody.Clauses)
            {
                if (!clause.IsKind(SyntaxKind.WhereClause) && !clause.IsKind(SyntaxKind.OrderByClause))
                {
                    return false;
                }
            }

            return true;
        }
开发者ID:CAPCHIK,项目名称:roslyn,代码行数:65,代码来源:LambdaUtilities.cs

示例5: GetTypeInfo

 public override TypeInfo GetTypeInfo(SelectOrGroupClauseSyntax node, CancellationToken cancellationToken = default(CancellationToken))
 {
     using (Logger.LogBlock(FunctionId.CSharp_SemanticModel_GetTypeInfo, message: this.SyntaxTree.FilePath, cancellationToken: cancellationToken))
     {
         CheckSyntaxNode(node);
         var model = this.GetMemberModel(node);
         return (model == null) ? default(TypeInfo) : model.GetTypeInfo(node, cancellationToken);
     }
 }
开发者ID:elemk0vv,项目名称:roslyn-1,代码行数:9,代码来源:SyntaxTreeSemanticModel.cs

示例6: Clear

 public void Clear()
 {
     fromExpression = null;
     rangeVariable = null;
     selectOrGroup = null;
     foreach (var b in allRangeVariables.Values) b.Free();
     allRangeVariables.Clear();
     clauses.Clear();
 }
开发者ID:ehsansajjad465,项目名称:roslyn,代码行数:9,代码来源:Binder.QueryTranslationState.cs


注:本文中的SelectOrGroupClauseSyntax类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。