DicomDirInterface Class Reference

An interface class for simplified creation of a DICOMDIR. More...

List of all members.

Public Types

enum  E_ApplicationProfile {
  AP_GeneralPurpose, AP_Default = AP_GeneralPurpose, AP_GeneralPurposeDVD, AP_GeneralPurposeMIME,
  AP_USBandFlash, AP_MPEG2MPatML, AP_BasicCardiac, AP_XrayAngiographic,
  AP_XrayAngiographicDVD, AP_DentalRadiograph, AP_CTandMR, AP_UltrasoundIDSF,
  AP_UltrasoundSCSF, AP_UltrasoundCCSF, AP_UltrasoundIDMF, AP_UltrasoundSCMF,
  AP_UltrasoundCCMF, AP_TwelveLeadECG, AP_HemodynamicWaveform
}
 list of supported media storage application profiles More...

Public Member Functions

 DicomDirInterface ()
 constructor (default).
virtual ~DicomDirInterface ()
 destructor (virtual).
void cleanup ()
 reset the object to its initial state.
OFBool isDicomDirValid () const
 check whether current DICOMDIR is valid.
OFCondition createNewDicomDir (const E_ApplicationProfile profile=AP_GeneralPurpose, const char *filename=DEFAULT_DICOMDIR_NAME, const char *filesetID=DEFAULT_FILESETID)
 create a new DICOMDIR object.
OFCondition appendToDicomDir (const E_ApplicationProfile profile, const char *filename)
 create a DICOMDIR object based on an existing DICOMDIR file.
OFCondition writeDicomDir (const E_EncodingType encodingType=EET_UndefinedLength, const E_GrpLenEncoding groupLength=EGL_withoutGL)
 write the current DICOMDIR object to file.
OFBool isFilenameValid (const char *filename, const OFBool allowEmpty=OFFalse)
 check whether specified filename is valid.
OFBool isCharsetValid (const char *charset)
 check whether given charset identifier is valid.
OFCondition checkDicomFile (const char *filename, const char *directory=NULL)
 check whether specified DICOM file is suitable to be included into the DICOMDIR.
OFCondition addDicomFile (const char *filename, const char *directory=NULL)
 add specified DICOM file to the current DICOMDIR.
OFCondition setFilesetDescriptor (const char *filename, const char *charset=DEFAULT_DESCRIPTOR_CHARSET)
 set the fileset descriptor file ID and character set.
OFCondition setIconSize (const unsigned int size)
 set preferred size of the icon images.
OFCondition setIconPrefix (const char *prefix)
 set filename prefix for alternative icon images.
OFCondition setDefaultIcon (const char *filename)
 set filename of default icon image.
OFBool verboseMode () const
 get current status of the verbose mode
OFBool abortMode () const
 get current status of the "abort on first error" mode.
OFBool mapFilenamesMode () const
 get current status of the "map filenames" mode.
OFBool inventMode () const
 get current status of the "invent missing values" mode.
OFBool inventPatientIDMode () const
 get current status of the "invent missing patient ID" mode.
OFBool iconImageMode () const
 get current status of the "create icon images" mode.
OFBool backupMode () const
 get current status of the "create backup" mode.
OFBool encodingCheck () const
 get current status of the "pixel encoding check" mode.
OFBool resolutionCheck () const
 get current status of the "spatial resolution check" mode.
OFBool transferSyntaxCheck () const
 get current status of the "transfer syntax check" mode.
OFBool consistencyCheck () const
 get current status of the "consistency check" mode.
OFBool enableVerboseMode (const OFBool newMode=OFTrue)
 enable/disable the verbose mode.
OFBool enableAbortMode (const OFBool newMode=OFTrue)
 enable/disable the "abort on first error" mode.
OFBool enableMapFilenamesMode (const OFBool newMode=OFTrue)
 enable/disable the "map filenames" mode.
OFBool enableInventMode (const OFBool newMode=OFTrue)
 enable/disable the "invent missing values" mode.
OFBool enableInventPatientIDMode (const OFBool newMode=OFTrue)
 enable/disable the "invent new patient ID" mode.
OFBool enableIconImageMode (const OFBool newMode=OFTrue)
 enable/disable the "create icon images" mode.
OFBool disableBackupMode (const OFBool newMode=OFFalse)
 disable/enable the "create backup file" mode.
OFBool disableEncodingCheck (const OFBool newMode=OFFalse)
 disable/enable the "pixel encoding check".
OFBool disableResolutionCheck (const OFBool newMode=OFFalse)
 disable/enable the "spatial resolution check".
OFBool disableTransferSyntaxCheck (const OFBool newMode=OFFalse)
 disable/enable the "transfer syntax check".
OFBool disableConsistencyCheck (const OFBool newMode=OFFalse)
 disable/enable the "consistency check".
OFBool addImageSupport (DicomDirImagePlugin *plugin)
 add pluggable image support.
void setLogStream (OFConsole *stream)
 set the log stream.

Static Public Member Functions

static const char * getProfileName (const E_ApplicationProfile profile)
 get name/identifier associated with the given application profile

Protected Member Functions

OFCondition selectApplicationProfile (const E_ApplicationProfile profile)
 select given application profile
OFCondition loadAndCheckDicomFile (const char *filename, const char *directory, DcmFileFormat &fileformat)
 load and check DICOM file regarding the current application profile
OFCondition checkSOPClassAndXfer (DcmMetaInfo *metainfo, DcmItem *dataset, const char *filename)
 check SOP class and transfer syntax for compliance with current profile
OFCondition checkBasicCardiacAttributes (DcmItem *dataset, const char *filename)
 check attributes for compliance with Basic Cardiac application profile
OFCondition checkXrayAngiographicAttributes (DcmItem *dataset, const OFString &sopClass, const char *filename)
 check attributes for compliance with X-ray Angiography application profile
OFCondition checkDentalRadiographAttributes (DcmItem *dataset, const char *filename)
 check attributes for compliance with dental radiograph application profile
OFCondition checkCTandMRAttributes (DcmItem *dataset, const OFString &sopClass, const char *filename)
 check attributes for compliance with CT and MR application profile
OFCondition checkUltrasoundAttributes (DcmItem *dataset, const OFString &transferSyntax, const char *filename)
 check attributes for compliance with Ultrasound application profiles
OFCondition checkMandatoryAttributes (DcmMetaInfo *metainfo, DcmItem *dataset, const char *filename)
 check attributes for comliance with current application profile
