69 |
BOOL g_console_session = False; |
BOOL g_console_session = False; |
70 |
BOOL g_numlock_sync = False; |
BOOL g_numlock_sync = False; |
71 |
extern BOOL g_owncolmap; |
extern BOOL g_owncolmap; |
72 |
|
extern BOOL g_ownbackstore; |
73 |
|
extern uint32 g_embed_wnd; |
74 |
|
|
75 |
#ifdef WITH_RDPSND |
#ifdef WITH_RDPSND |
76 |
BOOL g_rdpsnd = False; |
BOOL g_rdpsnd = False; |
109 |
fprintf(stderr, " -g: desktop geometry (WxH)\n"); |
fprintf(stderr, " -g: desktop geometry (WxH)\n"); |
110 |
fprintf(stderr, " -f: full-screen mode\n"); |
fprintf(stderr, " -f: full-screen mode\n"); |
111 |
fprintf(stderr, " -b: force bitmap updates\n"); |
fprintf(stderr, " -b: force bitmap updates\n"); |
112 |
|
fprintf(stderr, " -B: use BackingStore of X-server (if available)\n"); |
113 |
fprintf(stderr, " -e: disable encryption (French TS)\n"); |
fprintf(stderr, " -e: disable encryption (French TS)\n"); |
114 |
fprintf(stderr, " -E: disable encryption from client to server\n"); |
fprintf(stderr, " -E: disable encryption from client to server\n"); |
115 |
fprintf(stderr, " -m: do not send motion events\n"); |
fprintf(stderr, " -m: do not send motion events\n"); |
119 |
fprintf(stderr, " -S: caption button size (single application mode)\n"); |
fprintf(stderr, " -S: caption button size (single application mode)\n"); |
120 |
fprintf(stderr, " -T: window title\n"); |
fprintf(stderr, " -T: window title\n"); |
121 |
fprintf(stderr, " -N: enable numlock syncronization\n"); |
fprintf(stderr, " -N: enable numlock syncronization\n"); |
122 |
|
fprintf(stderr, " -X: embed into another window with a given id.\n"); |
123 |
fprintf(stderr, " -a: connection colour depth\n"); |
fprintf(stderr, " -a: connection colour depth\n"); |
124 |
fprintf(stderr, " -r: enable specified device redirection (this flag can be repeated)\n"); |
fprintf(stderr, " -r: enable specified device redirection (this flag can be repeated)\n"); |
125 |
fprintf(stderr, |
fprintf(stderr, |
133 |
fprintf(stderr, " or LPT1=/dev/lp0,LPT2=/dev/lp1\n"); |
fprintf(stderr, " or LPT1=/dev/lp0,LPT2=/dev/lp1\n"); |
134 |
fprintf(stderr, " '-r printer:mydeskjet': enable printer redirection\n"); |
fprintf(stderr, " '-r printer:mydeskjet': enable printer redirection\n"); |
135 |
fprintf(stderr, |
fprintf(stderr, |
136 |
" or mydeskjet=\"HP LaserJet IIIP\" to enter server driver as well\n"); |
" or mydeskjet=\"HP LaserJet IIIP\" to enter server driver as well\n"); |
137 |
fprintf(stderr, " '-r sound': enable sound redirection\n"); |
fprintf(stderr, " '-r sound:[local|off|remote]': enable sound redirection\n"); |
138 |
|
fprintf(stderr, " remote would leave sound on server\n"); |
139 |
fprintf(stderr, " -0: attach to console\n"); |
fprintf(stderr, " -0: attach to console\n"); |
140 |
fprintf(stderr, " -4: use RDP version 4\n"); |
fprintf(stderr, " -4: use RDP version 4\n"); |
141 |
fprintf(stderr, " -5: use RDP version 5 (default)\n"); |
fprintf(stderr, " -5: use RDP version 5 (default)\n"); |
247 |
prompt_password = False; |
prompt_password = False; |
248 |
domain[0] = password[0] = shell[0] = directory[0] = 0; |
domain[0] = password[0] = shell[0] = directory[0] = 0; |
249 |
strcpy(keymapname, "en-us"); |
strcpy(keymapname, "en-us"); |
250 |
|
g_embed_wnd = 0; |
251 |
|
|
252 |
g_num_devices = 0; |
g_num_devices = 0; |
253 |
|
|
257 |
#define VNCOPT |
#define VNCOPT |
258 |
#endif |
#endif |
259 |
|
|
260 |
while ((c = getopt(argc, argv, VNCOPT "u:d:s:c:p:n:k:g:fbeEmCDKS:T:Na:r:045h?")) != -1) |
while ((c = getopt(argc, argv, VNCOPT "u:d:s:c:p:n:k:g:fbBeEmCDKS:T:NX:a:r:045h?")) != -1) |
261 |
{ |
{ |
262 |
switch (c) |
switch (c) |
263 |
{ |
{ |
353 |
g_orders = False; |
g_orders = False; |
354 |
break; |
break; |
355 |
|
|
356 |
|
case 'B': |
357 |
|
g_ownbackstore = False; |
358 |
|
break; |
359 |
|
|
360 |
case 'e': |
case 'e': |
361 |
g_encryption = False; |
g_encryption = False; |
362 |
break; |
break; |
404 |
g_numlock_sync = True; |
g_numlock_sync = True; |
405 |
break; |
break; |
406 |
|
|
407 |
|
case 'X': |
408 |
|
g_embed_wnd = strtol(optarg, NULL, 10); |
409 |
|
break; |
410 |
|
|
411 |
case 'a': |
case 'a': |
412 |
g_server_bpp = strtol(optarg, NULL, 10); |
g_server_bpp = strtol(optarg, NULL, 10); |
413 |
if (g_server_bpp != 8 && g_server_bpp != 16 && g_server_bpp != 15 |
if (g_server_bpp != 8 && g_server_bpp != 16 && g_server_bpp != 15 |
422 |
|
|
423 |
if (strncmp("sound", optarg, 5) == 0) |
if (strncmp("sound", optarg, 5) == 0) |
424 |
{ |
{ |
425 |
|
optarg += 5; |
426 |
|
|
427 |
|
if (*optarg == ':') |
428 |
|
{ |
429 |
|
*optarg++; |
430 |
|
while ((p = next_arg(optarg, ','))) |
431 |
|
{ |
432 |
|
if (strncmp("remote", optarg, 6) == 0) |
433 |
|
flags |= RDP_LOGON_LEAVE_AUDIO; |
434 |
|
|
435 |
|
if (strncmp("local", optarg, 5) == 0) |
436 |
|
#ifdef WITH_RDPSND |
437 |
|
g_rdpsnd = True; |
438 |
|
#else |
439 |
|
warning("Not compiled with sound support"); |
440 |
|
#endif |
441 |
|
|
442 |
|
if (strncmp("off", optarg, 3) == 0) |
443 |
|
g_rdpsnd = False; |
444 |
|
|
445 |
|
optarg = p; |
446 |
|
} |
447 |
|
} |
448 |
|
else |
449 |
|
{ |
450 |
#ifdef WITH_RDPSND |
#ifdef WITH_RDPSND |
451 |
g_rdpsnd = True; |
g_rdpsnd = True; |
452 |
#else |
#else |
453 |
warning("Not compiled with sound support"); |
warning("Not compiled with sound support"); |
454 |
#endif |
#endif |
455 |
|
} |
456 |
} |
} |
457 |
else if (strncmp("disk", optarg, 4) == 0) |
else if (strncmp("disk", optarg, 4) == 0) |
458 |
{ |
{ |
497 |
} |
} |
498 |
} |
} |
499 |
|
|
500 |
if (argc - optind < 1) |
if (argc - optind != 1) |
501 |
{ |
{ |
502 |
usage(argv[0]); |
usage(argv[0]); |
503 |
return 1; |
return 1; |
772 |
} |
} |
773 |
|
|
774 |
/* |
/* |
775 |
input: src is the string we look in for needle |
input: src is the string we look in for needle. |
776 |
|
Needle may be escaped by a backslash, in |
777 |
|
that case we ignore that particular needle. |
778 |
return value: returns next src pointer, for |
return value: returns next src pointer, for |
779 |
succesive executions, like in a while loop |
succesive executions, like in a while loop |
780 |
if retval is 0, then there are no more args. |
if retval is 0, then there are no more args. |
856 |
#define LTOA_BUFSIZE (sizeof(long) * 8 + 1) |
#define LTOA_BUFSIZE (sizeof(long) * 8 + 1) |
857 |
|
|
858 |
char * |
char * |
859 |
ltoa(long N, int base) |
l_to_a(long N, int base) |
860 |
{ |
{ |
861 |
static char ret[LTOA_BUFSIZE]; |
static char ret[LTOA_BUFSIZE]; |
862 |
|
|
863 |
register int i = 2; |
char *head = ret, buf[LTOA_BUFSIZE], *tail = buf + sizeof(buf); |
|
long uarg; |
|
|
char *tail, *head = ret, buf[LTOA_BUFSIZE]; |
|
864 |
|
|
865 |
if (36 < base || 2 > base) |
register int divrem; |
|
base = 10; |
|
866 |
|
|
867 |
tail = &buf[LTOA_BUFSIZE - 1]; |
if (base < 36 || 2 > base) |
868 |
*tail-- = '\0'; |
base = 10; |
869 |
|
|
870 |
if (10 == base && N < 0L) |
if (N < 0) |
871 |
{ |
{ |
872 |
*head++ = '-'; |
*head++ = '-'; |
873 |
uarg = -N; |
N = -N; |
874 |
} |
} |
|
else |
|
|
uarg = N; |
|
875 |
|
|
876 |
if (uarg) |
tail = buf + sizeof(buf); |
877 |
{ |
*--tail = 0; |
|
for (i = 1; uarg; ++i) |
|
|
{ |
|
|
register ldiv_t r; |
|
878 |
|
|
879 |
r = ldiv(uarg, base); |
do |
880 |
*tail-- = (char) (r.rem + ((9L < r.rem) ? ('A' - 10L) : '0')); |
{ |
881 |
uarg = r.quot; |
divrem = N % base; |
882 |
} |
*--tail = (divrem <= 9) ? divrem + '0' : divrem + 'a' - 10; |
883 |
|
N /= base; |
884 |
} |
} |
885 |
else |
while (N); |
|
*tail-- = '0'; |
|
886 |
|
|
887 |
memcpy(head, ++tail, i); |
strcpy(head, tail); |
888 |
return ret; |
return ret; |
889 |
} |
} |
890 |
|
|