/usr/include/gdcm-2.8/gdcmAAssociateRQPDU.h is in libgdcm2-dev 2.8.4-1build2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 | /*=========================================================================
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.
=========================================================================*/
#ifndef GDCMAASSOCIATERQPDU_H
#define GDCMAASSOCIATERQPDU_H
#include "gdcmTypes.h"
#include "gdcmVR.h" // AEComp
#include "gdcmApplicationContext.h"
#include "gdcmPresentationContextRQ.h"
#include "gdcmUserInformation.h"
#include "gdcmBasePDU.h"
namespace gdcm
{
namespace network
{
class AAssociateACPDU;
/**
* \brief AAssociateRQPDU
* \details Table 9-11 ASSOCIATE-RQ PDU fields
*/
class AAssociateRQPDU : public BasePDU
{
public:
AAssociateRQPDU();
std::istream &Read(std::istream &is);
const std::ostream &Write(std::ostream &os) const;
size_t Size() const;
void AddPresentationContext( PresentationContextRQ const &pc );
/// Set the Called AE Title
void SetCalledAETitle(const char calledaetitle[16]);
std::string GetCalledAETitle() const { return std::string(CalledAETitle,16); }
/// Set the Calling AE Title
void SetCallingAETitle(const char callingaetitle[16]);
std::string GetCallingAETitle() const { return std::string(CallingAETitle,16); }
/// Check whether or not the \param title is a valid AE title
static bool IsAETitleValid(const char title[16]);
/// This function will initialize an AAssociateACPDU from
/// the fields in the AAssociateRQPDU structure
//void InitFromRQ( AAssociateACPDU & acpdu );
void Print(std::ostream &os) const;
AAssociateRQPDU(const AAssociateRQPDU &pdu):BasePDU(pdu)
{
assert( 0 );
}
//this function fails to compile on windows.
// AAssociateRQPDU &operator=(const AAssociateRQPDU &_val)
// {
// assert( 0 );
// }
typedef std::vector<PresentationContextRQ>::size_type SizeType;
SizeType GetNumberOfPresentationContext() const {
return PresContext.size();
}
PresentationContextRQ const &GetPresentationContext(SizeType i) const {
assert( !PresContext.empty() && i < PresContext.size() );
return PresContext[i];
}
typedef std::vector<PresentationContextRQ> PresentationContextArrayType;
PresentationContextArrayType const &GetPresentationContexts() { return PresContext; }
const PresentationContextRQ *GetPresentationContextByID(uint8_t i) const;
const PresentationContextRQ *GetPresentationContextByAbstractSyntax(AbstractSyntax const & absyn ) const;
bool IsLastFragment() const { return true; }
const UserInformation & GetUserInformation() const { return UserInfo; }
void SetUserInformation( UserInformation const & ui );
protected:
friend class AAssociateACPDU;
std::string GetReserved43_74() const;
private:
// 1 PDU-type 01H
static const uint8_t ItemType; // PDUType ?
// 2 Reserved This reserved field shall be sent with a value 00H but not tested to this value when received.
static const uint8_t Reserved2;
/* 3-6 PDU-length This PDU-length shall be the number of bytes from the first byte of the
following field to the last byte of the variable field. It shall be encoded as
an unsigned binary number
*/
uint32_t ItemLength; // PDU Length
/*
7-8 Protocol-version This two byte field shall use one bit to identify each version of the
DICOM UL protocol supported by the calling end-system. This is
Version 1 and shall be identified with bit 0 set. A receiver of this PDU
implementing only this version of the DICOM UL protocol shall only test
that bit 0 is set.
*/
static const uint16_t ProtocolVersion;
/*
9-10 Reserved This reserved field shall be sent with a value 0000H but not tested to
this value when received.
*/
static const uint16_t Reserved9_10;
/*
11-26 Called-AE-title Destination DICOM Application Name. It shall be encoded as 16
characters as defined by the ISO 646:1990-Basic G0 Set with leading
and trailing spaces (20H) being non-significant. The value made of 16
spaces (20H) meaning "no Application Name specified" shall not be
used. For a complete description of the use of this field, see Section
7.1.1.4.
*/
char CalledAETitle[16];
/*
27-42 Calling-AE-title Source DICOM Application Name. It shall be encoded as 16
characters as defined by the ISO 646:1990-Basic G0 Set with leading
and trailing spaces (20H) being non-significant. The value made of 16
spaces (20H) meaning "no Application Name specified" shall not be
used. For a complete description of the use of this field, see Section
7.1.1.3.
*/
char CallingAETitle[16];
/*
43-74 Reserved This reserved field shall be sent with a value 00H for all bytes but not
tested to this value when received
*/
char Reserved43_74[32]; // { 0 }
/*
75-xxx Variable items This variable field shall contain the following items: one Application
Context Item, one or more Presentation Context Items and one User
Information Item. For a complete description of the use of these items
see Sections 7.1.1.2, 7.1.1.13, and 7.1.1.6.
*/
ApplicationContext AppContext;
std::vector<PresentationContextRQ> PresContext;
UserInformation UserInfo;
};
} // end namespace network
} // end namespace gdcm
#endif //GDCMAASSOCIATERQPDU_H
|