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 using Microsoft.Build.Framework;
36 namespace Microsoft.Build.BuildEngine {
37 public class BuildProperty {
39 XmlElement propertyElement;
44 Project parentProject;
45 PropertyType propertyType;
51 public BuildProperty (string propertyName, string propertyValue)
52 : this (propertyName, propertyValue, PropertyType.Normal)
54 if (propertyName == null)
55 throw new ArgumentNullException ("propertyName");
56 if (propertyValue == null)
57 throw new ArgumentNullException ("propertyValue");
60 internal BuildProperty (string propertyName,
61 string propertyValue, PropertyType propertyType)
63 this.name = propertyName;
64 this.value = propertyValue;
65 this.finalValue = propertyValue;
66 this.propertyType = propertyType;
67 this.isImported = false;
70 internal BuildProperty (Project parentProject, XmlElement propertyElement)
72 if (propertyElement == null)
73 throw new ArgumentNullException ("propertyElement");
75 this.propertyElement = propertyElement;
76 this.propertyType = PropertyType.Normal;
77 this.parentProject = parentProject;
78 this.name = propertyElement.Name;
79 this.value = propertyElement.InnerXml;
80 this.isImported = false;
84 public BuildProperty Clone (bool deepClone)
88 throw new NotImplementedException ();
90 return (BuildProperty) this.MemberwiseClone ();
93 throw new NotImplementedException ();
95 throw new InvalidOperationException ("A shallow clone of this object cannot be created.");
99 public static explicit operator string (BuildProperty propertyToCast)
101 if (propertyToCast == null)
104 return propertyToCast.ToString ();
107 public override string ToString ()
109 if (finalValue != null)
115 internal void Evaluate ()
117 BuildProperty evaluated = new BuildProperty (Name, Value);
119 Expression exp = new Expression ();
120 exp.Parse (Value, false, false);
121 evaluated.finalValue = (string) exp.ConvertTo (parentProject, typeof (string));
123 parentProject.EvaluatedProperties.AddProperty (evaluated);
126 internal string ConvertToString (Project project)
128 Expression exp = new Expression ();
129 exp.Parse (Value, true, false);
131 return (string) exp.ConvertTo (project, typeof (string));
134 internal ITaskItem[] ConvertToITaskItemArray (Project project)
136 Expression exp = new Expression ();
137 exp.Parse (Value, true, false);
139 return (ITaskItem[]) exp.ConvertTo (project, typeof (ITaskItem[]));
142 internal bool FromXml {
144 return propertyElement != null;
148 public string Condition {
151 return propertyElement.GetAttribute ("Condition");
157 propertyElement.SetAttribute ("Condition", value);
159 throw new InvalidOperationException ("Cannot set a condition on an object not represented by an XML element in the project file.");
163 public string FinalValue {
165 if (finalValue == null)
172 public bool IsImported {
173 get { return isImported; }
180 public string Value {
187 propertyElement.InnerXml = value;
194 internal PropertyType PropertyType {
200 internal XmlElement XmlElement {
201 get { return propertyElement; }
205 internal enum PropertyType {