author | ar <ar> | 2004-06-06 19:43:58 (UTC) |
---|---|---|
committer | ar <ar> | 2004-06-06 19:43:58 (UTC) |
commit | a1ef1c3fe8700a16329358288299276fd16c8fa0 (patch) (unidiff) | |
tree | 3db826a2b2df0fd407721aaefe03bfc61ffd35f0 /library/quuid.cpp | |
parent | d5f6057374caf1c81e02628f0fcca01394b1dc9d (diff) | |
download | opie-a1ef1c3fe8700a16329358288299276fd16c8fa0.zip opie-a1ef1c3fe8700a16329358288299276fd16c8fa0.tar.gz opie-a1ef1c3fe8700a16329358288299276fd16c8fa0.tar.bz2 |
- solve problems with padded memory - dont use memcpy
-rw-r--r-- | library/quuid.cpp | 133 |
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 | */ |
60 | QUuid::QUuid( const QString &text ) | 62 | QUuid::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 | */ |
123 | QString QUuid::toString() const | 132 | QString 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 | */ |
141 | bool QUuid::isNull() const | 151 | bool 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 | */ | ||
167 | QUuid::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); | ||
189 | bool 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); | ||
214 | bool 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 | } |