#if NET20 || NET30 || !NET_4_6 // Copyright (c) Microsoft. All rights reserved. // Licensed under the MIT license. See LICENSE file in the project root for full license information. using System.Diagnostics; namespace System.Linq.Expressions.Reimplement { /// /// Represents a label, which can be placed in any context. If /// it is jumped to, it will get the value provided by the corresponding /// . Otherwise, it gets the value in . If the /// equals System.Void, no value should be provided. /// [DebuggerTypeProxy(typeof(LabelExpressionProxy))] public sealed class LabelExpression : Expression { private readonly Expression _defaultValue; private readonly LabelTarget _target; internal LabelExpression(LabelTarget label, Expression defaultValue) { _target = label; _defaultValue = defaultValue; } /// /// Gets the static type of the expression that this represents. (Inherited from .) /// /// The that represents the static type of the expression. public override Type Type { get { return _target.Type; } } /// /// Returns the node type of this . (Inherited from .) /// /// The that represents this expression. public override ExpressionType NodeType { get { return ExpressionType.Label; } } /// /// The which this label is associated with. /// public LabelTarget Target { get { return _target; } } /// /// The value of the when the label is reached through /// normal control flow (e.g. is not jumped to). /// public Expression DefaultValue { get { return _defaultValue; } } protected internal override Expression Accept(ExpressionVisitor visitor) { return visitor.VisitLabel(this); } /// /// Creates a new expression that is like this one, but using the /// supplied children. If all of the children are the same, it will /// return this expression. /// /// The property of the result. /// The property of the result. /// This expression if no children changed, or an expression with the updated children. public LabelExpression Update(LabelTarget target, Expression defaultValue) { if (target == Target && defaultValue == DefaultValue) { return this; } return Label(target, defaultValue); } } public partial class Expression { /// /// Creates a representing a label with no default value. /// /// The which this will be associated with. /// A with no default value. public static LabelExpression Label(LabelTarget target) { return Label(target, null); } /// /// Creates a representing a label with the given default value. /// /// The which this will be associated with. /// The value of this when the label is reached through normal control flow. /// A with the given default value. public static LabelExpression Label(LabelTarget target, Expression defaultValue) { ValidateGoto(target, ref defaultValue, "label", "defaultValue"); return new LabelExpression(target, defaultValue); } } } #endif