diff options
author | runge <runge> | 2004-07-19 23:14:35 +0000 |
---|---|---|
committer | runge <runge> | 2004-07-19 23:14:35 +0000 |
commit | 64605a8c207c4dde469e7ec7b052be7a5cdbe995 (patch) | |
tree | 6a7b4d0ac760b8e5959a31d72d5f9b31fff975b6 /x11vnc/x11vnc.c | |
parent | 57234c523d9337ded3b5c8835c4dd0bc444d5eb1 (diff) | |
download | libtdevnc-64605a8c207c4dde469e7ec7b052be7a5cdbe995.tar.gz libtdevnc-64605a8c207c4dde469e7ec7b052be7a5cdbe995.zip |
x11vnc: ignore keysyms >4 for a keycode, add lastmod to -help, -version
Diffstat (limited to 'x11vnc/x11vnc.c')
-rw-r--r-- | x11vnc/x11vnc.c | 27 |
1 files changed, 21 insertions, 6 deletions
diff --git a/x11vnc/x11vnc.c b/x11vnc/x11vnc.c index 97b8a9f..47934d3 100644 --- a/x11vnc/x11vnc.c +++ b/x11vnc/x11vnc.c @@ -156,7 +156,7 @@ #endif /* date +'"lastmod: %Y-%m-%d";' */ -char lastmod[] = "lastmod: 2004-07-15"; +char lastmod[] = "lastmod: 2004-07-19"; /* X display info */ Display *dpy = 0; @@ -1970,6 +1970,14 @@ void initialize_modtweak(void) { } for (i = minkey; i <= maxkey; i++) { for (j = 0; j < syms_per_keycode; j++) { + if (j >= 4) { + /* + * Something wacky in the keymapping. + * Ignore these non Shift/AltGr chords + * for now... + */ + continue; + } keysym = keymap[ (i - minkey) * syms_per_keycode + j ]; if ( keysym >= ' ' && keysym < 0x100 && i == XKeysymToKeycode(dpy, keysym) ) { @@ -1995,13 +2003,13 @@ static void tweak_mod(signed char mod, rfbBool down) { if (mod < 0) { if (debug_keyboard) { - rfbLog("tweak_mod: Skip: down=%d mod=0x%x\n", down, + rfbLog("tweak_mod: Skip: down=%d j-mod=0x%x\n", down, (int) mod); } return; } if (debug_keyboard) { - rfbLog("tweak_mod: Start: down=%d mod=0x%x mod_state=0x%x" + rfbLog("tweak_mod: Start: down=%d j-mod=0x%x mod_state=0x%x" " is_shift=%d\n", down, (int) mod, (int) mod_state, is_shift); } @@ -2026,7 +2034,7 @@ static void tweak_mod(signed char mod, rfbBool down) { } X_UNLOCK; if (debug_keyboard) { - rfbLog("tweak_mod: Finish: down=%d mod=0x%x mod_state=0x%x" + rfbLog("tweak_mod: Finish: down=%d j-mod=0x%x mod_state=0x%x" " is_shift=%d\n", down, (int) mod, (int) mod_state, is_shift); } @@ -6761,7 +6769,7 @@ static void watch_loop(void) { static void print_help(void) { char help[] = "\n" -"x11vnc: allow VNC connections to real X11 displays.\n" +"x11vnc: allow VNC connections to real X11 displays. %s\n" "\n" "Typical usage is:\n" "\n" @@ -6952,6 +6960,8 @@ static void print_help(void) { " to the terminal. Same as -logfile.\n" "-rc filename Use \"filename\" instead of $HOME/.x11vncrc for rc file.\n" "-norc Do not process any .x11vncrc file for options.\n" +"-h, -help Print this help text.\n" +"-V, -version Print program version (last modification date).\n" "\n" "-q Be quiet by printing less informational output to\n" " stderr. Same as -quiet.\n" @@ -7073,7 +7083,9 @@ static void print_help(void) { "These options are passed to libvncserver:\n" "\n" ; - fprintf(stderr, help, + /* have both our help and rfbUsage to stdout for more(1), etc. */ + dup2(1, 2); + fprintf(stderr, help, lastmod, view_only ? "on":"off", shared ? "on":"off", use_modifier_tweak ? "on":"off", @@ -7572,6 +7584,9 @@ int main(int argc, char* argv[]) { } else if (!strcmp(arg, "-h") || !strcmp(arg, "-help") || !strcmp(arg, "-?")) { print_help(); + } else if (!strcmp(arg, "-V") || !strcmp(arg, "-version")) { + fprintf(stderr, "x11vnc: %s\n", lastmod); + exit(0); } else if (!strcmp(arg, "-o") || !strcmp(arg, "-logfile")) { CHECK_ARGC logfile = argv[++i]; |