202 |
|
|
203 |
/* Before connecting and creating UI */ |
/* Before connecting and creating UI */ |
204 |
void |
void |
205 |
xkeymap_init1(void) |
xkeymap_init(void) |
206 |
{ |
{ |
207 |
|
unsigned int max_keycode; |
208 |
int i; |
int i; |
209 |
|
|
|
/* Zeroing keymap */ |
|
|
for (i = 0; i < KEYMAP_SIZE; i++) |
|
|
{ |
|
|
keymap[i].scancode = 0; |
|
|
keymap[i].modifiers = 0; |
|
|
} |
|
|
|
|
210 |
if (strcmp(keymapname, "none")) |
if (strcmp(keymapname, "none")) |
|
{ |
|
211 |
xkeymap_read(keymapname); |
xkeymap_read(keymapname); |
|
} |
|
212 |
|
|
213 |
|
XDisplayKeycodes(display, &min_keycode, (int *) &max_keycode); |
214 |
} |
} |
215 |
|
|
216 |
/* After connecting and creating UI */ |
/* Handles, for example, multi-scancode keypresses (which is not |
217 |
void |
possible via keymap-files) */ |
218 |
xkeymap_init2(void) |
BOOL |
219 |
|
handle_special_keys(KeySym keysym, uint32 ev_time, BOOL pressed) |
220 |
{ |
{ |
221 |
unsigned int max_keycode; |
switch (keysym) |
222 |
XDisplayKeycodes(display, &min_keycode, (int *) &max_keycode); |
{ |
223 |
|
case XK_Break: /* toggle full screen */ |
224 |
|
if (pressed && (get_key_state(XK_Alt_L) || get_key_state(XK_Alt_R))) |
225 |
|
{ |
226 |
|
toggle_fullscreen(); |
227 |
|
return True; |
228 |
|
} |
229 |
|
break; |
230 |
|
|
231 |
|
case XK_Meta_L: /* Windows keys */ |
232 |
|
case XK_Super_L: |
233 |
|
case XK_Hyper_L: |
234 |
|
case XK_Meta_R: |
235 |
|
case XK_Super_R: |
236 |
|
case XK_Hyper_R: |
237 |
|
if (pressed) |
238 |
|
{ |
239 |
|
rdp_send_scancode(ev_time, RDP_KEYPRESS, SCANCODE_CHAR_LCTRL); |
240 |
|
rdp_send_scancode(ev_time, RDP_KEYPRESS, SCANCODE_CHAR_ESC); |
241 |
|
} |
242 |
|
else |
243 |
|
{ |
244 |
|
rdp_send_scancode(ev_time, RDP_KEYRELEASE, SCANCODE_CHAR_ESC); |
245 |
|
rdp_send_scancode(ev_time, RDP_KEYRELEASE, SCANCODE_CHAR_LCTRL); |
246 |
|
} |
247 |
|
return True; |
248 |
|
break; |
249 |
|
} |
250 |
|
return False; |
251 |
} |
} |
252 |
|
|
253 |
|
|