2009-03-28 5 views
44

<see cref="switch" />, उदाहरण के लिए, काम नहीं करता है - मैं संकलन चेतावनी मिलती है: जो रुचि रखते हैं के लिए XML comment on ... has syntactically incorrect cref attribute 'switch'मैं XML दस्तावेज़ में सी # कीवर्ड का संदर्भ कैसे लगा सकता हूं?


प्रसंग ...

/// <summary>Provides base functionality for hand-coded abstractions of API method wrappers, mostly those that abstract over 
/// parameters that are required to be JSON-encoded.</summary> 
public class FacebookArgs : Dictionary<String, Object> 
{ 
    /// <summary>Initializes an instance of <see cref="FacebookArgs" />.</summary> 
    public FacebookArgs() { } 

    /// <summary>Intializes an instance of <see cref="FacebookArgs" />, that contains elements copied from <paramref name="dictionary "/>.</summary> 
    /// <param name="dictionary"></param> 
    public FacebookArgs(IDictionary<String, Object> dictionary) 
     : base(dictionary) { } 

    /// <summary>Gets or sets the value associated with the specified key.</summary> 
    /// <param name="key">The key of the value to get or set.</param> 
    /// <returns>The value associated with the specified key.</returns> 
    /// <remarks>This implementation hides the base indexer implementation such that specifying a key that does not exist returns null rather than throwing a <see cref="KeyNotFoundException" />.</remarks> 
    public new Object this[String key] 
    { 
     get 
     { 
      Object value; 
      if (this.TryGetValue(key, out value)) return value; 
      else return null; 
     } 
     set { base[key] = value; } 
    } 

    /// <summary>In derived classes, provides specialized serialization logic for specific properties contained in this object.</summary> 
    /// <param name="key">The key of the property to serialize.</param> 
    /// <param name="args">A reference to a dictionary of arguments that will be passed directly to a <see cref="FacebookRequest" /> object.</param> 
    /// <remarks> 
    /// <para>This method allows specialized serialization logic, such as JSON encoding, to be applied to specific properties.</para> 
    /// <para>To implement, use a <c>switch</c> (<c>Select</c> in VB.NET) statement to filter based on <paramref name="key" /> and provide the property-specific logic. 
    /// The resulting value should then be added to <paramref name="args" /> using the same <paramref name="key "/>. 
    /// </para> 
    /// <para>Properties that do not require additional processing (strings, integral values, etc) should be ignored.</para> 
    /// </remarks> 
    protected virtual void SerializeProperty(String key, ref IDictionary<String, Object> args) { } 

    /// <summary>Returns a dictionary of key/value pairs suitable to be passed a <see cref="FacebookRequest" /> object.</summary> 
    /// <returns>A dictionary of key/value pairs suitable to be passed a <see cref="FacebookRequest" /> object.</returns> 
    /// <remarks>This method calls the <see cref="SerializeProperty" /> for each key in the object, which allows property-specific processing 
    /// to be done on any property.</remarks> 
    /// <seealso cref="SerializeProperty" /> 
    public IDictionary<String, Object> GetArgs() 
    { 
     IDictionary<String, Object> args = new Dictionary<String, Object>(); 

     foreach (String key in this.Keys) 
     { 
      this.SerializeProperty(key, ref args); 

      if (!args.ContainsKey(key) && this[key] != null) 
      { 
       args.Add(key, this[key]); 
      } 
     } 

     return args; 
    } 
} 

प्रश्न में टैग कर सकते हैं SerializeProperty के लिए <remarks> टैग में पाया जाए। मैं verbose प्रलेखन के पक्ष में गड़बड़ कर रहा हूँ। मैं कुछ <example> एस प्रदान करने की भी योजना बना रहा हूं, मुझे अभी तक इसके आसपास नहीं मिला है।

उत्तर

64

cref किसी अन्य सदस्य का उल्लेख करने के लिए होती है - एक वर्ग, एक विधि आदि

क्या आप इसे इस मामले में से जोड़ने के लिए उम्मीद करेंगे? आम तौर पर, आप समग्र प्रभाव क्या चाहते हैं?

<see langword="switch" /> 

है कि आप में मदद:

इस excellent XML doc guide के अनुसार, <see> टैग एक गैर-दस्तावेजी विशेषता langword है? यह देखने के लायक हो सकता है कि यह क्या करता है।

आप सिर्फ एक सामान्य हाइपरलिंक का उपयोग करना चाहते हैं, तो cref के बजाय href का उपयोग करें:

<see href="http://msdn.microsoft.com/en-us/library/06tc147t.aspx">switch</a> 
+0

स्विच कीवर्ड के लिए MSDN लेख: http://msdn.microsoft.com/en-us/library/ 06tc147t.aspx –

+0

यह सी # परियोजना के भीतर भी VB.NET के लिए काम करता है! कार्यान्वित करने के लिए, ( VB.NET में देखें) –

+0

मुझे स्वीकार करना है, मैंने पहले कभी उस विशेषता को नहीं देखा होगा। मुझे बस पृष्ठ के बारे में पता था, और देखा कि उसे खुद के लिए क्या कहना है :) –