-rw-r--r-- | inputmethods/keyboard/keyboard.cpp | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/inputmethods/keyboard/keyboard.cpp b/inputmethods/keyboard/keyboard.cpp index 9dd24e4..233f08e 100644 --- a/inputmethods/keyboard/keyboard.cpp +++ b/inputmethods/keyboard/keyboard.cpp | |||
@@ -28,6 +28,8 @@ | |||
28 | #include <qtimer.h> | 28 | #include <qtimer.h> |
29 | #include <ctype.h> | 29 | #include <ctype.h> |
30 | 30 | ||
31 | #include <sys/utsname.h> | ||
32 | |||
31 | 33 | ||
32 | #define USE_SMALL_BACKSPACE | 34 | #define USE_SMALL_BACKSPACE |
33 | 35 | ||
@@ -49,8 +51,20 @@ Keyboard::Keyboard(QWidget* parent, const char* name, WFlags f) : | |||
49 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); | 51 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); |
50 | 52 | ||
51 | repeatTimer = new QTimer( this ); | 53 | repeatTimer = new QTimer( this ); |
54 | |||
55 | // temporary quick and dirty fix for the "sticky keyboard bug" | ||
56 | // on ipaq. | ||
57 | struct utsname name; | ||
58 | if (uname(&name) != -1) | ||
59 | { | ||
60 | QString release=name.release; | ||
61 | qWarning("System release: %s\n", name.release); | ||
62 | if(release.find("embedix",0,TRUE) !=-1) | ||
63 | { | ||
52 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); | 64 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); |
53 | } | 65 | } |
66 | } | ||
67 | } | ||
54 | 68 | ||
55 | void Keyboard::resizeEvent(QResizeEvent*) | 69 | void Keyboard::resizeEvent(QResizeEvent*) |
56 | { | 70 | { |
@@ -761,7 +775,8 @@ void Keyboard::timerEvent(QTimerEvent* e) | |||
761 | 775 | ||
762 | void Keyboard::repeat() | 776 | void Keyboard::repeat() |
763 | { | 777 | { |
764 | repeatTimer->start( 150 ); | 778 | |
779 | repeatTimer->start( 200 ); | ||
765 | emit key( unicode, qkeycode, modifiers, true, true ); | 780 | emit key( unicode, qkeycode, modifiers, true, true ); |
766 | } | 781 | } |
767 | 782 | ||