/*
* QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
* Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
using QuantConnect.Interfaces;
namespace QuantConnect.Exceptions
{
///
/// Defines an exception interpreter. Interpretations are invoked on
///
public interface IExceptionInterpreter
{
///
/// Determines the order that a class that implements this interface should be called
///
int Order { get; }
///
/// Determines if this interpreter should be applied to the specified exception.
///
/// The exception to check
/// True if the exception can be interpreted, false otherwise
bool CanInterpret(Exception exception);
///
/// Interprets the specified exception into a new exception
///
/// The exception to be interpreted
/// An interpreter that should be applied to the inner exception.
/// This provides a link back allowing the inner exceptions to be interpreted using the interpreters
/// configured in the . Individual implementations *may* ignore
/// this value if required.
/// The interpreted exception
Exception Interpret(Exception exception, IExceptionInterpreter innerInterpreter);
}
}