ntwain/NTwain/TwainException.cs
2014-04-20 16:57:38 -04:00

90 lines
4.2 KiB
C#

using NTwain.Data;
using System;
using System.Runtime.Serialization;
using System.Security.Permissions;
namespace NTwain
{
/// <summary>
/// Represents a general exception with TWAIN.
/// </summary>
[Serializable]
public class TwainException : Exception
{
/// <summary>
/// Initializes a new instance of the <see cref="TwainException"/> class.
/// </summary>
public TwainException() { }
/// <summary>
/// Initializes a new instance of the <see cref="TwainException" /> class.
/// </summary>
/// <param name="returnCode">The return code.</param>
/// <param name="message">The message.</param>
public TwainException(ReturnCode returnCode, string message)
: this(returnCode, message, null) { }
/// <summary>
/// Initializes a new instance of the <see cref="TwainException" /> class.
/// </summary>
/// <param name="returnCode">The return code.</param>
/// <param name="message">The message.</param>
/// <param name="innerException">The inner exception.</param>
public TwainException(ReturnCode returnCode, string message, Exception innerException)
: base(message, innerException)
{
ReturnCode = returnCode;
}
/// <summary>
/// Initializes a new instance of the <see cref="TwainException"/> class.
/// </summary>
/// <param name="info">The <see cref="T:System.Runtime.Serialization.SerializationInfo"/> that holds the serialized object data about the exception being thrown.</param>
/// <param name="context">The <see cref="T:System.Runtime.Serialization.StreamingContext"/> that contains contextual information about the source or destination.</param>
/// <exception cref="T:System.ArgumentNullException">
/// The <paramref name="info"/> parameter is null.
/// </exception>
/// <exception cref="T:System.Runtime.Serialization.SerializationException">
/// The class name is null or <see cref="P:System.Exception.HResult"/> is zero (0).
/// </exception>
protected TwainException(SerializationInfo info, StreamingContext context)
: base(info, context)
{
if (info != null)
{
ReturnCode = (ReturnCode)info.GetUInt16("RC");
}
}
/// <summary>
/// When overridden in a derived class, sets the <see cref="T:System.Runtime.Serialization.SerializationInfo"/> with information about the exception.
/// </summary>
/// <param name="info">The <see cref="T:System.Runtime.Serialization.SerializationInfo"/> that holds the serialized object data about the exception being thrown.</param>
/// <param name="context">The <see cref="T:System.Runtime.Serialization.StreamingContext"/> that contains contextual information about the source or destination.</param>
/// <exception cref="T:System.ArgumentNullException">
/// The <paramref name="info"/> parameter is a null reference (Nothing in Visual Basic).
/// </exception>
/// <PermissionSet>
/// <IPermission class="System.Security.Permissions.FileIOPermission, mscorlib, Version=2.0.3600.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" version="1" Read="*AllFiles*" PathDiscovery="*AllFiles*"/>
/// <IPermission class="System.Security.Permissions.SecurityPermission, mscorlib, Version=2.0.3600.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" version="1" Flags="SerializationFormatter"/>
/// </PermissionSet>
[SecurityPermissionAttribute(SecurityAction.Demand, SerializationFormatter = true)]
public override void GetObjectData(SerializationInfo info, StreamingContext context)
{
if (info != null)
{
info.AddValue("RC", ReturnCode);
}
base.GetObjectData(info, context);
}
/// <summary>
/// Gets the return code from the TWAIN operation if applicable.
/// </summary>
/// <value>
/// The return code.
/// </value>
public ReturnCode ReturnCode { get; private set; }
}
}