2 // BuildProperty.cs: Represents a property
5 // Marek Sieradzki (marek.sieradzki@gmail.com)
7 // (C) 2005 Marek Sieradzki
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:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
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.
34 namespace Microsoft.Build.BuildEngine {
35 public class BuildProperty {
37 XmlElement propertyElement;
42 Project parentProject;
43 PropertyType propertyType;
45 private BuildProperty ()
49 public BuildProperty (string propertyName, string propertyValue)
50 : this (propertyName, propertyValue, PropertyType.Normal)
52 if (propertyName == null)
53 throw new ArgumentNullException ("propertyName");
54 if (propertyValue == null)
55 throw new ArgumentNullException ("propertyValue");
58 internal BuildProperty (string propertyName,
59 string propertyValue, PropertyType propertyType)
61 this.name = propertyName;
62 this.value = propertyValue;
63 this.finalValue = propertyValue;
64 this.propertyType = propertyType;
65 this.isImported = false;
68 internal BuildProperty (Project parentProject, XmlElement propertyElement)
70 if (propertyElement == null)
71 throw new ArgumentNullException ("propertyElement");
73 this.propertyElement = propertyElement;
74 this.propertyType = PropertyType.Normal;
75 this.parentProject = parentProject;
76 this.name = propertyElement.Name;
77 this.value = propertyElement.InnerText;
78 this.isImported = false;
82 public BuildProperty Clone (bool deepClone)
86 throw new NotImplementedException ();
88 return (BuildProperty) this.MemberwiseClone ();
91 throw new NotImplementedException ();
93 throw new InvalidOperationException ("A shallow clone of this object cannot be created.");
97 public static explicit operator string (BuildProperty propertyToCast)
99 if (propertyToCast == null)
102 return propertyToCast.ToString ();
105 public override string ToString ()
107 if (finalValue != null)
113 internal void Evaluate ()
116 Expression exp = new Expression ();
118 finalValue = (string) exp.ConvertTo (parentProject, typeof (string));
119 parentProject.EvaluatedProperties.AddProperty (this);
123 private bool FromXml {
125 return propertyElement != null;
129 public string Condition {
132 return propertyElement.GetAttribute ("Condition");
138 propertyElement.SetAttribute ("Condition", value);
140 throw new InvalidOperationException ("Cannot set a condition on an object not represented by an XML element in the project file.");
144 public string FinalValue {
146 if (finalValue == null)
153 public bool IsImported {
154 get { return isImported; }
161 public string Value {
168 propertyElement.InnerText = value;
175 internal PropertyType PropertyType {
182 internal enum PropertyType {