OFBool recordMatchesDataset (DcmDirectoryRecord *record, DcmItem *dataset)
 check whether given DICOMDIR record matches dataset.
DcmDirectoryRecordfindExistingRecord (DcmDirectoryRecord *parent, const E_DirRecType recordType, DcmItem *dataset)
 search for a given DICOMDIR record
DcmDirectoryRecordbuildPatientRecord (DcmItem *dataset, const OFString &sourceFilename)
 create new patient record and copy required values from dataset
DcmDirectoryRecordbuildStudyRecord (DcmItem *dataset, const OFString &sourceFilename)
 create new study record and copy required values from dataset
DcmDirectoryRecordbuildSeriesRecord (DcmItem *dataset, const OFString &sourceFilename)
 create new series record and copy required values from dataset
DcmDirectoryRecordbuildOverlayRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new overlay record and copy required values from dataset
DcmDirectoryRecordbuildModalityLutRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new modality LUT record and copy required values from dataset
DcmDirectoryRecordbuildVoiLutRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new VOI LUT record and copy required values from dataset
DcmDirectoryRecordbuildCurveRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new curve record and copy required values from dataset
DcmDirectoryRecordbuildStructReportRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new structure reporting record and copy required values from dataset
DcmDirectoryRecordbuildPresentationRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new presentation state record and copy required values from dataset
DcmDirectoryRecordbuildWaveformRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new waveform record and copy required values from dataset
DcmDirectoryRecordbuildRTDoseRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new RT dose record and copy required values from dataset
DcmDirectoryRecordbuildRTStructureSetRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new RT structure set record and copy required values from dataset
DcmDirectoryRecordbuildRTPlanRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new RT plan record and copy required values from dataset
DcmDirectoryRecordbuildRTTreatmentRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new RT treatment record and copy required values from dataset
DcmDirectoryRecordbuildStoredPrintRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new stored print record and copy required values from dataset
DcmDirectoryRecordbuildKeyObjectDocRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new key object doc record and copy required values from dataset
DcmDirectoryRecordbuildRegistrationRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new registration record and copy required values from dataset
DcmDirectoryRecordbuildFiducialRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new fiducial record and copy required values from dataset
DcmDirectoryRecordbuildRawDataRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new raw data record and copy required values from dataset
DcmDirectoryRecordbuildSpectroscopyRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new spectroscopy record and copy required values from dataset
DcmDirectoryRecordbuildEncapDocRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new encap doc record and copy required values from dataset
DcmDirectoryRecordbuildValueMapRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new value map record and copy required values from dataset
DcmDirectoryRecordbuildImageRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new image record and copy required values from dataset
DcmDirectoryRecordbuildHangingProtocolRecord (DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 create new hanging protocol record and copy required values from dataset
OFBool getIconFromFile (const OFString &filename, Uint8 *pixel, const unsigned long count, const unsigned int width, const unsigned int height)
 create icon image from given PGM (portable gray map) file.
OFBool getIconFromDataset (DcmItem *dataset, Uint8 *pixel, const unsigned long count, const unsigned int width, const unsigned int height)
 create icon image from DICOM dataset.
OFCondition addIconImage (DcmDirectoryRecord *record, DcmItem *dataset, const unsigned int size, const OFString &sourceFilename)
 add icon image sequence to DICOMDIR record.
DcmDirectoryRecordaddRecord (DcmDirectoryRecord *parent, const E_DirRecType recordType, DcmItem *dataset, const OFString &referencedFileID, const OFString &sourceFilename)
 add child record to a given parent record.
void inventMissingAttributes (DcmDirectoryRecord *parent, const OFBool recurse=OFTrue)
 invent missing type 1 attributes for all child records (from patient level)
void inventMissingStudyLevelAttributes (DcmDirectoryRecord *parent)
 invent missing type 1 attributes for all child records (from study level)
void inventMissingSeriesLevelAttributes (DcmDirectoryRecord *parent)
 invent missing type 1 attributes for all child records (from series level)
void inventMissingInstanceLevelAttributes (DcmDirectoryRecord *parent)
 invent missing type 1 attributes for all child records (from instance level)
void createDicomDirBackup (const char *filename)
 create backup of a given file
void deleteDicomDirBackup ()
 delete backup file if one has been created
void printMessage (const char *message, const char *suffix=NULL)
 print a message on the log stream (stdout)
void printWarningMessage (const char *message, const char *suffix=NULL)
 print a warning message on the log stream (stderr).
void printErrorMessage (const char *message, const char *suffix=NULL)
 print an error message on the log stream (stderr).
void printUnexpectedValueMessage (const DcmTagKey &key, const char *filename=NULL, const OFBool errorMsg=OFTrue)
 print a message that the value of a given tag is unexpected.
void printRequiredAttributeMessage (const DcmTagKey &key, const char *filename=NULL, const OFBool emptyMsg=OFFalse)
 print an error message that a required attribute is missing/empty.
void printAttributeErrorMessage (const DcmTagKey &key, const OFCondition &error, const char *operation)
 print an error message that something went wrong with an attribute.
void printRecordErrorMessage (const OFCondition &error, const E_DirRecType recordType, const char *operation)
 print an error message that something went wrong with a given record.
void printFileErrorMessage (const OFCondition &error, const char *operation, const char *filename)
 print the given error status to the log stream (stderr).
OFBool copyFile (const char *fromFilename, const char *toFilename)
 copy contents of specified file
OFBool warnAboutInconsistentAttributes (DcmDirectoryRecord *record, DcmItem *dataset, const OFString &sourceFilename, const OFBool abortCheck=OFFalse)
 see if all the attributes in record match the values in dataset and warn if not
OFBool checkFilesetID (const OFString &filesetID)
 check whether given fileset ID is valid
OFBool checkExists (DcmItem *dataset, const DcmTagKey &key, const char *filename=NULL)
 check whether given tag exists in the DICOM dataset
OFBool checkExistsWithValue (DcmItem *dataset, const DcmTagKey &key, const char *filename=NULL)
 check whether given tag exists with a value in the DICOM dataset
OFBool checkExistsWithStringValue (DcmItem *dataset, const DcmTagKey &key, const OFString &value, const char *filename=NULL)
 check whether given tag exists in the DICOM dataset and has the expected string value
OFBool checkExistsWithIntegerValue (DcmItem *dataset, const DcmTagKey &key, const long value, const char *filename=NULL, const OFBool reject=OFTrue)
 check whether given tag exists in the DICOM dataset and has the expected integer value
OFBool checkExistsWithMinMaxValue (DcmItem *dataset, const DcmTagKey &key, const long min, const long max, const char *filename=NULL, const OFBool reject=OFTrue)
 check whether given tag exists in the DICOM dataset and has an integer value in the expected range
OFStringgetStringFromDataset (DcmItem *dataset, const DcmTagKey &key, OFString &result, OFBool searchIntoSub=OFFalse)
 get string value from dataset and report an error (if any)
OFStringgetStringFromFile (const char *filename, const DcmTagKey &key, OFString &result, OFBool searchIntoSub=OFFalse)
 get string value from file and report an error (if any)
void copyElement (DcmItem *dataset, const DcmTagKey &key, DcmDirectoryRecord *record, const OFBool optional=OFFalse, const OFBool copyEmpty=OFTrue)
 copy element from dataset to directory record
void copyStringWithDefault (DcmItem *dataset, const DcmTagKey &key, DcmDirectoryRecord *record, const char *defaultValue="", const OFBool printWarning=OFFalse)
 copy optional string value from dataset to directory record
OFBool compareStringAttributes (DcmItem *dataset, DcmTagKey &key, DcmDirectoryRecord *record, const OFString &sourceFilename)
 compare string attribute from dataset and record and report any deviation
OFBool compareSequenceAttributes (DcmItem *dataset, DcmTagKey &key, DcmDirectoryRecord *record, const OFString &sourceFilename)
 compare sequence attribute from dataset and record and report any deviation
void setDefaultValue (DcmDirectoryRecord *record, const DcmTagKey &key, const unsigned long number, const char *prefix=NULL)
 set default value (number or prefix and number) to a given tag

Private Member Functions

 DicomDirInterface (const DicomDirInterface &obj)
 private undefined copy constructor
DicomDirInterfaceoperator= (const DicomDirInterface &obj)
 private undefined assignment operator

Private Attributes

OFConsoleLogStream
 output stream for error messages, NULL for no messages
DcmDicomDirDicomDir
 pointer to the current DICOMDIR object
DicomDirImagePluginImagePlugin
 pointer to the optional image plugin (required for icon image support)
E_ApplicationProfile ApplicationProfile
 currently selected application profile
OFBool VerboseMode
 print verbose messages
OFBool BackupMode
 create DICOMDIR backup
OFBool AbortMode
 abort on first inconsistent record
OFBool MapFilenamesMode
 automatically map filenames
OFBool InventMode
 invent missing attributes mode
OFBool InventPatientIDMode
 invent missing patient ID mode
OFBool EncodingCheck
 check pixel encoding
OFBool ResolutionCheck
 check image resolution
OFBool TransferSyntaxCheck
 check transfer syntax
OFBool ConsistencyCheck
 check consistency of newly added record
OFBool IconImageMode
 create icon images
OFString BackupFilename
 name of the DICOMDIR backup file
OFBool BackupCreated
 flag indicating whether a backup has been created
unsigned int IconSize
 size of the optional icon image in pixels
OFString IconPrefix
 filename prefix for the external icon images
OFString DefaultIcon
 filename of the default icon (if any)
OFBool JPEGSupport
 flag indicating whether JPEG compression is supported
OFBool RLESupport
 flag indicating whether RLE compression is supported
unsigned long AutoPatientNumber
 current patient number used to invent missing attribute values
unsigned long AutoStudyNumber
 current study number used to invent missing attribute values
unsigned long AutoSeriesNumber
 current series number used to invent missing attribute values
unsigned long AutoInstanceNumber
 current instance number used to invent missing attribute values
unsigned long AutoOverlayNumber
 current overlay number used to invent missing attribute values
unsigned long AutoLutNumber
 current LUT number used to invent missing attribute values
unsigned long AutoCurveNumber
 current curve number used to invent missing attribute values


Detailed Description

An interface class for simplified creation of a DICOMDIR.

Definition at line 113 of file dcddirif.h.


Member Enumeration Documentation

enum DicomDirInterface::E_ApplicationProfile
 

list of supported media storage application profiles

Enumerator:
AP_GeneralPurpose  General Purpose Interchange on CD-R or DVD-RAM Media (STD-GEN-CD/DVD-RAM).
AP_Default  default application profile: GeneralPurpose
AP_GeneralPurposeDVD  General Purpose DVD with Compression Interchange (STD-GEN-DVD).
AP_GeneralPurposeMIME  General Purpose MIME Interchange Profile (STD-GEN-MIME).
AP_USBandFlash  General Purpose USB and Flash Memory with Compression Interchange (STD-GEN-USB/MMC/CF/SD-JPEG/J2K).
AP_MPEG2MPatML  DVD Interchange with MPEG2 MP (STD-DVD-MPEG2-MPML).
AP_BasicCardiac  Basic Cardiac X-Ray Angiographic Studies on CD-R Media (STD-XABC-CD).
AP_XrayAngiographic  1024 X-Ray Angiographic Studies on CD-R Media (STD-XA1K-CD)
AP_XrayAngiographicDVD  1024 X-Ray Angiographic Studies on DVD Media (STD-XA1K-DVD)
AP_DentalRadiograph  Dental Radiograph Interchange (STD-DEN-CD).
AP_CTandMR  CT/MR Studies (STD-CTMR-xxxx).
AP_UltrasoundIDSF  Ultrasound Single Frame for Image Display (STD-US-ID-SF-xxxx).
AP_UltrasoundSCSF  Ultrasound Single Frame with Spatial Calibration (STD-US-SC-SF-xxxx).
AP_UltrasoundCCSF  Ultrasound Single Frame with Combined Calibration (STD-US-CC-SF-xxxx).
AP_UltrasoundIDMF  Ultrasound Single & Multi-Frame for Image Display (STD-US-ID-MF-xxxx).
AP_UltrasoundSCMF  Ultrasound Single & Multi-Frame with Spatial Calibration (STD-UD-SC-MF-xxxx).
AP_UltrasoundCCMF  Ultrasound Single & Multi-Frame with Combined Calibration (STD-UD-CC-MF-xxxx).
AP_TwelveLeadECG  12-lead ECG Interchange on Diskette (STD-WVFM-ECG-FD)
AP_HemodynamicWaveform  Hemodynamic Waveform Interchange on Diskette (STD-WVFM-HD-FD).

Definition at line 120 of file dcddirif.h.


Constructor & Destructor Documentation

DicomDirInterface::DicomDirInterface  ) 
 

