// Copyright (c) 2010-2013 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 ICSharpCode.NRefactory.Semantics; using ICSharpCode.NRefactory.TypeSystem; namespace ICSharpCode.NRefactory.CSharp.Resolver { /// /// Allows controlling which nodes are resolved by the resolve visitor. /// /// public interface IResolveVisitorNavigator { /// /// Asks the navigator whether to scan, skip, or resolve a node. /// ResolveVisitorNavigationMode Scan(AstNode node); /// /// Notifies the navigator that a node was resolved. /// /// The node that was resolved /// Resolve result void Resolved(AstNode node, ResolveResult result); /// /// Notifies the navigator that an implicit conversion was applied. /// /// The expression that was resolved. /// The resolve result of the expression. /// The conversion applied to the expressed. /// The target type of the conversion. void ProcessConversion(Expression expression, ResolveResult result, Conversion conversion, IType targetType); } /// /// Represents the operation mode of the resolve visitor. /// /// public enum ResolveVisitorNavigationMode { /// /// Scan into the children of the current node, without resolving the current node. /// Scan, /// /// Skip the current node - do not scan into it; do not resolve it. /// Skip, /// /// Resolve the current node. /// Subnodes which are not required for resolving the current node /// will ask the navigator again whether they should be resolved. /// Resolve } sealed class ConstantModeResolveVisitorNavigator : IResolveVisitorNavigator { readonly ResolveVisitorNavigationMode mode; readonly IResolveVisitorNavigator targetForResolveCalls; public ConstantModeResolveVisitorNavigator(ResolveVisitorNavigationMode mode, IResolveVisitorNavigator targetForResolveCalls) { this.mode = mode; this.targetForResolveCalls = targetForResolveCalls; } ResolveVisitorNavigationMode IResolveVisitorNavigator.Scan(AstNode node) { return mode; } void IResolveVisitorNavigator.Resolved(AstNode node, ResolveResult result) { if (targetForResolveCalls != null) targetForResolveCalls.Resolved(node, result); } void IResolveVisitorNavigator.ProcessConversion(Expression expression, ResolveResult result, Conversion conversion, IType targetType) { if (targetForResolveCalls != null) targetForResolveCalls.ProcessConversion(expression, result, conversion, targetType); } } }