File: TestDicts.cxx

package info (click to toggle)
gdcm 3.0.24-5
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 27,560 kB
  • sloc: cpp: 203,722; ansic: 76,471; xml: 48,131; python: 3,473; cs: 2,308; java: 1,629; lex: 1,290; sh: 334; php: 128; makefile: 97
file content (58 lines) | stat: -rw-r--r-- 1,800 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*=========================================================================

  Program: GDCM (Grassroots DICOM). A DICOM library

  Copyright (c) 2006-2011 Mathieu Malaterre
  All rights reserved.
  See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details.

     This software is distributed WITHOUT ANY WARRANTY; without even
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     PURPOSE.  See the above copyright notice for more information.

=========================================================================*/
#include "gdcmDicts.h"
#include "gdcmGlobal.h"
#include "gdcmDict.h"

#include <set>

int TestDicts(int, char *[])
{
  gdcm::Dicts dicts;
  //const gdcm::Dict &d = dicts.GetPublicDict();
  //std::cout << d << std::endl;

  const gdcm::Global& g = gdcm::GlobalInstance;
  // get the Part 6 dicts from it:
  const gdcm::Dicts &ds = g.GetDicts();
  const gdcm::Dict &pub = ds.GetPublicDict();
  gdcm::Dict::ConstIterator it = pub.Begin();
  int ret = 0;
  std::set<std::string> names;
  for( ; it != pub.End(); ++it)
    {
    const gdcm::Tag &t = it->first;
    const gdcm::DictEntry &de = it->second;
    // A couple of tests:
    if( t.GetElement() == 0x0 )
      {
      // Check group length
      if( de.GetVR() != gdcm::VR::UL || de.GetVM() != gdcm::VM::VM1 )
        {
        std::cerr << "Group length issue: Problem with tag: " << t << " " << de << std::endl;
        ++ret;
        }
      }
    // I need a test that check there is no duplicate name for data elements since python-gdcm
    // will rely on it
    if( names.count( de.GetName() ) != 0 )
      {
      //std::cerr << "Name issue: Problem with tag: " << t << " " << de << std::endl;
      //++ret;
      }
    names.insert( de.GetName() );
    }

  return ret;
}