SqlException.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. //
  2. // System.Data.SqlClient.SqlException.cs
  3. //
  4. // Author:
  5. // Rodrigo Moya ([email protected])
  6. // Daniel Morgan ([email protected])
  7. // Tim Coleman ([email protected])
  8. //
  9. // (C) Ximian, Inc
  10. // Copyright (C) Tim Coleman, 2002
  11. //
  12. //
  13. // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
  14. //
  15. // Permission is hereby granted, free of charge, to any person obtaining
  16. // a copy of this software and associated documentation files (the
  17. // "Software"), to deal in the Software without restriction, including
  18. // without limitation the rights to use, copy, modify, merge, publish,
  19. // distribute, sublicense, and/or sell copies of the Software, and to
  20. // permit persons to whom the Software is furnished to do so, subject to
  21. // the following conditions:
  22. //
  23. // The above copyright notice and this permission notice shall be
  24. // included in all copies or substantial portions of the Software.
  25. //
  26. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  27. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  28. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  29. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  30. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  31. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  32. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  33. //
  34. using Mono.Data.Tds.Protocol;
  35. using System;
  36. using System.ComponentModel;
  37. using System.Data;
  38. using System.Data.Common;
  39. using System.Runtime.Serialization;
  40. using System.Text;
  41. namespace System.Data.SqlClient {
  42. [SerializableAttribute()]
  43. public sealed class SqlException
  44. #if NET_2_0
  45. : DbException
  46. #else
  47. : SystemException
  48. #endif //NET_1_1
  49. {
  50. #region Fields
  51. private SqlErrorCollection errors;
  52. private const string DEF_MESSAGE = "SQL Exception has occured.";
  53. #endregion // Fields
  54. #region Constructors
  55. internal SqlException ()
  56. : this (DEF_MESSAGE, null, null)
  57. {
  58. }
  59. internal SqlException (string message, Exception inner)
  60. : this (message, inner, null)
  61. {
  62. }
  63. internal SqlException (string message, Exception inner, SqlError sqlError)
  64. : base (message == null ? DEF_MESSAGE : message, inner)
  65. {
  66. errors = new SqlErrorCollection ();
  67. if (sqlError != null)
  68. errors.Add (sqlError);
  69. }
  70. internal SqlException (byte theClass, int lineNumber, string message, int number, string procedure, string server, string source, byte state)
  71. : this (message,
  72. null,
  73. new SqlError (theClass, lineNumber, message,
  74. number, procedure, server, source,
  75. state))
  76. {
  77. }
  78. private SqlException(SerializationInfo si, StreamingContext sc)
  79. {
  80. errors = (SqlErrorCollection)si.GetValue("Errors", typeof(SqlErrorCollection));
  81. }
  82. #endregion // Constructors
  83. #region Properties
  84. public byte Class {
  85. get { return Errors [0].Class; }
  86. }
  87. [DesignerSerializationVisibility (DesignerSerializationVisibility.Content)]
  88. public SqlErrorCollection Errors {
  89. get { return errors; }
  90. }
  91. public int LineNumber {
  92. get { return Errors [0].LineNumber; }
  93. }
  94. public override string Message {
  95. get {
  96. if (Errors.Count == 0)
  97. return base.Message;
  98. StringBuilder result = new StringBuilder ();
  99. if (base.Message != DEF_MESSAGE) {
  100. result.Append (base.Message);
  101. result.Append ("\n");
  102. }
  103. for (int i=0; i < Errors.Count -1; i++) {
  104. result.Append (Errors [i].Message);
  105. result.Append ("\n");
  106. }
  107. if (Errors.Count > 0)
  108. result.Append (Errors [Errors.Count - 1].Message);
  109. return result.ToString ();
  110. }
  111. }
  112. public int Number {
  113. get { return Errors [0].Number; }
  114. }
  115. public string Procedure {
  116. get { return Errors [0].Procedure; }
  117. }
  118. public string Server {
  119. get { return Errors [0].Server; }
  120. }
  121. public override string Source {
  122. get { return Errors [0].Source; }
  123. }
  124. public byte State {
  125. get { return Errors [0].State; }
  126. }
  127. #endregion // Properties
  128. #region Methods
  129. internal static SqlException FromTdsInternalException (TdsInternalException e)
  130. {
  131. return FromTdsInternalException (null, e);
  132. }
  133. internal static SqlException FromTdsInternalException (string message,
  134. TdsInternalException e)
  135. {
  136. SqlError sqlError = new SqlError (e.Class, e.LineNumber, e.Message,
  137. e.Number, e.Procedure, e.Server,
  138. "Mono SqlClient Data Provider", e.State);
  139. return new SqlException (message, e, sqlError);
  140. }
  141. public override void GetObjectData (SerializationInfo si, StreamingContext context)
  142. {
  143. if (si == null)
  144. throw new ArgumentNullException ("si");
  145. si.AddValue ("Errors", errors, typeof(SqlErrorCollection));
  146. base.GetObjectData (si, context);
  147. }
  148. #endregion // Methods
  149. }
  150. }