Few name changes and expose AdditionalParameters in CreationContext.
[castle.git] / Core / Castle.Core / Model / ParameterModel.cs
blob0c3ec5bfaf849df3273f33fd4d6949928da7d81c
1 // Copyright 2004-2008 Castle Project - http://www.castleproject.org/
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
15 namespace Castle.Core
17 using System;
18 using Castle.Core.Configuration;
20 /// <summary>
21 /// Represents a parameter. Usually the parameter
22 /// comes from the external world, ie, an external configuration.
23 /// </summary>
24 [Serializable]
25 public class ParameterModel
27 private String name;
28 private String value;
29 private IConfiguration configValue;
31 /// <summary>
32 /// Initializes a new instance of the <see cref="ParameterModel"/> class.
33 /// </summary>
34 /// <param name="name">The name.</param>
35 /// <param name="value">The value.</param>
36 public ParameterModel(String name, String value)
38 this.name = name;
39 this.value = value;
42 /// <summary>
43 /// Initializes a new instance of the <see cref="ParameterModel"/> class.
44 /// </summary>
45 /// <param name="name">The name.</param>
46 /// <param name="value">The value.</param>
47 public ParameterModel(String name, IConfiguration value)
49 this.name = name;
50 configValue = value;
53 /// <summary>
54 /// Gets the name.
55 /// </summary>
56 /// <value>The name.</value>
57 public String Name
59 get { return name; }
62 /// <summary>
63 /// Gets the value.
64 /// </summary>
65 /// <value>The value.</value>
66 public String Value
68 get { return value; }
71 /// <summary>
72 /// Gets the config value.
73 /// </summary>
74 /// <value>The config value.</value>
75 public IConfiguration ConfigValue
77 get { return configValue; }