Qt 4.8
qaxbindable.cpp
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/legal
5 **
6 ** This file is part of the ActiveQt framework of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:BSD$
9 ** You may use this file under the terms of the BSD license as follows:
10 **
11 ** "Redistribution and use in source and binary forms, with or without
12 ** modification, are permitted provided that the following conditions are
13 ** met:
14 ** * Redistributions of source code must retain the above copyright
15 ** notice, this list of conditions and the following disclaimer.
16 ** * Redistributions in binary form must reproduce the above copyright
17 ** notice, this list of conditions and the following disclaimer in
18 ** the documentation and/or other materials provided with the
19 ** distribution.
20 ** * Neither the name of Digia Plc and its Subsidiary(-ies) nor the names
21 ** of its contributors may be used to endorse or promote products derived
22 ** from this software without specific prior written permission.
23 **
24 **
25 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
26 ** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
27 ** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28 ** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
29 ** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
30 ** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
31 ** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32 ** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33 ** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
34 ** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
35 ** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
36 **
37 ** $QT_END_LICENSE$
38 **
39 ****************************************************************************/
40 
41 #include "qaxbindable.h"
42 
43 #ifndef QT_NO_WIN_ACTIVEQT
44 
45 #include <qmetaobject.h>
46 
47 #include <qt_windows.h> // for IUnknown
48 #include "../shared/qaxtypes.h"
49 
51 
93 :activex(0)
94 {
95 }
96 
101 {
102 }
103 
118 {
119  if (!activex)
120  return true;
121 
122  return activex->emitRequestPropertyChange(property);
123 }
124 
135 {
136  if (!activex)
137  return;
138 
139  activex->emitPropertyChanged(property);
140 }
141 
149 IUnknown *QAxBindable::clientSite() const
150 {
151  if (!activex)
152  return 0;
153 
154  return activex->clientSite();
155 }
156 
166 {
167  return 0;
168 }
169 
180 void QAxBindable::reportError(int code, const QString &src, const QString &desc, const QString &context)
181 {
182  if (!activex)
183  return;
184 
185  activex->reportError(code, src, desc, context);
186 }
187 
215 {
216  Q_UNUSED(source);
217  Q_UNUSED(format);
218  return false;
219 }
220 
242 {
243  Q_UNUSED(sink);
244  return false;
245 }
246 
340 #endif // QT_NO_WIN_ACTIVEQT
bool requestPropertyChange(const char *property)
Call this function to request permission to change the property property from the client that is host...
#define QT_END_NAMESPACE
This macro expands to.
Definition: qglobal.h:90
virtual void emitPropertyChanged(const char *)=0
QAxBindable()
Constructs an empty QAxBindable object.
Definition: qaxbindable.cpp:92
virtual bool emitRequestPropertyChange(const char *)=0
virtual bool writeData(QIODevice *sink)
If the COM object supports a MIME type then this function is called to store the COM object into sink...
The QString class provides a Unicode character string.
Definition: qstring.h:83
The QAxAggregated class is an abstract base class for implementations of additional COM interfaces...
Definition: qaxaggregated.h:58
void reportError(int code, const QString &src, const QString &desc, const QString &help=QString())
Reports an error to the client application.
virtual QAxAggregated * createAggregate()
Reimplement this function when you want to implement additional COM interfaces in the ActiveX control...
#define QT_BEGIN_NAMESPACE
This macro expands to.
Definition: qglobal.h:89
IAxServerBase * activex
Definition: qaxbindable.h:80
virtual bool readData(QIODevice *source, const QString &format)
If the COM object supports a MIME type then this function is called to initialize the COM object from...
void propertyChanged(const char *property)
Call this function to notify the client that is hosting this ActiveX control that the property proper...
IUnknown * clientSite() const
Returns a pointer to the client site interface for this ActiveX object, or null if no client site has...
virtual ~QAxBindable()
Destroys the QAxBindable object.
const char * property
Definition: qwizard.cpp:138
The QIODevice class is the base interface class of all I/O devices in Qt.
Definition: qiodevice.h:66
virtual IUnknown * clientSite() const =0
#define Q_UNUSED(x)
Indicates to the compiler that the parameter with the specified name is not used in the body of a fun...
Definition: qglobal.h:1729
virtual void reportError(int code, const QString &src, const QString &desc, const QString &context)=0