constructor (default).

No DICOMDIR object is created by default (see methods createNewDicomDir and appendToDicomDir).

virtual DicomDirInterface::~DicomDirInterface  )  [virtual]
 

destructor (virtual).

Free all memory allocated by this class.


Member Function Documentation

OFBool DicomDirInterface::abortMode  )  const [inline]
 

get current status of the "abort on first error" mode.

See enableAbortMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 319 of file dcddirif.h.

References AbortMode.

OFCondition DicomDirInterface::addDicomFile const char *  filename,
const char *  directory = NULL
 

add specified DICOM file to the current DICOMDIR.

This method loads the given file, checks whether it conforms to the current application profile and finally adds it to the DICOMDIR (in case of conformance).

Parameters:
filename name of the DICOM file to be added
directory directory where the DICOM file is stored (optional). This parameter might be useful in cases where the DICOM file is not (yet) stored in the final directory (i.e. "relative" to the DICOMDIR location).
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::addIconImage DcmDirectoryRecord record,
DcmItem dataset,
const unsigned int  size,
const OFString sourceFilename
[protected]
 

add icon image sequence to DICOMDIR record.

If the icon image cannot be created from the DICOM dataset and there is no PGM file specified (neither for the particular image not a default one) a black image is used instead.

Parameters:
record DICOMDIR record where the icon image is stored
dataset DICOM dataset from which the icon image is possibly created
size resolution of the icon image to be created (width and height)
sourceFilename name of the source DICOM file
Returns:
EC_Normal upon success, an error code otherwise

