// Copyright (c) AlphaSierraPapa for the SharpDevelop Team // // 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 NUnit.Framework; namespace ICSharpCode.NRefactory.CSharp.Parser.Expression { [TestFixture] public class CastExpressionTests { [Test] public void SimpleCastExpression() { ParseUtilCSharp.AssertExpression( "(MyObject)o", new CastExpression { Type = new SimpleType("MyObject"), Expression = new IdentifierExpression("o") }); } [Test] public void ArrayCastExpression() { ParseUtilCSharp.AssertExpression( "(MyType[])o", new CastExpression { Type = new SimpleType("MyType").MakeArrayType(1), Expression = new IdentifierExpression("o") }); } [Test] public void NullablePrimitiveCastExpression() { ParseUtilCSharp.AssertExpression( "(int?)o", new CastExpression { Type = new ComposedType { BaseType = new PrimitiveType("int"), HasNullableSpecifier = true }, Expression = new IdentifierExpression("o") }); } [Test] public void NullableCastExpression() { ParseUtilCSharp.AssertExpression( "(MyType?)o", new CastExpression { Type = new ComposedType { BaseType = new SimpleType("MyType"), HasNullableSpecifier = true }, Expression = new IdentifierExpression("o") }); } [Test] public void NullableTryCastExpression() { ParseUtilCSharp.AssertExpression( "o as int?", new AsExpression { Type = new ComposedType { BaseType = new PrimitiveType("int"), HasNullableSpecifier = true }, Expression = new IdentifierExpression("o") }); } [Test] public void GenericCastExpression() { ParseUtilCSharp.AssertExpression( "(List)o", new CastExpression { Type = new SimpleType("List") { TypeArguments = { new PrimitiveType("string") } }, Expression = new IdentifierExpression("o") }); } [Test] public void GenericArrayCastExpression() { ParseUtilCSharp.AssertExpression( "(List[])o", new CastExpression { Type = new ComposedType { BaseType = new SimpleType("List") { TypeArguments = { new PrimitiveType("string") } }, ArraySpecifiers = { new ArraySpecifier(1) } }, Expression = new IdentifierExpression("o") }); } [Test] public void GenericArrayAsCastExpression() { ParseUtilCSharp.AssertExpression( "o as List[]", new AsExpression { Type = new ComposedType { BaseType = new SimpleType("List") { TypeArguments = { new PrimitiveType("string") } }, ArraySpecifiers = { new ArraySpecifier(1) } }, Expression = new IdentifierExpression("o") }); } [Test] public void CastMemberReferenceOnParenthesizedExpression() { // yes, we really want to evaluate .Member on expr and THEN cast the result to MyType ParseUtilCSharp.AssertExpression( "(MyType)(expr).Member", new CastExpression { Type = new SimpleType("MyType"), Expression = new ParenthesizedExpression { Expression = new IdentifierExpression("expr") }.Member("Member") }); } [Test] public void TryCastParenthesizedExpression() { ParseUtilCSharp.AssertExpression( "(o) as string", new AsExpression { Expression = new ParenthesizedExpression { Expression = new IdentifierExpression("o") }, Type = new PrimitiveType("string") }); } [Test] public void CastNegation() { ParseUtilCSharp.AssertExpression( "(uint)-negativeValue", new CastExpression { Type = new PrimitiveType("uint"), Expression = new UnaryOperatorExpression( UnaryOperatorType.Minus, new IdentifierExpression("negativeValue") )}); } [Test] public void SubtractionIsNotCast() { ParseUtilCSharp.AssertExpression( "(BigInt)-negativeValue", new BinaryOperatorExpression { Left = new ParenthesizedExpression { Expression = new IdentifierExpression("BigInt") }, Operator = BinaryOperatorType.Subtract, Right = new IdentifierExpression("negativeValue") }); } [Test] public void IntMaxValueToBigInt() { ParseUtilCSharp.AssertExpression( "(BigInt)int.MaxValue", new CastExpression { Type = new SimpleType("BigInt"), Expression = new PrimitiveType("int").Member("MaxValue") }); } } }