Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

135 lines
4.0 KiB
C#

//
// ConditionFactorExpression.cs
//
// Author:
// Marek Sieradzki (marek.sieradzki@gmail.com)
//
// (C) 2006 Marek Sieradzki
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
using System;
using System.Collections;
using System.Collections.Specialized;
using System.Globalization;
using System.Xml;
namespace Microsoft.Build.BuildEngine {
internal sealed class ConditionFactorExpression : ConditionExpression {
readonly Token token;
static Hashtable allValues;
static Hashtable trueValues;
static Hashtable falseValues;
static ConditionFactorExpression ()
{
string[] trueValuesArray = new string[] {"true", "on", "yes"};
string[] falseValuesArray = new string[] {"false", "off", "no"};
allValues = CollectionsUtil.CreateCaseInsensitiveHashtable ();
trueValues = CollectionsUtil.CreateCaseInsensitiveHashtable ();
falseValues = CollectionsUtil.CreateCaseInsensitiveHashtable ();
foreach (string s in trueValuesArray) {
trueValues.Add (s, s);
allValues.Add (s, s);
}
foreach (string s in falseValuesArray) {
falseValues.Add (s, s);
allValues.Add (s, s);
}
}
public ConditionFactorExpression (Token token)
{
this.token = token;
}
public override bool BoolEvaluate (Project context)
{
Token evaluatedToken = EvaluateToken (token, context);
if (trueValues [evaluatedToken.Value] != null)
return true;
else if (falseValues [evaluatedToken.Value] != null)
return false;
else
throw new ExpressionEvaluationException (
String.Format ("Expression \"{0}\" evaluated to \"{1}\" instead of a boolean value",
token.Value, evaluatedToken.Value));
}
public override float NumberEvaluate (Project context)
{
Token evaluatedToken = EvaluateToken (token, context);
return Single.Parse (evaluatedToken.Value, CultureInfo.InvariantCulture);
}
public override string StringEvaluate (Project context)
{
Token evaluatedToken = EvaluateToken (token, context);
return evaluatedToken.Value;
}
// FIXME: check if we really can do it
public override bool CanEvaluateToBool (Project context)
{
Token evaluatedToken = EvaluateToken (token, context);
if (token.Type == TokenType.String && allValues [evaluatedToken.Value] != null)
return true;
else
return false;
}
public override bool CanEvaluateToNumber (Project context)
{
if (token.Type == TokenType.Number)
return true;
else if (token.Type == TokenType.String) {
var text = StringEvaluate (context);
Single number;
return Single.TryParse (text, out number);
}
else
return false;
}
public override bool CanEvaluateToString (Project context)
{
return true;
}
// FIXME: in some situations items might not be allowed
static Token EvaluateToken (Token token, Project context)
{
Expression oe = new Expression ();
oe.Parse (token.Value, ParseOptions.AllowItemsMetadataAndSplit);
return new Token ((string) oe.ConvertTo (context, typeof (string)), token.Type, token.Position);
}
}
}