File: gdcmULWritingCallback.cxx

package info (click to toggle)
gdcm 2.4.4-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 32,868 kB
  • sloc: cpp: 188,481; ansic: 124,526; xml: 41,799; sh: 7,162; python: 3,667; cs: 2,128; java: 1,344; lex: 1,290; tcl: 677; php: 128; makefile: 116
file content (72 lines) | stat: -rw-r--r-- 2,482 bytes parent folder | download | duplicates (4)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
/*=========================================================================
 *
 *  Copyright Insight Software Consortium
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0.txt
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 *=========================================================================*/
#include "gdcmULWritingCallback.h"

#include "gdcmFile.h"
#include "gdcmWriter.h"

namespace gdcm
{

namespace network
{

// writes the data set to disk immediately, rather than keeping it memory.
// could have potential timing issues if datasets come over the network faster than
// they can be written, which could be the case on very fast connections with slow disks
void ULWritingCallback::HandleDataSet(const DataSet& inDataSet)
{
  if (inDataSet.FindDataElement(Tag(0x0008,0x0018)) &&
    !inDataSet.GetDataElement(Tag(0x0008,0x0018)).IsEmpty() )
    {
    const DataElement &de = inDataSet.GetDataElement(Tag(0x0008,0x0018));
    const ByteValue *bv = de.GetByteValue();
    const std::string sopclassuid_str( bv->GetPointer(), bv->GetLength() );
    Writer w;
    std::string theLoc = mDirectoryName + "/" + sopclassuid_str.c_str() + ".dcm";
    w.SetFileName(theLoc.c_str());
    File &f = w.GetFile();
    f.SetDataSet(inDataSet);
    FileMetaInformation &fmi = f.GetHeader();
    if( mImplicit )
      fmi.SetDataSetTransferSyntax( TransferSyntax::ImplicitVRLittleEndian );
    else
      fmi.SetDataSetTransferSyntax( TransferSyntax::ExplicitVRLittleEndian );
    w.SetCheckFileMetaInformation( true );
    if (!w.Write())
      {
      gdcmErrorMacro("Failed to write " << sopclassuid_str.c_str() << std::endl);
      }
    else 
      {
      gdcmDebugMacro( "Wrote " << sopclassuid_str.c_str() << " to disk. " << std::endl);
      }
    }
  else 
    {
    gdcmErrorMacro( "Failed to write data set, could not find tag 0x0008, 0x0018" << std::endl);
    }
  DataSetHandled();
}

void ULWritingCallback::HandleResponse(const DataSet& )
{
}

} // end namespace network
} // end namespace gdcm