// // UnaryOperatorExpression.cs // // Author: // Mike Krüger // // Copyright (c) 2009 Novell, Inc (http://www.novell.com) // // 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; namespace ICSharpCode.NRefactory.CSharp { /// /// Operator Expression /// public class UnaryOperatorExpression : Expression { public readonly static Role OperatorRole = BinaryOperatorExpression.OperatorRole; public UnaryOperatorExpression() { } public UnaryOperatorExpression(UnaryOperatorType op, Expression expression) { this.Operator = op; this.Expression = expression; } public UnaryOperatorType Operator { get; set; } public CSharpTokenNode OperatorToken { get { return GetChildByRole (OperatorRole); } } public Expression Expression { get { return GetChildByRole (Roles.Expression); } set { SetChildByRole (Roles.Expression, value); } } public override S AcceptVisitor (IAstVisitor visitor, T data) { return visitor.VisitUnaryOperatorExpression (this, data); } protected internal override bool DoMatch(AstNode other, PatternMatching.Match match) { UnaryOperatorExpression o = other as UnaryOperatorExpression; return o != null && this.Operator == o.Operator && this.Expression.DoMatch(o.Expression, match); } public static string GetOperatorSymbol(UnaryOperatorType op) { switch (op) { case UnaryOperatorType.Not: return "!"; case UnaryOperatorType.BitNot: return "~"; case UnaryOperatorType.Minus: return "-"; case UnaryOperatorType.Plus: return "+"; case UnaryOperatorType.Increment: case UnaryOperatorType.PostIncrement: return "++"; case UnaryOperatorType.PostDecrement: case UnaryOperatorType.Decrement: return "--"; case UnaryOperatorType.Dereference: return "*"; case UnaryOperatorType.AddressOf: return "&"; default: throw new NotSupportedException("Invalid value for UnaryOperatorType"); } } } public enum UnaryOperatorType { /// Logical not (!a) Not, /// Bitwise not (~a) BitNot, /// Unary minus (-a) Minus, /// Unary plus (+a) Plus, /// Pre increment (++a) Increment, /// Pre decrement (--a) Decrement, /// Post increment (a++) PostIncrement, /// Post decrement (a--) PostDecrement, /// Dereferencing (*a) Dereference, /// Get address (&a) AddressOf } }