summaryrefslogtreecommitdiffstats
path: root/src/plugins/platforms/cocoa/qcocoaintegration.h
diff options
context:
space:
mode:
authorMorten Johan Sørvig <morten.sorvig@digia.com>2014-01-20 09:11:35 +0100
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-02-04 22:59:04 +0100
commitd01f0213b837d71dd77e29752ebcbf161f227a11 (patch)
tree82595e1bf63a1b6b991c5b94a4f3549fad009808 /src/plugins/platforms/cocoa/qcocoaintegration.h
parentb0e6bc42ebec357816d53456d3ef214f9fb8754c (diff)
Cocoa: Establish pattern for accessing globals
Use a static QCocoaIntegration pointer instead of QGuiApplication. This removes the need to call out of the platform plugin as well as the casting from "platform" to "cocoa" types. Change-Id: If432b3567811223b73a67548e475e07d63635b73 Reviewed-by: Gabriel de Dietrich <gabriel.dedietrich@digia.com>
Diffstat (limited to 'src/plugins/platforms/cocoa/qcocoaintegration.h')
-rw-r--r--src/plugins/platforms/cocoa/qcocoaintegration.h30
1 files changed, 19 insertions, 11 deletions
diff --git a/src/plugins/platforms/cocoa/qcocoaintegration.h b/src/plugins/platforms/cocoa/qcocoaintegration.h
index 111329aaee..8babfcf8ae 100644
--- a/src/plugins/platforms/cocoa/qcocoaintegration.h
+++ b/src/plugins/platforms/cocoa/qcocoaintegration.h
@@ -46,6 +46,10 @@
#include "qcocoaautoreleasepool.h"
#include "qcocoacursor.h"
+#include "qcocoawindow.h"
+#include "qcocoanativeinterface.h"
+#include "qcocoainputcontext.h"
+#include "qcocoaaccessibility.h"
#include "qcocoaclipboard.h"
#include "qcocoadrag.h"
#include "qcocoaservices.h"
@@ -53,6 +57,7 @@
#include <QtCore/QScopedPointer>
#include <qpa/qplatformintegration.h>
+#include <QtPlatformSupport/private/qcoretextfontdatabase_p.h>
QT_BEGIN_NAMESPACE
@@ -103,23 +108,25 @@ public:
QCocoaIntegration();
~QCocoaIntegration();
+ static QCocoaIntegration *instance();
+
bool hasCapability(QPlatformIntegration::Capability cap) const;
QPlatformWindow *createPlatformWindow(QWindow *window) const;
QPlatformOpenGLContext *createPlatformOpenGLContext(QOpenGLContext *context) const;
QPlatformBackingStore *createPlatformBackingStore(QWindow *widget) const;
QAbstractEventDispatcher *createEventDispatcher() const;
- QPlatformFontDatabase *fontDatabase() const;
- QPlatformNativeInterface *nativeInterface() const;
- QPlatformInputContext *inputContext() const;
- QPlatformAccessibility *accessibility() const;
- QPlatformClipboard *clipboard() const;
- QPlatformDrag *drag() const;
+ QCoreTextFontDatabase *fontDatabase() const;
+ QCocoaNativeInterface *nativeInterface() const;
+ QCocoaInputContext *inputContext() const;
+ QCocoaAccessibility *accessibility() const;
+ QCocoaClipboard *clipboard() const;
+ QCocoaDrag *drag() const;
QStringList themeNames() const;
QPlatformTheme *createPlatformTheme(const QString &name) const;
- QPlatformServices *services() const;
+ QCocoaServices *services() const;
QVariant styleHint(StyleHint hint) const;
QList<int> possibleKeys(const QKeyEvent *event) const;
@@ -128,18 +135,19 @@ public:
QCocoaScreen *screenAtIndex(int index);
private:
+ static QCocoaIntegration *mInstance;
- QScopedPointer<QPlatformFontDatabase> mFontDb;
+ QScopedPointer<QCoreTextFontDatabase> mFontDb;
- QScopedPointer<QPlatformInputContext> mInputContext;
+ QScopedPointer<QCocoaInputContext> mInputContext;
#ifndef QT_NO_ACCESSIBILITY
- QScopedPointer<QPlatformAccessibility> mAccessibility;
+ QScopedPointer<QCocoaAccessibility> mAccessibility;
#endif
QScopedPointer<QPlatformTheme> mPlatformTheme;
QList<QCocoaScreen *> mScreens;
QCocoaClipboard *mCocoaClipboard;
QScopedPointer<QCocoaDrag> mCocoaDrag;
- QScopedPointer<QPlatformNativeInterface> mNativeInterface;
+ QScopedPointer<QCocoaNativeInterface> mNativeInterface;
QScopedPointer<QCocoaServices> mServices;
QScopedPointer<QCocoaKeyMapper> mKeyboardMapper;
};