Welcome to mirror list, hosted at ThFree Co, Russian Federation.

DictionarySectionHandler.cs « System.Configuration « System « class « mcs - github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: f48eea8f38a231cfede1190fd20f394b7ed94ac2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91

//
// System.Configuration.DictionarySectionHandler.cs
//
// Author:
//   Christopher Podurgiel (cpodurgiel@msn.com)
//
// (C) Chris Podurgiel
//
using System;
using System.Collections.Specialized;
using System.Xml;

namespace System.Configuration
{
	/// <summary>
	/// Summary description for DictionarySectionHandler.
	/// </summary>
	public class DictionarySectionHandler : IConfigurationSectionHandler
	{
		private static string _stringKeyName;
		private static string _stringValueName;

		/// <summary>
		///		DictionarySectionHandler Constructor
		/// </summary>
		public DictionarySectionHandler()
		{
			//Set Default Values.
			_stringKeyName = "key";
			_stringValueName = "value";
		}

		/// <summary>
		///		Creates a new DictionarySectionHandler object and adds the object to the collection.
		/// </summary>
		/// <param name="parent">Composed from the configuration settings in a corresponding parent configuration section.</param>
		/// <param name="context">Provides access to the virtual path for which the configuration section handler computes configuration values. Normally this parameter is reserved and is null.</param>
		/// <param name="section">The XML node that contains the configuration information to be handled. section provides direct access to the XML contents of the configuration section.</param>
		/// <returns></returns>
		[MonoTODO]
		public virtual object Create(object parent, object context, XmlNode section)
		{
			//FIXME: Enter a meaningful error message
			if(section == null)
			{ throw new ConfigurationException("XML Node can not be null."); }
			
			//FIXME: Enter a meaningful error message
			if(parent == null)
			{ throw new ConfigurationException("", section); }

			
			DictionarySectionHandler objHandler = new DictionarySectionHandler();
			NameValueCollection objCollection;
			
			//Unbox parent as a NameValueCollection type.
			objCollection=(NameValueCollection)parent;

			objCollection.Add(section.Attributes[_stringKeyName].Value, section.Attributes[_stringValueName].Value);
			 
			return null;

			//FIXME: this code is far form complete, probably not even correct.
			
		}

		/// <summary>
		///		Gets the name of the key attribute tag. This property is overidden by derived classes to change 
		///		the name of the key attribute tag. The default is "key".
		/// </summary>
		protected virtual string KeyAttributeName
		{
			get
			{
				return _stringKeyName;
			}
		}

		/// <summary>
		///		Gets the name of the value tag. This property may be overidden by derived classes to change
		///		the name of the value tag. The default is "value".
		/// </summary>
		protected virtual string ValueAttributeName 
		{
			get
			{
				return _stringValueName;
			}
		}
	}
}