/usr/include/dcmtk/ofstd/ofuuid.h is in libdcmtk-dev 3.6.1~20160216-4.
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 | /*
*
* Copyright (C) 2011-2013, OFFIS e.V.
* All rights reserved. See COPYRIGHT file for details.
*
* This software and supporting documentation were developed by
*
* OFFIS e.V.
* R&D Division Health
* Escherweg 2
* D-26121 Oldenburg, Germany
*
*
* Module: ofstd
*
* Author: Uli Schlachter
*
* Purpose: Definitions for generating UUIDs, as defined by ITU-T X.667
*
*/
#ifndef OFUUID_H
#define OFUUID_H
#include "dcmtk/config/osconfig.h" /* make sure OS specific configuration is included first */
#include "dcmtk/ofstd/oftypes.h"
#include "dcmtk/ofstd/ofstring.h"
#include "dcmtk/ofstd/ofstream.h"
/** Helper class for generating and storing UUIDs, as specified in ITU-T X.667.
* A UUID is an Universally Unique IDentifier. If UUIDs are generated
* correctly, it's almost impossible that the same UUID is generated twice.
*/
class DCMTK_OFSTD_EXPORT OFUUID {
public:
/** The possible ways to represent a UUID */
enum E_Representation {
/** The UUID is printed as one, long integer in base 10 (up to 39 digits long) */
ER_RepresentationInteger,
/** The UUID is printed in hexadecimal notation with hyphens (-) separating groups */
ER_RepresentationHex,
/** The UUID is printed as one, long integer with the prefix "2.25." */
ER_RepresentationOID,
/** The UUID is printed in hexadecimal notation with the prefix "urn:uuid:" */
ER_RepresentationURN,
/** The default representation that is used when none is given */
ER_RepresentationDefault = ER_RepresentationHex
};
struct BinaryRepresentation {
Uint8 value[16];
};
/** Default constructor. Generates a new UUID. */
OFUUID();
/** Construct a new UUID from its binary representation.
* @param val the binary representation
* @see getBinaryRepresentation
*/
OFUUID(const struct BinaryRepresentation& val);
/* This class uses the default assignment operator */
/** Generate a new UUID. The old UUID is discarded. */
void generate();
/** Get the string representation of this UUID.
* @param result string instance to save the result in
* @param representation the representation to use
* @return result
*/
OFString& toString(OFString& result, E_Representation representation = ER_RepresentationDefault) const;
/** Write the string representation of this UUID to a stream.
* @param stream the output stream to write to
* @param representation the representation to use
* @return stream
*/
STD_NAMESPACE ostream& print(STD_NAMESPACE ostream& stream, E_Representation representation = ER_RepresentationDefault) const;
/** Get the binary representation of this UUID.
* @param val the structure where the result should be saved to
*/
void getBinaryRepresentation(struct BinaryRepresentation& val) const;
/** Compare this instance to another OFUUID instance.
* @param other the other instance
* @return OFTrue if both UUIDs are equal.
*/
OFBool operator==(const OFUUID& other) const;
/** Compare this instance to another OFUUID instance.
* @param other the other instance
* @return OFFalse if both UUIDs are equal.
*/
OFBool operator!=(const OFUUID& other) const
{
return !(*this == other);
}
private:
/** Print the integer representation to the given stream.
* @param stream stream to print to.
*/
void printInteger(STD_NAMESPACE ostream& stream) const;
/** Print the hexadecimal representation to the given stream.
* @param stream stream to print to.
*/
void printHex(STD_NAMESPACE ostream& stream) const;
/* The fields of an UUID, as defined by ITU-T X.667 */
/** Octets 0-3 of the time field */
Uint32 time_low;
/** Octets 4-5 of the time field */
Uint16 time_mid;
/** 4 bits for the version and the 12 highest bits of the time */
Uint16 version_and_time_high;
/** 2 bits for the variant and the 6 highest bits of the clock sequence */
Uint8 variant_and_clock_seq_high;
/** The lowest 8 bits of the clock sequence */
Uint8 clock_seq_low;
/** The node value in the form of a MAC address */
Uint8 node[6];
};
/** Print an UUID to a stream with OFUUID::ER_RepresentationDefault.
* @param stream the output stream to use
* @param uuid the UUID to print
* @return stream
*/
static inline STD_NAMESPACE ostream& operator<< (STD_NAMESPACE ostream& stream, const OFUUID& uuid)
{
return uuid.print(stream);
}
#endif
|