using System;
using NHapi.Base.Model;
using NHapi.Base.Log;
using NHapi.Base;
using NHapi.Base.Model.Primitive;
namespace NHapi.Model.V251.Datatype{
///<summary>
/// <p>The HL7 PT (Processing Type) data type. Consists of the following components: </p><ol>
/// <li>Processing ID (ID)</li>
/// <li>Processing Mode (ID)</li>
/// </ol>
///</summary>
[Serializable]
public class PT : AbstractType, IComposite{
private IType[] data;
///<summary>
/// Creates a PT.
/// <param name="message">The Message to which this Type belongs</param>
///</summary>
public PT(IMessage message) : this(message, null){}
///<summary>
/// Creates a PT.
/// <param name="message">The Message to which this Type belongs</param>
/// <param name="description">The description of this type</param>
///</summary>
public PT(IMessage message, string description) : base(message, description){
data = new IType[2];
data[0] = new ID(message, 103,"Processing ID");
data[1] = new ID(message, 207,"Processing Mode");
}
///<summary>
/// Returns an array containing the data elements.
///</summary>
public IType[] Components
{
get{
return this.data;
}
}
///<summary>
/// Returns an individual data component.
/// @throws DataTypeException if the given element number is out of range.
///<param name="index">The index item to get (zero based)</param>
///<returns>The data component (as a type) at the requested number (ordinal)</returns>
///</summary>
public IType this[int index] {
get{
try {
return this.data[index];
} catch (System.ArgumentOutOfRangeException) {
throw new DataTypeException("Element " + index + " doesn't exist in 2 element PT composite");
}
}
}
///<summary>
/// Returns Processing ID (component #0). This is a convenience method that saves you from
/// casting and handling an exception.
///</summary>
public ID ProcessingID {
get{
ID ret = null;
try {
ret = (ID)this[0];
} catch (DataTypeException e) {
HapiLogFactory.getHapiLog(this.GetType()).error("Unexpected problem accessing known data type component - this is a bug.", e);
throw new System.Exception("An unexpected error ocurred",e);
}
return ret;
}
}
///<summary>
/// Returns Processing Mode (component #1). This is a convenience method that saves you from
/// casting and handling an exception.
///</summary>
public ID ProcessingMode {
get{
ID ret = null;
try {
ret = (ID)this[1];
} catch (DataTypeException e) {
HapiLogFactory.getHapiLog(this.GetType()).error("Unexpected problem accessing known data type component - this is a bug.", e);
throw new System.Exception("An unexpected error ocurred",e);
}
return ret;
}
}
}}
|