00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #ifndef WlmFileSystemInteractionManager_h
00030 #define WlmFileSystemInteractionManager_h
00031
00032 #include "dcmtk/config/osconfig.h"
00033 #include "dcmtk/ofstd/ofstring.h"
00034 #include "dcmtk/ofstd/oftypes.h"
00035
00036 template <class T> class OFOrderedSet;
00037 struct WlmSuperiorSequenceInfoType;
00038 class DcmDataset;
00039 class DcmTagKey;
00040 class OFConsole;
00041 class OFCondition;
00042 class DcmItem;
00043
00048 class WlmFileSystemInteractionManager
00049 {
00050 private:
00054 WlmFileSystemInteractionManager(const WlmFileSystemInteractionManager &old);
00055
00059 WlmFileSystemInteractionManager &operator=(const WlmFileSystemInteractionManager &obj);
00060
00061 protected:
00063 OFString dfPath;
00065 OFBool enableRejectionOfIncompleteWlFiles;
00067 OFString calledApplicationEntityTitle;
00069 DcmDataset **matchingRecords;
00071 unsigned long numOfMatchingRecords;
00072
00078 void DetermineWorklistFiles( OFOrderedSet<OFString> &worklistFiles );
00079
00085 OFBool IsWorklistFile( const char *fname );
00086
00121 OFBool DatasetIsComplete( DcmDataset *dataset );
00122
00130 OFBool ReferencedStudyOrPatientSequenceIsAbsentOrExistentButNonEmptyAndIncomplete( DcmTagKey sequenceTagKey, DcmItem *dset );
00131
00138 OFBool DescriptionAndCodeSequenceAttributesAreIncomplete( DcmTagKey descriptionTagKey, DcmTagKey codeSequenceTagKey, DcmItem *dset );
00139
00145 OFBool AttributeIsAbsentOrEmpty( DcmTagKey elemTagKey, DcmItem *dset );
00146
00153 OFBool DatasetMatchesSearchMask( DcmDataset *dataset, DcmDataset *searchMask );
00154
00160 void DetermineMatchingKeyAttributeValues( DcmDataset *dataset, const char **&matchingKeyAttrValues );
00161
00168 OFBool ScheduledStationAETitlesMatch( const char *datasetValue, const char *searchMaskValue );
00169
00179 OFBool ScheduledProcedureStepStartDateTimesMatch( const char *datasetDateValue, const char *datasetTimeValue, const char *searchMaskDateValue, const char *searchMaskTimeValue );
00180
00187 OFBool ModalitiesMatch( const char *datasetValue, const char *searchMaskValue );
00188
00195 OFBool ScheduledPerformingPhysicianNamesMatch( const char *datasetValue, const char *searchMaskValue );
00196
00203 OFBool PatientsNamesMatch( const char *datasetValue, const char *searchMaskValue );
00204
00211 OFBool PatientsIDsMatch( const char *datasetValue, const char *searchMaskValue );
00212
00219 OFBool AccessionNumbersMatch( const char *datasetValue, const char *searchMaskValue );
00220
00227 OFBool RequestedProcedureIdsMatch( const char *datasetValue, const char *searchMaskValue );
00228
00235 OFBool ReferringPhysicianNamesMatch( const char *datasetValue, const char *searchMaskValue );
00236
00243 OFBool PatientsSexesMatch( const char *datasetValue, const char *searchMaskValue );
00244
00251 OFBool RequestingPhysiciansMatch( const char *datasetValue, const char *searchMaskValue );
00252
00259 OFBool AdmissionIdsMatch( const char *datasetValue, const char *searchMaskValue );
00260
00267 OFBool RequestedProcedurePrioritiesMatch( const char *datasetValue, const char *searchMaskValue );
00268
00275 OFBool PatientsBirthDatesMatch( const char *datasetValue, const char *searchMaskValue );
00276
00286 OFBool DateTimeRangeMatch( const char *datasetDateValue, const char *datasetTimeValue, const char *searchMaskDateValue, const char *searchMaskTimeValue );
00287
00295 OFBool DateRangeMatch( const char *datasetDateValue, const char *searchMaskDateValue );
00296
00304 OFBool TimeRangeMatch( const char *datasetTimeValue, const char *searchMaskTimeValue );
00305
00315 OFBool DateTimeSingleValueMatch( const char *datasetDateValue, const char *datasetTimeValue, const char *searchMaskDateValue, const char *searchMaskTimeValue );
00316
00324 OFBool DateSingleValueMatch( const char *datasetDateValue, const char *searchMaskDateValue );
00325
00333 OFBool TimeSingleValueMatch( const char *datasetTimeValue, const char *searchMaskTimeValue );
00334
00342 OFBool CaseSensitiveSingleValueMatch( const char *datasetValue, const char *searchMaskValue );
00343
00350 OFBool WildcardMatch( const char *datasetValue, const char *searchMaskValue );
00351
00361 OFBool MatchStarSymbol( const char *dv, const char *sv );
00362
00371 void ExtractValuesFromRange( const char *range, char *&lower, char *&upper );
00372
00373 public:
00376 WlmFileSystemInteractionManager();
00377
00380 ~WlmFileSystemInteractionManager();
00381
00385 void SetEnableRejectionOfIncompleteWlFiles( OFBool value );
00386
00391 OFCondition ConnectToFileSystem( const OFString& dfPathv );
00392
00396 OFCondition DisconnectFromFileSystem();
00397
00405 OFBool IsCalledApplicationEntityTitleSupported( const OFString& calledApplicationEntityTitlev );
00406
00414 unsigned long DetermineMatchingRecords( DcmDataset *searchMask );
00415
00431 unsigned long GetNumberOfSequenceItemsForMatchingRecord( DcmTagKey sequenceTag, WlmSuperiorSequenceInfoType *superiorSequenceArray, unsigned long numOfSuperiorSequences, unsigned long idx );
00432
00443 void GetAttributeValueForMatchingRecord( DcmTagKey tag, WlmSuperiorSequenceInfoType *superiorSequenceArray, unsigned long numOfSuperiorSequences, unsigned long idx, char *&value );
00444
00448 void ClearMatchingRecords();
00449 };
00450
00451 #endif
00452
00453
00454
00455
00456
00457
00458
00459
00460
00461
00462
00463
00464
00465
00466
00467
00468
00469
00470
00471
00472
00473
00474
00475
00476
00477
00478
00479
00480
00481
00482
00483
00484
00485
00486
00487
00488
00489
00490
00491
00492
00493
00494
00495
00496
00497
00498
00499
00500
00501
00502
00503
00504
00505
00506
00507
00508
00509
00510
00511
00512
00513
00514
00515
00516
00517
00518
00519
00520
00521
00522
00523
00524
00525
00526
00527
00528
00529
00530
00531
00532
00533
00534
00535
00536