9 #ifndef _8836a563_24f6_4afb_89ba_377d49ce9f5d 10 #define _8836a563_24f6_4afb_89ba_377d49ce9f5d 18 #include "odil/DataSet.h" 20 #include "odil/Writer.h" 33 typedef std::map<std::string, std::vector<RecordKey>>
RecordKeyMap;
61 std::string
const & root=
"",
62 std::vector<std::string>
const & files=std::vector<std::string>(),
73 typedef std::shared_ptr<Record> Pointer;
75 std::map<std::string, Record::Pointer> children;
80 std::vector<Record::Pointer> records;
81 std::vector<long> sibling;
82 std::vector<long> child;
85 typedef std::map<std::string, Record::Pointer> RecordMap;
88 std::map<std::string, Record::Pointer> _create_records()
const;
91 Record & _find_record(RecordMap & records, std::string
const & key)
const;
95 DataSet const & data_set, Record & record,
96 std::string
const & type)
const;
100 DataSet const & data_set, Record & record,
101 std::vector<RecordKey>
const & keys)
const;
104 LinearizedTree _linearize_records(RecordMap
const & record_tree)
const;
107 std::vector<std::streampos> _get_relative_offsets(
108 std::vector<Record::Pointer>
const & records)
const;
112 LinearizedTree
const & linearized_tree,
113 std::vector<std::streampos>
const & relative_offsets)
const;
118 #endif // _8836a563_24f6_4afb_89ba_377d49ce9f5d std::vector< std::string > files
Path to the DICOM files, relative to root.
Definition: BasicDirectoryCreator.h:51
RecordKeyMap extra_record_keys
User-defined record keys, classified by record type.
Definition: BasicDirectoryCreator.h:54
std::string root
Root of the DICOM files and location of the output DICOMDIR file.
Definition: BasicDirectoryCreator.h:44
Write a Basic Directory (i.e. DICOMDIR) object to the disk.
Definition: BasicDirectoryCreator.h:26
Definition: Association.cpp:39
Writer::ItemEncoding item_encoding
Encoding of sequence items, defaults to Writer::ItemEncoding::ExplicitLength.
Definition: BasicDirectoryCreator.h:57
static RecordKeyMap const default_record_keys
Default record keys, classified by record type.
Definition: BasicDirectoryCreator.h:36
DICOM Data set.
Definition: DataSet.h:28
ItemEncoding
Encodings of sequence items.
Definition: Writer.h:31
std::pair< Tag, int > RecordKey
The tag and its associated type in the record.
Definition: BasicDirectoryCreator.h:30
BasicDirectoryCreator(std::string const &root="", std::vector< std::string > const &files=std::vector< std::string >(), RecordKeyMap const &extra_record_keys=RecordKeyMap(), Writer::ItemEncoding item_encoding=Writer::ItemEncoding::ExplicitLength)
Constructor.
Definition: BasicDirectoryCreator.cpp:61
std::map< std::string, std::vector< RecordKey > > RecordKeyMap
Map from a record type to the extra keys.
Definition: BasicDirectoryCreator.h:33
void operator()() const
Create and write the Basic Directory.
Definition: BasicDirectoryCreator.cpp:72