]> git.saurik.com Git - wxWidgets.git/blame - src/msw/ole/uuid.cpp
Simplified event based Drag API for wxDataViewCtrl
[wxWidgets.git] / src / msw / ole / uuid.cpp
CommitLineData
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
43Uuid::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
63Uuid& 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
85bool 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
93Uuid::~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
111void 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
127void 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 138bool 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
167void 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