| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- // Licensed to the .NET Foundation under one or more agreements.
- // The .NET Foundation licenses this file to you under the MIT license.
- // See the LICENSE file in the project root for more information.
- /*=============================================================================
- **
- **
- **
- ** Purpose: Exception class for method arguments outside of the legal range.
- **
- **
- =============================================================================*/
- using System.Globalization;
- using System.Runtime.Serialization;
- namespace System
- {
- // The ArgumentOutOfRangeException is thrown when an argument
- // is outside the legal range for that argument.
- [Serializable]
- [System.Runtime.CompilerServices.TypeForwardedFrom("mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089")]
- public class ArgumentOutOfRangeException : ArgumentException
- {
- private object _actualValue;
- // Creates a new ArgumentOutOfRangeException with its message
- // string set to a default message explaining an argument was out of range.
- public ArgumentOutOfRangeException()
- : base(SR.Arg_ArgumentOutOfRangeException)
- {
- HResult = HResults.COR_E_ARGUMENTOUTOFRANGE;
- }
- public ArgumentOutOfRangeException(string paramName)
- : base(SR.Arg_ArgumentOutOfRangeException, paramName)
- {
- HResult = HResults.COR_E_ARGUMENTOUTOFRANGE;
- }
- public ArgumentOutOfRangeException(string paramName, string message)
- : base(message, paramName)
- {
- HResult = HResults.COR_E_ARGUMENTOUTOFRANGE;
- }
- public ArgumentOutOfRangeException(string message, Exception innerException)
- : base(message, innerException)
- {
- HResult = HResults.COR_E_ARGUMENTOUTOFRANGE;
- }
- // We will not use this in the classlibs, but we'll provide it for
- // anyone that's really interested so they don't have to stick a bunch
- // of printf's in their code.
- public ArgumentOutOfRangeException(string paramName, object actualValue, string message)
- : base(message, paramName)
- {
- _actualValue = actualValue;
- HResult = HResults.COR_E_ARGUMENTOUTOFRANGE;
- }
- protected ArgumentOutOfRangeException(SerializationInfo info, StreamingContext context)
- : base(info, context)
- {
- _actualValue = info.GetValue("ActualValue", typeof(object));
- }
- public override void GetObjectData(SerializationInfo info, StreamingContext context)
- {
- base.GetObjectData(info, context);
- info.AddValue("ActualValue", _actualValue, typeof(object));
- }
- public override string Message
- {
- get
- {
- string s = base.Message;
- if (_actualValue != null)
- {
- string valueMessage = SR.Format(SR.ArgumentOutOfRange_ActualValue, _actualValue.ToString());
- if (s == null)
- return valueMessage;
- return s + Environment.NewLine + valueMessage;
- }
- return s;
- }
- }
- // Gets the value of the argument that caused the exception.
- // Note - we don't set this anywhere in the class libraries in
- // version 1, but it might come in handy for other developers who
- // want to avoid sticking printf's in their code.
- public virtual object ActualValue
- {
- get { return _actualValue; }
- }
- }
- }
|