OFBool DicomDirInterface::addImageSupport DicomDirImagePlugin plugin  ) 
 

add pluggable image support.

NB: This plugin is required to create icon images from DICOM files!

Parameters:
plugin pointer to an instance of the plugin implementation. See class DicomDirImageImplementation (dcmjpeg/include/ddpiimpl.h).
Returns:
OFTrue if successful, OFFalse otherwise

DcmDirectoryRecord* DicomDirInterface::addRecord DcmDirectoryRecord parent,
const E_DirRecType  recordType,
DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

add child record to a given parent record.

A new record is only added if it does not already exist.

Parameters:
parent parent record (add new record as a child of this one)
recordType type of DICOMDIR record to be created
dataset DICOM dataset containing data of the new record
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new/existing record, NULL if an error occurred

OFCondition DicomDirInterface::appendToDicomDir const E_ApplicationProfile  profile,
const char *  filename
 

create a DICOMDIR object based on an existing DICOMDIR file.

This function can be used to append new entries to an existing DICOMDIR file. If the backup mode (see 'enableBackupMode') is enabled a backup copy ('filename' + ".BAK") is created from the existing file and automatically deleted after the new file has been written without any errors.

Parameters:
profile media storage application profile to be used for the DICOMDIR. NB: The same profile should be used as for the creation of the DICOMDIR file.
filename name of the DICOMDIR file to be appended. The filename may include a fully qualified pathname.
Returns:
EC_Normal upon success, an error code otherwise

OFBool DicomDirInterface::backupMode  )  const [inline]
 

get current status of the "create backup" mode.

See enableBackupMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 364 of file dcddirif.h.

References BackupMode.

DcmDirectoryRecord* DicomDirInterface::buildCurveRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new curve record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildEncapDocRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new encap doc record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildFiducialRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new fiducial record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildHangingProtocolRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new hanging protocol record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildImageRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new image record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildKeyObjectDocRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new key object doc record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildModalityLutRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new modality LUT record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildOverlayRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new overlay record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildPatientRecord DcmItem dataset,
const OFString sourceFilename
[protected]
 

create new patient record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildPresentationRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new presentation state record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRawDataRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new raw data record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRegistrationRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new registration record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRTDoseRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new RT dose record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRTPlanRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new RT plan record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRTStructureSetRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new RT structure set record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildRTTreatmentRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new RT treatment record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildSeriesRecord DcmItem dataset,
const OFString sourceFilename
[protected]
 

create new series record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildSpectroscopyRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new spectroscopy record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildStoredPrintRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new stored print record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildStructReportRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new structure reporting record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildStudyRecord DcmItem dataset,
const OFString sourceFilename
[protected]
 

create new study record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildValueMapRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new value map record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildVoiLutRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new VOI LUT record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

DcmDirectoryRecord* DicomDirInterface::buildWaveformRecord DcmItem dataset,
const OFString referencedFileID,
const OFString sourceFilename
[protected]
 

create new waveform record and copy required values from dataset

Parameters:
dataset DICOM dataset of the current file
referencedFileID value of the Referenced File ID attribute
sourceFilename name of the source DICOM file
Returns:
pointer to new record, NULL if an error occurred

OFCondition DicomDirInterface::checkBasicCardiacAttributes DcmItem dataset,
const char *  filename
[protected]
 

check attributes for compliance with Basic Cardiac application profile

Parameters:
dataset object where the DICOM dataset is stored
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkCTandMRAttributes DcmItem dataset,
const OFString sopClass,
const char *  filename
[protected]
 

check attributes for compliance with CT and MR application profile

Parameters:
dataset object where the DICOM dataset is stored
sopClass SOP class of the DICOM data to be checked
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkDentalRadiographAttributes DcmItem dataset,
const char *  filename
[protected]
 

check attributes for compliance with dental radiograph application profile

Parameters:
dataset object where the DICOM dataset is stored
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkDicomFile const char *  filename,
const char *  directory = NULL
 

check whether specified DICOM file is suitable to be included into the DICOMDIR.

This method loads the given file and checks whether it conforms to the current application profile. Since this check is also performed by addDicomFile() there is usually no need to call this method directly.

Parameters:
filename name of the DICOM file to be checked
directory directory where the DICOM file is stored (optional). This parameter might be useful in cases where the DICOM file is not (yet) stored in the final directory (i.e. "relative" to the DICOMDIR location).
Returns:
EC_Normal upon success, an error code otherwise

OFBool DicomDirInterface::checkExists DcmItem dataset,
const DcmTagKey key,
const char *  filename = NULL
[protected]
 

check whether given tag exists in the DICOM dataset

Parameters:
dataset DICOM dataset to be checked
key tag to be searched for
filename of the file (optional, report any error if specified)
Returns:
OFTrue if tag exists, OFFalse otherwise

