2010-05-19 Jb Evain <jbevain@novell.com>
[mcs.git] / tools / mconfig / Mono.MonoConfig / ConfigBlockNodeHandler.cs
blobacd5e7c71557d933af1a3e91d96b071137eaa5e7
1 //
2 // Authors:
3 // Marek Habersack (mhabersack@novell.com)
4 //
5 // (C) 2007 Novell, Inc
6 //
8 //
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
16 //
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
19 //
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 using System;
29 using System.Collections.Generic;
30 using System.Text;
31 using System.Xml;
32 using System.Xml.XPath;
34 namespace Mono.MonoConfig
36 public class ConfigBlockNodeHandler : IDocumentNodeHandler, IStorageConsumer, IConfigBlockContainer
38 string name;
39 Section requirements;
40 string contents;
41 Dictionary <string, ConfigBlockBlock> storage;
43 public void ReadConfiguration (XPathNavigator nav)
45 name = Helpers.GetRequiredNonEmptyAttribute (nav, "name");
47 requirements = new Section ();
48 Helpers.BuildSectionTree (nav.Select ("requires/section[string-length(@name) > 0]"), requirements);
50 XPathNodeIterator iter = nav.Select ("contents/text()");
51 StringBuilder sb = new StringBuilder ();
53 while (iter.MoveNext ())
54 sb.Append (iter.Current.Value);
55 if (sb.Length > 0)
56 contents = sb.ToString ();
59 public void StoreConfiguration ()
61 AssertStorage ();
63 ConfigBlockBlock block = new ConfigBlockBlock (name, requirements, contents);
64 if (storage.ContainsKey (name))
65 storage [name] = block; // allow for silent override
66 else
67 storage.Add (name, block);
69 // Prepare to handle more sections
70 requirements = new Section ();
71 contents = null;
74 public void SetStorage (object storage)
76 this.storage = storage as Dictionary <string, ConfigBlockBlock>;
77 if (this.storage == null)
78 throw new ApplicationException ("Invalid storage type.");
81 public ConfigBlockBlock FindConfigBlock (string name)
83 AssertStorage ();
85 if (storage.ContainsKey (name))
86 return storage [name];
88 return null;
91 void AssertStorage ()
93 if (storage == null)
94 throw new ApplicationException ("No storage attached");