summaryrefslogtreecommitdiff
path: root/library/quuid.cpp
authorar <ar>2004-06-06 19:43:58 (UTC)
committer ar <ar>2004-06-06 19:43:58 (UTC)
commita1ef1c3fe8700a16329358288299276fd16c8fa0 (patch) (unidiff)
tree3db826a2b2df0fd407721aaefe03bfc61ffd35f0 /library/quuid.cpp
parentd5f6057374caf1c81e02628f0fcca01394b1dc9d (diff)
downloadopie-a1ef1c3fe8700a16329358288299276fd16c8fa0.zip
opie-a1ef1c3fe8700a16329358288299276fd16c8fa0.tar.gz
opie-a1ef1c3fe8700a16329358288299276fd16c8fa0.tar.bz2
- solve problems with padded memory - dont use memcpy
Diffstat (limited to 'library/quuid.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--library/quuid.cpp133
1 files changed, 107 insertions, 26 deletions
diff --git a/library/quuid.cpp b/library/quuid.cpp
index 46fd816..36469a8 100644
--- a/library/quuid.cpp
+++ b/library/quuid.cpp
@@ -1,146 +1,227 @@
1/********************************************************************** 1/**********************************************************************
2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. 2** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
3** 3**
4** This file is part of the Qtopia Environment. 4** This file is part of the Qtopia Environment.
5** 5**
6** This file may be distributed and/or modified under the terms of the 6** This file may be distributed and/or modified under the terms of the
7** GNU General Public License version 2 as published by the Free Software 7** GNU General Public License version 2 as published by the Free Software
8** Foundation and appearing in the file LICENSE.GPL included in the 8** Foundation and appearing in the file LICENSE.GPL included in the
9** packaging of this file. 9** packaging of this file.
10** 10**
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20 20
21#include "quuid.h" 21#include "quuid.h"
22 22
23/*! 23/*!
24 \class QUuid quuid.h 24 \class QUuid quuid.h
25 \brief The QUuid class defines a Universally Unique Identifier (UUID). 25 \brief The QUuid class defines a Universally Unique Identifier (UUID).
26 26
27 This class is temporarily copied from Qt 3.0. 27 This class is temporarily copied from Qt 3.0.
28*/ 28*/
29 29
30/*! 30/*!
31 \fn QUuid::QUuid() 31 \fn QUuid::QUuid()
32 32
33 Creates the null UUID {00000000-0000-0000-0000-000000000000}. 33 Creates the null UUID {00000000-0000-0000-0000-000000000000}.
34*/ 34*/
35 35
36/*! 36/*!
37 \fn QUuid::QUuid( uint l, ushort w1, ushort w2, uchar b1, uchar b2, uchar b3, uchar b4, uchar b5, uchar b6, uchar b7, uchar b8 ) 37 \fn QUuid::QUuid( uint l, ushort w1, ushort w2, uchar b1, uchar b2, uchar b3, uchar b4, uchar b5, uchar b6, uchar b7, uchar b8 )
38 38
39 Creates an UUID with the value specified by the parameters, \a l, \a 39 Creates an UUID with the value specified by the parameters, \a l, \a
40 w1, \a w2, \a b1, \a b2, \a b3, \a b4, \a b5, \a b6, \a b7, \a b8. 40 w1, \a w2, \a b1, \a b2, \a b3, \a b4, \a b5, \a b6, \a b7, \a b8.
41 41
42 Example: 42 Example:
43 \code 43 \code
44 // {67C8770B-44F1-410A-AB9A-F9B5446F13EE} 44 // {67C8770B-44F1-410A-AB9A-F9B5446F13EE}
45 QUuid IID_MyInterface( 0x67c8770b, 0x44f1, 0x410a, 0xab, 0x9a, 0xf9, 0xb5, 0x44, 0x6f, 0x13, 0xee ) 45 QUuid IID_MyInterface( 0x67c8770b, 0x44f1, 0x410a, 0xab, 0x9a, 0xf9, 0xb5, 0x44, 0x6f, 0x13, 0xee )
46 \endcode 46 \endcode
47*/ 47*/
48 48
49/*! 49/*!
50 \fn QUuid::QUuid( const QUuid &orig ) 50 \fn QUuid::QUuid( const QUuid &orig )
51 51
52 Creates a copy of the QUuid \a orig. 52 Creates a copy of the QUuid \a orig.
53*/ 53*/
54
54#ifndef QT_NO_QUUID_STRING 55#ifndef QT_NO_QUUID_STRING
56
55/*! 57/*!
56 Creates a QUuid object from the string \a text. Right now, the function 58 Creates a QUuid object from the string \a text. Right now, the function
57 can only convert the format {12345678-1234-1234-1234-123456789ABC} and 59 can only convert the format {12345678-1234-1234-1234-123456789ABC} and
58 will create the null UUID when the conversion fails. 60 will create the null UUID when the conversion fails.
59*/ 61*/
60QUuid::QUuid( const QString &text ) 62QUuid::QUuid( const QString &text )
61{ 63{
62 bool ok; 64 bool ok;
63 QString temp = text.upper(); 65 QString temp = text.upper();
64 66
65 data1 = temp.mid( 1, 8 ).toULong( &ok, 16 ); 67 data1 = temp.mid( 1, 8 ).toULong( &ok, 16 );
66 if ( !ok ) { 68 if ( !ok )
67 *this = QUuid(); 69 {
68 return; 70 *this = QUuid();
71 return;
69 } 72 }
70 73
71 data2 = temp.mid( 10, 4 ).toUInt( &ok, 16 ); 74 data2 = temp.mid( 10, 4 ).toUInt( &ok, 16 );
72 if ( !ok ) { 75 if ( !ok )
73 *this = QUuid(); 76 {
74 return; 77 *this = QUuid();
78 return;
75 } 79 }
76 data3 = temp.mid( 15, 4 ).toUInt( &ok, 16 ); 80 data3 = temp.mid( 15, 4 ).toUInt( &ok, 16 );
77 if ( !ok ) { 81 if ( !ok )
78 *this = QUuid(); 82 {
79 return; 83 *this = QUuid();
84 return;
80 } 85 }
81 data4[0] = temp.mid( 20, 2 ).toUInt( &ok, 16 ); 86 data4[0] = temp.mid( 20, 2 ).toUInt( &ok, 16 );
82 if ( !ok ) { 87 if ( !ok )
83 *this = QUuid(); 88 {
84 return; 89 *this = QUuid();
90 return;
85 } 91 }
86 data4[1] = temp.mid( 22, 2 ).toUInt( &ok, 16 ); 92 data4[1] = temp.mid( 22, 2 ).toUInt( &ok, 16 );
87 if ( !ok ) { 93 if ( !ok )
88 *this = QUuid(); 94 {
89 return; 95 *this = QUuid();
96 return;
90 } 97 }
91 for ( int i = 2; i<8; i++ ) { 98 for ( int i = 2; i<8; i++ )
92 data4[i] = temp.mid( 25 + (i-2)*2, 2 ).toUShort( &ok, 16 ); 99 {
93 if ( !ok ) { 100 data4[i] = temp.mid( 25 + (i-2)*2, 2 ).toUShort( &ok, 16 );
94 *this = QUuid(); 101 if ( !ok )
95 return; 102 {
96 } 103 *this = QUuid();
104 return;
105 }
97 } 106 }
98} 107}
99#endif 108
100/*! 109/*!
101 \fn QUuid QUuid::operator=(const QUuid &uuid ) 110 \fn QUuid QUuid::operator=(const QUuid &uuid )
102 111
103 Assigns the value of \a uuid to this QUuid object. 112 Assigns the value of \a uuid to this QUuid object.
104*/ 113*/
105 114
106/*! 115/*!
107 \fn bool QUuid::operator==(const QUuid &other) const 116 \fn bool QUuid::operator==(const QUuid &other) const
108 117
109 Returns TRUE if this QUuid and the \a other QUuid are identical, otherwise returns FALSE. 118 Returns TRUE if this QUuid and the \a other QUuid are identical, otherwise returns FALSE.
110*/ 119*/
111 120
112/*! 121/*!
113 \fn bool QUuid::operator!=(const QUuid &other) const 122 \fn bool QUuid::operator!=(const QUuid &other) const
114 123
115 Returns TRUE if this QUuid and the \a other QUuid are different, otherwise returns FALSE. 124 Returns TRUE if this QUuid and the \a other QUuid are different, otherwise returns FALSE.
116*/ 125*/
117#ifndef QT_NO_QUUID_STRING 126
118/*! 127/*!
119 QString QUuid::toString() const 128 QString QUuid::toString() const
120 129
121 Returns a string in {12345678-1234-1234-1234-123456789ABC} format. 130 Returns a string in {12345678-1234-1234-1234-123456789ABC} format.
122*/ 131*/
123QString QUuid::toString() const 132QString QUuid::toString() const
124{ 133{
125 QString result; 134 QString result;
126 135
127 result = "{" + QString::number( data1, 16 ).rightJustify( 8, '0' ) + "-"; 136 result = "{" + QString::number( data1, 16 ).rightJustify( 8, '0' ) + "-";
128 result += QString::number( (int)data2, 16 ).rightJustify( 4, '0' ) + "-"; 137 result += QString::number( (int)data2, 16 ).rightJustify( 4, '0' ) + "-";
129 result += QString::number( (int)data3, 16 ).rightJustify( 4, '0' ) + "-"; 138 result += QString::number( (int)data3, 16 ).rightJustify( 4, '0' ) + "-";
130 result += QString::number( (int)data4[0], 16 ).rightJustify( 2, '0' ); 139 result += QString::number( (int)data4[0], 16 ).rightJustify( 2, '0' );
131 result += QString::number( (int)data4[1], 16 ).rightJustify( 2, '0' ) + "-"; 140 result += QString::number( (int)data4[1], 16 ).rightJustify( 2, '0' ) + "-";
132 for ( int i = 2; i < 8; i++ ) 141 for ( int i = 2; i < 8; i++ )
133 result += QString::number( (int)data4[i], 16 ).rightJustify( 2, '0' ); 142 result += QString::number( (int)data4[i], 16 ).rightJustify( 2, '0' );
134 143
135 return result + "}"; 144 return result + "}";
136} 145}
137#endif 146#endif
147
138/*! 148/*!
139 Returns TRUE if this is the null UUID {00000000-0000-0000-0000-000000000000}, otherwise returns FALSE. 149 Returns TRUE if this is the null UUID {00000000-0000-0000-0000-000000000000}, otherwise returns FALSE.
140*/ 150*/
141bool QUuid::isNull() const 151bool QUuid::isNull() const
142{ 152{
143 return data4[0] == 0 && data4[1] == 0 && data4[2] == 0 && data4[3] == 0 && 153 return data4[0] == 0 && data4[1] == 0 && data4[2] == 0 && data4[3] == 0 &&
144 data4[4] == 0 && data4[5] == 0 && data4[6] == 0 && data4[7] == 0 && 154 data4[4] == 0 && data4[5] == 0 && data4[6] == 0 && data4[7] == 0 &&
145 data1 == 0 && data2 == 0 && data3 == 0; 155 data1 == 0 && data2 == 0 && data3 == 0;
156}
157
158
159/*!
160 \fn QUuid::Variant QUuid::variant() const
161
162 Returns the variant of the UUID.
163 The null UUID is considered to be of an unknown variant.
164
165 \sa version()
166*/
167QUuid::Variant QUuid::variant() const
168{
169 if ( isNull() )
170 return VarUnknown;
171 // Check the 3 MSB of data4[0]
172 if ( (data4[0] & 0x80) == 0x00 ) return NCS;
173 else if ( (data4[0] & 0xC0) == 0x80 ) return DCE;
174 else if ( (data4[0] & 0xE0) == 0xC0 ) return Microsoft;
175 else if ( (data4[0] & 0xE0) == 0xE0 ) return Reserved;
176 return VarUnknown;
177}
178
179/*!
180 \fn bool QUuid::operator<(const QUuid &other) const
181
182 Returns TRUE if this QUuid is of the same variant,
183 and lexicographically before the \a other QUuid;
184 otherwise returns FALSE.
185
186 \sa variant()
187*/
188#define ISLESS(f1, f2) if (f1!=f2) return (f1<f2);
189bool QUuid::operator<(const QUuid &other ) const
190{
191 if ( variant() != other.variant() )
192 return FALSE;
193
194 ISLESS( data1, other.data1 );
195 ISLESS( data2, other.data2 );
196 ISLESS( data3, other.data3 );
197 for ( int n = 0; n < 8; n++ )
198 {
199 ISLESS( data4[n], other.data4[n] );
200 }
201 return FALSE;
202}
203
204/*!
205 \fn bool QUuid::operator>(const QUuid &other) const
206
207 Returns TRUE if this QUuid is of the same variant,
208 and lexicographically after the \a other QUuid;
209 otherwise returns FALSE.
210
211 \sa variant()
212*/
213#define ISMORE(f1, f2) if (f1!=f2) return (f1>f2);
214bool QUuid::operator>(const QUuid &other ) const
215{
216 if ( variant() != other.variant() )
217 return FALSE;
218
219 ISMORE( data1, other.data1 );
220 ISMORE( data2, other.data2 );
221 ISMORE( data3, other.data3 );
222 for ( int n = 0; n < 8; n++ )
223 {
224 ISMORE( data4[n], other.data4[n] );
225 }
226 return FALSE;
146} 227}