summaryrefslogtreecommitdiff
path: root/src/mscorlib/src/System/ArgumentOutOfRangeException.cs
diff options
context:
space:
mode:
Diffstat (limited to 'src/mscorlib/src/System/ArgumentOutOfRangeException.cs')
-rw-r--r--src/mscorlib/src/System/ArgumentOutOfRangeException.cs105
1 files changed, 105 insertions, 0 deletions
diff --git a/src/mscorlib/src/System/ArgumentOutOfRangeException.cs b/src/mscorlib/src/System/ArgumentOutOfRangeException.cs
new file mode 100644
index 0000000000..bfa281f8a4
--- /dev/null
+++ b/src/mscorlib/src/System/ArgumentOutOfRangeException.cs
@@ -0,0 +1,105 @@
+// Copyright (c) Microsoft. All rights reserved.
+// Licensed under the MIT license. See LICENSE file in the project root for full license information.
+
+/*=============================================================================
+**
+**
+**
+** Purpose: Exception class for method arguments outside of the legal range.
+**
+**
+=============================================================================*/
+
+namespace System {
+
+ using System;
+ using System.Runtime.Remoting;
+ using System.Runtime.Serialization;
+ using System.Globalization;
+ using System.Security.Permissions;
+ using System.Diagnostics.Contracts;
+
+ // The ArgumentOutOfRangeException is thrown when an argument
+ // is outside the legal range for that argument.
+[System.Runtime.InteropServices.ComVisible(true)]
+ [Serializable]
+ public class ArgumentOutOfRangeException : ArgumentException, ISerializable {
+
+ private static volatile String _rangeMessage;
+ private Object m_actualValue;
+
+ private static String RangeMessage {
+ get {
+ if (_rangeMessage == null)
+ _rangeMessage = Environment.GetResourceString("Arg_ArgumentOutOfRangeException");
+ return _rangeMessage;
+ }
+ }
+
+ // Creates a new ArgumentOutOfRangeException with its message
+ // string set to a default message explaining an argument was out of range.
+ public ArgumentOutOfRangeException()
+ : base(RangeMessage) {
+ SetErrorCode(__HResults.COR_E_ARGUMENTOUTOFRANGE);
+ }
+
+ public ArgumentOutOfRangeException(String paramName)
+ : base(RangeMessage, paramName) {
+ SetErrorCode(__HResults.COR_E_ARGUMENTOUTOFRANGE);
+ }
+
+ public ArgumentOutOfRangeException(String paramName, String message)
+ : base(message, paramName) {
+ SetErrorCode(__HResults.COR_E_ARGUMENTOUTOFRANGE);
+ }
+
+ public ArgumentOutOfRangeException(String message, Exception innerException)
+ : base(message, innerException) {
+ SetErrorCode(__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) {
+ m_actualValue = actualValue;
+ SetErrorCode(__HResults.COR_E_ARGUMENTOUTOFRANGE);
+ }
+
+ public override String Message {
+ get {
+ String s = base.Message;
+ if (m_actualValue != null) {
+ String valueMessage = Environment.GetResourceString("ArgumentOutOfRange_ActualValue", m_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 m_actualValue; }
+ }
+
+ [System.Security.SecurityCritical] // auto-generated_required
+ public override void GetObjectData(SerializationInfo info, StreamingContext context) {
+ if (info==null) {
+ throw new ArgumentNullException("info");
+ }
+ Contract.EndContractBlock();
+ base.GetObjectData(info, context);
+ info.AddValue("ActualValue", m_actualValue, typeof(Object));
+ }
+
+ protected ArgumentOutOfRangeException(SerializationInfo info, StreamingContext context) : base(info, context) {
+ m_actualValue = info.GetValue("ActualValue", typeof(Object));
+ }
+ }
+}