| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- //
- // System.Data.SqlClient.SqlException.cs
- //
- // Author:
- // Rodrigo Moya ([email protected])
- // Daniel Morgan ([email protected])
- // Tim Coleman ([email protected])
- //
- // (C) Ximian, Inc
- // Copyright (C) Tim Coleman, 2002
- //
- using Mono.Data.TdsClient.Internal;
- using System;
- using System.Data;
- using System.Runtime.Serialization;
- namespace System.Data.SqlClient {
- [Serializable]
- public sealed class SqlException : SystemException
- {
- private SqlErrorCollection errors;
- internal SqlException()
- : base ("a SQL Exception has occurred.")
- {
- errors = new SqlErrorCollection();
- }
- internal SqlException (byte theClass, int lineNumber, string message, int number, string procedure, string server, string source, byte state)
- : base (message)
- {
- errors = new SqlErrorCollection (theClass, lineNumber, message, number, procedure, server, source, state);
- }
- #region Properties
- [MonoTODO]
- public byte Class {
- get {
- if(errors.Count == 0)
- return 0; // FIXME: throw exception here?
- else
- return errors[0].Class;
- }
- set { errors[0].SetClass(value); }
- }
- [MonoTODO]
- public SqlErrorCollection Errors
- {
- get { return errors; }
- set { errors = value; }
- }
- [MonoTODO]
- public int LineNumber {
- get { if(errors.Count == 0)
- return 0; // FIXME: throw exception here?
- return errors[0].LineNumber;
- }
- set { errors[0].SetLineNumber(value); }
- }
-
- [MonoTODO]
- public override string Message {
- get {
- if(errors.Count == 0)
- return ""; // FIXME: throw exception?
- else {
- String msg = "";
- int i = 0;
-
- for(i = 0; i < errors.Count - 1; i++) {
- msg = msg + errors[i].Message + "\n";
- }
- msg = msg + errors[i].Message;
- return msg;
- }
- }
- }
-
- [MonoTODO]
- public int Number {
- get {
- if(errors.Count == 0)
- return 0; // FIXME: throw exception?
- else
- return errors[0].Number;
- }
- set { errors[0].SetNumber(value); }
- }
-
- [MonoTODO]
- public string Procedure {
- get {
- if(errors.Count == 0)
- return ""; // FIXME: throw exception?
- else
- return errors[0].Procedure;
- }
- set { errors[0].SetProcedure(value); }
- }
- [MonoTODO]
- public string Server {
- get {
- if(errors.Count == 0)
- return ""; // FIXME: throw exception?
- else
- return errors[0].Server;
- }
- set { errors[0].SetServer(value); }
- }
-
- [MonoTODO]
- public override string Source {
- get {
- if(errors.Count == 0)
- return ""; // FIXME: throw exception?
- else
- return errors[0].Source;
- }
- set { errors[0].SetSource(value); }
- }
- [MonoTODO]
- public byte State {
- get {
- if(errors.Count == 0)
- return 0; // FIXME: throw exception?
- else
- return errors[0].State;
- }
- set { errors[0].SetState(value); }
- }
- #endregion // Properties
- #region Methods
- [MonoTODO]
- public override void GetObjectData(SerializationInfo si, StreamingContext context)
- {
- throw new NotImplementedException ();
- }
- [MonoTODO]
- internal static SqlException FromTdsError (TdsPacketErrorResultCollection errors)
- {
- TdsMessage message = errors[0].Message;
- return new SqlException (message.Severity, message.Line, message.Message, message.Number, message.ProcName, message.Server, "Mono SqlClient Data Provider", message.State);
- }
- #endregion // Methods
- }
- }
|