/[rdesktop]/sourceforge.net/trunk/rdesktop/rdesktop.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /sourceforge.net/trunk/rdesktop/rdesktop.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 861 by stargo, Sun Mar 13 17:40:51 2005 UTC revision 968 by astrand, Thu Aug 4 11:19:06 2005 UTC
# Line 27  Line 27 
27  #include <sys/time.h>           /* gettimeofday */  #include <sys/time.h>           /* gettimeofday */
28  #include <sys/times.h>          /* times */  #include <sys/times.h>          /* times */
29  #include <ctype.h>              /* toupper */  #include <ctype.h>              /* toupper */
30    #include <limits.h>             /* PATH_MAX */
31  #include <errno.h>  #include <errno.h>
32  #include "rdesktop.h"  #include "rdesktop.h"
33    
 #ifdef HAVE_ICONV  
34  #ifdef HAVE_LOCALE_H  #ifdef HAVE_LOCALE_H
35  #include <locale.h>  #include <locale.h>
36  #endif  #endif
37    #ifdef HAVE_ICONV
38  #ifdef HAVE_LANGINFO_H  #ifdef HAVE_LANGINFO_H
39  #include <langinfo.h>  #include <langinfo.h>
40  #endif  #endif
41  #endif  #endif
42    
43  #ifdef EGD_SOCKET  #ifdef EGD_SOCKET
44    #include <sys/types.h>
45  #include <sys/socket.h>         /* socket connect */  #include <sys/socket.h>         /* socket connect */
46  #include <sys/un.h>             /* sockaddr_un */  #include <sys/un.h>             /* sockaddr_un */
47  #endif  #endif
# Line 49  Line 51 
51  char g_title[64] = "";  char g_title[64] = "";
52  char g_username[64];  char g_username[64];
53  char g_hostname[16];  char g_hostname[16];
54  char keymapname[16];  char keymapname[PATH_MAX] = "en-us";
55  int g_keylayout = 0x409;        /* Defaults to US keyboard layout */  int g_keylayout = 0x409;        /* Defaults to US keyboard layout */
56    int g_keyboard_type = 0x4;      /* Defaults to US keyboard layout */
57    int g_keyboard_subtype = 0x0;   /* Defaults to US keyboard layout */
58    int g_keyboard_functionkeys = 0xc;      /* Defaults to US keyboard layout */
59    
60  int g_width = 800;              /* width is special: If 0, the  int g_width = 800;              /* width is special: If 0, the
61                                     geometry will be fetched from                                     geometry will be fetched from
# Line 60  int g_width = 800;             /* width is special: Line 65  int g_width = 800;             /* width is special:
65  int g_height = 600;  int g_height = 600;
66  int g_xpos = 0;  int g_xpos = 0;
67  int g_ypos = 0;  int g_ypos = 0;
68    int g_pos = 0;                  /* 0 position unspecified,
69                                       1 specified,
70                                       2 xpos neg,
71                                       4 ypos neg  */
72  extern int g_tcp_port_rdp;  extern int g_tcp_port_rdp;
73  int g_server_bpp = 8;  int g_server_bpp = 8;
74  int g_win_button_size = 0;      /* If zero, disable single app mode */  int g_win_button_size = 0;      /* If zero, disable single app mode */
# Line 166  usage(char *program) Line 175  usage(char *program)
175          fprintf(stderr, "   -5: use RDP version 5 (default)\n");          fprintf(stderr, "   -5: use RDP version 5 (default)\n");
176  }  }
177    
178  void  static void
179  print_disconnect_reason(uint16 reason)  print_disconnect_reason(uint16 reason)
180  {  {
181          char *text;          char *text;
# Line 365  main(int argc, char *argv[]) Line 374  main(int argc, char *argv[])
374          uint32 flags, ext_disc_reason = 0;          uint32 flags, ext_disc_reason = 0;
375          char *p;          char *p;
376          int c;          int c;
377            char *locale;
378          int username_option = 0;          int username_option = 0;
379    
380            /* Set locale according to environment */
381            locale = setlocale(LC_ALL, "");
382            if (locale)
383            {
384                    xkeymap_from_locale(locale);
385            }
386    
387          flags = RDP_LOGON_NORMAL;          flags = RDP_LOGON_NORMAL;
388          prompt_password = False;          prompt_password = False;
389          domain[0] = password[0] = shell[0] = directory[0] = 0;          domain[0] = password[0] = shell[0] = directory[0] = 0;
         strcpy(keymapname, "en-us");  
390          g_embed_wnd = 0;          g_embed_wnd = 0;
391    
392          g_num_devices = 0;          g_num_devices = 0;
# Line 481  main(int argc, char *argv[]) Line 496  main(int argc, char *argv[])
496                                  }                                  }
497    
498                                  if (*p == '+' || *p == '-')                                  if (*p == '+' || *p == '-')
499                                    {
500                                            g_pos |= (*p == '-') ? 2 : 1;
501                                          g_xpos = strtol(p, &p, 10);                                          g_xpos = strtol(p, &p, 10);
502    
503                                    }
504                                  if (*p == '+' || *p == '-')                                  if (*p == '+' || *p == '-')
505                                    {
506                                            g_pos |= (*p == '-') ? 4 : 1;
507                                          g_ypos = strtol(p, NULL, 10);                                          g_ypos = strtol(p, NULL, 10);
508                                    }
509    
510                                  break;                                  break;
511    
# Line 548  main(int argc, char *argv[]) Line 569  main(int argc, char *argv[])
569                                  break;                                  break;
570    
571                          case 'X':                          case 'X':
572                                  g_embed_wnd = strtol(optarg, NULL, 10);                                  g_embed_wnd = strtol(optarg, NULL, 0);
573                                  break;                                  break;
574    
575                          case 'a':                          case 'a':
# Line 563  main(int argc, char *argv[]) Line 584  main(int argc, char *argv[])
584    
585                          case 'z':                          case 'z':
586                                  DEBUG(("rdp compression enabled\n"));                                  DEBUG(("rdp compression enabled\n"));
587                                  flags |= RDP_COMPRESSION;                                  flags |= (RDP_LOGON_COMPRESSION | RDP_LOGON_COMPRESSION2);
588                                  break;                                  break;
589    
590                          case 'x':                          case 'x':
# Line 729  main(int argc, char *argv[]) Line 750  main(int argc, char *argv[])
750                  STRNCPY(g_hostname, fullhostname, sizeof(g_hostname));                  STRNCPY(g_hostname, fullhostname, sizeof(g_hostname));
751          }          }
752    
         if ((flags & RDP_COMPRESSION) && (g_server_bpp > 8))  
         {  
                 warning("rdp compression not supported for bpp > 8, compression disabled\n");  
                 flags ^= RDP_COMPRESSION;  
         }  
   
753          if (prompt_password && read_password(password, sizeof(password)))          if (prompt_password && read_password(password, sizeof(password)))
754                  flags |= RDP_LOGON_AUTO;                  flags |= RDP_LOGON_AUTO;
755    

Legend:
Removed from v.861  
changed lines
  Added in v.968

  ViewVC Help
Powered by ViewVC 1.1.26