OFBool DicomDirInterface::checkExistsWithIntegerValue DcmItem dataset,
const DcmTagKey key,
const long  value,
const char *  filename = NULL,
const OFBool  reject = OFTrue
[protected]
 

check whether given tag exists in the DICOM dataset and has the expected integer value

Parameters:
dataset DICOM dataset to be checked
key tag to be searched for
value expected integer value
filename of the file (optional, report any error if specified)
reject report an "Error" if OFTrue, a "Warning" if OFFalse
Returns:
OFTrue if tag exists with given string value, OFFalse otherwise

OFBool DicomDirInterface::checkExistsWithMinMaxValue DcmItem dataset,
const DcmTagKey key,
const long  min,
const long  max,
const char *  filename = NULL,
const OFBool  reject = OFTrue
[protected]
 

check whether given tag exists in the DICOM dataset and has an integer value in the expected range

Parameters:
dataset DICOM dataset to be checked
key tag to be searched for
min minimum integer value of the expected range
max maximum integer value of the expected range
filename of the file (optional, report any error if specified)
reject report an "Error" if OFTrue, a "Warning" if OFFalse
Returns:
OFTrue if tag exists with given string value, OFFalse otherwise

OFBool DicomDirInterface::checkExistsWithStringValue DcmItem dataset,
const DcmTagKey key,
const OFString value,
const char *  filename = NULL
[protected]
 

check whether given tag exists in the DICOM dataset and has the expected string value

Parameters:
dataset DICOM dataset to be checked
key tag to be searched for
value expected string value
filename of the file (optional, report any error if specified)
Returns:
OFTrue if tag exists with given string value, OFFalse otherwise

OFBool DicomDirInterface::checkExistsWithValue DcmItem dataset,
const DcmTagKey key,
const char *  filename = NULL
[protected]
 

check whether given tag exists with a value in the DICOM dataset

Parameters:
dataset DICOM dataset to be checked
key tag to be searched for
filename of the file (optional, report any error if specified)
Returns:
OFTrue if tag exists with value, OFFalse otherwise

OFBool DicomDirInterface::checkFilesetID const OFString filesetID  )  [protected]
 

check whether given fileset ID is valid

Parameters:
filesetID fileset ID to be checked
Returns:
OFTrue if ID is valid, OFFalse otherwise

OFCondition DicomDirInterface::checkMandatoryAttributes DcmMetaInfo metainfo,
DcmItem dataset,
const char *  filename
[protected]
 

check attributes for comliance with current application profile

Parameters:
metainfo object where the DICOM file meta information is stored
dataset object where the DICOM dataset is stored
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkSOPClassAndXfer DcmMetaInfo metainfo,
DcmItem dataset,
const char *  filename
[protected]
 

check SOP class and transfer syntax for compliance with current profile

Parameters:
metainfo object where the DICOM file meta information is stored
dataset object where the DICOM dataset is stored
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkUltrasoundAttributes DcmItem dataset,
const OFString transferSyntax,
const char *  filename
[protected]
 

check attributes for compliance with Ultrasound application profiles

Parameters:
dataset object where the DICOM dataset is stored
transferSyntax transfer syntax of the DICOM data to be checked
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::checkXrayAngiographicAttributes DcmItem dataset,
const OFString sopClass,
const char *  filename
[protected]
 

check attributes for compliance with X-ray Angiography application profile

Parameters:
dataset object where the DICOM dataset is stored
sopClass SOP class of the DICOM data to be checked
filename name of the DICOM file to be checked
Returns:
EC_Normal upon success, an error code otherwise

void DicomDirInterface::cleanup  ) 
 

reset the object to its initial state.

That means e.g. free memory.

OFBool DicomDirInterface::compareSequenceAttributes DcmItem dataset,
DcmTagKey key,
DcmDirectoryRecord record,
const OFString sourceFilename
[protected]
 

compare sequence attribute from dataset and record and report any deviation

Parameters:
dataset DICOM dataset where the sequence value is stored
key tag of the sequence to be compared
record directory record where the sequence value is stored
sourceFilename name of the source DICOM file
Returns:
OFTrue if sequences are identical, OFFalse otherwise

OFBool DicomDirInterface::compareStringAttributes DcmItem dataset,
DcmTagKey key,
DcmDirectoryRecord record,
const OFString sourceFilename
[protected]
 

compare string attribute from dataset and record and report any deviation

Parameters:
dataset DICOM dataset where the string value is stored
key tag of the string value to be compared
record directory record where the string value is stored
sourceFilename name of the source DICOM file
Returns:
OFTrue if string values are identical, OFFalse otherwise

OFBool DicomDirInterface::consistencyCheck  )  const [inline]
 

get current status of the "consistency check" mode.

See enableConsistencyCheck() for more details.

Returns:
OFTrue if check is enabled, OFFalse otherwise

Definition at line 400 of file dcddirif.h.

References ConsistencyCheck.

void DicomDirInterface::copyElement DcmItem dataset,
const DcmTagKey key,
DcmDirectoryRecord record,
const OFBool  optional = OFFalse,
const OFBool  copyEmpty = OFTrue
[protected]
 

copy element from dataset to directory record

Parameters:
dataset DICOM dataset containing the original data
key tag of the element to be copied
record directory record to which the element is to be copied
optional flag indicating whether the element is optional or required
copyEmpty flag indicating whether to copy an empty element (no value)

OFBool DicomDirInterface::copyFile const char *  fromFilename,
const char *  toFilename
[protected]
 

copy contents of specified file

Parameters:
fromFilename name of the file to be copied
toFilename name of the new file (copy of 'fromFilename')
Returns:
OFTrue if successful, OFFalse otherwise

void DicomDirInterface::copyStringWithDefault DcmItem dataset,
const DcmTagKey key,
DcmDirectoryRecord record,
const char *  defaultValue = "",
const OFBool  printWarning = OFFalse
[protected]
 

copy optional string value from dataset to directory record

Parameters:
dataset DICOM dataset containing the original data
key tag of the element value to be copied
record directory record to which the element value is to be copied
defaultValue default string value used in case the element is missing
printWarning print warning message if element does not exist (with a value) and no default value is given

void DicomDirInterface::createDicomDirBackup const char *  filename  )  [protected]
 

create backup of a given file

Parameters:
filename name of the file to be backuped

OFCondition DicomDirInterface::createNewDicomDir const E_ApplicationProfile  profile = AP_GeneralPurpose,
const char *  filename = DEFAULT_DICOMDIR_NAME,
const char *  filesetID = DEFAULT_FILESETID
 

