Qt 4.8
qaxbindable.h
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 #ifndef QAXBINDABLE_H
42 #define QAXBINDABLE_H
43 
44 #include <QtGui/qwidget.h>
45 
46 struct IUnknown;
47 
49 
51 
52 QT_MODULE(ActiveQt)
53 
54 #ifndef QT_NO_WIN_ACTIVEQT
55 
56 class QAxAggregated;
57 class QIODevice;
58 struct IAxServerBase;
59 
61 {
62  friend class QAxServerBase;
63 public:
64  QAxBindable();
65  virtual ~QAxBindable();
66 
67  virtual QAxAggregated *createAggregate();
68  void reportError(int code, const QString &src, const QString &desc, const QString &help = QString());
69 
70  virtual bool readData(QIODevice *source, const QString &format);
71  virtual bool writeData(QIODevice *sink);
72 
73 protected:
74  bool requestPropertyChange(const char *property);
75  void propertyChanged(const char *property);
76 
77  IUnknown *clientSite() const;
78 
79 private:
81 };
82 
84 #endif // QT_NO_WIN_ACTIVEQT
85 
87 
88 #endif // QAXBINDABLE_H
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
#define QT_MODULE(x)
Definition: qglobal.h:2783
The QAxBindable class provides an interface between a QWidget and an ActiveX client.
Definition: qaxbindable.h:60
#define QT_BEGIN_HEADER
Definition: qglobal.h:136
QAxBindable()
Constructs an empty QAxBindable object.
Definition: qaxbindable.cpp:92
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
#define QT_END_HEADER
Definition: qglobal.h:137