summaryrefslogtreecommitdiff
path: root/core/launcher/inputmethods.h
Side-by-side diff
Diffstat (limited to 'core/launcher/inputmethods.h') (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/inputmethods.h50
1 files changed, 42 insertions, 8 deletions
diff --git a/core/launcher/inputmethods.h b/core/launcher/inputmethods.h
index 286a818..93b69de 100644
--- a/core/launcher/inputmethods.h
+++ b/core/launcher/inputmethods.h
@@ -1,5 +1,5 @@
/**********************************************************************
-** Copyright (C) 2000 Trolltech AS. All rights reserved.
+** Copyright (C) 2000-2002 Trolltech AS. All rights reserved.
**
-** This file is part of Qtopia Environment.
+** This file is part of the Qtopia Environment.
**
@@ -23,4 +23,4 @@
-
-#include <qpe/inputmethodinterface.h>
+#include <qtopia/qlibrary.h>
+#include <qtopia/inputmethodinterface.h>
@@ -30,3 +30,3 @@
class QToolButton;
-class QLibrary;
+class QWidgetStack;
@@ -38,3 +38,22 @@ struct InputMethod
QWidget *widget;
- InputMethodInterface *interface;
+ QString libName;
+ bool newIM;
+ union {
+ InputMethodInterface *interface;
+ ExtInputMethodInterface *extInterface;
+ };
+
+ inline void releaseInterface() {
+ newIM ? (void)extInterface->release() : (void)interface->release();
+ library->unload();
+ delete library; library = 0l;
+ }
+ inline QString name() const { return newIM ? extInterface->name() : interface->name(); }
+ inline QPixmap *icon() const { return newIM ? extInterface->icon() : interface->icon(); }
+ inline QUnknownInterface *iface() { return newIM ? (QUnknownInterface *)extInterface : (QUnknownInterface *)interface; }
+ inline void resetState() { if ( !newIM ) interface->resetState(); }
+
+ int operator <(const InputMethod& o) const;
+ int operator >(const InputMethod& o) const;
+ int operator <=(const InputMethod& o) const;
};
@@ -47,3 +66,3 @@ public:
~InputMethods();
-
+
QRect inputRect() const;
@@ -54,2 +73,3 @@ public:
void hideInputMethod();
+ void unloadInputMethods();
void loadInputMethods();
@@ -61,2 +81,3 @@ private slots:
void chooseKbd();
+ void chooseIm();
void showKbd( bool );
@@ -64,9 +85,22 @@ private slots:
void sendKey( ushort unicode, ushort scancode, ushort modifiers, bool, bool );
+ void qcopReceive( const QCString &msg, const QByteArray &data );
private:
+ void setPreferedHandlers();
+ /*static */QStringList plugins()const;
+ /*static */void installTranslator( const QString& );
+ void unloadMethod( QValueList<InputMethod>& );
void chooseMethod(InputMethod* im);
+ void chooseKeyboard(InputMethod* im);
+ void updateKeyboards(InputMethod *im);
+
+private:
QToolButton *kbdButton;
QToolButton *kbdChoice;
- InputMethod *method;
+ QWidgetStack *imButton; // later will be widget stack
+ QToolButton *imChoice;
+ InputMethod *mkeyboard;
+ InputMethod *imethod;
QValueList<InputMethod> inputMethodList;
+ QValueList<InputMethod> inputModifierList;
};