|
@@ -3,6 +3,7 @@
|
3
|
3
|
slrn::XEngine* xengine = new slrn::XEngine();
|
4
|
4
|
|
5
|
5
|
slrn::XEngine::XEngine() {
|
|
6
|
+ m_keypressed = false;
|
6
|
7
|
m_display = NULL;
|
7
|
8
|
m_visual = NULL;
|
8
|
9
|
m_screen = NULL;
|
|
@@ -65,6 +66,28 @@ int slrn::XEngine::init( std::string display ) {
|
65
|
66
|
return 0;
|
66
|
67
|
}
|
67
|
68
|
|
|
69
|
+int slrn::XEngine::grabKeyboard() {
|
|
70
|
+ if ( !m_good ) {
|
|
71
|
+ return 1;
|
|
72
|
+ }
|
|
73
|
+ int err = XGrabKeyboard( m_display, m_root, False,
|
|
74
|
+ GrabModeAsync, GrabModeAsync, CurrentTime );
|
|
75
|
+ if ( err != GrabSuccess ) {
|
|
76
|
+ fprintf( stderr, "Error: Failed to grab X keyboard.\n" );
|
|
77
|
+ fprintf( stderr, "This can be caused by launching slrn incorrectly.\n" );
|
|
78
|
+ fprintf( stderr, "gnome-session launches it fine from keyboard binds.\n" );
|
|
79
|
+ return 1;
|
|
80
|
+ }
|
|
81
|
+}
|
|
82
|
+
|
|
83
|
+int slrn::XEngine::releaseKeyboard() {
|
|
84
|
+ if ( !m_good ) {
|
|
85
|
+ return 1;
|
|
86
|
+ }
|
|
87
|
+ XUngrabKeyboard( m_display, CurrentTime );
|
|
88
|
+ return 0;
|
|
89
|
+}
|
|
90
|
+
|
68
|
91
|
int slrn::XEngine::grabCursor( slrn::CursorType type ) {
|
69
|
92
|
if ( !m_good ) {
|
70
|
93
|
return 1;
|
|
@@ -75,6 +98,8 @@ int slrn::XEngine::grabCursor( slrn::CursorType type ) {
|
75
|
98
|
GrabModeAsync, GrabModeAsync, m_root, xfontcursor, CurrentTime );
|
76
|
99
|
if ( err != GrabSuccess ) {
|
77
|
100
|
fprintf( stderr, "Error: Failed to grab X cursor.\n" );
|
|
101
|
+ fprintf( stderr, "This can be caused by launching slrn incorrectly.\n" );
|
|
102
|
+ fprintf( stderr, "gnome-session launches it fine from keyboard binds.\n" );
|
78
|
103
|
return 1;
|
79
|
104
|
}
|
80
|
105
|
|
|
@@ -130,6 +155,16 @@ void slrn::XEngine::tick() {
|
130
|
155
|
}
|
131
|
156
|
break;
|
132
|
157
|
}
|
|
158
|
+ // For this particular utility, we only care if a key is pressed.
|
|
159
|
+ // I'm too lazy to implement a keyhandler for that.
|
|
160
|
+ case KeyPress: {
|
|
161
|
+ m_keypressed = true;
|
|
162
|
+ break;
|
|
163
|
+ }
|
|
164
|
+ case KeyRelease: {
|
|
165
|
+ //m_keypressed = false;
|
|
166
|
+ break;
|
|
167
|
+ }
|
133
|
168
|
default: break;
|
134
|
169
|
}
|
135
|
170
|
}
|