create a new DICOMDIR object.

This function replaces any previously existing DICOMDIR file with the specified 'filename'. If the backup mode (see 'enableBackupMode') is enabled a backup copy ('filename' + ".BAK") is created from the existing file and automatically deleted after the new file has been written without any errors.

Parameters:
profile media storage application profile to be used for the DICOMDIR
filename name of the DICOMDIR file to be created (default: 'DICOMDIR'). The filename may include a fully qualified pathname.
filesetID value of the attribute FileSetID (default: 'DCMTK_MEDIA_DEMO')
Returns:
EC_Normal upon success, an error code otherwise

OFBool DicomDirInterface::disableBackupMode const OFBool  newMode = OFFalse  ) 
 

disable/enable the "create backup file" mode.

If this mode is disabled no backup file of an existing DICOMDIR is created. However, when appending new files to an existing DICOMDIR a _temporary_ backup file "<dicomdir>.$$$" is always created. Default: on, create a backup file "<dicomdir>.BAK"

Parameters:
newMode disable mode if OFFalse, enable if OFTrue
Returns:
previously stored value

OFBool DicomDirInterface::disableConsistencyCheck const OFBool  newMode = OFFalse  ) 
 

disable/enable the "consistency check".

If this mode is disabled the consistency of newly added records with already existing ones is not checked (see 'warnAboutInconsistentAttributes' for details). Default: on, perform consistency check

Parameters:
newMode disable check if OFFalse, enable if OFTrue
Returns:
previously stored value

OFBool DicomDirInterface::disableEncodingCheck const OFBool  newMode = OFFalse  ) 
 

disable/enable the "pixel encoding check".

If this mode is disabled the pixel encoding is not check for compliance with the selected application profile. Please use this switch with care since the resulting DICOMDIR will probably violate the rules for the selected application profile. Default: on, check pixel encoding (bits allocated/stored, high bit)

Parameters:
newMode disable check if OFFalse, enable if OFTrue
Returns:
previously stored value

OFBool DicomDirInterface::disableResolutionCheck const OFBool  newMode = OFFalse  ) 
 

disable/enable the "spatial resolution check".

If this mode is disabled the spatial resolution is not check for compliance with the selected application profile. Please use this switch with care since the resulting DICOMDIR will probably violate the rules for the selected application profile. Default: on, check spatial resolution

Parameters:
newMode disable check if OFFalse, enable if OFTrue
Returns:
previously stored value

OFBool DicomDirInterface::disableTransferSyntaxCheck const OFBool  newMode = OFFalse  ) 
 

disable/enable the "transfer syntax check".

If this mode is disabled the transfer syntax is not check for compliance with the selected application profile. Please use this switch with care since the resulting DICOMDIR will probably violate the rules for the selected application profile. Default: on, check transfer syntax

Parameters:
newMode disable check if OFFalse, enable if OFTrue
Returns:
previously stored value

OFBool DicomDirInterface::enableAbortMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the "abort on first error" mode.

If the mode is enabled addDicomFile() reports an error message and returns with an error status code if something went wrong. Default: off, do not abort

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::enableIconImageMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the "create icon images" mode.

If the mode is enabled icon images are created for each IMAGE record. Please note that particular application profiles (e.g. Basic Cardiac) require an icon images to be present. Therefore, this mode does not affect the icon images creation of such profiles. Default: off, do not create (optional) icon images

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::enableInventMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the "invent missing values" mode.

If the mode is enabled required DICOMDIR attributes (type 1) are invented when missing in the DICOM file. Default: off, do not invent attribute values

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::enableInventPatientIDMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the "invent new patient ID" mode.

If the mode is enabled a new PatientID is invented in case of inconsistent PatientsName attributes, i.e. when different patients share the same ID. Default: off, do not invent new patient ID

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::enableMapFilenamesMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the "map filenames" mode.

If the mode is enabled filenames are automatically mapped to DICOM format (convert lower case to upper case characters and remove trailing period). Default: off, do not map filenames

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::enableVerboseMode const OFBool  newMode = OFTrue  ) 
 

enable/disable the verbose mode.

If the mode is enabled messages like "creating DICOMDIR file ..." or "adding file ..." are reported to the log stream (see setLogStream). Default: off, no messages

Parameters:
newMode enable mode if OFTrue, disable if OFFalse
Returns:
previously stored value

OFBool DicomDirInterface::encodingCheck  )  const [inline]
 

get current status of the "pixel encoding check" mode.

See disableEncodingCheck() for more details.

Returns:
OFTrue if check is enabled, OFFalse otherwise

Definition at line 373 of file dcddirif.h.

References EncodingCheck.

DcmDirectoryRecord* DicomDirInterface::findExistingRecord DcmDirectoryRecord parent,
const E_DirRecType  recordType,
DcmItem dataset
[protected]
 

search for a given DICOMDIR record

Parameters:
parent higher-level structure where the records are stored
recordType type of DICOMDIR record to be searched for
dataset DICOM dataset of the current file
Returns:
pointer to record if found, NULL otherwise

OFBool DicomDirInterface::getIconFromDataset DcmItem dataset,
Uint8 *  pixel,
const unsigned long  count,
const unsigned int  width,
const unsigned int  height
[protected]
 

create icon image from DICOM dataset.

Please note that the memory buffer has to be allocated by the caller.

Parameters:
dataset DICOM dataset from which the icon image is created
pixel pointer to memory buffer where the pixel data are to be stored
count number of bytes allocated for the 'pixel' memory buffer
width width of the scaled icon image (in pixels )
height height of the scaled icon image (in pixels)
Returns:
OFTrue if successful, OFFalse otherwise

OFBool DicomDirInterface::getIconFromFile const OFString filename,
Uint8 *  pixel,
const unsigned long  count,
const unsigned int  width,
const unsigned int  height
[protected]
 

create icon image from given PGM (portable gray map) file.

Please note that only grayscale images in binary format are currently supported (magic word "P5"). Memory has to be allocated by the caller.

Parameters:
filename name of the PGM file to be loaded
pixel pointer to memory buffer where the pixel data are to be stored
count number of bytes allocated for the 'pixel' memory buffer
width width of the scaled icon image (in pixels )
height height of the scaled icon image (in pixels)
Returns:
OFTrue if successful, OFFalse otherwise

