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


C# SnapshotSpan.Contains方法代码示例

本文整理汇总了C#中SnapshotSpan.Contains方法的典型用法代码示例。如果您正苦于以下问题:C# SnapshotSpan.Contains方法的具体用法?C# SnapshotSpan.Contains怎么用?C# SnapshotSpan.Contains使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SnapshotSpan的用法示例。


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

示例1: AugmentQuickInfoSession

        /// <inheritdoc />
        public void AugmentQuickInfoSession(IQuickInfoSession session, IList<object> quickInfoContent,
          out ITrackingSpan applicableToSpan)
        {
            applicableToSpan = null;

            var tagAggregator = provider.AggregatorFactory.CreateTagAggregator<IClassificationTag>(session.TextView);
            var triggerPoint = session.GetTriggerPoint(textBuffer.CurrentSnapshot);

            if(triggerPoint != null)
            {
                SnapshotSpan tagSpan;
                var lineSpan = triggerPoint.Value.GetContainingLine();
                string elementName = null, attrName = null, identifier = null, name;
                UIElement content;

                // Get the tags for the line containing the mouse point
                foreach(IMappingTagSpan<IClassificationTag> curTag in tagAggregator.GetTags(
                  new SnapshotSpan(lineSpan.Start, lineSpan.End)))
                {
                    name = curTag.Tag.ClassificationType.Classification.ToLowerInvariant();
                    tagSpan = curTag.Span.GetSpans(textBuffer).First();

                    if(name.IndexOf("identifier", StringComparison.Ordinal) != -1)
                        name = "identifier";

                    switch(name)
                    {
                        case "xml doc tag":
                            // Track the last seen element or attribute.  The classifier in VS2013 and earlier does
                            // not break up the XML comments into elements and attributes so we may get a mix of text
                            // in the "tag".
                            attrName = tagSpan.GetText();

                            // If it contains "cref", ten next XML doc attribute value will be the target
                            if(attrName.IndexOf("cref=", StringComparison.Ordinal) != -1 && enableInCRef)
                                attrName = "cref";

                            // As above, for conceptualLink, the next XML doc attribute will be the target
                            if(attrName.StartsWith("<conceptualLink", StringComparison.Ordinal))
                                attrName = "conceptualLink";

                            // For token, the next XML doc comment will contain the token name
                            if(attrName == "<token>")
                                attrName = "token";
                            break;

                        case "xml doc attribute":
                            if((attrName == "cref" || attrName == "conceptualLink") &&
                              tagSpan.Contains(triggerPoint.Value) && tagSpan.Length > 2)
                            {
                                // Drop the quotes from the span
                                var span = new SnapshotSpan(tagSpan.Snapshot, tagSpan.Start + 1,
                                    tagSpan.Length - 2);

                                content = this.CreateInfoText(attrName, span.GetText());

                                if(content != null)
                                {
                                    applicableToSpan = textBuffer.CurrentSnapshot.CreateTrackingSpan(span,
                                        SpanTrackingMode.EdgeExclusive);

                                    quickInfoContent.Add(content);
                                }

                                return;
                            }
                            break;

                        case "xml doc comment":
                            if(attrName == "token" && tagSpan.Contains(triggerPoint.Value) && tagSpan.Length > 1)
                            {
                                content = this.CreateInfoText(attrName, tagSpan.GetText());

                                if(content != null)
                                {
                                    applicableToSpan = textBuffer.CurrentSnapshot.CreateTrackingSpan(tagSpan,
                                        SpanTrackingMode.EdgeExclusive);

                                    quickInfoContent.Add(content);
                                }

                                return;
                            }
                            break;

                        // VS2015 is more specific in its classifications
                        case "xml doc comment - name":
                            elementName = tagSpan.GetText().Trim();
                            break;

                        case "xml doc comment - attribute name":
                            attrName = tagSpan.GetText().Trim();
                            identifier = null;

                            if(attrName == "cref" && !enableInCRef)
                                attrName = null;
                            break;

                        case "xml doc comment - attribute value":
//.........这里部分代码省略.........
开发者ID:julianhaslinger,项目名称:SHFB,代码行数:101,代码来源:XmlCommentsLinkQuickInfoSource.cs

示例2: ProcessSpans

        //=====================================================================

        /// <inheritdoc />
        protected override bool ProcessSpans(SnapshotSpan mousePoint, IList<ClassificationSpan> spans)
        {
            string elementName = null, attrName = null, identifier = null;

            foreach(var classification in spans)
            {
                string name = classification.ClassificationType.Classification.ToLowerInvariant();

                // Not supporting VB for now due to problems looking up identifiers
                //if(name.StartsWith("vb ", StringComparison.Ordinal))
                //    name = name.Substring(3);

                if(name.IndexOf("identifier", StringComparison.Ordinal) != -1)
                    name = "identifier";

                // Highlight the span if it matches what we are looking for and it contains the mouse span
                switch(name)
                {
                    case "xml doc tag":
                        // Track the last seen element or attribute.  The classifier in VS2013 and earlier does
                        // not break up the XML comments into elements and attributes so we may get a mix of text
                        // in the "tag".
                        attrName = classification.Span.GetText();

                        // If it contains "cref", the next XML doc attribute value will be the target
                        if(attrName.IndexOf("cref=", StringComparison.Ordinal) != -1 && enableInCRef)
                            attrName = "cref";

                        // As above, for conceptualLink, the next XML doc attribute will be the target
                        if(attrName.StartsWith("<conceptualLink", StringComparison.Ordinal))
                            attrName = "conceptualLink";

                        // For token, the next XML doc comment will contain the token name
                        if(attrName == "<token>")
                            attrName = "token";
                        break;

                    case "xml doc attribute":
                        if((attrName == "cref" || attrName == "conceptualLink") &&
                          classification.Span.Contains(mousePoint) && classification.Span.Length > 2)
                        {
                            // Drop the quotes from the span
                            var span = new SnapshotSpan(classification.Span.Snapshot, classification.Span.Start + 1,
                                classification.Span.Length - 2);

                            if(this.SetHighlightSpan(span, (attrName == "cref") ? "codeEntityReference" : "link"))
                                return true;
                        }
                        break;

                    case "xml doc comment":
                        if(attrName == "token" && classification.Span.Contains(mousePoint) &&
                          classification.Span.Length > 1)
                        {
                            if(this.SetHighlightSpan(classification.Span, "token"))
                                return true;
                        }
                        break;

                    // VS2015 is more specific in its classifications
                    case "xml doc comment - name":
                        elementName = classification.Span.GetText().Trim();
                        break;

                    case "xml doc comment - attribute name":
                        attrName = classification.Span.GetText().Trim();
                        identifier = null;

                        if(attrName == "cref" && !enableInCRef)
                            attrName = null;
                        break;

                    case "xml doc comment - attribute value":
                        if((attrName == "cref" || (elementName == "conceptualLink" && attrName == "target")) &&
                          classification.Span.Contains(mousePoint) && classification.Span.Length > 1)
                        {
                            if(this.SetHighlightSpan(classification.Span,
                              (attrName == "cref") ? "codeEntityReference" : "link"))
                                return true;
                        }
                        break;

                    case "identifier":
                    case "keyword":
                    case "operator":
                        if(attrName != null)
                        {
                            identifier += classification.Span.GetText();

                            if(name == "keyword")
                                identifier += " ";
                        }
                        break;

                    case "punctuation":
                        if(identifier != null)
                            identifier += classification.Span.GetText();
//.........这里部分代码省略.........
开发者ID:julianhaslinger,项目名称:SHFB,代码行数:101,代码来源:CSharpGoToDefinitionMouseProcessor.cs

示例3: ProcessSpans

        /// <summary>
        /// This is used to process the spans and try to figure out whether or not we have something we can use
        /// for Go To Definition and, i so, the definition type.
        /// </summary>
        /// <param name="cursorPos">The cursor position.</param>
        /// <param name="spans">The spans to process.</param>
        /// <param name="definitionType">On return, this contains the definition type if one was found or null
        /// if not.</param>
        /// <returns>The snapshot span for the definition if one was found, null if not</returns>
        private SnapshotSpan? ProcessSpans(SnapshotPoint cursorPos, IList<ClassificationSpan> spans,
          out string definitionType)
        {
            string elementName = null, attrName = null, identifier = null, spanText;

            definitionType = null;

            foreach(var classification in spans)
            {
                string name = classification.ClassificationType.Classification.ToLowerInvariant();

                // Not supporting VB for now due to problems looking up identifiers
                //if(name.StartsWith("vb ", StringComparison.Ordinal))
                //    name = name.Substring(3);

                if(name.IndexOf("identifier", StringComparison.Ordinal) != -1)
                    name = "identifier";

                // Return the span if it matches what we are looking for and it contains the cursor
                switch(name)
                {
                    case "xml name":
                        elementName = classification.Span.GetText();
                        break;

                    case "xml attribute":
                        attrName = classification.Span.GetText();
                        break;

                    case "xml attribute value":
                        if(classification.Span.Contains(cursorPos))
                        {
                            if((elementName == "image" || elementName == "link") && attrName == "xlink:href")
                            {
                                definitionType = elementName;
                                return classification.Span;
                            }

                            return null;
                        }
                        break;

                    case "xml text":
                        if(classification.Span.Contains(cursorPos))
                        {
                            spanText = classification.Span.GetText().Trim();

                            switch(elementName)
                            {
                                case "codeEntityReference":
                                    if(spanText.IsCodeEntityReference())
                                    {
                                        definitionType = elementName;
                                        return classification.Span;
                                    }
                                    break;

                                case "codeReference":
                                    if(spanText.IsCodeReferenceId())
                                    {
                                        definitionType = elementName;
                                        return classification.Span;
                                    }
                                    break;

                                case "token":
                                    definitionType = elementName;
                                    return classification.Span;

                                default:
                                    // We only get info about the current line so we may just get some XML text
                                    // if the starting tag is on a prior line.  In such cases, see if the text
                                    // looks like an entity reference or a code reference ID.  If so, return it
                                    // as the definition.  If not, ignore it.
                                    if(String.IsNullOrWhiteSpace(elementName))
                                    {
                                        // Ignore any leading whitespace on the span
                                        string highlightText = classification.Span.GetText();

                                        int offset = highlightText.Length - highlightText.TrimStart().Length;
                                        var textSpan = new SnapshotSpan(classification.Span.Snapshot,
                                            classification.Span.Start.Position + offset,
                                            classification.Span.Length - offset);

                                        if(spanText.IsCodeEntityReference())
                                        {
                                            definitionType = "codeEntityReference";
                                            return textSpan;
                                        }
                                        else
                                            if(spanText.IsCodeReferenceId())
//.........这里部分代码省略.........
开发者ID:julianhaslinger,项目名称:SHFB,代码行数:101,代码来源:GoToDefinitionCommandTarget.cs


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