/[rdesktop]/jpeg/rdesktop/trunk/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 /jpeg/rdesktop/trunk/rdesktop.c

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

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

Legend:
Removed from v.857  
changed lines
  Added in v.964

  ViewVC Help
Powered by ViewVC 1.1.26