aboutsummaryrefslogtreecommitdiff
path: root/Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs')
-rw-r--r--Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs332
1 files changed, 168 insertions, 164 deletions
diff --git a/Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs b/Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs
index ea8a0b846..1db74d133 100644
--- a/Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs
+++ b/Emby.Common.Implementations/IO/SharpCifs/Smb/SmbException.cs
@@ -21,192 +21,196 @@ using SharpCifs.Util.Sharpen;
namespace SharpCifs.Smb
{
- /// <summary>
- /// There are hundreds of error codes that may be returned by a CIFS
- /// server.
- /// </summary>
- /// <remarks>
- /// There are hundreds of error codes that may be returned by a CIFS
- /// server. Rather than represent each with it's own <code>Exception</code>
- /// class, this class represents all of them. For many of the popular
- /// error codes, constants and text messages like "The device is not ready"
- /// are provided.
- /// <p>
- /// The jCIFS client maps DOS error codes to NTSTATUS codes. This means that
- /// the user may recieve a different error from a legacy server than that of
- /// a newer varient such as Windows NT and above. If you should encounter
- /// such a case, please report it to jcifs at samba dot org and we will
- /// change the mapping.
- /// </remarks>
-
- public class SmbException : IOException
- {
-
+ /// <summary>
+ /// There are hundreds of error codes that may be returned by a CIFS
+ /// server.
+ /// </summary>
+ /// <remarks>
+ /// There are hundreds of error codes that may be returned by a CIFS
+ /// server. Rather than represent each with it's own <code>Exception</code>
+ /// class, this class represents all of them. For many of the popular
+ /// error codes, constants and text messages like "The device is not ready"
+ /// are provided.
+ /// <p>
+ /// The jCIFS client maps DOS error codes to NTSTATUS codes. This means that
+ /// the user may recieve a different error from a legacy server than that of
+ /// a newer varient such as Windows NT and above. If you should encounter
+ /// such a case, please report it to jcifs at samba dot org and we will
+ /// change the mapping.
+ /// </remarks>
+
+ public class SmbException : IOException
+ {
+
internal static string GetMessageByCode(int errcode)
- {
- if (errcode == 0)
- {
- return "NT_STATUS_SUCCESS";
- }
- if ((errcode & unchecked((int)(0xC0000000))) == unchecked((int)(0xC0000000)))
- {
- int min = 1;
- int max = NtStatus.NtStatusCodes.Length - 1;
- while (max >= min)
- {
- int mid = (min + max) / 2;
+ {
+ if (errcode == 0)
+ {
+ return "NT_STATUS_SUCCESS";
+ }
+ if ((errcode & unchecked((int)(0xC0000000))) == unchecked((int)(0xC0000000)))
+ {
+ int min = 1;
+ int max = NtStatus.NtStatusCodes.Length - 1;
+ while (max >= min)
+ {
+ int mid = (min + max) / 2;
if (errcode > NtStatus.NtStatusCodes[mid])
- {
- min = mid + 1;
- }
- else
- {
+ {
+ min = mid + 1;
+ }
+ else
+ {
if (errcode < NtStatus.NtStatusCodes[mid])
- {
- max = mid - 1;
- }
- else
- {
+ {
+ max = mid - 1;
+ }
+ else
+ {
return NtStatus.NtStatusMessages[mid];
- }
- }
- }
- }
- else
- {
- int min = 0;
- int max = DosError.DosErrorCodes.Length - 1;
- while (max >= min)
- {
- int mid = (min + max) / 2;
+ }
+ }
+ }
+ }
+ else
+ {
+ int min = 0;
+ int max = DosError.DosErrorCodes.Length - 1;
+ while (max >= min)
+ {
+ int mid = (min + max) / 2;
if (errcode > DosError.DosErrorCodes[mid][0])
- {
- min = mid + 1;
- }
- else
- {
+ {
+ min = mid + 1;
+ }
+ else
+ {
if (errcode < DosError.DosErrorCodes[mid][0])
- {
- max = mid - 1;
- }
- else
- {
+ {
+ max = mid - 1;
+ }
+ else
+ {
return DosError.DosErrorMessages[mid];
- }
- }
- }
- }
- return "0x" + Hexdump.ToHexString(errcode, 8);
- }
+ }
+ }
+ }
+ }
+ return "0x" + Hexdump.ToHexString(errcode, 8);
+ }
- internal static int GetStatusByCode(int errcode)
- {
- if ((errcode & unchecked((int)(0xC0000000))) != 0)
- {
- return errcode;
- }
- int min = 0;
- int max = DosError.DosErrorCodes.Length - 1;
- while (max >= min)
- {
- int mid = (min + max) / 2;
- if (errcode > DosError.DosErrorCodes[mid][0])
- {
- min = mid + 1;
- }
- else
- {
- if (errcode < DosError.DosErrorCodes[mid][0])
- {
- max = mid - 1;
- }
- else
- {
- return DosError.DosErrorCodes[mid][1];
- }
- }
- }
- return NtStatus.NtStatusUnsuccessful;
- }
+ internal static int GetStatusByCode(int errcode)
+ {
+ if ((errcode & unchecked((int)(0xC0000000))) != 0)
+ {
+ return errcode;
+ }
+ int min = 0;
+ int max = DosError.DosErrorCodes.Length - 1;
+ while (max >= min)
+ {
+ int mid = (min + max) / 2;
+ if (errcode > DosError.DosErrorCodes[mid][0])
+ {
+ min = mid + 1;
+ }
+ else
+ {
+ if (errcode < DosError.DosErrorCodes[mid][0])
+ {
+ max = mid - 1;
+ }
+ else
+ {
+ return DosError.DosErrorCodes[mid][1];
+ }
+ }
+ }
+ return NtStatus.NtStatusUnsuccessful;
+ }
- internal static string GetMessageByWinerrCode(int errcode)
- {
- int min = 0;
- int max = WinError.WinerrCodes.Length - 1;
- while (max >= min)
- {
- int mid = (min + max) / 2;
+ internal static string GetMessageByWinerrCode(int errcode)
+ {
+ int min = 0;
+ int max = WinError.WinerrCodes.Length - 1;
+ while (max >= min)
+ {
+ int mid = (min + max) / 2;
if (errcode > WinError.WinerrCodes[mid])
- {
- min = mid + 1;
- }
- else
- {
+ {
+ min = mid + 1;
+ }
+ else
+ {
if (errcode < WinError.WinerrCodes[mid])
- {
- max = mid - 1;
- }
- else
- {
+ {
+ max = mid - 1;
+ }
+ else
+ {
return WinError.WinerrMessages[mid];
- }
- }
- }
- return errcode + string.Empty;
- }
+ }
+ }
+ }
+ return errcode + string.Empty;
+ }
- private int _status;
+ private int _status;
- private Exception _rootCause;
+ private Exception _rootCause;
- public SmbException()
- {
- }
+ public SmbException()
+ {
+ }
- internal SmbException(int errcode, Exception rootCause) : base(GetMessageByCode(errcode
- ))
- {
- _status = GetStatusByCode(errcode);
- this._rootCause = rootCause;
- }
+ internal SmbException(int errcode, Exception rootCause)
+ : base(GetMessageByCode(errcode))
+ {
+ _status = GetStatusByCode(errcode);
+ this._rootCause = rootCause;
+ }
- public SmbException(string msg) : base(msg)
- {
+ public SmbException(string msg) : base(msg)
+ {
_status = NtStatus.NtStatusUnsuccessful;
- }
+ }
- public SmbException(string msg, Exception rootCause) : base(msg)
- {
- this._rootCause = rootCause;
+ public SmbException(string msg, Exception rootCause) : base(msg)
+ {
+ this._rootCause = rootCause;
_status = NtStatus.NtStatusUnsuccessful;
- }
+ }
- public SmbException(int errcode, bool winerr) : base(winerr ? GetMessageByWinerrCode
- (errcode) : GetMessageByCode(errcode))
- {
- _status = winerr ? errcode : GetStatusByCode(errcode);
- }
+ public SmbException(int errcode, bool winerr)
+ : base(winerr
+ ? GetMessageByWinerrCode(errcode)
+ : GetMessageByCode(errcode))
+ {
+ _status = winerr
+ ? errcode
+ : GetStatusByCode(errcode);
+ }
- public virtual int GetNtStatus()
- {
- return _status;
- }
+ public virtual int GetNtStatus()
+ {
+ return _status;
+ }
- public virtual Exception GetRootCause()
- {
- return _rootCause;
- }
+ public virtual Exception GetRootCause()
+ {
+ return _rootCause;
+ }
- public override string ToString()
- {
- if (_rootCause != null)
- {
- StringWriter sw = new StringWriter();
- PrintWriter pw = new PrintWriter(sw);
- Runtime.PrintStackTrace(_rootCause, pw);
- return base.ToString() + "\n" + sw;
- }
- return base.ToString();
- }
- }
+ public override string ToString()
+ {
+ if (_rootCause != null)
+ {
+ StringWriter sw = new StringWriter();
+ PrintWriter pw = new PrintWriter(sw);
+ Runtime.PrintStackTrace(_rootCause, pw);
+ return base.ToString() + "\n" + sw;
+ }
+ return base.ToString();
+ }
+ }
}