static const char* DicomDirInterface::getProfileName const E_ApplicationProfile  profile  )  [static]
 

get name/identifier associated with the given application profile

Parameters:
profile media storage application profile
Returns:
name of the application profile (e.g. "STD-GEN-CD/DVD-RAM")

OFString& DicomDirInterface::getStringFromDataset DcmItem dataset,
const DcmTagKey key,
OFString result,
OFBool  searchIntoSub = OFFalse
[protected]
 

get string value from dataset and report an error (if any)

Parameters:
dataset dataset from which the string value is to be retrieved
key tag of the attribute to be retrieved
result string variable in which the resulting value is stored
searchIntoSub flag indicating whether to do a deep search or not
Returns:
reference to the resulting string value (parameter 'result')

OFString& DicomDirInterface::getStringFromFile const char *  filename,
const DcmTagKey key,
OFString result,
OFBool  searchIntoSub = OFFalse
[protected]
 

get string value from file and report an error (if any)

Parameters:
filename name of the file from which the string value is to be retrieved
key tag of the attribute to be retrieved
result string variable in which the resulting value is stored
searchIntoSub flag indicating whether to do a deep search or not
Returns:
reference to the resulting string value (parameter 'result')

OFBool DicomDirInterface::iconImageMode  )  const [inline]
 

get current status of the "create icon images" mode.

See enableIconImageMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 355 of file dcddirif.h.

References IconImageMode.

void DicomDirInterface::inventMissingAttributes DcmDirectoryRecord parent,
const OFBool  recurse = OFTrue
[protected]
 

invent missing type 1 attributes for all child records (from patient level)

Parameters:
parent invent missing attributes for all children of this record (root)
recurse invent missing attributes also for lower level records if OFTrue. Only invent attributes for the top (patient) level if OFFalse.

void DicomDirInterface::inventMissingInstanceLevelAttributes DcmDirectoryRecord parent  )  [protected]
 

invent missing type 1 attributes for all child records (from instance level)

Parameters:
parent invent missing attributes for all children of this record

void DicomDirInterface::inventMissingSeriesLevelAttributes DcmDirectoryRecord parent  )  [protected]
 

invent missing type 1 attributes for all child records (from series level)

Parameters:
parent invent missing attributes for all children of this record

void DicomDirInterface::inventMissingStudyLevelAttributes DcmDirectoryRecord parent  )  [protected]
 

invent missing type 1 attributes for all child records (from study level)

Parameters:
parent invent missing attributes for all children of this record

OFBool DicomDirInterface::inventMode  )  const [inline]
 

get current status of the "invent missing values" mode.

See enableInventMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 337 of file dcddirif.h.

References InventMode.

OFBool DicomDirInterface::inventPatientIDMode  )  const [inline]
 

get current status of the "invent missing patient ID" mode.

See enableInventPatientIDMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 346 of file dcddirif.h.

References InventPatientIDMode.

OFBool DicomDirInterface::isCharsetValid const char *  charset  ) 
 

check whether given charset identifier is valid.

Valid character sets are (see DICOM PS3.3 for details): ISO_IR 100, ISO_IR 101, ISO_IR 109, ISO_IR 110, ISO_IR 144, ISO_IR 127, ISO_IR 126, ISO_IR 138, ISO_IR 148, ISO_IR 166, ISO_IR 13, ISO_IR 192.

Parameters:
charset character set identifier to be checked
Returns:
OFTrue if charset is valid, OFFalse otherwise

OFBool DicomDirInterface::isDicomDirValid  )  const
 

check whether current DICOMDIR is valid.

That means e.g. that it can be written to a file.

Returns:
OFTrue if DICOMDIR is valid, OFFalse otherwise

OFBool DicomDirInterface::isFilenameValid const char *  filename,
const OFBool  allowEmpty = OFFalse
 

check whether specified filename is valid.

i.e. conforms to the DICOM standard requirements (length, number of component and proper characters). This function is called automatically for the following methods: checkDicomFile(), addDicomFile() and setFilesetDescriptor(). So usually there's no need to call it manually (especially not in addition to the above mentioned methods).

Parameters:
filename filename to be checked for standard conformance
allowEmpty empty filename (zero length) allowed if OFTrue
Returns:
OFTrue if filename is valid, OFFalse otherwise

OFCondition DicomDirInterface::loadAndCheckDicomFile const char *  filename,
const char *  directory,
DcmFileFormat fileformat
[protected]
 

load and check DICOM file regarding the current application profile

Parameters:
filename name of the DICOM file to be checked
directory directory where the DICOM file is stored (optional)
fileformat object in which the loaded data is stored
Returns:
EC_Normal upon success, an error code otherwise

OFBool DicomDirInterface::mapFilenamesMode  )  const [inline]
 

get current status of the "map filenames" mode.

See enableMapFilenamesMode() for more details.

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 328 of file dcddirif.h.

References MapFilenamesMode.

void DicomDirInterface::printAttributeErrorMessage const DcmTagKey key,
const OFCondition error,
const char *  operation
[protected]
 

print an error message that something went wrong with an attribute.

The output format is: "Error: <error.text()>: [cannot <operation> ]<key.tagName()> <key>"

Parameters:
key affected tag
error status to be reported (only if ".bad()")
operation name of the operation that failed (optional, might be NULL)

void DicomDirInterface::printErrorMessage const char *  message,
const char *  suffix = NULL
[protected]
 

print an error message on the log stream (stderr).

The prefix "Error: " is printed automatically.

Parameters:
message error message to be printed
suffix optional message suffix

void DicomDirInterface::printFileErrorMessage const OFCondition error,
const char *  operation,
const char *  filename
[protected]
 

print the given error status to the log stream (stderr).

The output format is: "Error: <error.text()>: [<operation> ][file: <filename>]"

Parameters:
error status to be reported (only if ".bad()")
operation name of the operation that failed (optional, might be NULL)
filename name of the file (optional, might be NULL)

void DicomDirInterface::printMessage const char *  message,
const char *  suffix = NULL
[protected]
 

print a message on the log stream (stdout)

Parameters:
message message to be printed
suffix optional message suffix

void DicomDirInterface::printRecordErrorMessage const OFCondition error,
const E_DirRecType  recordType,
const char *  operation
[protected]
 

print an error message that something went wrong with a given record.

The output format is: "Error: <error.text()>: [cannot <operation> ]<recordType> directory record"

Parameters:
error status to be reported (only if ".bad()")
recordType type of DICOMDIR record which caused the error
operation name of the operation that failed (optional, might be NULL)

