]>
Commit | Line | Data |
---|---|---|
bbf1f0e5 | 1 | /////////////////////////////////////////////////////////////////////////////// |
521bf4ff | 2 | // Name: src/msw/ole/uuid.cpp |
bbf1f0e5 KB |
3 | // Purpose: implements Uuid class, see uuid.h for details |
4 | // Author: Vadim Zeitlin | |
0a0e6a5b | 5 | // Modified by: |
bbf1f0e5 KB |
6 | // Created: 12.09.96 |
7 | // RCS-ID: $Id$ | |
8 | // Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr> | |
65571936 | 9 | // Licence: wxWindows licence |
bbf1f0e5 KB |
10 | /////////////////////////////////////////////////////////////////////////////// |
11 | ||
12 | // ============================================================================ | |
13 | // Declarations | |
14 | // ============================================================================ | |
15 | ||
bbf1f0e5 | 16 | // For compilers that support precompilation, includes "wx.h". |
bbf1f0e5 KB |
17 | #include "wx/wxprec.h" |
18 | ||
19 | #if defined(__BORLANDC__) | |
20 | #pragma hdrstop | |
21 | #endif | |
22 | ||
1d105d58 | 23 | #if wxUSE_OLE && ( wxUSE_DRAG_AND_DROP || (defined(__WXDEBUG__) && wxUSE_DATAOBJ) ) |
bbf1f0e5 | 24 | |
57bd4c60 | 25 | #ifndef WX_PRECOMP |
9ed0d735 | 26 | #include "wx/msw/wrapwin.h" |
7f017c64 | 27 | #endif |
57bd4c60 | 28 | |
bbf1f0e5 KB |
29 | #include <rpc.h> // UUID related functions |
30 | ||
3096bd2f | 31 | #include "wx/msw/ole/uuid.h" |
bbf1f0e5 KB |
32 | |
33 | ||
34 | ||
35 | // ============================================================================ | |
36 | // Implementation | |
37 | // ============================================================================ | |
38 | ||
39 | // length of UUID in C format | |
40 | #define UUID_CSTRLEN 100 // real length is 66 | |
41 | ||
42 | // copy ctor | |
43 | Uuid::Uuid(const Uuid& uuid) | |
44 | { | |
0a0e6a5b WS |
45 | // bitwise copy Ok for UUIDs |
46 | m_uuid = uuid.m_uuid; | |
bbf1f0e5 KB |
47 | |
48 | // force the string to be allocated by RPC | |
49 | // (we free it later with RpcStringFree) | |
5f8e1c16 OK |
50 | #ifdef _UNICODE |
51 | UuidToString(&m_uuid, (unsigned short **)&m_pszUuid); | |
52 | #else | |
bbf1f0e5 | 53 | UuidToString(&m_uuid, &m_pszUuid); |
5f8e1c16 | 54 | #endif |
bbf1f0e5 KB |
55 | |
56 | // allocate new buffer | |
5f8e1c16 | 57 | m_pszCForm = new wxChar[UUID_CSTRLEN]; |
bbf1f0e5 | 58 | // and fill it |
5f8e1c16 | 59 | memcpy(m_pszCForm, uuid.m_pszCForm, UUID_CSTRLEN*sizeof(wxChar)); |
bbf1f0e5 KB |
60 | } |
61 | ||
62 | // assignment operator | |
63 | Uuid& Uuid::operator=(const Uuid& uuid) | |
64 | { | |
65 | m_uuid = uuid.m_uuid; | |
66 | ||
67 | // force the string to be allocated by RPC | |
68 | // (we free it later with RpcStringFree) | |
5f8e1c16 OK |
69 | #ifdef _UNICODE |
70 | UuidToString(&m_uuid, (unsigned short **)&m_pszUuid); | |
71 | #else | |
bbf1f0e5 | 72 | UuidToString(&m_uuid, &m_pszUuid); |
5f8e1c16 | 73 | #endif |
bbf1f0e5 KB |
74 | |
75 | // allocate new buffer if not done yet | |
76 | if ( !m_pszCForm ) | |
5f8e1c16 | 77 | m_pszCForm = new wxChar[UUID_CSTRLEN]; |
bbf1f0e5 KB |
78 | |
79 | // and fill it | |
5f8e1c16 | 80 | memcpy(m_pszCForm, uuid.m_pszCForm, UUID_CSTRLEN*sizeof(wxChar)); |
bbf1f0e5 KB |
81 | |
82 | return *this; | |
83 | } | |
84 | ||
2753fd96 VZ |
85 | bool Uuid::operator==(const Uuid& uuid) const |
86 | { | |
a0fa7d39 VZ |
87 | // IsEqualGUID() returns BOOL and not bool so use an explicit comparison to |
88 | // avoid MSVC warnings about int->bool conversion | |
89 | return IsEqualGUID(m_uuid, uuid.m_uuid) == TRUE; | |
2753fd96 VZ |
90 | } |
91 | ||
bbf1f0e5 | 92 | // dtor |
0a0e6a5b WS |
93 | Uuid::~Uuid() |
94 | { | |
bbf1f0e5 KB |
95 | // this string must be allocated by RPC! |
96 | // (otherwise you get a debug breakpoint deep inside RPC DLL) | |
0a0e6a5b | 97 | if ( m_pszUuid ) |
5f8e1c16 OK |
98 | #ifdef _UNICODE |
99 | RpcStringFree((unsigned short **)&m_pszUuid); | |
100 | #else | |
bbf1f0e5 | 101 | RpcStringFree(&m_pszUuid); |
5f8e1c16 | 102 | #endif |
bbf1f0e5 KB |
103 | |
104 | // perhaps we should just use a static buffer and not bother | |
105 | // with new and delete? | |
106 | if ( m_pszCForm ) | |
107 | delete [] m_pszCForm; | |
108 | } | |
109 | ||
110 | // update string representation of new UUID | |
111 | void Uuid::Set(const UUID &uuid) | |
112 | { | |
113 | m_uuid = uuid; | |
114 | ||
115 | // get string representation | |
5f8e1c16 OK |
116 | #ifdef _UNICODE |
117 | UuidToString(&m_uuid, (unsigned short **)&m_pszUuid); | |
118 | #else | |
bbf1f0e5 | 119 | UuidToString(&m_uuid, &m_pszUuid); |
5f8e1c16 | 120 | #endif |
bbf1f0e5 KB |
121 | |
122 | // cache UUID in C format | |
123 | UuidToCForm(); | |
124 | } | |
125 | ||
126 | // create a new UUID | |
127 | void Uuid::Create() | |
128 | { | |
129 | UUID uuid; | |
130 | ||
131 | // can't fail | |
132 | UuidCreate(&uuid); | |
0a0e6a5b | 133 | |
bbf1f0e5 KB |
134 | Set(uuid); |
135 | } | |
136 | ||
137 | // set the value | |
5f8e1c16 | 138 | bool Uuid::Set(const wxChar *pc) |
bbf1f0e5 KB |
139 | { |
140 | // get UUID from string | |
5f8e1c16 OK |
141 | #ifdef _UNICODE |
142 | if ( UuidFromString((unsigned short *)pc, &m_uuid) != RPC_S_OK) | |
143 | #else | |
144 | if ( UuidFromString((wxUChar *)pc, &m_uuid) != RPC_S_OK) | |
145 | #endif | |
bbf1f0e5 | 146 | // failed: probably invalid string |
0a0e6a5b | 147 | return false; |
bbf1f0e5 KB |
148 | |
149 | // transform it back to string to normalize it | |
5f8e1c16 OK |
150 | #ifdef _UNICODE |
151 | UuidToString(&m_uuid, (unsigned short **)&m_pszUuid); | |
152 | #else | |
bbf1f0e5 | 153 | UuidToString(&m_uuid, &m_pszUuid); |
5f8e1c16 | 154 | #endif |
bbf1f0e5 KB |
155 | |
156 | // update m_pszCForm | |
157 | UuidToCForm(); | |
158 | ||
0a0e6a5b | 159 | return true; |
bbf1f0e5 KB |
160 | } |
161 | ||
162 | // stores m_uuid in m_pszCForm in a format required by | |
163 | // DEFINE_GUID macro: i.e. something like | |
164 | // 0x7D8A2281L,0x4C61,0x11D0,0xBA,0xBD,0x00,0x00,0xC0,0x18,0xBA,0x27 | |
165 | // m_pszUuid is of the form (no, it's not quite the same UUID :-) | |
166 | // 6aadc650-67b0-11d0-bac8-0000c018ba27 | |
167 | void Uuid::UuidToCForm() | |
168 | { | |
169 | if ( m_pszCForm == NULL ) | |
5f8e1c16 | 170 | m_pszCForm = new wxChar[UUID_CSTRLEN]; |
bbf1f0e5 | 171 | |
f6bcfd97 | 172 | wsprintf(m_pszCForm, wxT("0x%8.8X,0x%4.4X,0x%4.4X,0x%2.2X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X,0x2.2%X"), |
bbf1f0e5 | 173 | m_uuid.Data1, m_uuid.Data2, m_uuid.Data3, |
aacc44c6 VZ |
174 | m_uuid.Data4[0], m_uuid.Data4[1], m_uuid.Data4[2], m_uuid.Data4[3], |
175 | m_uuid.Data4[4], m_uuid.Data4[5], m_uuid.Data4[6], m_uuid.Data4[7]); | |
bbf1f0e5 KB |
176 | } |
177 | ||
178 | #endif | |
47d67540 | 179 | // wxUSE_DRAG_AND_DROP |