+
+// WARNING : push_bash in listElem ONLY during ParseHeader
+// TODO : something to allow further Elements addition
+// position to be taken care of !
+ listElem.push_back(newElValue);
+}
+
+/**
+ * \ingroup gdcmElValSet
+ * \brief Checks if a given Dicom element exists
+ * \ within a ElValSet
+ * @param Group
+ * @param Elem
+ * @return
+ */
+int gdcmElValSet::CheckIfExistByNumber(guint16 Group, guint16 Elem ) {
+ std::string key = TranslateToKey(Group, Elem );
+ return (tagHt.count(key));
+}
+
+/**
+ * \ingroup gdcmElValSet
+ * \brief
+ */
+void gdcmElValSet::Print(std::ostream & os) {
+
+ size_t o;
+ unsigned short int g, e;
+ TSKey v;
+ std::string d2;
+ gdcmTS * ts = gdcmGlobal::GetTS();
+ std::ostringstream s;
+
+ for (TagElValueHT::iterator tag = tagHt.begin();
+ tag != tagHt.end();
+ ++tag){
+ g = tag->second->GetGroup();
+ e = tag->second->GetElement();
+ v = tag->second->GetValue();
+ o = tag->second->GetOffset();
+ d2 = _CreateCleanString(v); // replace non printable characters by '.'
+
+ s << tag->first << ": ";
+ s << " lgr : " <<tag->second->GetLength();
+ s << ",\t Offset : " << o;
+ s << " x(" << std::hex << o << std::dec << ") ";
+ s << "\t[" << tag->second->GetVR() << "]";
+ s << "\t[" << tag->second->GetName() << "]";
+ s << "\t[" << d2 << "]";
+
+ // Display the UID value (instead of displaying the rough code)
+ if (g == 0x0002) { // Some more to be displayed ?
+ if ( (e == 0x0010) || (e == 0x0002) )
+ s << " ==>\t[" << ts->GetValue(v) << "]";
+ } else {
+ if (g == 0x0008) {
+ if ( (e == 0x0016) || (e == 0x1150) )
+ s << " ==>\t[" << ts->GetValue(v) << "]";
+ }
+ }
+ s << std::endl;
+ }
+
+
+ guint32 lgth;
+ char greltag[10]; //group element tag
+
+ for (ListTag::iterator i = listElem.begin();
+ i != listElem.end();
+ ++i){
+ g = (*i)->GetGroup();
+ e = (*i)->GetElement();
+ v = (*i)->GetValue();
+ o = (*i)->GetOffset();
+ sprintf(greltag,"%04x|%04x",g,e);
+ d2 = _CreateCleanString(v); // replace non printable characters by '.'
+ s << greltag << ": lgth : ";
+ lgth = (*i)->GetReadLength();
+ if ( lgth == 0xffffffff)
+ s << std::hex << lgth << std::dec ;
+ else
+ s << lgth;
+ s << ",\t Offset : " << o;
+ s << " x(" << std::hex << o << std::dec << ") ";
+ s << "\t[" << (*i)->GetVR() << "]";
+ s << "\t[" << (*i)->GetName() << "]";
+ s << "\t[" << d2 << "]";
+
+ // Display the UID value (instead of displaying the rough code)
+ if (g == 0x0002) { // Any more to be displayed ?
+ if ( (e == 0x0010) || (e == 0x0002) )
+ s << " ==>\t[" << ts->GetValue(v) << "]";
+ } else {
+ if (g == 0x0008) {
+ if ( (e == 0x0016) || (e == 0x1150) )
+ s << " ==>\t[" << ts->GetValue(v) << "]";
+ }
+ }
+ s << std::endl;
+ }
+ os<<s.str();
+}
+
+/**
+ * \ingroup gdcmElValSet
+ * \brief
+ */
+void gdcmElValSet::PrintByName(std::ostream & os) {
+ for (TagElValueNameHT::iterator tag = NameHt.begin();
+ tag != NameHt.end();
+ ++tag){
+ os << tag->first << ": ";
+ os << "[" << tag->second->GetValue() << "]";
+ os << "[" << tag->second->GetKey() << "]";
+ os << "[" << tag->second->GetVR() << "]" << std::endl;
+ }