void DicomDirInterface::printRequiredAttributeMessage const DcmTagKey key,
const char *  filename = NULL,
const OFBool  emptyMsg = OFFalse
[protected]
 

print an error message that a required attribute is missing/empty.

The output format is: "Error: <error.text()>: required attribute <key.tagName()> <key> {empty|missing}[ in file: <filename>]"

Parameters:
key affected tag
filename name of the file (optional, might be NULL)
emptyMsg print "empty" if OFTrue, "missing" otherwise

void DicomDirInterface::printUnexpectedValueMessage const DcmTagKey key,
const char *  filename = NULL,
const OFBool  errorMsg = OFTrue
[protected]
 

print a message that the value of a given tag is unexpected.

The output format is: "{Error|Warning}: attribute <key.tagName()> <key> has other value than expected[ in file: <filename>]"

Parameters:
key affected tag
filename name of the file (optional, might be NULL)
errorMsg print error message if OFTrue, a warning message otherwise

void DicomDirInterface::printWarningMessage const char *  message,
const char *  suffix = NULL
[protected]
 

print a warning message on the log stream (stderr).

The prefix "Warning: " is printed automatically.

Parameters:
message warning message to be printed
suffix optional message suffix

OFBool DicomDirInterface::recordMatchesDataset DcmDirectoryRecord record,
DcmItem dataset
[protected]
 

check whether given DICOMDIR record matches dataset.

The check depends on the record type and is performed mainly based on the unique key defined for the particular record type (e.g. SOPInstanceUID for IMAGE records). For PATIENT records the PatientsName may also be used if the PatientID is absent.

Parameters:
record DICOMDIR record to be checked
dataset DICOM dataset of the current file
Returns:
OFTrue if record matches, OFFalse otherwise

OFBool DicomDirInterface::resolutionCheck  )  const [inline]
 

get current status of the "spatial resolution check" mode.

See disableResolutionCheck() for more details.

Returns:
OFTrue if check is enabled, OFFalse otherwise

Definition at line 382 of file dcddirif.h.

References ResolutionCheck.

OFCondition DicomDirInterface::selectApplicationProfile const E_ApplicationProfile  profile  )  [protected]
 

select given application profile

Parameters:
profile storage media application profile to be selected
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::setDefaultIcon const char *  filename  ) 
 

set filename of default icon image.

For cases that the icon image cannot be created (neither from PGM nor from DICOM file, respectively) a default icon (8 bit binary PGM) can be specified. If this image also fails to load a black icon (filled with zeros) is used.

Parameters:
filename name of the default PGM file
Returns:
always returns EC_Normal

void DicomDirInterface::setDefaultValue DcmDirectoryRecord record,
const DcmTagKey key,
const unsigned long  number,
const char *  prefix = NULL
[protected]
 

set default value (number or prefix and number) to a given tag

Parameters:
record directory record where the elements are stored
key tag of the element to be modifed
number numeric value to be set as a the element value
prefix optional prefix to be added to the numeric value

OFCondition DicomDirInterface::setFilesetDescriptor const char *  filename,
const char *  charset = DEFAULT_DESCRIPTOR_CHARSET
 

set the fileset descriptor file ID and character set.

Prior to any internal modification both 'filename' and 'charset' are checked using the above checking routines. Existence of 'filename' is not checked. NB: Requires a DICOMDIR to exist (see createNewDicomDir and appendToDicomDir).

Parameters:
filename name of the fileset descriptor file to be set
charset character set of the fileset descriptor file to be set. default: ISO Latin 1 ("ISO_IR 100"), use NULL or empty string to omit value.
Returns:
EC_Normal upon success, an error code otherwise

OFCondition DicomDirInterface::setIconPrefix const char *  prefix  ) 
 

set filename prefix for alternative icon images.

If non-empty the filename prefix is used to create the icon image from an externally stored PGM (portable gray map, 8 bit binary) file instead of the DICOM image file. The PGM filename is: 'prefix' + 'dicom_filename'. The image does not need to have the correct size as it is scaled automatically.

Parameters:
prefix filename prefix (NULL to disable = default)
Returns:
always returns EC_Normal

OFCondition DicomDirInterface::setIconSize const unsigned int  size  ) 
 

set preferred size of the icon images.

NB: some application profiles require a particicular icon size. In those cases this manual setting is implicitly ignored.

Parameters:
size size of the icon images in pixels (1..256, initial: 64)
Returns:
EC_Normal upon success, an error code otherwise

void DicomDirInterface::setLogStream OFConsole stream  ) 
 

set the log stream.

The log stream is used to report any warnings, debug and error messages.

Parameters:
stream pointer to the log stream (initial: NULL = no messages)

OFBool DicomDirInterface::transferSyntaxCheck  )  const [inline]
 

get current status of the "transfer syntax check" mode.

See disableTransferSyntaxCheck() for more details.

Returns:
OFTrue if check is enabled, OFFalse otherwise

Definition at line 391 of file dcddirif.h.

References TransferSyntaxCheck.

OFBool DicomDirInterface::verboseMode  )  const [inline]
 

get current status of the verbose mode

Returns:
OFTrue if mode is enabled, OFFalse otherwise

Definition at line 310 of file dcddirif.h.

References VerboseMode.

OFBool DicomDirInterface::warnAboutInconsistentAttributes DcmDirectoryRecord record,
DcmItem dataset,
const OFString sourceFilename,
const OFBool  abortCheck = OFFalse
[protected]
 

see if all the attributes in record match the values in dataset and warn if not

Parameters:
record directory record to be checked
dataset DICOM dataset to be compared with the directory record
sourceFilename name of the source DICOM file
abortCheck flag indicating whether to abort on the first inconsistent record
Returns:
OFTrue in case of any inconsistency, OFFalse otherwise

OFCondition DicomDirInterface::writeDicomDir const E_EncodingType  encodingType = EET_UndefinedLength,
const E_GrpLenEncoding  groupLength = EGL_withoutGL
 

write the current DICOMDIR object to file.

NB: The filename has already been specified for the object creation (see above).

Parameters:
encodingType flag, specifying the encoding with undefined or explicit length
groupLength flag, specifying how to handle the group length tags
Returns:
EC_Normal upon success, an error code otherwise


The documentation for this class was generated from the following file:


Generated on 20 Dec 2005 for OFFIS DCMTK Version 3.5.4 by Doxygen 1.4.5