summaryrefslogtreecommitdiffstats
path: root/x11vnc/remote.c
diff options
context:
space:
mode:
authorChristian Beier <dontmind@freeshell.org>2014-09-03 20:54:39 +0200
committerChristian Beier <dontmind@freeshell.org>2014-09-03 20:54:39 +0200
commit498d222976975f53dea885cfe43ef0f805abd412 (patch)
treebac684fbde46fdc3e4cc3817616816b71bb67f9f /x11vnc/remote.c
parent8d2db0486dcc167f1b02d4454ebf4624ce03e1de (diff)
downloadlibtdevnc-498d222976975f53dea885cfe43ef0f805abd412.tar.gz
libtdevnc-498d222976975f53dea885cfe43ef0f805abd412.zip
Remove x11vnc subdir.
The new x11vnc repo is at https://github.com/LibVNC/x11vnc.
Diffstat (limited to 'x11vnc/remote.c')
-rw-r--r--x11vnc/remote.c6323
1 files changed, 0 insertions, 6323 deletions
diff --git a/x11vnc/remote.c b/x11vnc/remote.c
deleted file mode 100644
index 3e9e5f8..0000000
--- a/x11vnc/remote.c
+++ /dev/null
@@ -1,6323 +0,0 @@
-/*
- Copyright (C) 2002-2010 Karl J. Runge <runge@karlrunge.com>
- All rights reserved.
-
-This file is part of x11vnc.
-
-x11vnc is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2 of the License, or (at
-your option) any later version.
-
-x11vnc is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with x11vnc; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA
-or see <http://www.gnu.org/licenses/>.
-
-In addition, as a special exception, Karl J. Runge
-gives permission to link the code of its release of x11vnc with the
-OpenSSL project's "OpenSSL" library (or with modified versions of it
-that use the same license as the "OpenSSL" library), and distribute
-the linked executables. You must obey the GNU General Public License
-in all respects for all of the code used other than "OpenSSL". If you
-modify this file, you may extend this exception to your version of the
-file, but you are not obligated to do so. If you do not wish to do
-so, delete this exception statement from your version.
-*/
-
-/* -- remote.c -- */
-
-#include "x11vnc.h"
-#include "inet.h"
-#include "xwrappers.h"
-#include "xevents.h"
-#include "xinerama.h"
-#include "xrandr.h"
-#include "xdamage.h"
-#include "xrecord.h"
-#include "xkb_bell.h"
-#include "win_utils.h"
-#include "screen.h"
-#include "cleanup.h"
-#include "gui.h"
-#include "solid.h"
-#include "user.h"
-#include "rates.h"
-#include "scan.h"
-#include "connections.h"
-#include "pointer.h"
-#include "cursor.h"
-#include "userinput.h"
-#include "keyboard.h"
-#include "selection.h"
-#include "unixpw.h"
-#include "uinput.h"
-#include "userinput.h"
-#include "avahi.h"
-#include "sslhelper.h"
-
-int send_remote_cmd(char *cmd, int query, int wait);
-int do_remote_query(char *remote_cmd, char *query_cmd, int remote_sync,
- int qdefault);
-void check_black_fb(void);
-int check_httpdir(void);
-void http_connections(int on);
-int remote_control_access_ok(void);
-char *process_remote_cmd(char *cmd, int stringonly);
-
-
-static char *add_item(char *instr, char *item);
-static char *delete_item(char *instr, char *item);
-static void if_8bpp_do_new_fb(void);
-static void reset_httpport(int old, int newp);
-static void reset_rfbport(int old, int newp) ;
-
-char *query_result = NULL;
-
-/*
- * for the wild-n-crazy -remote/-R interface.
- */
-int send_remote_cmd(char *cmd, int query, int wait) {
- FILE *in = NULL;
-
- if (query_result != NULL) {
- free(query_result);
- query_result = NULL;
- }
-
- if (client_connect_file) {
- umask(077);
- in = fopen(client_connect_file, "w");
- if (in == NULL) {
- fprintf(stderr, "send_remote_cmd: could not open "
- "connect file \"%s\" for writing\n",
- client_connect_file);
- perror("fopen");
- return 1;
- }
- } else if (x11vnc_remote_prop == None) {
- initialize_x11vnc_remote_prop();
- if (x11vnc_remote_prop == None) {
- fprintf(stderr, "send_remote_cmd: could not obtain "
- "X11VNC_REMOTE X property\n");
- return 1;
- }
- }
-
- if (in != NULL) {
- fprintf(stderr, ">>> sending remote command: \"%s\"\n via"
- " connect file: %s\n", cmd, client_connect_file);
- fprintf(in, "%s\n", cmd);
- fclose(in);
- } else {
- fprintf(stderr, ">>> sending remote command: \"%s\" via"
- " X11VNC_REMOTE X property.\n", cmd);
- set_x11vnc_remote_prop(cmd);
- if (dpy) {
- XFlush_wr(dpy);
- }
- }
-
- if (query || wait) {
- char line[X11VNC_REMOTE_MAX];
- int rc=1, i=0, max=140, ms_sl=25;
-
- if (!strcmp(cmd, "cmd=stop")) {
- max = 40;
- }
- if (strstr(cmd, "script:")) {
- max = 400;
- }
- if (strstr(cmd, "bcx_xattach:")) {
- max = 400;
- }
- if (getenv("X11VNC_SYNC_TIMEOUT")) {
- max = (int) ((1000. * atof(getenv("X11VNC_SYNC_TIMEOUT")))/ms_sl);
- }
- for (i=0; i<max; i++) {
- if (i==0) {
- usleep(10 * 1000);
- } else {
- usleep(ms_sl * 1000);
- }
- if (client_connect_file) {
- char *q;
- in = fopen(client_connect_file, "r");
- if (in == NULL) {
- fprintf(stderr, "send_remote_cmd: could"
- " not open connect file \"%s\" for"
- " writing\n", client_connect_file);
- perror("fopen");
- return 1;
- }
- fgets(line, X11VNC_REMOTE_MAX, in);
- fclose(in);
- q = line;
- while (*q != '\0') {
- if (*q == '\n') *q = '\0';
- q++;
- }
- } else {
- read_x11vnc_remote_prop(1);
- strncpy(line, x11vnc_remote_str,
- X11VNC_REMOTE_MAX);
- }
- if (strcmp(cmd, line)) {
- if (query || wait) {
- query_result = strdup(line);
- fprintf(stdout, "%s\n", line);
- fflush(stdout);
- }
- rc = 0;
- break;
- }
- }
- if (rc) {
- fprintf(stderr, "error: could not connect to "
- "an x11vnc server at %s (rc=%d)\n",
- client_connect_file ? client_connect_file
- : DisplayString(dpy), rc);
- }
- return rc;
- }
- return 0;
-}
-
-int do_remote_query(char *remote_cmd, char *query_cmd, int remote_sync,
- int qdefault) {
- char *rcmd = NULL, *qcmd = NULL;
- int rc = 1, direct = 0;
-
- if (qdefault && !query_cmd) {
- query_cmd = remote_cmd;
- remote_cmd = NULL;
- }
- if (remote_cmd && strstr(remote_cmd, "DIRECT:") == remote_cmd) {
- direct = 1;
- remote_cmd += strlen("DIRECT:");
- }
- if (query_cmd && strstr(query_cmd, "DIRECT:") == query_cmd) {
- direct = 1;
- query_cmd += strlen("DIRECT:");
- }
-
- if (remote_cmd) {
- rcmd = (char *) malloc(strlen(remote_cmd) + 5);
- strcpy(rcmd, "cmd=");
- strcat(rcmd, remote_cmd);
- }
- if (query_cmd) {
- qcmd = (char *) malloc(strlen(query_cmd) + 5);
- strcpy(qcmd, "qry=");
- strcat(qcmd, query_cmd);
- }
- if (direct) {
- char *res;
- if (rcmd) {
- res = process_remote_cmd(rcmd, 1);
- fprintf(stdout, "%s\n", res);
- }
- if (qcmd) {
- res = process_remote_cmd(qcmd, 1);
- fprintf(stdout, "%s\n", res);
- }
- fflush(stdout);
- return 0;
- }
- if (qdefault) {
- char *res;
- if (!qcmd) {
- return 1;
- }
- res = process_remote_cmd(qcmd, 1);
- fprintf(stdout, "%s\n", res);
- fflush(stdout);
- return 0;
- }
-
- if (rcmd && qcmd) {
- rc = send_remote_cmd(rcmd, 0, 1);
- if (rc) {
- free(rcmd);
- free(qcmd);
- return(rc);
- }
- rc = send_remote_cmd(qcmd, 1, 1);
- } else if (rcmd) {
- rc = send_remote_cmd(rcmd, 0, remote_sync);
- free(rcmd);
- } else if (qcmd) {
- rc = send_remote_cmd(qcmd, 1, 1);
- free(qcmd);
- }
- return rc;
-}
-
-static char *add_item(char *instr, char *item) {
- char *p, *str;
- int len, saw_item = 0;
-
- if (! instr || *instr == '\0') {
- str = strdup(item);
- return str;
- }
- len = strlen(instr) + 1 + strlen(item) + 1;
- str = (char *) malloc(len);
- str[0] = '\0';
-
- /* n.b. instr will be modified; caller replaces with returned string */
- p = strtok(instr, ",");
- while (p) {
- if (!strcmp(p, item)) {
- if (saw_item) {
- p = strtok(NULL, ",");
- continue;
- }
- saw_item = 1;
- } else if (*p == '\0') {
- p = strtok(NULL, ",");
- continue;
- }
- if (str[0]) {
- strcat(str, ",");
- }
- strcat(str, p);
- p = strtok(NULL, ",");
- }
- if (! saw_item) {
- if (str[0]) {
- strcat(str, ",");
- }
- strcat(str, item);
- }
- return str;
-}
-
-static char *delete_item(char *instr, char *item) {
- char *p, *str;
- int len;
-
- if (! instr || *instr == '\0') {
- str = strdup("");
- return str;
- }
- len = strlen(instr) + 1;
- str = (char *) malloc(len);
- str[0] = '\0';
-
- /* n.b. instr will be modified; caller replaces with returned string */
- p = strtok(instr, ",");
- while (p) {
- if (!strcmp(p, item) || *p == '\0') {
- p = strtok(NULL, ",");
- continue;
- }
- if (str[0]) {
- strcat(str, ",");
- }
- strcat(str, p);
- p = strtok(NULL, ",");
- }
- return str;
-}
-
-static void if_8bpp_do_new_fb(void) {
- if (bpp == 8) {
- do_new_fb(0);
- } else {
- rfbLog(" bpp(%d) is not 8bpp, not resetting fb\n", bpp);
- }
-}
-
-void check_black_fb(void) {
- if (!screen) {
- return;
- }
- if (new_fb_size_clients(screen) != client_count) {
- rfbLog("trying to send a black fb for non-newfbsize"
- " clients %d != %d\n", client_count,
- new_fb_size_clients(screen));
- push_black_screen(4);
- }
-}
-
-int check_httpdir(void) {
- if (http_dir && http_dir[0] != '\0') {
- return 1;
- } else {
- char *prog = NULL, *httpdir, *q;
- struct stat sbuf;
- int len;
-
- rfbLog("check_httpdir: trying to guess httpdir... %s\n", program_name);
- if (program_name[0] == '/') {
- prog = strdup(program_name);
- } else {
- char cwd[1024];
- getcwd(cwd, 1024);
- len = strlen(cwd) + 1 + strlen(program_name) + 1;
- prog = (char *) malloc(len);
- snprintf(prog, len, "%s/%s", cwd, program_name);
- if (stat(prog, &sbuf) != 0) {
- char *path = strdup(getenv("PATH"));
- char *p, *base;
- base = strrchr(program_name, '/');
- if (base) {
- base++;
- } else {
- base = program_name;
- }
-
- p = strtok(path, ":");
- while(p) {
- if (prog) {
- free(prog);
- prog = NULL;
- }
- len = strlen(p) + 1 + strlen(base) + 1;
- prog = (char *) malloc(len);
- snprintf(prog, len, "%s/%s", p, base);
- if (stat(prog, &sbuf) == 0) {
- break;
- }
- p = strtok(NULL, ":");
- }
- free(path);
- }
- }
- /*
- * /path/to/bin/x11vnc
- * /path/to/bin/../share/x11vnc/classes
- * 12345678901234567
- * /path/to/bin/../share/x11vnc/classes/ssl
- * 123456789012345678901
- * 21
- */
- if ((q = strrchr(prog, '/')) == NULL) {
- rfbLog("check_httpdir: bad program path: %s\n", prog);
- free(prog);
- rfbLog("check_httpdir: *HTTP disabled* Use -httpdir path\n");
- return 0;
- }
-
- len = strlen(prog) + 21 + 1;
- *q = '\0';
- httpdir = (char *) malloc(len);
- if (use_stunnel && http_ssl) {
- snprintf(httpdir, len, "%s/../share/x11vnc/classes/ssl", prog);
- } else if (!enc_str && (use_openssl || use_stunnel || http_ssl)) {
- snprintf(httpdir, len, "%s/../share/x11vnc/classes/ssl", prog);
- } else {
- snprintf(httpdir, len, "%s/../share/x11vnc/classes", prog);
- }
- if (stat(httpdir, &sbuf) != 0) {
- if (use_stunnel && http_ssl) {
- snprintf(httpdir, len, "%s/../classes/ssl", prog);
- } else if (!enc_str && (use_openssl || use_stunnel || http_ssl)) {
- snprintf(httpdir, len, "%s/../classes/ssl", prog);
- } else {
- snprintf(httpdir, len, "%s/../classes", prog);
- }
- }
- free(prog);
-
- if (stat(httpdir, &sbuf) == 0) {
- /* good enough for me */
- rfbLog("check_httpdir: guessed directory:\n");
- rfbLog(" %s\n", httpdir);
- http_dir = httpdir;
- return 1;
- } else {
- /* try some hardwires: */
- int i;
- char **use;
- char *list[] = {
- "/usr/local/share/x11vnc/classes",
- "/usr/share/x11vnc/classes",
- NULL
- };
- char *ssllist[] = {
- "/usr/local/share/x11vnc/classes/ssl",
- "/usr/share/x11vnc/classes/ssl",
- NULL
- };
- if (use_stunnel && http_ssl) {
- use = ssllist;
- } else if (!enc_str && (use_openssl || use_stunnel || http_ssl)) {
- use = ssllist;
- } else {
- use = list;
- }
- i = 0;
- while (use[i] != NULL) {
- if (stat(use[i], &sbuf) == 0) {
- http_dir = strdup(use[i]);
- return 1;
- }
- i++;
- }
-
- rfbLog("check_httpdir: bad guess:\n");
- rfbLog(" %s\n", httpdir);
- rfbLog("check_httpdir: *HTTP disabled* Use -httpdir path\n");
- return 0;
- }
- }
-}
-
-static void rfb_http_init_sockets(void) {
- in_addr_t iface;
- if (!screen) {
- return;
- }
- iface = screen->listenInterface;
- if (getenv("X11VNC_HTTP_LISTEN_LOCALHOST")) {
- rfbLog("http_connections: HTTP listen on localhost only. (not HTTPS)\n");
- screen->listenInterface = htonl(INADDR_LOOPBACK);
- }
- rfbHttpInitSockets(screen);
- if (noipv4 || getenv("IPV4_FAILS")) {
- if (getenv("IPV4_FAILS")) {
- rfbLog("TESTING: IPV4_FAILS for rfb_http_init_sockets()\n");
- }
- if (screen->httpListenSock > -1) {
- close(screen->httpListenSock);
- screen->httpListenSock = -1;
- }
- }
- screen->listenInterface = iface;
-}
-
-void http_connections(int on) {
- if (!screen) {
- return;
- }
- if (on) {
- rfbLog("http_connections: turning on http service.\n");
-
- if (inetd && use_openssl) {
- /*
- * try to work around rapid fire https requests
- * in inetd mode... ugh.
- */
- if (screen->httpPort == 0) {
- int port = find_free_port(5800, 5850);
- if (port) {
- /* mutex */
- screen->httpPort = port;
- }
- }
- }
- screen->httpInitDone = FALSE;
- if (check_httpdir()) {
- int fd6 = -1;
- char *save = listen_str6;
-
- screen->httpDir = http_dir;
-
- rfb_http_init_sockets();
-
- if (getenv("X11VNC_HTTP_LISTEN_LOCALHOST")) {
- listen_str6 = "localhost";
- }
-
- if (screen->httpPort != 0 && screen->httpListenSock < 0) {
- rfbLog("http_connections: failed to listen on http port: %d\n", screen->httpPort);
- if (ipv6_listen) {
- fd6 = listen6(screen->httpPort);
- }
- if (fd6 < 0) {
- clean_up_exit(1);
- }
- rfbLog("http_connections: trying IPv6 only mode.\n");
- }
- if (ipv6_listen && screen->httpPort > 0) {
- if (fd6 < 0) {
- fd6 = listen6(screen->httpPort);
- }
- ipv6_http_fd = fd6;
- if (ipv6_http_fd >= 0) {
- rfbLog("http_connections: Listening %s on IPv6 port %d (socket %d)\n",
- screen->httpListenSock < 0 ? "only" : "also",
- screen->httpPort, ipv6_http_fd);
- }
- }
- listen_str6 = save;
- }
- } else {
- rfbLog("http_connections: turning off http service.\n");
- if (screen->httpListenSock > -1) {
- close(screen->httpListenSock);
- screen->httpListenSock = -1;
- }
- screen->httpDir = NULL;
- if (ipv6_http_fd >= 0) {
- close(ipv6_http_fd);
- ipv6_http_fd = -1;
- }
- }
-}
-
-static void reset_httpport(int old, int newp) {
- int hp = newp;
-
- if (! screen->httpDir) {
- return;
- } else if (inetd) {
- rfbLog("reset_httpport: cannot set httpport: %d in inetd.\n", hp);
- return;
- } else if (!screen) {
- rfbLog("reset_httpport: no screen.\n");
- return;
- } else if (hp < 0) {
- rfbLog("reset_httpport: invalid httpport: %d\n", hp);
- return;
- } else if (hp == old) {
- rfbLog("reset_httpport: unchanged httpport: %d\n", hp);
- return;
- }
-
- if (screen->httpListenSock > -1) {
- close(screen->httpListenSock);
- screen->httpListenSock = -1;
- }
-
- screen->httpPort = hp;
- screen->httpInitDone = FALSE;
-
- rfbLog("reset_httpport: setting httpport %d -> %d.\n",
- old == -1 ? hp : old, hp);
-
- if (noipv4 || getenv("IPV4_FAILS")) {
- if (getenv("IPV4_FAILS")) {
- rfbLog("TESTING: IPV4_FAILS for reset_httpport()\n");
- }
- } else if (screen->httpPort == 0) {
- ;
- } else {
- rfb_http_init_sockets();
- }
-
- if (screen->httpPort != 0 && screen->httpListenSock < 0) {
- rfbLog("reset_httpport: failed to listen on http port: %d\n",
- screen->httpPort);
- }
-
- if (ipv6_http_fd >= 0) {
- close(ipv6_http_fd);
- ipv6_http_fd = -1;
- }
- if (ipv6_listen && screen->httpPort > 0) {
- ipv6_http_fd = listen6(screen->httpPort);
- rfbLog("reset_httpport: ipv6_http_fd: %d port: %d\n",
- ipv6_http_fd, screen->httpPort);
- }
-}
-
-static void reset_rfbport(int old, int newp) {
- int rp = newp;
-
- if (inetd) {
- rfbLog("reset_rfbport: cannot set rfbport: %d in inetd.\n", rp);
- return;
- } else if (!screen) {
- rfbLog("reset_rfbport: no screen.\n");
- return;
- } else if (rp < 0) {
- rfbLog("reset_rfbport: invalid rfbport: %d\n", rp);
- return;
- } else if (rp == old) {
- rfbLog("reset_rfbport: unchanged rfbport: %d\n", rp);
- return;
- }
-
- rfbLog("reset_rfbport: setting rfbport %d -> %d.\n", old == -1 ? rp : old, rp);
-
- screen->port = rp;
-
- if (use_openssl) {
- openssl_port(1);
- if (openssl_sock < 0 && openssl_sock6 < 0) {
- rfbLog("reset_rfbport: warning could not listen on port: %d\n",
- screen->port);
- } else {
- set_vnc_desktop_name();
- }
- if (https_port_num >= 0) {
- https_port(1);
- }
- return;
- }
-
- if (screen->listenSock >= 0) {
- FD_CLR(screen->listenSock, &(screen->allFds));
- close(screen->listenSock);
- screen->listenSock = -1;
- }
-
- if (noipv4 || getenv("IPV4_FAILS")) {
- if (getenv("IPV4_FAILS")) {
- rfbLog("TESTING: IPV4_FAILS for reset_rfbport()\n");
- }
- } else {
- screen->listenSock = listen_tcp(screen->port, screen->listenInterface, 0);
- if (screen->listenSock >= 0) {
- if (screen->listenSock > screen->maxFd) {
- screen->maxFd = screen->listenSock;
- }
- FD_SET(screen->listenSock, &(screen->allFds));
- }
- }
-
- if (ipv6_listen_fd >= 0) {
- close(ipv6_listen_fd);
- ipv6_listen_fd = -1;
- }
- if (ipv6_listen && screen->port > 0) {
- ipv6_listen_fd = listen6(screen->port);
- rfbLog("reset_rfbport: ipv6_listen_fd: %d port: %d\n",
- ipv6_listen_fd, screen->port);
- }
-
- if (screen->listenSock < 0 && ipv6_listen_fd < 0) {
- rfbLog("reset_rfbport: warning could not listen on port: %d\n", screen->port);
- } else {
- set_vnc_desktop_name();
- }
-}
-
-/*
- * Do some sanity checking of the permissions on the XAUTHORITY and the
- * -connect file. This is -privremote. What should be done is check
- * for an empty host access list, currently we lazily do not bring in
- * libXau yet.
- */
-int remote_control_access_ok(void) {
-#if NO_X11
- return 0;
-#else
- struct stat sbuf;
-
- if (client_connect_file) {
- if (stat(client_connect_file, &sbuf) == 0) {
- if (sbuf.st_mode & S_IWOTH) {
- rfbLog("connect file is writable by others.\n");
- rfbLog(" %s\n", client_connect_file);
- return 0;
- }
- if (sbuf.st_mode & S_IWGRP) {
- rfbLog("connect file is writable by group.\n");
- rfbLog(" %s\n", client_connect_file);
- return 0;
- }
- }
- }
-
- if (dpy) {
- char tmp[1000];
- char *home, *xauth;
- char *dpy_str = DisplayString(dpy);
- Display *dpy2;
- XHostAddress *xha;
- Bool enabled;
- int n;
-
- home = get_home_dir();
- if (getenv("XAUTHORITY") != NULL) {
- xauth = getenv("XAUTHORITY");
- } else if (home) {
- int len = 1000 - strlen("/.Xauthority") - 1;
- strncpy(tmp, home, len);
- strcat(tmp, "/.Xauthority");
- xauth = tmp;
- } else {
- rfbLog("cannot determine default XAUTHORITY.\n");
- return 0;
- }
- if (home) {
- free(home);
- }
- if (stat(xauth, &sbuf) == 0) {
- if (sbuf.st_mode & S_IWOTH) {
- rfbLog("XAUTHORITY is writable by others!!\n");
- rfbLog(" %s\n", xauth);
- return 0;
- }
- if (sbuf.st_mode & S_IWGRP) {
- rfbLog("XAUTHORITY is writable by group!!\n");
- rfbLog(" %s\n", xauth);
- return 0;
- }
- if (sbuf.st_mode & S_IROTH) {
- rfbLog("XAUTHORITY is readable by others.\n");
- rfbLog(" %s\n", xauth);
- return 0;
- }
- if (sbuf.st_mode & S_IRGRP) {
- rfbLog("XAUTHORITY is readable by group.\n");
- rfbLog(" %s\n", xauth);
- return 0;
- }
- }
-
- X_LOCK;
- xha = XListHosts(dpy, &n, &enabled);
- X_UNLOCK;
- if (! enabled) {
- rfbLog("X access control is disabled, X clients can\n");
- rfbLog(" connect from any host. Run 'xhost -'\n");
- return 0;
- }
- if (xha) {
- int i;
- rfbLog("The following hosts can connect w/o X11 "
- "auth:\n");
- for (i=0; i<n; i++) {
- if (xha[i].family == FamilyInternet) {
- char *str = raw2host(xha[i].address,
- xha[i].length);
- char *ip = raw2ip(xha[i].address);
- rfbLog(" %s/%s\n", str, ip);
- free(str);
- free(ip);
- } else {
- rfbLog(" unknown-%d\n", i+1);
- }
- }
- XFree_wr(xha);
- return 0;
- }
-
- if (getenv("XAUTHORITY")) {
- xauth = strdup(getenv("XAUTHORITY"));
- } else {
- xauth = NULL;
- }
- set_env("XAUTHORITY", "/impossible/xauthfile");
-
- fprintf(stderr, "\nChecking if display %s requires "
- "XAUTHORITY\n", dpy_str);
- fprintf(stderr, " -- (ignore any Xlib: errors that"
- " follow) --\n");
- dpy2 = XOpenDisplay_wr(dpy_str);
- fflush(stderr);
- fprintf(stderr, " -- (done checking) --\n\n");
-
- if (xauth) {
- set_env("XAUTHORITY", xauth);
- free(xauth);
- } else {
- xauth = getenv("XAUTHORITY");
- if (xauth) {
- *(xauth-2) = '_'; /* yow */
- }
- }
- if (dpy2) {
- rfbLog("XAUTHORITY is not required on display.\n");
- rfbLog(" %s\n", DisplayString(dpy));
- XCloseDisplay_wr(dpy2);
- dpy2 = NULL;
- return 0;
- }
-
- }
- return 1;
-#endif /* NO_X11 */
-}
-
-#ifdef MACOSX
-void macosxCG_keycode_inject(int down, int keycode);
-#endif
-
-int rc_npieces = 0;
-
-/*
- * Huge, ugly switch to handle all remote commands and queries
- * -remote/-R and -query/-Q.
- */
-char *process_remote_cmd(char *cmd, int stringonly) {
-#if REMOTE_CONTROL
- char *p = cmd;
- char *co = "";
- char buf[X11VNC_REMOTE_MAX];
- int bufn = X11VNC_REMOTE_MAX;
- int query = 0;
- static char *prev_cursors_mode = NULL;
-
- if (!query_default && !accept_remote_cmds) {
- rfbLog("remote commands disabled: %s\n", cmd);
- return NULL;
- }
- if (unixpw_in_progress) {
- rfbLog("skip remote command: %s unixpw_in_progress.\n", cmd);
- return NULL;
- }
-
- if (!query_default && priv_remote) {
- if (! remote_control_access_ok()) {
- rfbLog("** Disabling remote commands in -privremote "
- "mode.\n");
- accept_remote_cmds = 0;
- return NULL;
- }
- }
-
-
- strcpy(buf, "");
- if (strstr(cmd, "cmd=") == cmd) {
- p += strlen("cmd=");
- if (strstr(p, "script:") == p) {
- char *s, *q, **pieces, tmp[1024];
- int k = 0, n = 0, dp = 1;
-
- p += strlen("script:");
-
- if (strstr(p, "file=") == p) {
- FILE *f;
- struct stat sbuf;
-
- p += strlen("file=");
-
- rfbLog("reading script from file '%s'\n", p);
-
- if (stat(p, &sbuf) != 0) {
- rfbLogPerror("stat");
- return NULL;
- }
-
- f = fopen(p, "r");
- if (f == NULL) {
- rfbLogPerror("fopen");
- return NULL;
- }
-
- p = (char *) calloc(sbuf.st_size + 1, 1);
- dp = 0;
- while (fgets(tmp, 1024, f) != NULL) {
- char *c = strchr(tmp, '#');
- if (c) *c = '\0';
- if (strlen(p) + strlen(tmp) > (size_t) sbuf.st_size) {
- break;
- }
- strcat(p, tmp);
- }
- fclose(f);
- }
-
- pieces = (char **) malloc(strlen(p) * sizeof(char *));
- if (dp) {
- s = strdup(p);
- } else {
- s = p;
- }
- q = strtok(s, ";");
-
- while (q) {
- char *t = lblanks(q);
- if (strstr(t, "cmd=") != t && strstr(t, "qry=") != t) {
- strcpy(tmp, "cmd=");
- } else {
- strcpy(tmp, "");
- }
- strncat(tmp, t, 1000);
- pieces[n] = strdup(tmp);
- n++;
- q = strtok(NULL, ";");
- }
- free(s);
-
- for (k=0; k < n; k++) {
- char *c = pieces[k];
- char *t = c + strlen(c) - 1; /* shortest is "cmd=" */
- while (isspace((unsigned char) (*t))) {
- *t = '\0';
- if (t <= c) break;
- t--;
- }
- if (k < n - 1) {
- process_remote_cmd(c, 1);
- } else {
- process_remote_cmd(c, 0);
- }
- }
- for (k=0; k<n; k++) {
- free(pieces[k]);
- }
- free(pieces);
- return NULL;
- }
- } else if (strstr(cmd, "qry=") == cmd) {
- query = 1;
- if (strchr(cmd, ',')) {
- /* comma separated batch mode */
- char *s, *q, *res, **pieces, tmp[1024];
- int k = 0, n = 0;
-
- pieces = (char **) malloc(strlen(cmd) * sizeof(char *));
- s = strdup(cmd + strlen("qry="));
- q = strtok(s, ",");
-
- while (q) {
- strcpy(tmp, "qry=");
- strncat(tmp, q, 1000);
- pieces[n] = strdup(tmp);
- n++;
- q = strtok(NULL, ",");
- }
- free(s);
-
- rc_npieces = n;
- strcpy(buf, "");
- for (k=0; k < n; k++) {
- res = process_remote_cmd(pieces[k], 1);
- if (res && strlen(buf)+strlen(res)
- >= X11VNC_REMOTE_MAX - 1) {
- rfbLog("overflow in process_remote_cmd:"
- " %s -- %s\n", buf, res);
- free(res);
- break;
- }
- if (res) {
- strcat(buf, res);
- free(res);
- }
- if (k < n - 1) {
- strcat(buf, ",");
- }
- }
- for (k=0; k<n; k++) {
- free(pieces[k]);
- }
- free(pieces);
- rc_npieces = 0;
- goto qry;
- }
- p += strlen("qry=");
- } else {
- rfbLog("ignoring malformed command: %s\n", cmd);
- goto done;
- }
-
- /* allow var=val usage */
- if (!strchr(p, ':')) {
- char *q = strchr(p, '=');
- if (q) *q = ':';
- }
-
- /* always call like: COLON_CHECK("foobar:") */
-#define COLON_CHECK(str) \
- if (strstr(p, str) != p) { \
- co = ":"; \
- if (! query) { \
- goto done; \
- } \
- } else { \
- char *q = strchr(p, ':'); \
- if (query && q != NULL) { \
- *(q+1) = '\0'; \
- } \
- }
-
-#define NOTAPP \
- if (query) { \
- if (strchr(p, ':')) { \
- snprintf(buf, bufn, "ans=%sN/A", p); \
- } else { \
- snprintf(buf, bufn, "ans=%s:N/A", p); \
- } \
- goto qry; \
- }
-
-#define NOTAPPRO \
- if (query) { \
- if (strchr(p, ':')) { \
- snprintf(buf, bufn, "aro=%sN/A", p); \
- } else { \
- snprintf(buf, bufn, "aro=%s:N/A", p); \
- } \
- goto qry; \
- }
-
-/*
- * Maybe add: passwdfile logfile bg rfbauth passwd...
- */
- if (!strcmp(p, "")) { /* skip-cmd-list */
- NOTAPP
- rfbLog("remote_cmd: empty command.\n");
- goto done;
- }
- if (strstr(p, "CR:") == p) { /* skip-cmd-list */
- /* CR:WxH+X+Y,dx,dy */
- int w, h, x, y, dx, dy;
- NOTAPP
- if (sscanf(p+3, "%dx%d+%d+%d,%d,%d", &w, &h, &x, &y, &dx, &dy) == 6) {
- sraRegionPtr r;
- rfbLog("rfbDoCopyRect(screen, %d, %d, %d, %d, %d, %d)\n", x, y, x+w, y+h, dx, dy);
- r = sraRgnCreateRect(x, y, x+w, y+h);
- do_copyregion(r, dx, dy, 0);
- fb_push();
- sraRgnDestroy(r);
- rfbLog("did\n");
- } else {
- rfbLog("remote_cmd: bad CR string: %s\n", p);
- }
- goto done;
- }
- if (!strcmp(p, "stop") || !strcmp(p, "quit") ||
- !strcmp(p, "exit") || !strcmp(p, "shutdown")) {
- NOTAPP
- if (client_connect_file) {
- FILE *in = fopen(client_connect_file, "w");
- if (in) {
- fprintf(in, "cmd=noop\n");
- fclose(in);
- }
- }
- rfbLog("remote_cmd: setting shut_down flag\n");
- shut_down = 1;
- close_all_clients();
- goto done;
- }
- if (!strcmp(p, "ping")
- || strstr(p, "ping:") == p) { /* skip-cmd-list */
- query = 1;
- if (rfb_desktop_name) {
- snprintf(buf, bufn, "ans=%s:%s", p, rfb_desktop_name);
- } else {
- snprintf(buf, bufn, "ans=%s:%s", p, "unknown");
- }
- goto qry;
- goto done;
- }
- if (!strcmp(p, "resend_cutbuffer")) {
- NOTAPP
- resend_selection("cutbuffer");
- goto done;
- }
- if (!strcmp(p, "resend_clipboard")) {
- NOTAPP
- resend_selection("clipboard");
- goto done;
- }
- if (!strcmp(p, "resend_primary")) {
- NOTAPP
- resend_selection("primary");
- goto done;
- }
- if (!strcmp(p, "blacken") || !strcmp(p, "zero")) {
- NOTAPP
- push_black_screen(4);
- goto done;
- }
- if (!strcmp(p, "refresh")) {
- NOTAPP
- refresh_screen(1);
- goto done;
- }
- if (!strcmp(p, "reset")) {
- NOTAPP
- do_new_fb(1);
- goto done;
- }
- if (strstr(p, "zero:") == p) { /* skip-cmd-list */
- int x1, y1, x2, y2;
- NOTAPP
- p += strlen("zero:");
- if (sscanf(p, "%d,%d,%d,%d", &x1, &y1, &x2, &y2) == 4) {
- int mark = 1;
- rfbLog("zeroing rect: %s\n", p);
- if (x1 < 0 || x2 < 0) {
- x1 = nabs(x1);
- x2 = nabs(x2);
- mark = 0; /* hack for testing */
- }
-
- zero_fb(x1, y1, x2, y2);
- if (mark) {
- mark_rect_as_modified(x1, y1, x2, y2, 0);
- }
- push_sleep(4);
- }
- goto done;
- }
- if (strstr(p, "damagefb:") == p) { /* skip-cmd-list */
- int delay;
- NOTAPP
- p += strlen("damagefb:");
- if (sscanf(p, "%d", &delay) == 1) {
- rfbLog("damaging client fb's for %d secs "
- "(by not marking rects.)\n", delay);
- damage_time = time(NULL);
- damage_delay = delay;
- }
- goto done;
- }
- if (strstr(p, "close") == p) {
- NOTAPP
- COLON_CHECK("close:")
- p += strlen("close:");
- close_clients(p);
- goto done;
- }
- if (strstr(p, "disconnect") == p) {
- NOTAPP
- COLON_CHECK("disconnect:")
- p += strlen("disconnect:");
- close_clients(p);
- goto done;
- }
- if (strstr(p, "id_cmd") == p) {
- NOTAPP
- COLON_CHECK("id_cmd:")
- p += strlen("id_cmd:");
- id_cmd(p);
- goto done;
- }
- if (strstr(p, "id") == p) {
- int ok = 0;
- Window twin;
- COLON_CHECK("id:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s0x%lx", p, co,
- rootshift ? 0 : subwin);
- goto qry;
- }
- p += strlen("id:");
- if (*p == '\0' || !strcmp("root", p)) { /* skip-cmd-list */
- /* back to root win */
- twin = 0x0;
- ok = 1;
- } else if (!strcmp("pick", p)) {
- twin = 0x0;
- if (safe_remote_only) {
- rfbLog("unsafe: '-id pick'\n");
- } else if (pick_windowid(&twin)) {
- ok = 1;
- }
- } else if (! scan_hexdec(p, &twin)) {
- rfbLog("-id: skipping incorrect hex/dec number:"
- " %s\n", p);
- } else {
- ok = 1;
- }
- if (ok) {
- X_LOCK;
- if (twin && ! valid_window(twin, NULL, 0)) {
- rfbLog("skipping invalid sub-window: 0x%lx\n", twin);
- X_UNLOCK;
- } else {
- subwin = twin;
- rootshift = 0;
- X_UNLOCK;
- check_black_fb();
- do_new_fb(1);
- }
- }
- goto done;
- }
- if (strstr(p, "sid") == p) {
- int ok = 0;
- Window twin;
- COLON_CHECK("sid:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s0x%lx", p, co,
- !rootshift ? 0 : subwin);
- goto qry;
- }
- p += strlen("sid:");
- if (*p == '\0' || !strcmp("root", p)) { /* skip-cmd-list */
- /* back to root win */
- twin = 0x0;
- ok = 1;
- } else if (!strcmp("pick", p)) {
- twin = 0x0;
- if (safe_remote_only) {
- rfbLog("unsafe: '-sid pick'\n");
- } else if (pick_windowid(&twin)) {
- ok = 1;
- }
- } else if (! scan_hexdec(p, &twin)) {
- rfbLog("-sid: skipping incorrect hex/dec number: %s\n", p);
- } else {
- ok = 1;
- }
- if (ok) {
- X_LOCK;
- if (twin && ! valid_window(twin, NULL, 0)) {
- rfbLog("skipping invalid sub-window: 0x%lx\n", twin);
- X_UNLOCK;
- } else {
- subwin = twin;
- rootshift = 1;
- X_UNLOCK;
- check_black_fb();
- do_new_fb(1);
- }
- }
- goto done;
- }
- if (strstr(p, "waitmapped") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- subwin_wait_mapped);
- goto qry;
- }
- subwin_wait_mapped = 1;
- goto done;
- }
- if (strstr(p, "nowaitmapped") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !subwin_wait_mapped);
- goto qry;
- }
- subwin_wait_mapped = 0;
- goto done;
- }
- if (!strcmp(p, "clip") ||
- strstr(p, "clip:") == p) { /* skip-cmd-list */
- COLON_CHECK("clip:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(clip_str));
- goto qry;
- }
- p += strlen("clip:");
- if (clip_str) {
- int w, h, x, y;
- free(clip_str);
- /* try to handle easy case where WxH is unchanged: */
- if (parse_geom(p, &w, &h, &x, &y, wdpy_x, wdpy_y)) {
- if (cdpy_x == w && cdpy_y == h) {
- if (x >= 0 && y >= 0) {
- if (x + w <= wdpy_x && y + h <= wdpy_y) {
- coff_x = x;
- coff_y = y;
- clip_str = strdup(p);
- goto done;
- }
- }
- }
- }
- }
- clip_str = strdup(p);
-
- /* OK, this requires a new fb... */
- do_new_fb(1);
- goto done;
- }
- if (!strcmp(p, "flashcmap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, flash_cmap);
- goto qry;
- }
- rfbLog("remote_cmd: turning on flashcmap mode.\n");
- flash_cmap = 1;
- goto done;
- }
- if (!strcmp(p, "noflashcmap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !flash_cmap);
- goto qry;
- }
- rfbLog("remote_cmd: turning off flashcmap mode.\n");
- flash_cmap = 0;
- goto done;
- }
- if (strstr(p, "shiftcmap") == p) {
- COLON_CHECK("shiftcmap:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, shift_cmap);
- goto qry;
- }
- p += strlen("shiftcmap:");
- shift_cmap = atoi(p);
- rfbLog("remote_cmd: set -shiftcmap %d\n", shift_cmap);
- do_new_fb(1);
- goto done;
- }
- if (!strcmp(p, "truecolor")) {
- int orig = force_indexed_color;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !force_indexed_color);
- goto qry;
- }
- rfbLog("remote_cmd: turning off notruecolor mode.\n");
- force_indexed_color = 0;
- if (orig != force_indexed_color) {
- if_8bpp_do_new_fb();
- }
- goto done;
- }
- if (!strcmp(p, "notruecolor")) {
- int orig = force_indexed_color;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- force_indexed_color);
- goto qry;
- }
- rfbLog("remote_cmd: turning on notruecolor mode.\n");
- force_indexed_color = 1;
- if (orig != force_indexed_color) {
- if_8bpp_do_new_fb();
- }
- goto done;
- }
- if (!strcmp(p, "overlay")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, overlay);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -overlay mode.\n");
- if (!overlay_present) {
- rfbLog("skipping: overlay extension not present.\n");
- } else if (overlay) {
- rfbLog("skipping: already in -overlay mode.\n");
- } else {
- int reset_mem = 0;
- /* here we go... */
- if (using_shm) {
- rfbLog("setting -noshm mode.\n");
- using_shm = 0;
- reset_mem = 1;
- }
- overlay = 1;
- do_new_fb(reset_mem);
- }
- goto done;
- }
- if (!strcmp(p, "nooverlay")) {
- int orig = overlay;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !overlay);
- goto qry;
- }
- rfbLog("remote_cmd: turning off overlay mode\n");
- overlay = 0;
- if (!overlay_present) {
- rfbLog("warning: overlay extension not present.\n");
- } else if (!orig) {
- rfbLog("skipping: already not in -overlay mode.\n");
- } else {
- /* here we go... */
- do_new_fb(0);
- }
- goto done;
- }
- if (!strcmp(p, "overlay_cursor") ||
- !strcmp(p, "overlay_yescursor") ||
- !strcmp(p, "nooverlay_nocursor")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, overlay_cursor);
- goto qry;
- }
- rfbLog("remote_cmd: turning on overlay_cursor mode.\n");
- overlay_cursor = 1;
- if (!overlay_present) {
- rfbLog("warning: overlay extension not present.\n");
- } else if (!overlay) {
- rfbLog("warning: not in -overlay mode.\n");
- } else {
- rfbLog("You may want to run -R noshow_cursor or\n");
- rfbLog(" -R cursor:none to disable any extra "
- "cursors.\n");
- }
- goto done;
- }
- if (!strcmp(p, "nooverlay_cursor") ||
- !strcmp(p, "nooverlay_yescursor") ||
- !strcmp(p, "overlay_nocursor")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !overlay_cursor);
- goto qry;
- }
- rfbLog("remote_cmd: turning off overlay_cursor mode\n");
- overlay_cursor = 0;
- if (!overlay_present) {
- rfbLog("warning: overlay extension not present.\n");
- } else if (!overlay) {
- rfbLog("warning: not in -overlay mode.\n");
- } else {
- rfbLog("You may want to run -R show_cursor or\n");
- rfbLog(" -R cursor:... to re-enable any cursors.\n");
- }
- goto done;
- }
- if (!strcmp(p, "8to24")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, cmap8to24);
- goto qry;
- }
- if (overlay) {
- rfbLog("disabling -overlay in -8to24 mode.\n");
- overlay = 0;
- }
- rfbLog("remote_cmd: turning on -8to24 mode.\n");
- cmap8to24 = 1;
- if (overlay) {
- rfbLog("disabling -overlay in -8to24 mode.\n");
- overlay = 0;
- }
- do_new_fb(0);
- goto done;
- }
- if (!strcmp(p, "no8to24")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !cmap8to24);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -8to24 mode.\n");
- cmap8to24 = 0;
- do_new_fb(0);
- goto done;
- }
- if (strstr(p, "8to24_opts") == p) {
- COLON_CHECK("8to24_opts:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(cmap8to24_str));
- goto qry;
- }
- p += strlen("8to24_opts:");
- if (cmap8to24_str) {
- free(cmap8to24_str);
- }
- cmap8to24_str = strdup(p);
- if (*p == '\0') {
- cmap8to24 = 0;
- } else {
- cmap8to24 = 1;
- }
- rfbLog("remote_cmd: set cmap8to24_str to: %s\n", cmap8to24_str);
- do_new_fb(0);
- goto done;
- }
- if (!strcmp(p, "24to32")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, xform24to32);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -24to32 mode.\n");
- xform24to32 = 1;
- do_new_fb(1);
- goto done;
- }
- if (!strcmp(p, "no24to32")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !xform24to32);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -24to32 mode.\n");
- if (set_visual_str_to_something) {
- if (visual_str) {
- rfbLog("unsetting: %d %d/%d\n", visual_str,
- (int) visual_id, visual_depth);
- free(visual_str);
- }
- visual_str = NULL;
- visual_id = (VisualID) 0;
- visual_depth = 0;
- }
- xform24to32 = 0;
- do_new_fb(1);
- goto done;
- }
- if (strstr(p, "visual") == p) {
- COLON_CHECK("visual:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(visual_str));
- goto qry;
- }
- p += strlen("visual:");
- if (visual_str) free(visual_str);
- visual_str = strdup(p);
-
- /* OK, this requires a new fb... */
- do_new_fb(0);
- goto done;
- }
- if (!strcmp(p, "scale") ||
- strstr(p, "scale:") == p) { /* skip-cmd-list */
- COLON_CHECK("scale:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(scale_str));
- goto qry;
- }
- p += strlen("scale:");
- if (scale_str) free(scale_str);
- scale_str = strdup(p);
-
- /* OK, this requires a new fb... */
- check_black_fb();
- do_new_fb(0);
- goto done;
- }
- if (!strcmp(p, "scale_cursor") ||
- strstr(p, "scale_cursor:") == p) { /* skip-cmd-list */
- COLON_CHECK("scale_cursor:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(scale_cursor_str));
- goto qry;
- }
- p += strlen("scale_cursor:");
- if (scale_cursor_str) free(scale_cursor_str);
- if (*p == '\0') {
- scale_cursor_str = NULL;
- } else {
- scale_cursor_str = strdup(p);
- }
- setup_cursors_and_push();
- goto done;
- }
- if (!strcmp(p, "viewonly")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, view_only);
- goto qry;
- }
- rfbLog("remote_cmd: enable viewonly mode.\n");
- view_only = 1;
- goto done;
- }
- if (!strcmp(p, "noviewonly")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !view_only);
- goto qry;
- }
- rfbLog("remote_cmd: disable viewonly mode.\n");
- view_only = 0;
- if (raw_fb) set_raw_fb_params(0);
- goto done;
- }
- if (!strcmp(p, "shared")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, shared); goto qry;
- }
- rfbLog("remote_cmd: enable sharing.\n");
- shared = 1;
- if (screen) {
- /* mutex */
- screen->alwaysShared = TRUE;
- screen->neverShared = FALSE;
- }
- goto done;
- }
- if (!strcmp(p, "noshared")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !shared); goto qry;
- }
- rfbLog("remote_cmd: disable sharing.\n");
- shared = 0;
- if (screen) {
- /* mutex */
- screen->alwaysShared = FALSE;
- screen->neverShared = TRUE;
- }
- goto done;
- }
- if (!strcmp(p, "forever")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, 1-connect_once);
- goto qry;
- }
- rfbLog("remote_cmd: enable -forever mode.\n");
- connect_once = 0;
- goto done;
- }
- if (!strcmp(p, "noforever") || !strcmp(p, "once")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, connect_once);
- goto qry;
- }
- rfbLog("remote_cmd: disable -forever mode.\n");
- connect_once = 1;
- goto done;
- }
- if (strstr(p, "timeout") == p) {
- int to;
- COLON_CHECK("timeout:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- first_conn_timeout);
- goto qry;
- }
- p += strlen("timeout:");
- to = atoi(p);
- if (to > 0 ) {
- to = -to;
- }
- first_conn_timeout = to;
- rfbLog("remote_cmd: set -timeout to %d\n", -to);
- goto done;
- }
- if (!strcmp(p, "tightfilexfer")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, tightfilexfer);
- goto qry;
- }
-#ifdef LIBVNCSERVER_WITH_TIGHTVNC_FILETRANSFER
- if (! tightfilexfer) {
- rfbLog("remote_cmd: enabling -tightfilexfer for *NEW* clients.\n");
- tightfilexfer = 1;
- rfbLog("rfbRegisterTightVNCFileTransferExtension: 4\n");
- rfbRegisterTightVNCFileTransferExtension();
- }
-#else
- rfbLog("remote_cmd: -tightfilexfer not supported in this binary.\n");
-#endif
- goto done;
- }
- if (!strcmp(p, "notightfilexfer")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !tightfilexfer);
- goto qry;
- }
-#ifdef LIBVNCSERVER_WITH_TIGHTVNC_FILETRANSFER
- if (tightfilexfer) {
- rfbLog("remote_cmd: disabling -tightfilexfer for *NEW* clients.\n");
- tightfilexfer = 0;
- rfbLog("rfbUnregisterTightVNCFileTransferExtension: 2\n");
- rfbUnregisterTightVNCFileTransferExtension();
- }
-#else
- rfbLog("remote_cmd: -tightfilexfer not supported in this binary.\n");
-#endif
- goto done;
- }
- if (!strcmp(p, "ultrafilexfer")) {
- if (query) {
- if (screen) {
- snprintf(buf, bufn, "ans=%s:%d", p, screen->permitFileTransfer == TRUE);
- } else {
- snprintf(buf, bufn, "ans=%s:%d", p, 0);
- }
- goto qry;
- }
- if (! screen->permitFileTransfer) {
- rfbLog("remote_cmd: enabling -ultrafilexfer for clients.\n");
- /* mutex */
- screen->permitFileTransfer = TRUE;
- }
- goto done;
- }
- if (!strcmp(p, "noultrafilexfer")) {
- if (query) {
- if (screen) {
- snprintf(buf, bufn, "ans=%s:%d", p, screen->permitFileTransfer == FALSE);
- } else {
- snprintf(buf, bufn, "ans=%s:%d", p, 1);
- }
- goto qry;
- }
- if (screen->permitFileTransfer) {
- rfbLog("remote_cmd: disabling -ultrafilexfer for clients.\n");
- /* mutex */
- screen->permitFileTransfer = FALSE;
- }
- goto done;
- }
- if (strstr(p, "rfbversion") == p) {
- int maj, min;
- COLON_CHECK("rfbversion:")
- if (query) {
- if (screen) {
- snprintf(buf, bufn, "ans=%s:%d.%d", p, screen->protocolMajorVersion, screen->protocolMinorVersion);
- } else {
- snprintf(buf, bufn, "ans=%s:%d.%d", p, 3, 8);
- }
- goto qry;
- }
- p += strlen("rfbversion:");
-
- if (sscanf(p, "%d.%d", &maj, &min) == 2) {
- /* mutex */
- screen->protocolMajorVersion = maj;
- screen->protocolMinorVersion = min;
- rfbLog("remote_cmd: set rfbversion to: %d.%d\n", maj, min);
- } else {
- rfbLog("remote_cmd: invalid rfbversion: %s\n", p);
- }
- goto done;
- }
- if (!strcmp(p, "deny") || !strcmp(p, "lock")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, deny_all);
- goto qry;
- }
- rfbLog("remote_cmd: denying new connections.\n");
- deny_all = 1;
- goto done;
- }
- if (!strcmp(p, "nodeny") || !strcmp(p, "unlock")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !deny_all);
- goto qry;
- }
- rfbLog("remote_cmd: allowing new connections.\n");
- deny_all = 0;
- goto done;
- }
- if (!strcmp(p, "avahi") || !strcmp(p, "mdns") || !strcmp(p, "zeroconf")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, avahi);
- goto qry;
- }
- rfbLog("remote_cmd: enable -avahi mDNS mode.\n");
- if (!avahi) {
- avahi = 1;
- avahi_initialise();
- avahi_advertise(vnc_desktop_name, this_host(),
- screen->port);
- }
- goto done;
- }
- if (!strcmp(p, "noavahi") || !strcmp(p, "nomdns") || !strcmp(p, "nozeroconf")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !avahi);
- goto qry;
- }
- rfbLog("remote_cmd: disable -avahi mDNS mode.\n");
- if (avahi) {
- avahi = 0;
- avahi_reset();
- }
- goto done;
- }
- if (strstr(p, "connect") == p) {
- NOTAPP
- COLON_CHECK("connect:")
- p += strlen("connect:");
- /* this is a reverse connection */
- reverse_connect(p);
- goto done;
- }
- if (strstr(p, "proxy") == p) {
- COLON_CHECK("proxy:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(connect_proxy));
- goto qry;
- }
- p += strlen("proxy:");
- if (connect_proxy) {
- free(connect_proxy);
- connect_proxy = NULL;
- }
- if (!strcmp(p, "") || !strcasecmp(p, "none")) { /* skip-cmd-list */
- rfbLog("remote_cmd: disabled -proxy\n");
- } else {
- connect_proxy = strdup(p);
- rfbLog("remote_cmd: set -proxy %s\n", connect_proxy);
- }
- goto done;
- }
- if (strstr(p, "allowonce") == p) {
- COLON_CHECK("allowonce:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(allow_once));
- goto qry;
- }
- p += strlen("allowonce:");
- allow_once = strdup(p);
- rfbLog("remote_cmd: set allow_once %s\n", allow_once);
- goto done;
- }
- if (strstr(p, "allow") == p) {
- char *before, *old;
- COLON_CHECK("allow:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(allow_list));
- goto qry;
- }
-
- if (unixpw) {
- rfbLog("remote_cmd: cannot change allow in -unixpw\n");
- goto done;
- }
- p += strlen("allow:");
- if (allow_list && strchr(allow_list, '/')) {
- rfbLog("remote_cmd: cannot use allow:host\n");
- rfbLog("in '-allow %s' mode.\n", allow_list);
- goto done;
- }
- if (allow_list) {
- before = strdup(allow_list);
- } else {
- before = strdup("");
- }
-
- old = allow_list;
- if (*p == '+') {
- p++;
- allow_list = add_item(allow_list, p);
- } else if (*p == '-') {
- p++;
- allow_list = delete_item(allow_list, p);
- } else {
- allow_list = strdup(p);
- }
-
- if (strcmp(before, allow_list)) {
- rfbLog("remote_cmd: modified allow_list:\n");
- rfbLog(" from: \"%s\"\n", before);
- rfbLog(" to: \"%s\"\n", allow_list);
- }
- if (old) free(old);
- free(before);
- goto done;
- }
- if (!strcmp(p, "noipv6")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, noipv6);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -noipv6 mode for future sockets.\n");
- noipv6 = 1;
- goto done;
- }
- if (!strcmp(p, "ipv6")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !noipv6);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -noipv6 mode for future sockets.\n");
- noipv6 = 0;
- goto done;
- }
- if (!strcmp(p, "noipv4")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, noipv4);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -noipv4 mode for future sockets.\n");
- noipv4 = 1;
- goto done;
- }
- if (!strcmp(p, "ipv4")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !noipv4);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -noipv4 mode for future sockets.\n");
- noipv4 = 0;
- goto done;
- }
- if (!strcmp(p, "no6")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ipv6_listen);
- goto qry;
- }
- if (ipv6_listen) {
- ipv6_listen = 0;
- rfbLog("disabling -6 IPv6 listening mode.\n");
- reset_rfbport(-1, screen->port);
- reset_httpport(-1, screen->httpPort);
- if (https_port_num > 0) {
- https_port(1);
- }
- }
- goto done;
- }
- if (!strcmp(p, "6")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ipv6_listen);
- goto qry;
- }
- if (!ipv6_listen) {
- ipv6_listen = 1;
- rfbLog("enabling -6 IPv6 listening mode.\n");
- reset_rfbport(-1, screen->port);
- reset_httpport(-1, screen->httpPort);
- if (https_port_num > 0) {
- https_port(1);
- }
- }
- goto done;
- }
- if (!strcmp(p, "localhost")) {
- char *before, *old;
- if (query) {
- int state = 0;
- char *s = allow_list;
- if (s && (!strcmp(s, "127.0.0.1") ||
- !strcmp(s, "localhost"))) {
- state = 1;
- }
- snprintf(buf, bufn, "ans=%s:%d", p, state);
- goto qry;
- }
- if (allow_list) {
- before = strdup(allow_list);
- } else {
- before = strdup("");
- }
- old = allow_list;
-
- allow_list = strdup("127.0.0.1");
-
- if (strcmp(before, allow_list)) {
- rfbLog("remote_cmd: modified allow_list:\n");
- rfbLog(" from: \"%s\"\n", before);
- rfbLog(" to: \"%s\"\n", allow_list);
- }
- if (old) free(old);
- free(before);
-
- if (listen_str) {
- free(listen_str);
- }
- listen_str = strdup("localhost");
-
- /* mutex */
- screen->listenInterface = htonl(INADDR_LOOPBACK);
- rfbLog("listening on loopback network only.\n");
- rfbLog("allow list is: '%s'\n", NONUL(allow_list));
- reset_rfbport(-1, screen->port);
- reset_httpport(-1, screen->httpPort);
- goto done;
- }
- if (!strcmp(p, "nolocalhost")) {
- char *before, *old;
- if (query) {
- int state = 0;
- char *s = allow_list;
- if (s && (!strcmp(s, "127.0.0.1") ||
- !strcmp(s, "localhost"))) {
- state = 1;
- }
- snprintf(buf, bufn, "ans=%s:%d", p, !state);
- goto qry;
- }
- if (unixpw) {
- rfbLog("remote_cmd: cannot change localhost in -unixpw\n");
- goto done;
- }
- if (allow_list) {
- before = strdup(allow_list);
- } else {
- before = strdup("");
- }
- old = allow_list;
-
- allow_list = strdup("");
-
- if (strcmp(before, allow_list)) {
- rfbLog("remote_cmd: modified allow_list:\n");
- rfbLog(" from: \"%s\"\n", before);
- rfbLog(" to: \"%s\"\n", allow_list);
- }
- if (old) free(old);
- free(before);
-
- if (listen_str) {
- free(listen_str);
- }
- listen_str = NULL;
-
- /* mutex */
- screen->listenInterface = htonl(INADDR_ANY);
- rfbLog("listening on ALL network interfaces.\n");
- rfbLog("allow list is: '%s'\n", NONUL(allow_list));
- reset_rfbport(-1, screen->port);
- reset_httpport(-1, screen->httpPort);
- goto done;
- }
- if (strstr(p, "listen") == p) {
- char *before;
- int ok, mod = 0;
-
- COLON_CHECK("listen:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(listen_str));
- goto qry;
- }
- if (unixpw) {
- rfbLog("remote_cmd: cannot change listen in -unixpw\n");
- goto done;
- }
- if (listen_str) {
- before = strdup(listen_str);
- } else {
- before = strdup("");
- }
- p += strlen("listen:");
-
- listen_str = strdup(p);
-
- if (strcmp(before, listen_str)) {
- rfbLog("remote_cmd: modified listen_str:\n");
- rfbLog(" from: \"%s\"\n", before);
- rfbLog(" to: \"%s\"\n", listen_str);
- mod = 1;
- }
-
- ok = 1;
- /* mutex */
- if (listen_str == NULL || *listen_str == '\0' ||
- !strcmp(listen_str, "any")) {
- screen->listenInterface = htonl(INADDR_ANY);
- } else if (!strcmp(listen_str, "localhost")) {
- screen->listenInterface = htonl(INADDR_LOOPBACK);
- } else {
- struct hostent *hp;
- in_addr_t iface = inet_addr(listen_str);
- if (iface == htonl(INADDR_NONE)) {
- if (!host_lookup) {
- ok = 0;
- } else if (!(hp = gethostbyname(listen_str))) {
- ok = 0;
- } else {
- iface = *(unsigned long *)hp->h_addr;
- }
- }
- if (ok) {
- screen->listenInterface = iface;
- }
- }
-
- if (ok && mod) {
- int is_loopback = 0;
- in_addr_t iface = screen->listenInterface;
-
- if (allow_list) {
- if (!strcmp(allow_list, "127.0.0.1") ||
- !strcmp(allow_list, "localhost")) {
- is_loopback = 1;
- }
- }
- if (iface != htonl(INADDR_LOOPBACK)) {
- if (is_loopback) {
- rfbLog("re-setting -allow list to all "
- "hosts for non-loopback listening.\n");
- if (allow_list) {
- free(allow_list);
- }
- allow_list = NULL;
- }
- } else {
- if (!is_loopback) {
- if (allow_list) {
- free(allow_list);
- }
- rfbLog("setting -allow list to 127.0.0.1\n");
- allow_list = strdup("127.0.0.1");
- }
- }
- }
- if (ok) {
- rfbLog("allow list is: '%s'\n", NONUL(allow_list));
- reset_rfbport(-1, screen->port);
- reset_httpport(-1, screen->httpPort);
- free(before);
- } else {
- rfbLog("invalid listen string: %s\n", listen_str);
- free(listen_str);
- listen_str = before;
- }
- goto done;
- }
- if (!strcmp(p, "lookup")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, host_lookup);
- goto qry;
- }
- rfbLog("remote_cmd: enabling hostname lookup.\n");
- host_lookup = 1;
- goto done;
- }
- if (!strcmp(p, "nolookup")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !host_lookup);
- goto qry;
- }
- rfbLog("remote_cmd: disabling hostname lookup.\n");
- host_lookup = 0;
- goto done;
- }
- if (strstr(p, "accept") == p) {
- int doit = 1, safe = 0;
- COLON_CHECK("accept:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(accept_cmd));
- goto qry;
- }
- p += strlen("accept:");
- if (!strcmp(p, "") || strstr(p, "popup") == p) { /* skip-cmd-list */
- safe = 1;
- }
- if (safe_remote_only && ! safe) {
- rfbLog("unsafe: %s\n", p);
- doit = 0;
- }
-
- if (doit) {
- if (accept_cmd) free(accept_cmd);
- accept_cmd = strdup(p);
- }
- goto done;
- }
- if (strstr(p, "afteraccept") == p) {
- int safe = 0;
- COLON_CHECK("afteraccept:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(afteraccept_cmd));
- goto qry;
- }
- p += strlen("afteraccept:");
- if (!strcmp(p, "")) { /* skip-cmd-list */
- safe = 1;
- }
- if (safe_remote_only && ! safe) {
- rfbLog("unsafe: %s\n", p);
- } else {
- if (afteraccept_cmd) free(afteraccept_cmd);
- afteraccept_cmd = strdup(p);
- }
- goto done;
- }
- if (strstr(p, "gone") == p) {
- int safe = 0;
- COLON_CHECK("gone:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(gone_cmd));
- goto qry;
- }
- p += strlen("gone:");
- if (!strcmp(p, "") || strstr(p, "popup") == p) { /* skip-cmd-list */
- safe = 1;
- }
- if (safe_remote_only && ! safe) {
- rfbLog("unsafe: %s\n", p);
- } else {
- if (gone_cmd) free(gone_cmd);
- gone_cmd = strdup(p);
- }
- goto done;
- }
- if (!strcmp(p, "shm")) {
- int orig = using_shm;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, using_shm);
- goto qry;
- }
- rfbLog("remote_cmd: turning off noshm mode.\n");
- using_shm = 1;
- if (raw_fb) set_raw_fb_params(0);
-
- if (orig != using_shm) {
- do_new_fb(1);
- } else {
- rfbLog(" already in shm mode.\n");
- }
- goto done;
- }
- if (!strcmp(p, "noshm")) {
- int orig = using_shm;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !using_shm);
- goto qry;
- }
- rfbLog("remote_cmd: turning on noshm mode.\n");
- using_shm = 0;
- if (orig != using_shm) {
- do_new_fb(1);
- } else {
- rfbLog(" already in noshm mode.\n");
- }
- goto done;
- }
- if (!strcmp(p, "flipbyteorder")) {
- int orig = flip_byte_order;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, flip_byte_order);
- goto qry;
- }
- rfbLog("remote_cmd: turning on flipbyteorder mode.\n");
- flip_byte_order = 1;
- if (orig != flip_byte_order) {
- if (! using_shm || xform24to32) {
- do_new_fb(1);
- } else {
- rfbLog(" using shm, not resetting fb\n");
- }
- }
- goto done;
- }
- if (!strcmp(p, "noflipbyteorder")) {
- int orig = flip_byte_order;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !flip_byte_order);
- goto qry;
- }
- rfbLog("remote_cmd: turning off flipbyteorder mode.\n");
- flip_byte_order = 0;
- if (orig != flip_byte_order) {
- if (! using_shm || xform24to32) {
- do_new_fb(1);
- } else {
- rfbLog(" using shm, not resetting fb\n");
- }
- }
- goto done;
- }
- if (!strcmp(p, "onetile")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, single_copytile);
- goto qry;
- }
- rfbLog("remote_cmd: enable -onetile mode.\n");
- single_copytile = 1;
- goto done;
- }
- if (!strcmp(p, "noonetile")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !single_copytile);
- goto qry;
- }
- rfbLog("remote_cmd: disable -onetile mode.\n");
- if (tile_shm_count < ntiles_x) {
- rfbLog(" this has no effect: tile_shm_count=%d"
- " ntiles_x=%d\n", tile_shm_count, ntiles_x);
-
- }
- single_copytile = 0;
- goto done;
- }
- if (strstr(p, "solid_color") == p) {
- /*
- * n.b. this solid stuff perhaps should reflect
- * safe_remote_only but at least the command names
- * are fixed.
- */
- char *newc;
- int doit = 1;
- COLON_CHECK("solid_color:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(solid_str));
- goto qry;
- }
- p += strlen("solid_color:");
- if (*p != '\0') {
- newc = strdup(p);
- } else {
- newc = strdup(solid_default);
- }
- rfbLog("remote_cmd: solid %s -> %s\n", NONUL(solid_str), newc);
-
- if (solid_str) {
- if (!strcmp(solid_str, newc)) {
- doit = 0;
- }
- free(solid_str);
- }
- solid_str = newc;
- use_solid_bg = 1;
- if (raw_fb && !macosx_console) set_raw_fb_params(0);
-
- if (doit && client_count) {
- solid_bg(0);
- }
- goto done;
- }
- if (!strcmp(p, "solid")) {
- int orig = use_solid_bg;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_solid_bg);
- goto qry;
- }
- rfbLog("remote_cmd: enable -solid mode\n");
- if (! solid_str) {
- solid_str = strdup(solid_default);
- }
- use_solid_bg = 1;
- if (raw_fb && !macosx_console) set_raw_fb_params(0);
- if (client_count && !orig) {
- solid_bg(0);
- }
- goto done;
- }
- if (!strcmp(p, "nosolid")) {
- int orig = use_solid_bg;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_solid_bg);
- goto qry;
- }
- rfbLog("remote_cmd: disable -solid mode\n");
- use_solid_bg = 0;
- if (client_count && orig) {
- solid_bg(1);
- }
- goto done;
- }
- if (strstr(p, "blackout") == p) {
- char *before, *old;
- COLON_CHECK("blackout:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(blackout_str));
- goto qry;
- }
- p += strlen("blackout:");
- if (blackout_str) {
- before = strdup(blackout_str);
- } else {
- before = strdup("");
- }
- old = blackout_str;
- if (*p == '+') {
- p++;
- blackout_str = add_item(blackout_str, p);
- } else if (*p == '-') {
- p++;
- blackout_str = delete_item(blackout_str, p);
- } else {
- blackout_str = strdup(p);
- }
- if (strcmp(before, blackout_str)) {
- rfbLog("remote_cmd: changing -blackout\n");
- rfbLog(" from: %s\n", before);
- rfbLog(" to: %s\n", blackout_str);
- if (0 && !strcmp(blackout_str, "") &&
- single_copytile_orig != single_copytile) {
- rfbLog("resetting single_copytile to: %d\n",
- single_copytile_orig);
- single_copytile = single_copytile_orig;
- }
- initialize_blackouts_and_xinerama();
- }
- if (old) free(old);
- free(before);
- goto done;
- }
- if (!strcmp(p, "xinerama")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, xinerama);
- goto qry;
- }
- rfbLog("remote_cmd: enable xinerama mode. (if applicable).\n");
- xinerama = 1;
- initialize_blackouts_and_xinerama();
- goto done;
- }
- if (!strcmp(p, "noxinerama")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !xinerama);
- goto qry;
- }
- rfbLog("remote_cmd: disable xinerama mode. (if applicable).\n");
- xinerama = 0;
- initialize_blackouts_and_xinerama();
- goto done;
- }
- if (!strcmp(p, "xtrap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, xtrap_input);
- goto qry;
- }
- rfbLog("remote_cmd: enable xtrap input mode."
- "(if applicable).\n");
- if (! xtrap_input) {
- xtrap_input = 1;
- disable_grabserver(dpy, 1);
- }
- goto done;
- }
- if (!strcmp(p, "noxtrap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !xtrap_input);
- goto qry;
- }
- rfbLog("remote_cmd: disable xtrap input mode."
- "(if applicable).\n");
- if (xtrap_input) {
- xtrap_input = 0;
- disable_grabserver(dpy, 1);
- }
- goto done;
- }
- if (!strcmp(p, "xrandr")) {
- int orig = xrandr;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, xrandr); goto qry;
- }
- if (xrandr_present) {
- rfbLog("remote_cmd: enable xrandr mode.\n");
- xrandr = 1;
- if (raw_fb) set_raw_fb_params(0);
- if (! xrandr_mode) {
- xrandr_mode = strdup("default");
- }
- if (orig != xrandr) {
- initialize_xrandr();
- }
- } else {
- rfbLog("remote_cmd: XRANDR ext. not present.\n");
- }
- goto done;
- }
- if (!strcmp(p, "noxrandr")) {
- int orig = xrandr;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !xrandr); goto qry;
- }
- xrandr = 0;
- xrandr_maybe = 0;
- if (xrandr_present) {
- rfbLog("remote_cmd: disable xrandr mode.\n");
- if (orig != xrandr) {
- initialize_xrandr();
- }
- } else {
- rfbLog("remote_cmd: XRANDR ext. not present.\n");
- }
- goto done;
- }
- if (strstr(p, "xrandr_mode") == p) {
- int orig = xrandr;
- COLON_CHECK("xrandr_mode:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(xrandr_mode));
- goto qry;
- }
- p += strlen("xrandr_mode:");
- if (!strcmp("none", p)) {
- xrandr = 0;
- xrandr_maybe = 0;
- } else {
- if (known_xrandr_mode(p)) {
- if (xrandr_mode) free(xrandr_mode);
- xrandr_mode = strdup(p);
- } else {
- rfbLog("skipping unknown xrandr mode: %s\n", p);
- goto done;
- }
- xrandr = 1;
- }
- if (xrandr_present) {
- if (xrandr) {
- rfbLog("remote_cmd: enable xrandr mode.\n");
- } else {
- rfbLog("remote_cmd: disable xrandr mode.\n");
- }
- if (! xrandr_mode) {
- xrandr_mode = strdup("default");
- }
- if (orig != xrandr) {
- initialize_xrandr();
- }
- } else {
- rfbLog("remote_cmd: XRANDR ext. not present.\n");
- }
- goto done;
- }
- if (strstr(p, "rotate") == p) {
- COLON_CHECK("rotate:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(rotating_str));
- goto qry;
- }
- p += strlen("rotate:");
- if (rotating_str) free(rotating_str);
- rotating_str = strdup(p);
- rfbLog("remote_cmd: set rotate to \"%s\"\n", rotating_str);
-
- do_new_fb(0);
- goto done;
- }
- if (strstr(p, "padgeom") == p) {
- COLON_CHECK("padgeom:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(pad_geometry));
- goto qry;
- }
- p += strlen("padgeom:");
- if (!strcmp("force", p) || !strcmp("do",p) || !strcmp("go",p)) {
- rfbLog("remote_cmd: invoking install_padded_fb()\n");
- install_padded_fb(pad_geometry);
- } else {
- if (pad_geometry) free(pad_geometry);
- pad_geometry = strdup(p);
- rfbLog("remote_cmd: set padgeom to: %s\n",
- pad_geometry);
- }
- goto done;
- }
- if (!strcmp(p, "quiet") || !strcmp(p, "q")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, quiet); goto qry;
- }
- rfbLog("remote_cmd: turning on quiet mode.\n");
- quiet = 1;
- goto done;
- }
- if (!strcmp(p, "noquiet")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !quiet); goto qry;
- }
- rfbLog("remote_cmd: turning off quiet mode.\n");
- quiet = 0;
- goto done;
- }
- if (!strcmp(p, "modtweak")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_modifier_tweak);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -modtweak mode.\n");
- if (! use_modifier_tweak) {
- use_modifier_tweak = 1;
- initialize_modtweak();
- }
- use_modifier_tweak = 1;
- goto done;
- }
- if (!strcmp(p, "nomodtweak")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !use_modifier_tweak);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -nomodtweak mode.\n");
- got_nomodtweak = 1;
- use_modifier_tweak = 0;
- goto done;
- }
- if (!strcmp(p, "xkb")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_xkb_modtweak);
- goto qry;
- }
- if (! xkb_present) {
- rfbLog("remote_cmd: cannot enable -xkb "
- "modtweak mode (not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: enabling -xkb modtweak mode"
- " (if supported).\n");
- if (! use_modifier_tweak || ! use_xkb_modtweak) {
- use_modifier_tweak = 1;
- use_xkb_modtweak = 1;
- initialize_modtweak();
- }
- use_modifier_tweak = 1;
- use_xkb_modtweak = 1;
- goto done;
- }
- if (!strcmp(p, "noxkb")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_xkb_modtweak);
- goto qry;
- }
- if (! xkb_present) {
- rfbLog("remote_cmd: cannot disable -xkb "
- "modtweak mode (not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: disabling -xkb modtweak mode.\n");
- use_xkb_modtweak = 0;
- got_noxkb = 1;
- initialize_modtweak();
- goto done;
- }
- if (!strcmp(p, "capslock")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_capslock);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -capslock mode\n");
- watch_capslock = 1;
- goto done;
- }
- if (!strcmp(p, "nocapslock")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_capslock);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -capslock mode\n");
- watch_capslock = 0;
- goto done;
- }
- if (!strcmp(p, "skip_lockkeys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, skip_lockkeys);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -skip_lockkeys mode\n");
- skip_lockkeys = 1;
- goto done;
- }
- if (!strcmp(p, "noskip_lockkeys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !skip_lockkeys);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -skip_lockkeys mode\n");
- skip_lockkeys = 0;
- goto done;
- }
- if (strstr(p, "skip_keycodes") == p) {
- COLON_CHECK("skip_keycodes:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(skip_keycodes));
- goto qry;
- }
- p += strlen("skip_keycodes:");
- rfbLog("remote_cmd: setting xkb -skip_keycodes"
- " to:\n\t'%s'\n", p);
- if (! xkb_present) {
- rfbLog("remote_cmd: warning xkb not present\n");
- } else if (! use_xkb_modtweak) {
- rfbLog("remote_cmd: turning on xkb.\n");
- use_xkb_modtweak = 1;
- if (! use_modifier_tweak) {
- rfbLog("remote_cmd: turning on modtweak.\n");
- use_modifier_tweak = 1;
- }
- }
- if (skip_keycodes) free(skip_keycodes);
- skip_keycodes = strdup(p);
- initialize_modtweak();
- goto done;
- }
- if (!strcmp(p, "sloppy_keys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, sloppy_keys);
- goto qry;
- }
- sloppy_keys += 1;
- rfbLog("remote_cmd: set sloppy_keys to: %d\n", sloppy_keys);
- goto done;
- }
- if (!strcmp(p, "nosloppy_keys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !sloppy_keys);
- goto qry;
- }
- sloppy_keys = 0;
- rfbLog("remote_cmd: set sloppy_keys to: %d\n", sloppy_keys);
- goto done;
- }
- if (!strcmp(p, "skip_dups")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- skip_duplicate_key_events);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -skip_dups mode\n");
- skip_duplicate_key_events = 1;
- goto done;
- }
- if (!strcmp(p, "noskip_dups")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !skip_duplicate_key_events);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -skip_dups mode\n");
- skip_duplicate_key_events = 0;
- goto done;
- }
- if (!strcmp(p, "add_keysyms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, add_keysyms);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -add_keysyms mode.\n");
- add_keysyms = 1;
- goto done;
- }
- if (!strcmp(p, "noadd_keysyms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !add_keysyms);
- goto qry;
- }
- rfbLog("remote_cmd: disabling -add_keysyms mode.\n");
- add_keysyms = 0;
- goto done;
- }
- if (!strcmp(p, "clear_mods")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, clear_mods == 1);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -clear_mods mode.\n");
- clear_mods = 1;
- if (use_threads) {X_LOCK;}
- clear_modifiers(0);
- if (use_threads) {X_UNLOCK;}
- goto done;
- }
- if (!strcmp(p, "noclear_mods")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !(clear_mods == 1));
- goto qry;
- }
- rfbLog("remote_cmd: disabling -clear_mods mode.\n");
- clear_mods = 0;
- goto done;
- }
- if (!strcmp(p, "clear_keys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- clear_mods == 2);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -clear_keys mode.\n");
- clear_mods = 2;
- if (use_threads) {X_LOCK;}
- clear_keys();
- if (use_threads) {X_UNLOCK;}
- goto done;
- }
- if (!strcmp(p, "noclear_keys")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !(clear_mods == 2));
- goto qry;
- }
- rfbLog("remote_cmd: disabling -clear_keys mode.\n");
- clear_mods = 0;
- goto done;
- }
- if (!strcmp(p, "clear_all")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- clear_mods == 3);
- goto qry;
- }
- rfbLog("remote_cmd: doing clear_all action.\n");
- clear_mods = 3;
- if (use_threads) {X_LOCK;}
- clear_keys();
- clear_locks();
- if (use_threads) {X_UNLOCK;}
- goto done;
- }
- if (!strcmp(p, "clear_locks")) {
- NOTAPP
- rfbLog("remote_cmd: doing clear_locks action.\n");
- if (use_threads) {X_LOCK;}
- clear_locks();
- if (use_threads) {X_UNLOCK;}
- goto done;
- }
- if (!strcmp(p, "keystate")) {
- int i, state[256];
- NOTAPP
- for (i=0; i<256; i++) {
- state[i] = 0;
- }
- if (use_threads) {X_LOCK;}
- get_keystate(state);
- if (use_threads) {X_UNLOCK;}
- for (i=0; i<256; i++) {
- fprintf(stderr, "keystate[%03d] %d\n", i, state[i]);
- }
- goto done;
- }
- if (strstr(p, "remap") == p) {
- char *before, *old;
- COLON_CHECK("remap:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(remap_file));
- goto qry;
- }
- p += strlen("remap:");
- if ((*p == '+' || *p == '-') && remap_file &&
- strchr(remap_file, '/')) {
- rfbLog("remote_cmd: cannot use remap:+/-\n");
- rfbLog("in '-remap %s' mode.\n", remap_file);
- goto done;
- }
- if (remap_file) {
- before = strdup(remap_file);
- } else {
- before = strdup("");
- }
- old = remap_file;
- if (*p == '+') {
- p++;
- remap_file = add_item(remap_file, p);
- } else if (*p == '-') {
- p++;
- remap_file = delete_item(remap_file, p);
- if (! strchr(remap_file, '-')) {
- *remap_file = '\0';
- }
- } else {
- remap_file = strdup(p);
- }
- if (strcmp(before, remap_file)) {
- rfbLog("remote_cmd: changed -remap\n");
- rfbLog(" from: %s\n", before);
- rfbLog(" to: %s\n", remap_file);
- initialize_remap(remap_file);
- }
- if (old) free(old);
- free(before);
- goto done;
- }
- if (!strcmp(p, "repeat")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !no_autorepeat);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -repeat mode.\n");
- autorepeat(1, 0); /* restore initial setting */
- no_autorepeat = 0;
- goto done;
- }
- if (!strcmp(p, "norepeat")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, no_autorepeat);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -norepeat mode.\n");
- no_autorepeat = 1;
- if (no_repeat_countdown >= 0) {
- no_repeat_countdown = 2;
- }
- if (client_count && ! view_only) {
- autorepeat(0, 0); /* disable if any clients */
- }
- goto done;
- }
- if (!strcmp(p, "fb")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !nofb);
- goto qry;
- }
- if (nofb) {
- rfbLog("remote_cmd: disabling nofb mode.\n");
- rfbLog(" you may need to these turn back on:\n");
- rfbLog(" xfixes, xdamage, solid, flashcmap\n");
- rfbLog(" overlay, shm, noonetile, nap, cursor\n");
- rfbLog(" cursorpos, cursorshape, bell.\n");
- nofb = 0;
- set_nofb_params(1);
- do_new_fb(1);
- }
- goto done;
- }
- if (!strcmp(p, "nofb")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, nofb);
- goto qry;
- }
- if (!nofb) {
- rfbLog("remote_cmd: enabling nofb mode.\n");
- if (main_fb) {
- push_black_screen(4);
- }
- nofb = 1;
- sound_bell = 0;
- initialize_watch_bell();
- set_nofb_params(0);
- do_new_fb(1);
- }
- goto done;
- }
- if (!strcmp(p, "bell")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, sound_bell);
- goto qry;
- }
- rfbLog("remote_cmd: enabling bell (if supported).\n");
- initialize_watch_bell();
- sound_bell = 1;
- goto done;
- }
- if (!strcmp(p, "nobell")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !sound_bell);
- goto qry;
- }
- rfbLog("remote_cmd: disabling bell.\n");
- initialize_watch_bell();
- sound_bell = 0;
- goto done;
- }
- if (!strcmp(p, "sendbell")) {
- NOTAPP
- rfbLog("remote_cmd: sendbell.\n");
- if (screen && client_count) {
- rfbSendBell(screen);
- }
- goto done;
- }
- if (!strcmp(p, "sel")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_selection);
- goto qry;
- }
- rfbLog("remote_cmd: enabling watch selection+primary.\n");
- watch_selection = 1;
- watch_primary = 1;
- watch_clipboard = 1;
- goto done;
- }
- if (!strcmp(p, "nosel")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_selection);
- goto qry;
- }
- rfbLog("remote_cmd: disabling watch selection+primary.\n");
- watch_selection = 0;
- watch_primary = 0;
- watch_clipboard = 0;
- goto done;
- }
- if (!strcmp(p, "primary")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_primary);
- goto qry;
- }
- rfbLog("remote_cmd: enabling watch_primary.\n");
- watch_primary = 1;
- goto done;
- }
- if (!strcmp(p, "noprimary")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_primary);
- goto qry;
- }
- rfbLog("remote_cmd: disabling watch_primary.\n");
- watch_primary = 0;
- goto done;
- }
- if (!strcmp(p, "setprimary")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, set_primary);
- goto qry;
- }
- rfbLog("remote_cmd: enabling set_primary.\n");
- set_primary = 1;
- goto done;
- }
- if (!strcmp(p, "nosetprimary")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !set_primary);
- goto qry;
- }
- rfbLog("remote_cmd: disabling set_primary.\n");
- set_primary = 0;
- goto done;
- }
- if (!strcmp(p, "clipboard")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_clipboard);
- goto qry;
- }
- rfbLog("remote_cmd: enabling watch_clipboard.\n");
- watch_clipboard = 1;
- goto done;
- }
- if (!strcmp(p, "noclipboard")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_clipboard);
- goto qry;
- }
- rfbLog("remote_cmd: disabling watch_clipboard.\n");
- watch_clipboard = 0;
- goto done;
- }
- if (!strcmp(p, "setclipboard")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, set_clipboard);
- goto qry;
- }
- rfbLog("remote_cmd: enabling set_clipboard.\n");
- set_clipboard = 1;
- goto done;
- }
- if (!strcmp(p, "nosetclipboard")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !set_clipboard);
- goto qry;
- }
- rfbLog("remote_cmd: disabling set_clipboard.\n");
- set_clipboard = 0;
- goto done;
- }
- if (strstr(p, "seldir") == p) {
- COLON_CHECK("seldir:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(sel_direction));
- goto qry;
- }
- p += strlen("seldir:");
- rfbLog("remote_cmd: setting -seldir to %s\n", p);
- if (sel_direction) free(sel_direction);
- sel_direction = strdup(p);
- goto done;
- }
- if (!strcmp(p, "set_no_cursor")) { /* skip-cmd-list */
- rfbLog("remote_cmd: calling set_no_cursor()\n");
- set_no_cursor();
- goto done;
- }
- if (!strcmp(p, "cursorshape")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- cursor_shape_updates);
- goto qry;
- }
- rfbLog("remote_cmd: turning on cursorshape mode.\n");
-
- set_no_cursor();
- cursor_shape_updates = 1;
- restore_cursor_shape_updates(screen);
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "nocursorshape")) {
- int i, max = 5;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !cursor_shape_updates);
- goto qry;
- }
- rfbLog("remote_cmd: turning off cursorshape mode.\n");
-
- set_no_cursor();
- for (i=0; i<max; i++) {
- /* XXX: try to force empty cursor back to client */
- rfbPE(-1);
- }
- cursor_shape_updates = 0;
- disable_cursor_shape_updates(screen);
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "cursorpos")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- cursor_pos_updates);
- goto qry;
- }
- rfbLog("remote_cmd: turning on cursorpos mode.\n");
- cursor_pos_updates = 1;
- goto done;
- }
- if (!strcmp(p, "nocursorpos")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !cursor_pos_updates);
- goto qry;
- }
- rfbLog("remote_cmd: turning off cursorpos mode.\n");
- cursor_pos_updates = 0;
- goto done;
- }
- if (!strcmp(p, "cursor_drag")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, cursor_drag_changes);
- goto qry;
- }
- cursor_drag_changes = 1;
- rfbLog("remote_cmd: setting cursor_drag_changes: %d.\n", cursor_drag_changes);
- goto done;
- }
- if (!strcmp(p, "nocursor_drag")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !cursor_drag_changes);
- goto qry;
- }
- cursor_drag_changes = 0;
- rfbLog("remote_cmd: setting cursor_drag_changes: %d.\n", cursor_drag_changes);
- goto done;
- }
- if (strstr(p, "cursor") == p) {
- COLON_CHECK("cursor:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(multiple_cursors_mode));
- goto qry;
- }
- p += strlen("cursor:");
- if (multiple_cursors_mode) {
- if (prev_cursors_mode) free(prev_cursors_mode);
- prev_cursors_mode = strdup(multiple_cursors_mode);
- free(multiple_cursors_mode);
- }
- multiple_cursors_mode = strdup(p);
-
- rfbLog("remote_cmd: changed -cursor mode "
- "to: %s\n", multiple_cursors_mode);
-
- if (strcmp(multiple_cursors_mode, "none") && !show_cursor) {
- show_cursor = 1;
- rfbLog("remote_cmd: changed show_cursor "
- "to: %d\n", show_cursor);
- }
- initialize_cursors_mode();
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "show_cursor")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, show_cursor);
- goto qry;
- }
- rfbLog("remote_cmd: enabling show_cursor.\n");
- show_cursor = 1;
- if (multiple_cursors_mode && !strcmp(multiple_cursors_mode,
- "none")) {
- free(multiple_cursors_mode);
- if (prev_cursors_mode) {
- multiple_cursors_mode =
- strdup(prev_cursors_mode);
- } else {
- multiple_cursors_mode = strdup("default");
- }
- rfbLog("remote_cmd: changed -cursor mode "
- "to: %s\n", multiple_cursors_mode);
- }
- initialize_cursors_mode();
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "noshow_cursor") || !strcmp(p, "nocursor")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !show_cursor);
- goto qry;
- }
- if (prev_cursors_mode) free(prev_cursors_mode);
- prev_cursors_mode = strdup(multiple_cursors_mode);
-
- rfbLog("remote_cmd: disabling show_cursor.\n");
- show_cursor = 0;
- initialize_cursors_mode();
- first_cursor();
- goto done;
- }
- if (strstr(p, "arrow") == p) {
- COLON_CHECK("arrow:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, alt_arrow);
- goto qry;
- }
- p += strlen("arrow:");
- alt_arrow = atoi(p);
- rfbLog("remote_cmd: setting alt_arrow: %d.\n", alt_arrow);
- setup_cursors_and_push();
- goto done;
- }
- if (!strcmp(p, "xfixes")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_xfixes);
- goto qry;
- }
- if (! xfixes_present) {
- rfbLog("remote_cmd: cannot enable xfixes "
- "(not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: enabling -xfixes"
- " (if supported).\n");
- use_xfixes = 1;
- initialize_xfixes();
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "noxfixes")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_xfixes);
- goto qry;
- }
- if (! xfixes_present) {
- rfbLog("remote_cmd: disabling xfixes "
- "(but not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: disabling -xfixes.\n");
- use_xfixes = 0;
- initialize_xfixes();
- first_cursor();
- goto done;
- }
- if (!strcmp(p, "xdamage")) {
- int orig = use_xdamage;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_xdamage);
- goto qry;
- }
- if (! xdamage_present) {
- rfbLog("remote_cmd: cannot enable xdamage hints "
- "(not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: enabling xdamage hints"
- " (if supported).\n");
- use_xdamage = 1;
- if (use_xdamage != orig) {
- initialize_xdamage();
- create_xdamage_if_needed(0);
- }
- goto done;
- }
- if (!strcmp(p, "noxdamage")) {
- int orig = use_xdamage;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_xdamage);
- goto qry;
- }
- if (! xdamage_present) {
- rfbLog("remote_cmd: disabling xdamage hints "
- "(but not supported on X display)\n");
- goto done;
- }
- rfbLog("remote_cmd: disabling xdamage hints.\n");
- use_xdamage = 0;
- if (use_xdamage != orig) {
- initialize_xdamage();
- destroy_xdamage_if_needed();
- }
- goto done;
- }
- if (strstr(p, "xd_area") == p) {
- int a;
- COLON_CHECK("xd_area:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- xdamage_max_area);
- goto qry;
- }
- p += strlen("xd_area:");
- a = atoi(p);
- if (a >= 0) {
- rfbLog("remote_cmd: setting xdamage_max_area "
- "%d -> %d.\n", xdamage_max_area, a);
- xdamage_max_area = a;
- }
- goto done;
- }
- if (strstr(p, "xd_mem") == p) {
- double a;
- COLON_CHECK("xd_mem:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%.3f", p, co,
- xdamage_memory);
- goto qry;
- }
- p += strlen("xd_mem:");
- a = atof(p);
- if (a >= 0.0) {
- rfbLog("remote_cmd: setting xdamage_memory "
- "%.3f -> %.3f.\n", xdamage_memory, a);
- xdamage_memory = a;
- }
- goto done;
- }
- if (strstr(p, "alphacut") == p) {
- int a;
- COLON_CHECK("alphacut:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- alpha_threshold);
- goto qry;
- }
- p += strlen("alphacut:");
- a = atoi(p);
- if (a < 0) a = 0;
- if (a > 256) a = 256; /* allow 256 for testing. */
- if (alpha_threshold != a) {
- rfbLog("remote_cmd: setting alphacut "
- "%d -> %d.\n", alpha_threshold, a);
- if (a == 256) {
- rfbLog("note: alphacut=256 leads to completely"
- " transparent cursors.\n");
- }
- alpha_threshold = a;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "alphafrac") == p) {
- double a;
- COLON_CHECK("alphafrac:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%f", p, co,
- alpha_frac);
- goto qry;
- }
- p += strlen("alphafrac:");
- a = atof(p);
- if (a < 0.0) a = 0.0;
- if (a > 1.0) a = 1.0;
- if (alpha_frac != a) {
- rfbLog("remote_cmd: setting alphafrac "
- "%f -> %f.\n", alpha_frac, a);
- alpha_frac = a;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "alpharemove") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, alpha_remove);
- goto qry;
- }
- if (!alpha_remove) {
- rfbLog("remote_cmd: enable alpharemove\n");
- alpha_remove = 1;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "noalpharemove") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !alpha_remove);
- goto qry;
- }
- if (alpha_remove) {
- rfbLog("remote_cmd: disable alpharemove\n");
- alpha_remove = 0;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "alphablend") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, alpha_blend);
- goto qry;
- }
- if (!alpha_blend) {
- rfbLog("remote_cmd: enable alphablend\n");
- alpha_remove = 0;
- alpha_blend = 1;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "noalphablend") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !alpha_blend);
- goto qry;
- }
- if (alpha_blend) {
- rfbLog("remote_cmd: disable alphablend\n");
- alpha_blend = 0;
- setup_cursors_and_push();
- }
- goto done;
- }
- if (strstr(p, "xwarppointer") == p || strstr(p, "xwarp") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_xwarppointer);
- goto qry;
- }
- rfbLog("remote_cmd: turning on xwarppointer mode.\n");
- use_xwarppointer = 1;
- goto done;
- }
- if (strstr(p, "noxwarppointer") == p ||
- strstr(p, "noxwarp") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_xwarppointer);
- goto qry;
- }
- rfbLog("remote_cmd: turning off xwarppointer mode.\n");
- use_xwarppointer = 0;
- goto done;
- }
- if (strstr(p, "always_inject") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, always_inject);
- goto qry;
- }
- rfbLog("remote_cmd: turning on always_inject mode.\n");
- always_inject = 1;
- goto done;
- }
- if (strstr(p, "noalways_inject") == p) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !always_inject);
- goto qry;
- }
- rfbLog("remote_cmd: turning off always_inject mode.\n");
- always_inject = 0;
- goto done;
- }
- if (strstr(p, "buttonmap") == p) {
- COLON_CHECK("buttonmap:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(pointer_remap));
- goto qry;
- }
- p += strlen("buttonmap:");
- if (pointer_remap) free(pointer_remap);
- pointer_remap = strdup(p);
-
- rfbLog("remote_cmd: setting -buttonmap to:\n\t'%s'\n", p);
- initialize_pointer_map(p);
- goto done;
- }
- if (!strcmp(p, "dragging")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, show_dragging);
- goto qry;
- }
- rfbLog("remote_cmd: enabling mouse dragging mode.\n");
- show_dragging = 1;
- goto done;
- }
- if (!strcmp(p, "nodragging")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !show_dragging);
- goto qry;
- }
- rfbLog("remote_cmd: enabling mouse nodragging mode.\n");
- show_dragging = 0;
- goto done;
- }
-#ifndef NO_NCACHE
- if (!strcmp(p, "ncache_cr")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_copyrect);
- goto qry;
- }
- ncache_copyrect = 1;
- rfbLog("remote_cmd: set -ncache_cr %d\n", ncache_copyrect);
- goto done;
- }
- if (!strcmp(p, "noncache_cr")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_copyrect);
- goto qry;
- }
- ncache_copyrect = 0;
- rfbLog("remote_cmd: disabled -ncache_cr %d\n", ncache_copyrect);
-
- goto done;
- }
- if (!strcmp(p, "ncache_no_moveraise")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_wf_raises);
- goto qry;
- }
- ncache_wf_raises = 0;
- rfbLog("remote_cmd: set -ncache_no_moveraise\n");
- goto done;
- }
- if (!strcmp(p, "noncache_no_moveraise")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_wf_raises);
- goto qry;
- }
- ncache_wf_raises = 1;
- rfbLog("remote_cmd: disabled -ncache_no_moveraise\n");
- goto done;
- }
- if (!strcmp(p, "ncache_no_dtchange")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_dt_change);
- goto qry;
- }
- ncache_dt_change = 0;
- rfbLog("remote_cmd: set -ncache_no_dt_change\n");
- goto done;
- }
- if (!strcmp(p, "noncache_no_dtchange")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_dt_change);
- goto qry;
- }
- ncache_dt_change = 1;
- rfbLog("remote_cmd: disabled -ncache_no_dt_change\n");
- goto done;
- }
- if (!strcmp(p, "ncache_no_rootpixmap")) {
- int orig = ncache_xrootpmap;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_xrootpmap);
- goto qry;
- }
- ncache_xrootpmap = 0;
- rfbLog("remote_cmd: set -ncache_no_rootpixmap\n");
- if (orig != ncache_xrootpmap) {
- do_new_fb(1);
- }
- goto done;
- }
- if (!strcmp(p, "noncache_no_rootpixmap")) {
- int orig = ncache_xrootpmap;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_xrootpmap);
- goto qry;
- }
- ncache_xrootpmap = 1;
- rfbLog("remote_cmd: disabled -ncache_no_rootpixmap\n");
- if (orig != ncache_xrootpmap) {
- do_new_fb(1);
- }
- goto done;
- }
- if (!strcmp(p, "ncache_reset_rootpixmap") || !strcmp(p, "ncrp")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_xrootpmap);
- goto qry;
- }
- if (ncache_xrootpmap) {
- rfbLog("remote_cmd: resetting root pixmap.\n");
- set_ncache_xrootpmap();
- }
- goto done;
- }
- if (!strcmp(p, "ncache_keep_anims")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_keep_anims);
- goto qry;
- }
- kde_no_animate(0);
- ncache_keep_anims = 1;
- rfbLog("remote_cmd: set -ncache_keep_anims\n");
- goto done;
- }
- if (!strcmp(p, "noncache_keep_anims")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_keep_anims);
- goto qry;
- }
- ncache_keep_anims = 0;
- kde_no_animate(1);
- rfbLog("remote_cmd: disabled -ncache_keep_anims\n");
- goto done;
- }
- if (!strcmp(p, "ncache_old_wm")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncache_old_wm);
- goto qry;
- }
- ncache_old_wm = 1;
- rfbLog("remote_cmd: set -ncache_old_wm\n");
- goto done;
- }
- if (!strcmp(p, "noncache_old_wm")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache_old_wm);
- goto qry;
- }
- ncache_old_wm = 0;
- rfbLog("remote_cmd: disabled -ncache_old_wm\n");
- goto done;
- }
- if (strstr(p, "ncache_pad") == p) {
- int orig = ncache_pad, n;
- COLON_CHECK("ncache_pad:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, ncache_pad);
- goto qry;
- }
- p += strlen("ncache_pad:");
- n = atoi(p);
-
- rfbLog("remote_cmd: setting ncache_pad %d to: %d\n", orig, n);
- goto done;
- }
- if (!strcmp(p, "ncache")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !!ncache);
- goto qry;
- }
- ncache = ncache0;
- rfbLog("remote_cmd: set ncache %d\n", ncache);
- goto done;
- }
- if (!strcmp(p, "noncache")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncache);
- goto qry;
- }
- ncache = 0;
- rfbLog("remote_cmd: disabled ncache %d\n", ncache);
- goto done;
- }
- if (strstr(p, "ncache_size") == p) {
- int orig = ncache, n;
- COLON_CHECK("ncache_size:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, ncache);
- goto qry;
- }
- p += strlen("ncache_size:");
- n = atoi(p);
-
- if (n >= 0 && n != ncache) {
- rfbLog("remote_cmd: setting ncache %d to: %d\n", orig, ncache);
- ncache = n;
- do_new_fb(1);
- if (client_count) {
- check_ncache(1,0);
- }
- }
- goto done;
- }
- if (!strcmp(p, "debug_ncache")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ncdb);
- goto qry;
- }
- ncdb = 1;
- rfbLog("remote_cmd: enabled debug_ncache\n");
- goto done;
- }
- if (!strcmp(p, "nodebug_ncache")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ncdb);
- goto qry;
- }
- ncdb = 0;
- rfbLog("remote_cmd: disabled debug_ncache\n");
- goto done;
- }
-#endif
- if (strstr(p, "wireframe_mode") == p) {
- COLON_CHECK("wireframe_mode:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- wireframe_str ? wireframe_str : WIREFRAME_PARMS);
- goto qry;
- }
- p += strlen("wireframe_mode:");
- if (*p) {
- if (wireframe_str) {
- free(wireframe_str);
- }
- wireframe_str = strdup(p);
- parse_wireframe();
- }
- rfbLog("remote_cmd: enabling -wireframe mode.\n");
- wireframe = 1;
- goto done;
- }
- if (strstr(p, "wireframe:") == p) { /* skip-cmd-list */
- COLON_CHECK("wireframe:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, wireframe);
- goto qry;
- }
- p += strlen("wireframe:");
- if (*p) {
- if (wireframe_str) {
- free(wireframe_str);
- }
- wireframe_str = strdup(p);
- parse_wireframe();
- }
- rfbLog("remote_cmd: enabling -wireframe mode.\n");
- wireframe = 1;
- goto done;
- }
- if (strstr(p, "wf:") == p) { /* skip-cmd-list */
- COLON_CHECK("wf:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, wireframe);
- goto qry;
- }
- p += strlen("wf:");
- if (*p) {
- if (wireframe_str) {
- free(wireframe_str);
- }
- wireframe_str = strdup(p);
- parse_wireframe();
- }
- rfbLog("remote_cmd: enabling -wireframe mode.\n");
- wireframe = 1;
- goto done;
- }
- if (!strcmp(p, "wireframe") || !strcmp(p, "wf")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, wireframe);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -wireframe mode.\n");
- wireframe = 1;
- goto done;
- }
- if (!strcmp(p, "nowireframe") || !strcmp(p, "nowf")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !wireframe);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -nowireframe mode.\n");
- wireframe = 0;
- goto done;
- }
- if (!strcmp(p, "wireframelocal") || !strcmp(p, "wfl")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, wireframe_local);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -wireframelocal mode.\n");
- wireframe_local = 1;
- goto done;
- }
- if (!strcmp(p, "nowireframelocal") || !strcmp(p, "nowfl")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !wireframe_local);
- goto qry;
- }
- rfbLog("remote_cmd: enabling -nowireframelocal mode.\n");
- wireframe_local = 0;
- goto done;
- }
- if (strstr(p, "wirecopyrect") == p) {
- COLON_CHECK("wirecopyrect:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(wireframe_copyrect));
- goto qry;
- }
- p += strlen("wirecopyrect:");
-
- set_wirecopyrect_mode(p);
- rfbLog("remote_cmd: changed -wirecopyrect mode "
- "to: %s\n", NONUL(wireframe_copyrect));
- got_wirecopyrect = 1;
- goto done;
- }
- if (strstr(p, "wcr") == p) {
- COLON_CHECK("wcr:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(wireframe_copyrect));
- goto qry;
- }
- p += strlen("wcr:");
-
- set_wirecopyrect_mode(p);
- rfbLog("remote_cmd: changed -wirecopyrect mode "
- "to: %s\n", NONUL(wireframe_copyrect));
- got_wirecopyrect = 1;
- goto done;
- }
- if (!strcmp(p, "nowirecopyrect") || !strcmp(p, "nowcr")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%s", p,
- NONUL(wireframe_copyrect));
- goto qry;
- }
-
- set_wirecopyrect_mode("never");
- rfbLog("remote_cmd: changed -wirecopyrect mode "
- "to: %s\n", NONUL(wireframe_copyrect));
- goto done;
- }
- if (strstr(p, "scr_area") == p) {
- COLON_CHECK("scr_area:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- scrollcopyrect_min_area);
- goto qry;
- }
- p += strlen("scr_area:");
-
- scrollcopyrect_min_area = atoi(p);
- rfbLog("remote_cmd: changed -scr_area to: %d\n",
- scrollcopyrect_min_area);
- goto done;
- }
- if (strstr(p, "scr_skip") == p) {
- char *s = scroll_skip_str;
- COLON_CHECK("scr_skip:")
- if (!s || *s == '\0') s = scroll_skip_str0;
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co, NONUL(s));
- goto qry;
- }
- p += strlen("scr_skip:");
- if (scroll_skip_str) {
- free(scroll_skip_str);
- }
-
- scroll_skip_str = strdup(p);
- rfbLog("remote_cmd: changed -scr_skip to: %s\n",
- scroll_skip_str);
- initialize_scroll_matches();
- goto done;
- }
- if (strstr(p, "scr_inc") == p) {
- char *s = scroll_good_str;
- if (!s || *s == '\0') s = scroll_good_str0;
- COLON_CHECK("scr_inc:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co, NONUL(s));
- goto qry;
- }
- p += strlen("scr_inc:");
- if (scroll_good_str) {
- free(scroll_good_str);
- }
-
- scroll_good_str = strdup(p);
- rfbLog("remote_cmd: changed -scr_inc to: %s\n",
- scroll_good_str);
- initialize_scroll_matches();
- goto done;
- }
- if (strstr(p, "scr_keys") == p) {
- COLON_CHECK("scr_keys:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(scroll_key_list_str));
- goto qry;
- }
- p += strlen("scr_keys:");
- if (scroll_key_list_str) {
- free(scroll_key_list_str);
- }
-
- scroll_key_list_str = strdup(p);
- rfbLog("remote_cmd: changed -scr_keys to: %s\n",
- scroll_key_list_str);
- initialize_scroll_keys();
- goto done;
- }
- if (strstr(p, "scr_term") == p) {
- char *s = scroll_term_str;
- if (!s || *s == '\0') s = scroll_term_str0;
- COLON_CHECK("scr_term:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co, NONUL(s));
- goto qry;
- }
- p += strlen("scr_term:");
- if (scroll_term_str) {
- free(scroll_term_str);
- }
-
- scroll_term_str = strdup(p);
- rfbLog("remote_cmd: changed -scr_term to: %s\n",
- scroll_term_str);
- initialize_scroll_term();
- goto done;
- }
- if (strstr(p, "scr_keyrepeat") == p) {
- char *s = max_keyrepeat_str;
- if (!s || *s == '\0') s = max_keyrepeat_str0;
- COLON_CHECK("scr_keyrepeat:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co, NONUL(s));
- goto qry;
- }
- p += strlen("scr_keyrepeat:");
- if (max_keyrepeat_str) {
- free(max_keyrepeat_str);
- }
-
- max_keyrepeat_str = strdup(p);
- rfbLog("remote_cmd: changed -scr_keyrepeat to: %s\n",
- max_keyrepeat_str);
- initialize_max_keyrepeat();
- goto done;
- }
- if (strstr(p, "scr_parms") == p) {
- COLON_CHECK("scr_parms:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- scroll_copyrect_str ? scroll_copyrect_str
- : SCROLL_COPYRECT_PARMS);
- goto qry;
- }
- p += strlen("scr_parms:");
- if (*p) {
- if (scroll_copyrect_str) {
- free(scroll_copyrect_str);
- }
- set_scrollcopyrect_mode("always");
- scroll_copyrect_str = strdup(p);
- parse_scroll_copyrect();
- }
- rfbLog("remote_cmd: set -scr_parms %s.\n",
- NONUL(scroll_copyrect_str));
- got_scrollcopyrect = 1;
- goto done;
- }
- if (strstr(p, "scrollcopyrect") == p) {
- COLON_CHECK("scrollcopyrect:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(scroll_copyrect));
- goto qry;
- }
- p += strlen("scrollcopyrect:");
-
- set_scrollcopyrect_mode(p);
- rfbLog("remote_cmd: changed -scrollcopyrect mode "
- "to: %s\n", NONUL(scroll_copyrect));
- got_scrollcopyrect = 1;
- goto done;
- }
- if (!strcmp(p, "scr") ||
- strstr(p, "scr:") == p) { /* skip-cmd-list */
- COLON_CHECK("scr:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(scroll_copyrect));
- goto qry;
- }
- p += strlen("scr:");
-
- set_scrollcopyrect_mode(p);
- rfbLog("remote_cmd: changed -scrollcopyrect mode "
- "to: %s\n", NONUL(scroll_copyrect));
- got_scrollcopyrect = 1;
- goto done;
- }
- if (!strcmp(p, "noscrollcopyrect") || !strcmp(p, "noscr")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%s", p,
- NONUL(scroll_copyrect));
- goto qry;
- }
-
- set_scrollcopyrect_mode("never");
- rfbLog("remote_cmd: changed -scrollcopyrect mode "
- "to: %s\n", NONUL(scroll_copyrect));
- goto done;
- }
- if (strstr(p, "fixscreen") == p) {
- COLON_CHECK("fixscreen:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(screen_fixup_str));
- goto qry;
- }
- p += strlen("fixscreen:");
- if (screen_fixup_str) {
- free(screen_fixup_str);
- }
- screen_fixup_str = strdup(p);
- parse_fixscreen();
- rfbLog("remote_cmd: set -fixscreen %s.\n",
- NONUL(screen_fixup_str));
- goto done;
- }
- if (!strcmp(p, "noxrecord")) {
- int orig = noxrecord;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, noxrecord);
- goto qry;
- }
- noxrecord = 1;
- rfbLog("set noxrecord to: %d\n", noxrecord);
- if (orig != noxrecord) {
- shutdown_xrecord();
- }
- goto done;
- }
- if (!strcmp(p, "xrecord")) {
- int orig = noxrecord;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !noxrecord);
- goto qry;
- }
- noxrecord = 0;
- rfbLog("set noxrecord to: %d\n", noxrecord);
- if (orig != noxrecord) {
- initialize_xrecord();
- }
- goto done;
- }
- if (!strcmp(p, "reset_record")) {
- NOTAPP
- if (use_xrecord) {
- rfbLog("resetting RECORD\n");
- check_xrecord_reset(1);
- } else {
- rfbLog("RECORD is disabled, not resetting.\n");
- }
- goto done;
- }
- if (strstr(p, "pointer_mode") == p) {
- int pm;
- COLON_CHECK("pointer_mode:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, pointer_mode);
- goto qry;
- }
- p += strlen("pointer_mode:");
- pm = atoi(p);
- if (pm < 0 || pm > pointer_mode_max) {
- rfbLog("remote_cmd: pointer_mode out of range:"
- " 1-%d: %d\n", pointer_mode_max, pm);
- } else {
- rfbLog("remote_cmd: setting pointer_mode %d\n", pm);
- pointer_mode = pm;
- }
- goto done;
- }
- if (strstr(p, "pm") == p) {
- int pm;
- COLON_CHECK("pm:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, pointer_mode);
- goto qry;
- }
- p += strlen("pm:");
- pm = atoi(p);
- if (pm < 0 || pm > pointer_mode_max) {
- rfbLog("remote_cmd: pointer_mode out of range:"
- " 1-%d: %d\n", pointer_mode_max, pm);
- } else {
- rfbLog("remote_cmd: setting pointer_mode %d\n", pm);
- pointer_mode = pm;
- }
- goto done;
- }
- if (strstr(p, "input_skip") == p) {
- int is;
- COLON_CHECK("input_skip:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, ui_skip);
- goto qry;
- }
- p += strlen("input_skip:");
- is = atoi(p);
- rfbLog("remote_cmd: setting input_skip %d\n", is);
- ui_skip = is;
- goto done;
- }
- if (!strcmp(p, "allinput")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, all_input);
- goto qry;
- }
- all_input = 1;
- rfbLog("enabled allinput\n");
- if (handle_events_eagerly) {
- rfbLog("disabled input_eagerly\n");
- handle_events_eagerly = 0;
- }
- goto done;
- }
- if (!strcmp(p, "noallinput")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !all_input);
- goto qry;
- }
- all_input = 0;
- rfbLog("disabled allinput\n");
- goto done;
- }
- if (!strcmp(p, "input_eagerly")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, handle_events_eagerly);
- goto qry;
- }
- handle_events_eagerly = 1;
- rfbLog("enabled input_eagerly\n");
- if (all_input) {
- rfbLog("disabled allinput\n");
- all_input = 0;
- }
- goto done;
- }
- if (!strcmp(p, "noinput_eagerly")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !handle_events_eagerly);
- goto qry;
- }
- handle_events_eagerly = 0;
- rfbLog("disabled input_eagerly\n");
- goto done;
- }
- if (strstr(p, "input") == p) {
- int doit = 1;
- COLON_CHECK("input:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(allowed_input_str));
- goto qry;
- }
- p += strlen("input:");
- if (allowed_input_str && !strcmp(p, allowed_input_str)) { /* skip-cmd-list */
- doit = 0;
- }
- rfbLog("remote_cmd: setting input %s\n", p);
- if (allowed_input_str) free(allowed_input_str);
- if (*p == '\0') {
- allowed_input_str = NULL;
- } else {
- allowed_input_str = strdup(p);
- }
- if (doit) {
- initialize_allowed_input();
- }
- goto done;
- }
- if (!strcmp(p, "grabkbd")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, grab_kbd);
- goto qry;
- }
- grab_kbd = 1;
- if (grab_always) {
- adjust_grabs(1, 0);
- }
- rfbLog("enabled grab_kbd\n");
- goto done;
- }
- if (!strcmp(p, "nograbkbd")) {
- int orig = grab_kbd;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !grab_kbd);
- goto qry;
- }
- grab_kbd = 0;
- if (orig && dpy) {
-#if !NO_X11
- X_LOCK;
- XUngrabKeyboard(dpy, CurrentTime);
- X_UNLOCK;
-#endif
- }
- rfbLog("disabled grab_kbd\n");
-
- goto done;
- }
- if (!strcmp(p, "grabptr")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, grab_ptr);
- goto qry;
- }
- grab_ptr = 1;
- if (grab_always) {
- adjust_grabs(1, 0);
- }
- rfbLog("enabled grab_ptr\n");
- goto done;
- }
- if (!strcmp(p, "ungrabboth")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, ungrab_both);
- goto qry;
- }
- ungrab_both = 1;
- rfbLog("enabled ungrab_both\n");
- goto done;
- }
- if (!strcmp(p, "noungrabboth")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !ungrab_both);
- goto qry;
- }
- ungrab_both = 0;
- rfbLog("disabled ungrab_both\n");
- goto done;
- }
- if (!strcmp(p, "nograbptr")) {
- int orig = grab_ptr;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !grab_ptr);
- goto qry;
- }
- grab_ptr = 0;
- if (orig && dpy) {
-#if !NO_X11
- X_LOCK;
- XUngrabPointer(dpy, CurrentTime);
- X_UNLOCK;
-#endif
- }
- rfbLog("disabled grab_ptr\n");
- goto done;
- }
- if (!strcmp(p, "grabalways")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, grab_always);
- goto qry;
- }
- grab_ptr = 1;
- grab_kbd = 1;
- grab_always = 1;
- adjust_grabs(1, 0);
- rfbLog("enabled grab_always\n");
- goto done;
- }
- if (!strcmp(p, "nograbalways")) {
- int orig = grab_always;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !grab_always);
- goto qry;
- }
- grab_ptr = 0;
- grab_kbd = 0;
- grab_always = 0;
- if (orig && dpy) {
-#if !NO_X11
- X_LOCK;
- XUngrabKeyboard(dpy, CurrentTime);
- XUngrabPointer(dpy, CurrentTime);
- X_UNLOCK;
-#endif
- }
- adjust_grabs(0, 0);
- rfbLog("disabled grab_always\n");
- goto done;
- }
- if (strstr(p, "grablocal") == p) {
- COLON_CHECK("grablocal:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- grab_local);
- goto qry;
- }
- p += strlen("grablocal:");
-
- grab_local = atoi(p);
- rfbLog("remote_cmd: changed -grablocal to: %d\n",
- grab_local);
- goto done;
- }
- if (strstr(p, "client_input") == p) {
- NOTAPP
- COLON_CHECK("client_input:")
- p += strlen("client_input:");
- set_client_input(p);
- goto done;
- }
- if (strstr(p, "ssltimeout") == p) {
- int is;
- COLON_CHECK("ssltimeout:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- ssl_timeout_secs);
- goto qry;
- }
- p += strlen("ssltimeout:");
- is = atoi(p);
- rfbLog("remote_cmd: setting ssltimeout: %d\n", is);
- ssl_timeout_secs = is;
- goto done;
- }
- if (strstr(p, "speeds") == p) {
- COLON_CHECK("speeds:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(speeds_str));
- goto qry;
- }
- p += strlen("speeds:");
- if (speeds_str) free(speeds_str);
- speeds_str = strdup(p);
-
- rfbLog("remote_cmd: setting -speeds to:\n\t'%s'\n", p);
- initialize_speeds();
- goto done;
- }
- if (strstr(p, "wmdt") == p) {
- COLON_CHECK("wmdt:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(wmdt_str));
- goto qry;
- }
- p += strlen("wmdt:");
- if (wmdt_str) free(wmdt_str);
- wmdt_str = strdup(p);
-
- rfbLog("remote_cmd: setting -wmdt to: %s\n", p);
- goto done;
- }
- if (!strcmp(p, "debug_pointer") || !strcmp(p, "dp")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_pointer);
- goto qry;
- }
- rfbLog("remote_cmd: turning on debug_pointer.\n");
- debug_pointer = 1;
- goto done;
- }
- if (!strcmp(p, "nodebug_pointer") || !strcmp(p, "nodp")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_pointer);
- goto qry;
- }
- rfbLog("remote_cmd: turning off debug_pointer.\n");
- debug_pointer = 0;
- goto done;
- }
- if (!strcmp(p, "debug_keyboard") || !strcmp(p, "dk")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_keyboard);
- goto qry;
- }
- rfbLog("remote_cmd: turning on debug_keyboard.\n");
- debug_keyboard = 1;
- goto done;
- }
- if (!strcmp(p, "nodebug_keyboard") || !strcmp(p, "nodk")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_keyboard);
- goto qry;
- }
- rfbLog("remote_cmd: turning off debug_keyboard.\n");
- debug_keyboard = 0;
- goto done;
- }
- if (strstr(p, "keycode") == p) {
- int kc, down = -1;
- char *c;
- NOTAPP
- COLON_CHECK("keycode:")
- p += strlen("keycode:");
- kc = atoi(p);
- if (kc < 0) kc = 0;
- kc = kc % 256;
- c = strchr(p, ',');
- if (c) down = atoi(c+1);
- rfbLog("remote_cmd: insert keycode %d down=%d\n", kc, down);
-
- if (macosx_console) {
-#ifdef MACOSX
- if (down == -1) {
- macosxCG_keycode_inject(1, kc);
- usleep(50*1000);
- macosxCG_keycode_inject(0, kc);
- } else {
- macosxCG_keycode_inject(down, kc);
- }
-#endif
- } else {
- X_LOCK;
- if (down == -1) {
- XTestFakeKeyEvent_wr(dpy, kc, 1, CurrentTime);
- usleep(50*1000);
- XTestFakeKeyEvent_wr(dpy, kc, 0, CurrentTime);
- } else {
- XTestFakeKeyEvent_wr(dpy, kc, down, CurrentTime);
- }
- XFlush_wr(dpy);
- X_UNLOCK;
- }
- goto done;
- }
- if (strstr(p, "keysym") == p) {
- int down = -1;
- unsigned int in;
- KeySym ks;
- char *c, *str;
- NOTAPP
- COLON_CHECK("keysym:")
- p += strlen("keysym:");
-
- c = strchr(p, ',');
- if (c) {
- down = atoi(c+1);
- *c = '\0';
- }
-
- if (sscanf(p, "0x%x", &in) == 1) {
- ks = (KeySym) in;
- } else if (sscanf(p, "%u", &in) == 1) {
- ks = (KeySym) in;
- } else if ((ks = XStringToKeysym(p)) != NoSymbol) {
- ;
- } else {
- rfbLog("remote_cmd: bad keysym: %s\n", p);
- goto done;
- }
- str = XKeysymToString(ks);
- str = str ? str : "NoSymbol";
- rfbLog("remote_cmd: insert keysym %s 0x%x '%s' down=%d\n", p, ks, str, down);
- if (down == -1) {
- keyboard(1, ks, NULL);
- usleep(50*1000);
- keyboard(0, ks, NULL);
- } else {
- keyboard(down, ks, NULL);
- }
- goto done;
- }
- if (strstr(p, "ptr") == p) {
- int x, y, m = 0;
- NOTAPP
- COLON_CHECK("ptr:")
- p += strlen("ptr:");
- rfbLog("remote_cmd: insert pointer event: %s\n", p);
- if (sscanf(p, "%d,%d,%d", &x, &y, &m) == 3) {
- pointer_event(m, x, y, NULL);
- } else if (sscanf(p, "%d,%d", &x, &y) == 2) {
- pointer_event(m, x, y, NULL);
- } else {
- rfbLog("remote_cmd: bad ptr:x,y,mask\n");
- }
-
- goto done;
- }
- if (strstr(p, "fakebuttonevent") == p) {
- int mb, down = 0;
- NOTAPP
- COLON_CHECK("fakebuttonevent:")
- p += strlen("fakebuttonevent:");
- rfbLog("remote_cmd: insert fakebuttonevent: %s\n", p);
- if (sscanf(p, "%d,%d", &mb, &down) == 2) {
- X_LOCK;
- rfbLog("remote_cmd: XTestFakeButtonEvent(mb=%d, down=%d)\n", mb, down);
- XTestFakeButtonEvent_wr(dpy, mb, down ? True : False, CurrentTime);
- XFlush_wr(dpy);
- X_UNLOCK;
- }
-
- goto done;
- }
- if (strstr(p, "sleep") == p) {
- NOTAPP
- COLON_CHECK("sleep:")
- p += strlen("sleep:");
- rfbLog("remote_cmd: sleeping: %s\n", p);
- usleep((int) (1.0e+6 * atof(p)));
- rfbLog("remote_cmd: done sleeping.\n");
- goto done;
- }
- if (strstr(p, "get_xprop") == p) {
- char *res;
- unsigned long id;
- Window win = None; /* None implies root in get_xprop() */
-
- /* note we force query and assume the colon is there. */
- query = 1;
- if (strstr(p, "get_xprop:") != p) { /* skip-cmd-list */
- snprintf(buf, bufn, "ans=%s:N/A", p);
- goto qry;
- }
- p += strlen("get_xprop:");
-
- if (strstr(p, "id=") == p) { /* skip-cmd-list */
- p += strlen("id=");
- if (scan_hexdec(p, &id)) {
- win = (Window) id;
- }
- if (strchr(p, ':')) {
- p = strchr(p, ':') + 1;
- }
- }
-
- res = get_xprop(p, win);
- if (res == NULL) {
- res = strdup("NULL");
- }
- snprintf(buf, bufn, "ans=get_xprop:%s:%s", p, res);
- free(res);
-
- goto qry;
- }
- if (strstr(p, "set_xprop") == p) {
- char *q;
- int rc = -2;
- unsigned long id;
- Window win = None; /* None implies root in set_xprop() */
-
- /* note we force query and assume the colon is there. */
- query = 1;
- if (strstr(p, "set_xprop:") != p) { /* skip-cmd-list */
- snprintf(buf, bufn, "ans=%s:N/A", p);
- goto qry;
- }
- p += strlen("set_xprop:");
-
- if (strstr(p, "id=") == p) { /* skip-cmd-list */
- p += strlen("id=");
- if (scan_hexdec(p, &id)) {
- win = (Window) id;
- }
- if (strchr(p, ':')) {
- p = strchr(p, ':') + 1;
- }
- }
-
- q = strchr(p, ':');
- if (q) {
- *q = '\0';
- rc = set_xprop(p, win, q+1);
- *q = ':';
- }
- snprintf(buf, bufn, "ans=set_xprop:%s:%d", p, rc);
-
- goto qry;
- }
- if (strstr(p, "wininfo") == p) {
- char *res, *t = "";
- unsigned long id;
- Window win = None;
- int show_children = 0;
-
- /* note we force query and assume the colon is there. */
- query = 1;
- if (strstr(p, "wininfo:") != p) { /* skip-cmd-list */
- snprintf(buf, bufn, "ans=%s:N/A", p);
- goto qry;
- }
- p += strlen("wininfo:");
-
- if (p[0] == '+') {
- show_children = 1;
- t = "+";
- p++;
- }
- if (!strcmp(p, "root")) { /* skip-cmd-list */
- win = rootwin;
- } else if (scan_hexdec(p, &id)) {
- win = (Window) id;
- }
-
- res = wininfo(win, show_children);
- if (res == NULL) {
- res = strdup("NULL");
- }
- snprintf(buf, bufn, "ans=wininfo:%s%s:%s", t, p, res);
- free(res);
-
- goto qry;
- }
- if (strstr(p, "bcx_xattach") == p) {
- char *res;
- int pg_init = -1, kg_init = -1;
- int try = 0, max_tries = 4;
-
- /* note we force query and assume the colon is there. */
- query = 1;
- if (strstr(p, "bcx_xattach:") != p) { /* skip-cmd-list */
- snprintf(buf, bufn, "ans=%s:N/A", p);
- goto qry;
- }
- p += strlen("bcx_xattach:");
-
- if (strstr(p, "retry=")) { /* skip-cmd-list */
- int n;
- char *q = strstr(p, "retry="); /* skip-cmd-list */
- if (sscanf(q, "retry=%d", &n) == 1) {
- if (n < 0) n = 0;
- max_tries = 1 + n;
- }
- }
-
- try_again:
-
- res = bcx_xattach(p, &pg_init, &kg_init);
- try++;
- if (res == NULL) {
- res = strdup("NULL");
- } else if (strstr(res, "GRAB_FAIL_INIT")) {
- rfbLog("bcx_xattach: failed grab check for '%s': %s. Final state OK, not Retrying.\n", p, res);
- } else if (strstr(res, "GRAB_FAIL") && try < max_tries) {
- rfbLog("bcx_xattach: failed grab check for '%s': %s. Retrying[%d]...\n", p, res, try);
- free(res);
- pointer_event(0, dpy_x/2 + try, dpy_y/2 + try, NULL);
-#if !NO_X11
- X_LOCK;
- XFlush_wr(dpy);
- if (dpy) {
- if (try == 2) {
- XSync(dpy, False);
- } else if (try == 3) {
- XSync(dpy, True);
- }
- }
- X_UNLOCK;
-#endif
- if (try == 1) {
- usleep(250*1000);
- } else if (try <= 4) {
- usleep(try*400*1000);
- } else {
- usleep(4*500*1000);
- }
- goto try_again;
- }
-
- snprintf(buf, bufn, "ans=bcx_xattach:%s:%s", p, res);
- free(res);
-
- goto qry;
- }
- if (strstr(p, "deferupdate") == p) {
- int d;
- COLON_CHECK("deferupdate:")
- if (query) {
- if (!screen) {
- d = defer_update;
- } else {
- d = screen->deferUpdateTime;
- }
- snprintf(buf, bufn, "ans=%s%s%d", p, co, d);
- goto qry;
- }
- p += strlen("deferupdate:");
- d = atoi(p);
- if (d < 0) d = 0;
- rfbLog("remote_cmd: setting defer to %d ms.\n", d);
- defer_update = d;
- /* mutex */
- screen->deferUpdateTime = d;
- got_defer = 1;
- goto done;
- }
- if (strstr(p, "defer") == p) {
- int d;
- COLON_CHECK("defer:")
- if (query) {
- if (!screen) {
- d = defer_update;
- } else {
- d = screen->deferUpdateTime;
- }
- snprintf(buf, bufn, "ans=%s%s%d", p, co, d);
- goto qry;
- }
- p += strlen("defer:");
- d = atoi(p);
- if (d < 0) d = 0;
- rfbLog("remote_cmd: setting defer to %d ms.\n", d);
- defer_update = d;
- /* mutex */
- screen->deferUpdateTime = d;
- got_defer = 1;
- goto done;
- }
- if (strstr(p, "setdefer") == p) {
- COLON_CHECK("setdefer:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, set_defer);
- goto qry;
- }
- p += strlen("setdefer:");
- set_defer = atoi(p);
- rfbLog("remote_cmd: setting set_defer to %d\n", set_defer);
- goto done;
- }
- if (strstr(p, "extra_fbur") == p) {
- COLON_CHECK("extra_fbur:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, extra_fbur);
- goto qry;
- }
- p += strlen("extra_fbur:");
- extra_fbur = atoi(p);
- rfbLog("remote_cmd: setting extra_fbur to %d\n", extra_fbur);
- goto done;
- }
- if (strstr(p, "wait_ui") == p) {
- double w;
- COLON_CHECK("wait_ui:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%.2f", p, co, wait_ui);
- goto qry;
- }
- p += strlen("wait_ui:");
- w = atof(p);
- if (w <= 0) w = 1.0;
- rfbLog("remote_cmd: setting wait_ui factor %.2f -> %.2f\n",
- wait_ui, w);
- wait_ui = w;
- goto done;
- }
- if (!strcmp(p, "wait_bog")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, wait_bog);
- goto qry;
- }
- wait_bog = 1;
- rfbLog("remote_cmd: setting wait_bog to %d\n", wait_bog);
- goto done;
- }
- if (!strcmp(p, "nowait_bog")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !wait_bog);
- goto qry;
- }
- wait_bog = 0;
- rfbLog("remote_cmd: setting wait_bog to %d\n", wait_bog);
- goto done;
- }
- if (strstr(p, "slow_fb") == p) {
- double w;
- COLON_CHECK("slow_fb:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%.2f", p, co, slow_fb);
- goto qry;
- }
- p += strlen("slow_fb:");
- w = atof(p);
- if (w <= 0) w = 0.0;
- rfbLog("remote_cmd: setting slow_fb factor %.2f -> %.2f\n",
- slow_fb, w);
- slow_fb = w;
- goto done;
- }
- if (strstr(p, "xrefresh") == p) {
- double w;
- COLON_CHECK("xrefresh:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%.2f", p, co, xrefresh);
- goto qry;
- }
- p += strlen("xrefresh:");
- w = atof(p);
- if (w <= 0) w = 0.0;
- rfbLog("remote_cmd: setting xrefresh delay %.2f -> %.2f\n",
- xrefresh, w);
- xrefresh = w;
- goto done;
- }
- if (strstr(p, "wait") == p) {
- int w;
- COLON_CHECK("wait:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, waitms);
- goto qry;
- }
- p += strlen("wait:");
- w = atoi(p);
- if (w < 0) w = 0;
- rfbLog("remote_cmd: setting wait %d -> %d ms.\n", waitms, w);
- waitms = w;
- goto done;
- }
- if (strstr(p, "readtimeout") == p) {
- int w, orig = rfbMaxClientWait;
- COLON_CHECK("readtimeout:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- rfbMaxClientWait/1000);
- goto qry;
- }
- p += strlen("readtimeout:");
- w = atoi(p) * 1000;
- if (w <= 0) w = 0;
- rfbLog("remote_cmd: setting rfbMaxClientWait %d -> "
- "%d msec.\n", orig, w);
- rfbMaxClientWait = w;
- goto done;
- }
- if (!strcmp(p, "nap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, take_naps);
- goto qry;
- }
- rfbLog("remote_cmd: turning on nap mode.\n");
- take_naps = 1;
- goto done;
- }
- if (!strcmp(p, "nonap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !take_naps);
- goto qry;
- }
- rfbLog("remote_cmd: turning off nap mode.\n");
- take_naps = 0;
- goto done;
- }
- if (strstr(p, "sb") == p) {
- int w;
- COLON_CHECK("sb:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, screen_blank);
- goto qry;
- }
- p += strlen("sb:");
- w = atoi(p);
- if (w < 0) w = 0;
- rfbLog("remote_cmd: setting screen_blank %d -> %d sec.\n",
- screen_blank, w);
- screen_blank = w;
- goto done;
- }
- if (strstr(p, "screen_blank") == p) {
- int w;
- COLON_CHECK("screen_blank:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, screen_blank);
- goto qry;
- }
- p += strlen("screen_blank:");
- w = atoi(p);
- if (w < 0) w = 0;
- rfbLog("remote_cmd: setting screen_blank %d -> %d sec.\n",
- screen_blank, w);
- screen_blank = w;
- goto done;
- }
- if (!strcmp(p, "fbpm")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_fbpm);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -nofbpm mode.\n");
- watch_fbpm = 0;
- goto done;
- }
- if (!strcmp(p, "nofbpm")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_fbpm);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -nofbpm mode.\n");
- watch_fbpm = 1;
- goto done;
- }
- if (!strcmp(p, "dpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !watch_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -nodpms mode.\n");
- watch_dpms = 0;
- goto done;
- }
- if (!strcmp(p, "nodpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, watch_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -nodpms mode.\n");
- watch_dpms = 1;
- goto done;
- }
- if (!strcmp(p, "clientdpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, client_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -clientdpms mode.\n");
- client_dpms = 1;
- goto done;
- }
- if (!strcmp(p, "noclientdpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !client_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -clientdpms mode.\n");
- client_dpms = 0;
- goto done;
- }
- if (!strcmp(p, "forcedpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, force_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -forcedpms mode.\n");
- force_dpms = 1;
- goto done;
- }
- if (!strcmp(p, "noforcedpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !force_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -forcedpms mode.\n");
- force_dpms = 0;
- goto done;
- }
- if (!strcmp(p, "noserverdpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, no_ultra_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -noserverdpms mode.\n");
- no_ultra_dpms = 1;
- goto done;
- }
- if (!strcmp(p, "serverdpms")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !no_ultra_dpms);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -noserverdpms mode.\n");
- no_ultra_dpms = 0;
- goto done;
- }
- if (!strcmp(p, "noultraext")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, no_ultra_ext);
- goto qry;
- }
- rfbLog("remote_cmd: turning on -noultraext mode.\n");
- no_ultra_ext = 1;
- goto done;
- }
- if (!strcmp(p, "ultraext")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !no_ultra_ext);
- goto qry;
- }
- rfbLog("remote_cmd: turning off -noultraext mode.\n");
- no_ultra_ext = 0;
- goto done;
- }
- if (!strcmp(p, "chatwindow")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, chat_window);
- goto qry;
- }
- rfbLog("remote_cmd: enabling the local chat window.\n");
- chat_window = 1;
- goto done;
- }
- if (!strcmp(p, "nochatwindow")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !chat_window);
- goto qry;
- }
- rfbLog("remote_cmd: disabling the local chat window.\n");
- chat_window = 0;
- goto done;
- }
- if (!strcmp(p, "chaton")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, (chat_window_client != NULL));
- goto qry;
- }
- rfbLog("remote_cmd: turning local chat window on.\n");
- chat_window = 1;
- set_text_chat(NULL, rfbTextChatOpen, "");
- goto done;
- }
- if (!strcmp(p, "chatoff")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, (chat_window_client == NULL));
- goto qry;
- }
- rfbLog("remote_cmd: turning local chat window off.\n");
- set_text_chat(NULL, rfbTextChatClose, "");
- set_text_chat(NULL, rfbTextChatFinished, "");
- goto done;
- }
- if (strstr(p, "fs") == p) {
- COLON_CHECK("fs:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%f", p, co, fs_frac);
- goto qry;
- }
- p += strlen("fs:");
- fs_frac = atof(p);
- rfbLog("remote_cmd: setting -fs frac to %f\n", fs_frac);
- goto done;
- }
- if (strstr(p, "gaps") == p) {
- int g;
- COLON_CHECK("gaps:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, gaps_fill);
- goto qry;
- }
- p += strlen("gaps:");
- g = atoi(p);
- if (g < 0) g = 0;
- rfbLog("remote_cmd: setting gaps_fill %d -> %d.\n",
- gaps_fill, g);
- gaps_fill = g;
- goto done;
- }
- if (strstr(p, "grow") == p) {
- int g;
- COLON_CHECK("grow:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, grow_fill);
- goto qry;
- }
- p += strlen("grow:");
- g = atoi(p);
- if (g < 0) g = 0;
- rfbLog("remote_cmd: setting grow_fill %d -> %d.\n",
- grow_fill, g);
- grow_fill = g;
- goto done;
- }
- if (strstr(p, "fuzz") == p) {
- int f;
- COLON_CHECK("fuzz:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, tile_fuzz);
- goto qry;
- }
- p += strlen("fuzz:");
- f = atoi(p);
- if (f < 0) f = 0;
- rfbLog("remote_cmd: setting tile_fuzz %d -> %d.\n",
- tile_fuzz, f);
- grow_fill = f;
- goto done;
- }
- if (!strcmp(p, "snapfb")) {
- int orig = use_snapfb;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, use_snapfb);
- goto qry;
- }
- rfbLog("remote_cmd: turning on snapfb mode.\n");
- use_snapfb = 1;
- if (orig != use_snapfb) {
- do_new_fb(1);
- }
- goto done;
- }
- if (!strcmp(p, "nosnapfb")) {
- int orig = use_snapfb;
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !use_snapfb);
- goto qry;
- }
- rfbLog("remote_cmd: turning off snapfb mode.\n");
- use_snapfb = 0;
- if (orig != use_snapfb) {
- do_new_fb(1);
- }
-
- goto done;
- }
- if (strstr(p, "rawfb") == p) {
- COLON_CHECK("rawfb:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(raw_fb_str));
- goto qry;
- }
- p += strlen("rawfb:");
- if (raw_fb_str) free(raw_fb_str);
- raw_fb_str = strdup(p);
- if (safe_remote_only && strstr(p, "setup:") == p) { /* skip-cmd-list */
- /* n.b. we still allow filename, shm, of rawfb */
- fprintf(stderr, "unsafe rawfb setup: %s\n", p);
- exit(1);
- }
-
- rfbLog("remote_cmd: setting -rawfb to:\n\t'%s'\n", p);
-
- if (*raw_fb_str == '\0') {
- free(raw_fb_str);
- raw_fb_str = NULL;
- if (raw_fb_mmap) {
- munmap(raw_fb_addr, raw_fb_mmap);
- }
- if (raw_fb_fd >= 0) {
- close(raw_fb_fd);
- }
- raw_fb_fd = -1;
- raw_fb = NULL;
- raw_fb_addr = NULL;
- raw_fb_offset = 0;
- raw_fb_shm = 0;
- raw_fb_mmap = 0;
- raw_fb_seek = 0;
- rfbLog("restoring per-rawfb settings...\n");
- set_raw_fb_params(1);
- }
- rfbLog("hang on tight, here we go...\n");
- raw_fb_back_to_X = 1;
- do_new_fb(1);
- raw_fb_back_to_X = 0;
- goto done;
- }
- if (strstr(p, "uinput_accel") == p) {
- COLON_CHECK("uinput_accel:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(get_uinput_accel()));
- goto qry;
- }
- p += strlen("uinput_accel:");
- rfbLog("set_uinput_accel: %s\n", p);
- set_uinput_accel(p);
- goto done;
- }
- if (strstr(p, "uinput_thresh") == p) {
- COLON_CHECK("uinput_thresh:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(get_uinput_thresh()));
- goto qry;
- }
- p += strlen("uinput_thresh:");
- rfbLog("set_uinput_thresh: %s\n", p);
- set_uinput_thresh(p);
- goto done;
- }
- if (strstr(p, "uinput_reset") == p) {
- COLON_CHECK("uinput_reset:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- get_uinput_reset());
- goto qry;
- }
- p += strlen("uinput_reset:");
- rfbLog("set_uinput_reset: %s\n", p);
- set_uinput_reset(atoi(p));
- goto done;
- }
- if (strstr(p, "uinput_always") == p) {
- COLON_CHECK("uinput_always:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- get_uinput_always());
- goto qry;
- }
- p += strlen("uinput_always:");
- rfbLog("set_uinput_always: %s\n", p);
- set_uinput_always(atoi(p));
- goto done;
- }
- if (strstr(p, "progressive") == p) {
- int f;
- COLON_CHECK("progressive:")
- if (query) {
- if (!screen) {
- f = 0;
- } else {
- f = screen->progressiveSliceHeight;
- }
- snprintf(buf, bufn, "ans=%s%s%d", p, co, f);
- goto qry;
- }
- p += strlen("progressive:");
- f = atoi(p);
- if (f < 0) f = 0;
- rfbLog("remote_cmd: setting progressive %d -> %d.\n",
- screen->progressiveSliceHeight, f);
- /* mutex */
- screen->progressiveSliceHeight = f;
- goto done;
- }
- if (strstr(p, "rfbport") == p) {
- int rp, orig = screen ? screen->port : 5900;
- COLON_CHECK("rfbport:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, orig);
- goto qry;
- }
- p += strlen("rfbport:");
- rp = atoi(p);
- reset_rfbport(orig, rp);
- goto done;
- }
- if (!strcmp(p, "http")) {
- if (query) {
- int ls = screen ? screen->httpListenSock : -1;
- snprintf(buf, bufn, "ans=%s:%d", p, (ls > -1));
- goto qry;
- }
- if (screen->httpListenSock > -1 || ipv6_http_fd > -1) {
- rfbLog("already listening for http connections.\n");
- } else {
- rfbLog("turning on listening for http connections.\n");
- if (check_httpdir()) {
- http_connections(1);
- }
- }
- goto done;
- }
- if (!strcmp(p, "nohttp")) {
- if (query) {
- int ls = screen ? screen->httpListenSock : -1;
- snprintf(buf, bufn, "ans=%s:%d", p, !(ls > -1));
- goto qry;
- }
- if (screen->httpListenSock < 0 && ipv6_http_fd < 0) {
- rfbLog("already not listening for http connections.\n");
- } else {
- rfbLog("turning off listening for http connections.\n");
- if (check_httpdir()) {
- http_connections(0);
- }
- }
- goto done;
- }
- if (strstr(p, "httpport") == p) {
- int hp, orig = screen ? screen->httpPort : 0;
- COLON_CHECK("httpport:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, orig);
- goto qry;
- }
- p += strlen("httpport:");
- hp = atoi(p);
- reset_httpport(orig, hp);
- goto done;
- }
- if (strstr(p, "httpdir") == p) {
- COLON_CHECK("httpdir:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(http_dir));
- goto qry;
- }
- p += strlen("httpdir:");
- if (http_dir && !strcmp(http_dir, p)) {
- rfbLog("no change in httpdir: %s\n", http_dir);
- } else {
- if (http_dir) {
- free(http_dir);
- }
- http_dir = strdup(p);
- http_connections(0);
- if (*p != '\0') {
- http_connections(1);
- }
- }
- goto done;
- }
- if (!strcmp(p, "enablehttpproxy")) {
- if (query) {
- int ht = screen ? screen->httpEnableProxyConnect : 0;
- snprintf(buf, bufn, "ans=%s:%d", p, ht != 0);
- goto qry;
- }
- rfbLog("turning on enablehttpproxy.\n");
- /* mutex */
- screen->httpEnableProxyConnect = 1;
- goto done;
- }
- if (!strcmp(p, "noenablehttpproxy")) {
- if (query) {
- int ht = screen ? screen->httpEnableProxyConnect : 0;
- snprintf(buf, bufn, "ans=%s:%d", p, ht == 0);
- goto qry;
- }
- rfbLog("turning off enablehttpproxy.\n");
- screen->httpEnableProxyConnect = 0;
- goto done;
- }
- if (!strcmp(p, "alwaysshared")) {
- if (query) {
- int t = screen ? screen->alwaysShared : 0;
- snprintf(buf, bufn, "ans=%s:%d", p, t != 0);
- goto qry;
- }
- rfbLog("turning on alwaysshared.\n");
- screen->alwaysShared = 1;
- goto done;
- }
- if (!strcmp(p, "noalwaysshared")) {
- if (query) {
- int t = screen ? screen->alwaysShared : 0;
- snprintf(buf, bufn, "ans=%s:%d", p, t == 0);
- goto qry;
- }
- rfbLog("turning off alwaysshared.\n");
- screen->alwaysShared = 0;
- goto done;
- }
- if (!strcmp(p, "nevershared")) {
- if (query) {
- int t = screen ? screen->neverShared : 1;
- snprintf(buf, bufn, "ans=%s:%d", p, t != 0);
- goto qry;
- }
- rfbLog("turning on nevershared.\n");
- screen->neverShared = 1;
- goto done;
- }
- if (!strcmp(p, "noalwaysshared")) {
- if (query) {
- int t = screen ? screen->neverShared : 1;
- snprintf(buf, bufn, "ans=%s:%d", p, t == 0);
- goto qry;
- }
- rfbLog("turning off nevershared.\n");
- screen->neverShared = 0;
- goto done;
- }
- if (!strcmp(p, "dontdisconnect")) {
- if (query) {
- int t = screen ? screen->dontDisconnect : 1;
- snprintf(buf, bufn, "ans=%s:%d", p, t != 0);
- goto qry;
- }
- rfbLog("turning on dontdisconnect.\n");
- screen->dontDisconnect = 1;
- goto done;
- }
- if (!strcmp(p, "nodontdisconnect")) {
- if (query) {
- int t = screen ? screen->dontDisconnect : 1;
- snprintf(buf, bufn, "ans=%s:%d", p, t == 0);
- goto qry;
- }
- rfbLog("turning off dontdisconnect.\n");
- screen->dontDisconnect = 0;
- goto done;
- }
- if (!strcmp(p, "desktop") ||
- strstr(p, "desktop:") == p) { /* skip-cmd-list */
- COLON_CHECK("desktop:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%s", p, co,
- NONUL(rfb_desktop_name));
- goto qry;
- }
- p += strlen("desktop:");
- if (rfb_desktop_name) {
- free(rfb_desktop_name);
- }
- rfb_desktop_name = strdup(p);
- /* mutex */
- screen->desktopName = rfb_desktop_name;
- rfbLog("remote_cmd: setting desktop name to %s\n",
- rfb_desktop_name);
- goto done;
- }
- if (!strcmp(p, "debug_xevents")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_xevents);
- goto qry;
- }
- debug_xevents = 1;
- rfbLog("set debug_xevents to: %d\n", debug_xevents);
- goto done;
- }
- if (!strcmp(p, "nodebug_xevents")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_xevents);
- goto qry;
- }
- debug_xevents = 0;
- rfbLog("set debug_xevents to: %d\n", debug_xevents);
- goto done;
- }
- if (strstr(p, "debug_xevents") == p) {
- COLON_CHECK("debug_xevents:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, debug_xevents);
- goto qry;
- }
- p += strlen("debug_xevents:");
- debug_xevents = atoi(p);
- rfbLog("set debug_xevents to: %d\n", debug_xevents);
- goto done;
- }
- if (!strcmp(p, "debug_xdamage")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_xdamage);
- goto qry;
- }
- debug_xdamage = 1;
- rfbLog("set debug_xdamage to: %d\n", debug_xdamage);
- goto done;
- }
- if (!strcmp(p, "nodebug_xdamage")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_xdamage);
- goto qry;
- }
- debug_xdamage = 0;
- rfbLog("set debug_xdamage to: %d\n", debug_xdamage);
- goto done;
- }
- if (strstr(p, "debug_xdamage") == p) {
- COLON_CHECK("debug_xdamage:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, debug_xdamage);
- goto qry;
- }
- p += strlen("debug_xdamage:");
- debug_xdamage = atoi(p);
- rfbLog("set debug_xdamage to: %d\n", debug_xdamage);
- goto done;
- }
- if (!strcmp(p, "debug_wireframe")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_wireframe);
- goto qry;
- }
- debug_wireframe = 1;
- rfbLog("set debug_wireframe to: %d\n", debug_wireframe);
- goto done;
- }
- if (!strcmp(p, "nodebug_wireframe")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_wireframe);
- goto qry;
- }
- debug_wireframe = 0;
- rfbLog("set debug_wireframe to: %d\n", debug_wireframe);
- goto done;
- }
- if (strstr(p, "debug_wireframe") == p) {
- COLON_CHECK("debug_wireframe:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- debug_wireframe);
- goto qry;
- }
- p += strlen("debug_wireframe:");
- debug_wireframe = atoi(p);
- rfbLog("set debug_wireframe to: %d\n", debug_wireframe);
- goto done;
- }
- if (!strcmp(p, "debug_scroll")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_scroll);
- goto qry;
- }
- debug_scroll = 1;
- rfbLog("set debug_scroll to: %d\n", debug_scroll);
- goto done;
- }
- if (!strcmp(p, "nodebug_scroll")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_scroll);
- goto qry;
- }
- debug_scroll = 0;
- rfbLog("set debug_scroll to: %d\n", debug_scroll);
- goto done;
- }
- if (strstr(p, "debug_scroll") == p) {
- COLON_CHECK("debug_scroll:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- debug_scroll);
- goto qry;
- }
- p += strlen("debug_scroll:");
- debug_scroll = atoi(p);
- rfbLog("set debug_scroll to: %d\n", debug_scroll);
- goto done;
- }
- if (!strcmp(p, "debug_tiles") || !strcmp(p, "dbt")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_tiles);
- goto qry;
- }
- debug_tiles = 1;
- rfbLog("set debug_tiles to: %d\n", debug_tiles);
- goto done;
- }
- if (!strcmp(p, "nodebug_tiles") || !strcmp(p, "nodbt")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_tiles);
- goto qry;
- }
- debug_tiles = 0;
- rfbLog("set debug_tiles to: %d\n", debug_tiles);
- goto done;
- }
- if (strstr(p, "debug_tiles") == p) {
- COLON_CHECK("debug_tiles:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co,
- debug_tiles);
- goto qry;
- }
- p += strlen("debug_tiles:");
- debug_tiles = atoi(p);
- rfbLog("set debug_tiles to: %d\n", debug_tiles);
- goto done;
- }
- if (!strcmp(p, "debug_grabs")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_grabs);
- goto qry;
- }
- debug_grabs = 1;
- rfbLog("set debug_grabs to: %d\n", debug_grabs);
- goto done;
- }
- if (!strcmp(p, "nodebug_grabs")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_grabs);
- goto qry;
- }
- debug_grabs = 0;
- rfbLog("set debug_grabs to: %d\n", debug_grabs);
- goto done;
- }
- if (!strcmp(p, "debug_sel")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, debug_sel);
- goto qry;
- }
- debug_sel = 1;
- rfbLog("set debug_sel to: %d\n", debug_sel);
- goto done;
- }
- if (!strcmp(p, "nodebug_sel")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !debug_sel);
- goto qry;
- }
- debug_sel = 0;
- rfbLog("set debug_sel to: %d\n", debug_sel);
- goto done;
- }
- if (!strcmp(p, "dbg")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, crash_debug);
- goto qry;
- }
- crash_debug = 1;
- rfbLog("set crash_debug to: %d\n", crash_debug);
- goto done;
- }
- if (!strcmp(p, "nodbg")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !crash_debug);
- goto qry;
- }
- crash_debug = 0;
- rfbLog("set crash_debug to: %d\n", crash_debug);
- goto done;
- }
- if (!strcmp(p, "macnosaver")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_noscreensaver); goto qry;
- }
- rfbLog("remote_cmd: turn on macnosaver.\n");
- macosx_noscreensaver = 1;
- goto done;
- }
- if (!strcmp(p, "macsaver") || !strcmp(p, "nomacnosaver")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_noscreensaver); goto qry;
- }
- rfbLog("remote_cmd: turn off macnosaver.\n");
- macosx_noscreensaver = 0;
- goto done;
- }
- if (!strcmp(p, "macnowait")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_wait_for_switch); goto qry;
- }
- rfbLog("remote_cmd: disable macosx_wait_for_switch.\n");
- macosx_wait_for_switch = 0;
- goto done;
- }
- if (!strcmp(p, "macwait") || !strcmp(p, "nomacnowait")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_wait_for_switch); goto qry;
- }
- rfbLog("remote_cmd: enable macosx_wait_for_switch.\n");
- macosx_wait_for_switch = 1;
- goto done;
- }
- if (strstr(p, "macwheel") == p) {
- COLON_CHECK("macwheel:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, macosx_mouse_wheel_speed);
- goto qry;
- }
- p += strlen("macwheel:");
- macosx_mouse_wheel_speed = atoi(p);
- rfbLog("set macosx_mouse_wheel_speed to: %d\n", macosx_mouse_wheel_speed);
- goto done;
- }
- if (!strcmp(p, "macnoswap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_swap23); goto qry;
- }
- rfbLog("remote_cmd: disable macosx_swap23.\n");
- macosx_swap23 = 0;
- goto done;
- }
- if (!strcmp(p, "macswap") || !strcmp(p, "nomacnoswap")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_swap23); goto qry;
- }
- rfbLog("remote_cmd: enable macosx_swap23.\n");
- macosx_swap23 = 1;
- goto done;
- }
- if (!strcmp(p, "macnoresize")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_resize); goto qry;
- }
- rfbLog("remote_cmd: disable macosx_resize.\n");
- macosx_resize = 0;
- goto done;
- }
- if (!strcmp(p, "macresize") || !strcmp(p, "nomacnoresize")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_resize); goto qry;
- }
- rfbLog("remote_cmd: enable macosx_resize.\n");
- macosx_resize = 1;
- goto done;
- }
- if (strstr(p, "maciconanim") == p) {
- COLON_CHECK("maciconanim:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, macosx_icon_anim_time);
- goto qry;
- }
- p += strlen("maciconanim:");
- macosx_icon_anim_time = atoi(p);
- rfbLog("set macosx_icon_anim_time to: %d\n", macosx_icon_anim_time);
- goto done;
- }
- if (!strcmp(p, "macmenu")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_ncache_macmenu); goto qry;
- }
- rfbLog("remote_cmd: enable macosx_ncache_macmenu.\n");
- macosx_ncache_macmenu = 1;
- goto done;
- }
- if (!strcmp(p, "macnomenu") || !strcmp(p, "nomacmenu")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_ncache_macmenu); goto qry;
- }
- rfbLog("remote_cmd: disable macosx_ncache_macmenu.\n");
- macosx_ncache_macmenu = 0;
- goto done;
- }
- if (!strcmp(p, "macuskbd")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, macosx_us_kbd); goto qry;
- }
- rfbLog("remote_cmd: enable macosx_us_kbd.\n");
- macosx_us_kbd = 1;
- goto done;
- }
- if (!strcmp(p, "nomacuskbd")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p, !macosx_us_kbd); goto qry;
- }
- rfbLog("remote_cmd: disable macosx_us_kbd.\n");
- macosx_us_kbd = 0;
- goto done;
- }
- if (strstr(p, "hack") == p) { /* skip-cmd-list */
- COLON_CHECK("hack:")
- if (query) {
- snprintf(buf, bufn, "ans=%s%s%d", p, co, hack_val);
- goto qry;
- }
- p += strlen("hack:");
- hack_val = atoi(p);
- rfbLog("set hack_val to: %d\n", hack_val);
- goto done;
- }
- if (!strcmp(p, "noremote")) {
- if (query) {
- snprintf(buf, bufn, "ans=%s:%d", p,
- !accept_remote_cmds);
- goto qry;
- }
- rfbLog("remote_cmd: disabling remote commands.\n");
- accept_remote_cmds = 0; /* cannot be turned back on. */
- goto done;
- }
- if (strstr(p, "client_info_sock") == p) { /* skip-cmd-list */
- NOTAPP
- p += strlen("client_info_sock:");
- if (*p != '\0') {
- start_client_info_sock(p);
- }
- goto done;
- }
- if (strstr(p, "noop") == p) {
- NOTAPP
- rfbLog("remote_cmd: noop\n");
- goto done;
- }
- if (icon_mode && !query && strstr(p, "passwd") == p) { /* skip-cmd-list */
- char **passwds_new = (char **) malloc(3*sizeof(char *));
- char **passwds_old = (char **) screen->authPasswdData;
-
- COLON_CHECK("passwd:")
- p += strlen("passwd:");
-
- passwds_new[0] = strdup(p);
-
- /* mutex */
- if (screen->authPasswdData &&
- screen->passwordCheck == rfbCheckPasswordByList) {
- passwds_new[1] = passwds_old[1];
- } else {
- passwds_new[1] = NULL;
- screen->passwordCheck = rfbCheckPasswordByList;
- }
- passwds_new[2] = NULL;
-
- screen->authPasswdData = (void*) passwds_new;
- if (*p == '\0') {
- screen->authPasswdData = (void*) NULL;
- }
- rfbLog("remote_cmd: changed full access passwd.\n");
- goto done;
- }
- if (icon_mode && !query && strstr(p, "viewpasswd") == p) { /* skip-cmd-list */
- char **passwds_new = (char **) malloc(3*sizeof(char *));
- char **passwds_old = (char **) screen->authPasswdData;
-
- COLON_CHECK("viewpasswd:")
- p += strlen("viewpasswd:");
-
- passwds_new[1] = strdup(p);
-
- if (screen->authPasswdData &&
- screen->passwordCheck == rfbCheckPasswordByList) {
- passwds_new[0] = passwds_old[0];
- } else {
- char *tmp = (char *) malloc(4 + CHALLENGESIZE);
- rfbRandomBytes((unsigned char*)tmp);
- passwds_new[0] = tmp;
- screen->passwordCheck = rfbCheckPasswordByList;
- }
- passwds_new[2] = NULL;
-
- if (*p == '\0') {
- passwds_new[1] = NULL;
- }
-
- screen->authPasswdData = (void*) passwds_new;
- rfbLog("remote_cmd: changed view only passwd.\n");
- goto done;
- }
- if (strstr(p, "trayembed") == p) { /* skip-cmd-list */
- unsigned long id;
- NOTAPP
-
- COLON_CHECK("trayembed:")
- p += strlen("trayembed:");
- if (scan_hexdec(p, &id)) {
- tray_request = (Window) id;
- tray_unembed = 0;
- rfbLog("remote_cmd: will try to embed 0x%x in"
- " the system tray.\n", id);
- }
- goto done;
- }
- if (strstr(p, "trayunembed") == p) { /* skip-cmd-list */
- unsigned long id;
- NOTAPP
-
- COLON_CHECK("trayunembed:")
- p += strlen("trayunembed:");
- if (scan_hexdec(p, &id)) {
- tray_request = (Window) id;
- tray_unembed = 1;
- rfbLog("remote_cmd: will try to unembed 0x%x out"
- " of the system tray.\n", id);
- }
- goto done;
- }
- if (query) {
- /* read-only variables that can only be queried: */
-
- if (!strcmp(p, "display")) {
- if (raw_fb) {
- snprintf(buf, bufn, "aro=%s:rawfb:%p",
- p, raw_fb_addr);
- } else if (! dpy) {
- snprintf(buf, bufn, "aro=%s:", p);
- } else {
- char *d;
- d = DisplayString(dpy);
- if (! d) d = "unknown";
- if (*d == ':') {
- snprintf(buf, bufn, "aro=%s:%s%s", p,
- this_host(), d);
- } else {
- snprintf(buf, bufn, "aro=%s:%s", p, d);
- }
- }
- goto qry;
- }
- if (!strcmp(p, "vncdisplay")) {
- snprintf(buf, bufn, "aro=%s:%s", p,
- NONUL(vnc_desktop_name));
- goto qry;
- }
- if (!strcmp(p, "icon_mode")) {
- snprintf(buf, bufn, "aro=%s:%d", p, icon_mode);
- goto qry;
- }
- if (!strcmp(p, "autoport")) {
- snprintf(buf, bufn, "aro=%s:%d", p, auto_port);
- goto qry;
- }
- if (!strcmp(p, "loop") || !strcmp(p, "loopbg")) {
- snprintf(buf, bufn, "aro=%s:%d", p, 0);
- goto qry;
- }
- if (!strcmp(p, "desktopname")) {
- snprintf(buf, bufn, "aro=%s:%s", p,
- NONUL(rfb_desktop_name));
- goto qry;
- }
- if (!strcmp(p, "guess_desktop")) {
- snprintf(buf, bufn, "aro=%s:%s", p,
- NONUL(guess_desktop()));
- goto qry;
- }
- if (!strcmp(p, "guess_dbus")) {
- snprintf(buf, bufn, "aro=%s:%s", p,
- NONUL(dbus_session()));
- goto qry;
- }
- if (!strcmp(p, "http_url")) {
- if (!screen) {
- snprintf(buf, bufn, "aro=%s:", p);
- } else if (screen->httpListenSock > -1) {
- snprintf(buf, bufn, "aro=%s:http://%s:%d", p,
- NONUL(screen->thisHost), screen->httpPort);
- } else {
- snprintf(buf, bufn, "aro=%s:%s", p,
- "http_not_active");
- }
- goto qry;
- }
- if (!strcmp(p, "auth") || !strcmp(p, "xauth")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(auth_file));
- goto qry;
- }
- if (!strcmp(p, "users")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(users_list));
- goto qry;
- }
- if (!strcmp(p, "rootshift")) {
- snprintf(buf, bufn, "aro=%s:%d", p, rootshift);
- goto qry;
- }
- if (!strcmp(p, "clipshift")) {
- snprintf(buf, bufn, "aro=%s:%d", p, clipshift);
- goto qry;
- }
- if (!strcmp(p, "scale_str")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(scale_str));
- goto qry;
- }
- if (!strcmp(p, "scaled_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scaled_x);
- goto qry;
- }
- if (!strcmp(p, "scaled_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scaled_y);
- goto qry;
- }
- if (!strcmp(p, "scale_numer")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scale_numer);
- goto qry;
- }
- if (!strcmp(p, "scale_denom")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scale_denom);
- goto qry;
- }
- if (!strcmp(p, "scale_fac_x")) {
- snprintf(buf, bufn, "aro=%s:%f", p, scale_fac_x);
- goto qry;
- }
- if (!strcmp(p, "scale_fac_y")) {
- snprintf(buf, bufn, "aro=%s:%f", p, scale_fac_y);
- goto qry;
- }
- if (!strcmp(p, "scaling_blend")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scaling_blend);
- goto qry;
- }
- if (!strcmp(p, "scaling_nomult4")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scaling_nomult4);
- goto qry;
- }
- if (!strcmp(p, "scaling_pad")) {
- snprintf(buf, bufn, "aro=%s:%d", p, scaling_pad);
- goto qry;
- }
- if (!strcmp(p, "scaling_interpolate")) {
- snprintf(buf, bufn, "aro=%s:%d", p,
- scaling_interpolate);
- goto qry;
- }
- if (!strcmp(p, "inetd")) {
- snprintf(buf, bufn, "aro=%s:%d", p, inetd);
- goto qry;
- }
- if (!strcmp(p, "privremote")) {
- snprintf(buf, bufn, "aro=%s:%d", p, priv_remote);
- goto qry;
- }
- if (!strcmp(p, "unsafe")) {
- snprintf(buf, bufn, "aro=%s:%d", p, !safe_remote_only);
- goto qry;
- }
- if (!strcmp(p, "safer")) {
- snprintf(buf, bufn, "aro=%s:%d", p, more_safe);
- goto qry;
- }
- if (!strcmp(p, "nocmds")) {
- snprintf(buf, bufn, "aro=%s:%d", p, no_external_cmds);
- goto qry;
- }
- if (!strcmp(p, "passwdfile")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(passwdfile));
- goto qry;
- }
- if (!strcmp(p, "unixpw")) {
- snprintf(buf, bufn, "aro=%s:%d", p, unixpw);
- goto qry;
- }
- if (!strcmp(p, "unixpw_nis")) {
- snprintf(buf, bufn, "aro=%s:%d", p, unixpw_nis);
- goto qry;
- }
- if (!strcmp(p, "unixpw_list")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(unixpw_list));
- goto qry;
- }
- if (!strcmp(p, "ssl")) {
- snprintf(buf, bufn, "aro=%s:%d", p, use_openssl);
- goto qry;
- }
- if (!strcmp(p, "ssl_pem")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(openssl_pem));
- goto qry;
- }
- if (!strcmp(p, "sslverify")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(ssl_verify));
- goto qry;
- }
- if (!strcmp(p, "stunnel")) {
- snprintf(buf, bufn, "aro=%s:%d", p, use_stunnel);
- goto qry;
- }
- if (!strcmp(p, "stunnel_pem")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(stunnel_pem));
- goto qry;
- }
- if (!strcmp(p, "https")) {
- snprintf(buf, bufn, "aro=%s:%d", p, https_port_num);
- goto qry;
- }
- if (!strcmp(p, "httpsredir")) {
- snprintf(buf, bufn, "aro=%s:%d", p, https_port_redir);
- goto qry;
- }
- if (!strcmp(p, "usepw")) {
- snprintf(buf, bufn, "aro=%s:%d", p, usepw);
- goto qry;
- }
- if (!strcmp(p, "using_shm")) {
- snprintf(buf, bufn, "aro=%s:%d", p, !using_shm);
- goto qry;
- }
- if (!strcmp(p, "logfile") || !strcmp(p, "o")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(logfile));
- goto qry;
- }
- if (!strcmp(p, "flag")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(flagfile));
- goto qry;
- }
- if (!strcmp(p, "rmflag")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(rm_flagfile));
- goto qry;
- }
- if (!strcmp(p, "rc")) {
- char *s = rc_rcfile;
- if (rc_rcfile_default) {
- s = NULL;
- }
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(s));
- goto qry;
- }
- if (!strcmp(p, "norc")) {
- snprintf(buf, bufn, "aro=%s:%d", p, got_norc);
- goto qry;
- }
- if (!strcmp(p, "h") || !strcmp(p, "help") ||
- !strcmp(p, "V") || !strcmp(p, "version") ||
- !strcmp(p, "lastmod")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(lastmod));
- goto qry;
- }
- if (!strcmp(p, "bg")) {
- snprintf(buf, bufn, "aro=%s:%d", p, opts_bg);
- goto qry;
- }
- if (!strcmp(p, "sigpipe")) {
- snprintf(buf, bufn, "aro=%s:%s", p, NONUL(sigpipe));
- goto qry;
- }
- if (!strcmp(p, "threads")) {
- snprintf(buf, bufn, "aro=%s:%d", p, use_threads);
- goto qry;
- }
- if (!strcmp(p, "readrate")) {
- snprintf(buf, bufn, "aro=%s:%d", p, get_read_rate());
- goto qry;
- }
- if (!strcmp(p, "netrate")) {
- snprintf(buf, bufn, "aro=%s:%d", p, get_net_rate());
- goto qry;
- }
- if (!strcmp(p, "netlatency")) {
- snprintf(buf, bufn, "aro=%s:%d", p, get_net_latency());
- goto qry;
- }
- if (!strcmp(p, "pipeinput")) {
- snprintf(buf, bufn, "aro=%s:%s", p,
- NONUL(pipeinput_str));
- goto qry;
- }
- if (!strcmp(p, "clients")) {
- char *str = list_clients();
- snprintf(buf, bufn, "aro=%s:%s", p, str);
- free(str);
- goto qry;
- }
- if (!strcmp(p, "client_count")) {
- snprintf(buf, bufn, "aro=%s:%d", p, client_count);
- goto qry;
- }
- if (!strcmp(p, "pid")) {
- snprintf(buf, bufn, "aro=%s:%d", p, (int) getpid());
- goto qry;
- }
- if (!strcmp(p, "ext_xtest")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xtest_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xtrap")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xtrap_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xrecord")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xrecord_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xkb")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xkb_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xshm")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xshm_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xinerama")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xinerama_present);
- goto qry;
- }
- if (!strcmp(p, "ext_overlay")) {
- snprintf(buf, bufn, "aro=%s:%d", p, overlay_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xfixes")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xfixes_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xdamage")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xdamage_present);
- goto qry;
- }
- if (!strcmp(p, "ext_xrandr")) {
- snprintf(buf, bufn, "aro=%s:%d", p, xrandr_present);
- goto qry;
- }
- if (!strcmp(p, "rootwin")) {
- snprintf(buf, bufn, "aro=%s:0x%x", p,
- (unsigned int) rootwin);
- goto qry;
- }
- if (!strcmp(p, "num_buttons")) {
- snprintf(buf, bufn, "aro=%s:%d", p, num_buttons);
- goto qry;
- }
- if (!strcmp(p, "button_mask")) {
- snprintf(buf, bufn, "aro=%s:%d", p, button_mask);
- goto qry;
- }
- if (!strcmp(p, "mouse_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, cursor_x);
- goto qry;
- }
- if (!strcmp(p, "mouse_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, cursor_y);
- goto qry;
- }
- if (!strcmp(p, "grab_state")) {
- int ptr_grabbed, kbd_grabbed;
-
- grab_state(&ptr_grabbed, &kbd_grabbed);
- snprintf(buf, bufn, "aro=%s:%d,%d", p, ptr_grabbed, kbd_grabbed);
- if (dpy && rc_npieces < 10) {
- rfbLog("remote_cmd: ptr,kbd: %s\n", buf);
- }
- goto qry;
- }
- if (!strcmp(p, "pointer_pos") || !strcmp(p, "pointer_x") || !strcmp(p, "pointer_y") || !strcmp(p, "pointer_same") || !strcmp(p, "pointer_root") || !strcmp(p, "pointer_mask")) {
- int px = -1, py = -1;
- int wx, wy;
- unsigned int m = 0;
- Window r, c;
- Bool same_screen = True;
-
-
- if (!strcmp(p, "pointer_pos")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d,%d", p, px, py);
- } else if (!strcmp(p, "pointer_x")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, px);
- } else if (!strcmp(p, "pointer_y")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, py);
- } else if (!strcmp(p, "pointer_same")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, same_screen);
- } else if (!strcmp(p, "pointer_root")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:0x%x", p, (unsigned int) rootwin);
- } else if (!strcmp(p, "pointer_mask")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:0x%x", p, m);
- }
- if (!dpy) {
- goto qry;
- }
-#if NO_X11
- goto qry;
-#else
- X_LOCK;
- same_screen = XQueryPointer_wr(dpy, rootwin, &r, &c, &px, &py, &wx, &wy, &m);
- X_UNLOCK;
-#endif
-
- if (!strcmp(p, "pointer_pos")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d,%d", p, px, py);
- } else if (!strcmp(p, "pointer_x")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, px);
- } else if (!strcmp(p, "pointer_y")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, py);
- } else if (!strcmp(p, "pointer_same")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:%d", p, same_screen);
- } else if (!strcmp(p, "pointer_root")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:0x%x", p, (unsigned int) r);
- } else if (!strcmp(p, "pointer_mask")) { /* skip-cmd-list */
- snprintf(buf, bufn, "aro=%s:0x%x", p, m);
- }
- if (rc_npieces < 10) {
- rfbLog("remote_cmd: %s: %s\n", p, buf);
- }
- goto qry;
- }
- if (!strcmp(p, "bpp")) {
- snprintf(buf, bufn, "aro=%s:%d", p, bpp);
- goto qry;
- }
- if (!strcmp(p, "depth")) {
- snprintf(buf, bufn, "aro=%s:%d", p, depth);
- goto qry;
- }
- if (!strcmp(p, "indexed_color")) {
- snprintf(buf, bufn, "aro=%s:%d", p, indexed_color);
- goto qry;
- }
- if (!strcmp(p, "dpy_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, dpy_x);
- goto qry;
- }
- if (!strcmp(p, "dpy_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, dpy_y);
- goto qry;
- }
- if (!strcmp(p, "wdpy_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, wdpy_x);
- goto qry;
- }
- if (!strcmp(p, "wdpy_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, wdpy_y);
- goto qry;
- }
- if (!strcmp(p, "off_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, off_x);
- goto qry;
- }
- if (!strcmp(p, "off_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, off_y);
- goto qry;
- }
- if (!strcmp(p, "cdpy_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, cdpy_x);
- goto qry;
- }
- if (!strcmp(p, "cdpy_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, cdpy_y);
- goto qry;
- }
- if (!strcmp(p, "coff_x")) {
- snprintf(buf, bufn, "aro=%s:%d", p, coff_x);
- goto qry;
- }
- if (!strcmp(p, "coff_y")) {
- snprintf(buf, bufn, "aro=%s:%d", p, coff_y);
- goto qry;
- }
- if (!strcmp(p, "rfbauth")) {
- NOTAPPRO
- goto qry;
- }
- if (!strcmp(p, "passwd")) {
- NOTAPPRO
- goto qry;
- }
- if (!strcmp(p, "viewpasswd")) {
- NOTAPPRO
- goto qry;
- }
- if (1) {
- NOTAPP
- goto qry;
- }
- goto done;
- }
- if (1) {
- char tmp[100];
- NOTAPP
- rfbLog("remote_cmd: warning unknown\n");
- strncpy(tmp, p, 90);
- rfbLog("command \"%s\"\n", tmp);
- goto done;
- }
-
- done:
-
- if (*buf == '\0') {
- sprintf(buf, "%s", "ack=1");
- }
-
- qry:
-
- if (stringonly) {
- return strdup(buf);
- } else if (client_connect_file) {
- FILE *out = fopen(client_connect_file, "w");
- if (out != NULL) {
- fprintf(out, "%s\n", buf);
- fclose(out);
- usleep(20*1000);
- }
- } else {
- if (dpy) { /* raw_fb hack */
- X_LOCK;
- set_x11vnc_remote_prop(buf);
- XFlush_wr(dpy);
- X_UNLOCK;
- }
- }
-#endif /* REMOTE_CONTROL */
- return NULL;
-}
-
-