/[winpt]/trunk/Src/wptRegistry.cpp
ViewVC logotype

Diff of /trunk/Src/wptRegistry.cpp

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

revision 48 by werner, Mon Oct 31 21:14:11 2005 UTC revision 181 by twoaday, Tue Mar 14 11:01:22 2006 UTC
# Line 33  Line 33 
33  #include "wptTypes.h"  #include "wptTypes.h"
34  #include "wptNLS.h"  #include "wptNLS.h"
35  #include "wptVersion.h"  #include "wptVersion.h"
36    #include "wptHotkey.h"
37    
38  #define rc_ok(rc) ((rc) == ERROR_SUCCESS)  #define rc_ok(rc) ((rc) == ERROR_SUCCESS)
39    
40  static gpg_filetype gpg_filetypes[] = {  #define WINPT_REG "Software\\WinPT"
     {"GPG Detached Signature", ".sig", 1},  
     {"GPG Encrypted Data",     ".gpg", 2},  
     {"GPG Armored Data",       ".asc", 2},  
     {0}  
 };  
41    
42  struct reg_hotkey_s reg_hotkeys[] = {  /* GPG file association context. */
43      {"ClipEncrypt", NULL, 0},  struct gpg_filetype {    
44      {"ClipDecrypt", NULL, 0},      const char *descr;
45      {"ClipSign",    NULL, 0},      const char *ext;
46      {"ClipSignEnc", NULL, 0},      int nicon;
     {"CwsEncrypt",  NULL, 0},  
     {"CwsDecrypt",  NULL, 0},  
     {"CwsSign",     NULL, 0},  
     {"CwsSignEnc",  NULL, 0},  
     {0}  
47  };  };
48    
49    /* Global WinPT registry prefereneces. */
50  winpt_reg_prefs_s reg_prefs;  winpt_reg_prefs_s reg_prefs;
51    
52  #define WINPT_REG "Software\\WinPT"  
53    /* Return != 0 if GPG4win is installed. */
54    int
55    is_gpg4win_installed (void)
56    {
57        char *p;
58    
59        p = get_reg_entry_gpg4win (NULL);
60        if (!p)
61            return 0;
62        if (dir_exist_check (p)) {
63            free_if_alloc (p);
64            return 0;
65        }
66        free_if_alloc (p);
67        return -1;
68    }
69    
70    
71    /* Return != 0 if GPGee is installed. */
72    int
73    is_gpgee_installed (void)
74    {
75        HKEY hk;
76        LONG ec;
77    
78        ec = RegOpenKeyEx (HKEY_CURRENT_USER, "Software\\GPGee", 0, KEY_READ, &hk);
79        if (ec == ERROR_SUCCESS) {
80            RegCloseKey (hk);
81            return -1;
82        }
83    
84        return 0;
85    }
86    
87    
88    /* Free all members in the registry preference struct. */
89  void  void
90  free_reg_prefs (void)  free_reg_prefs (void)
91  {  {
# Line 67  free_reg_prefs (void) Line 93  free_reg_prefs (void)
93      free_if_alloc (reg_prefs.kserv_conf);      free_if_alloc (reg_prefs.kserv_conf);
94      free_if_alloc (reg_prefs.homedir);      free_if_alloc (reg_prefs.homedir);
95      memset (&reg_prefs, 0, sizeof reg_prefs);      memset (&reg_prefs, 0, sizeof reg_prefs);
96  } /* free_reg_prefs */  }
97    
98    
99  /* Register the given WinPT filetype. */  /* Register the given WinPT filetype. */
100  static int  static int
101  regist_single_filetype (gpg_filetype *gfile)  regist_single_filetype (gpg_filetype *gfile)
102  {  {
103      char icon[256], prog[256];      char icon[256];
104        char prog[256];
105            
106      memset (&icon, 0, sizeof (icon));      memset (&icon, 0, sizeof (icon));
107      GetModuleFileName (glob_hinst, prog, sizeof (prog)-1);      GetModuleFileName (glob_hinst, prog, sizeof (prog)-1);
108      _snprintf (icon, sizeof (icon) -1, "%s,%d", prog, gfile->nicon);      _snprintf (icon, sizeof (icon) -1, "%s,%d", prog, gfile->nicon);
109      return create_file_type (prog, gfile->ext, gfile->descr, icon);      return create_file_type (prog, gfile->ext, gfile->descr, icon);
110  } /* regist_single_filetype */  }
111    
112    
113  /* Install the GPG related into the W32 resgistry, if the entry already  /* Install the GPG related into the W32 resgistry, if the entry already
# Line 113  regist_inst_gnupg (int create_mokey) Line 140  regist_inst_gnupg (int create_mokey)
140      }      }
141    
142      return 0;      return 0;
143  } /* regist_inst_gpg */  }
144    
145    
146  /* Install WinPT into the W32 registry, if the entry already  /* Install WinPT into the W32 registry, if the entry already
147     exists the function returns immediately.*/     exists the function returns immediately. @with_ext can be
148       used to register some file types (if 1). @created contains
149       1 if the registry key was created.
150       Return value: 0 on success. */
151  int  int
152  regist_inst_winpt (int with_ext, int * created)  regist_inst_winpt (int with_ext, int *created)
153  {  {    
154      HKEY reg;      HKEY reg;
155      char * p = NULL;      char *p = NULL;
156      int rc, i, id, n = 0;      char modpath[MAX_PATH+1];
157        int rc, i, id, n;
158    
159        gpg_filetype gpg_filetypes[] = {
160            {_("GPG Detached Signature"), ".sig", 1},
161            {_("GPG Encrypted Data"),     ".gpg", 2},
162            {_("GPG Armored Data"),       ".asc", 2},
163            {0}
164        };
165    
166      if( created )      if (created)
167          *created = 0;          *created = 0;
168        if (is_gpgee_installed ())
     p = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, "Extensions");  
     if (p && *p == '1')  
169          with_ext = 0;          with_ext = 0;
     free_if_alloc( p );  
170    
171      if( with_ext ) {      rc = RegOpenKeyEx (HKEY_CURRENT_USER, WINPT_REG, 0, KEY_READ, &reg);
172          id = msg_box( NULL, _("WinPT can register some GPG file types for you so they can "      if (rc_ok (rc)) {
173                                "be processed with a double click in the explorer.\n"          RegCloseKey (reg);
174                                "Do you want to continue?"), _("WinPT"), MB_YESNO|MB_INFO );          rc = RegOpenKeyEx (HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", 0, KEY_READ, &reg);
175          if( id == IDNO ) {          if (!rc_ok (rc)) {
176              set_reg_entry( HKEY_CURRENT_USER, WINPT_REG, "Extensions", "1" );              RegCreateKey (HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", &reg);
177              goto start;              RegCloseKey (reg);
         }  
         for( i = 0; gpg_filetypes[i].ext; i++ ) {  
             rc = RegOpenKeyEx( HKEY_CLASSES_ROOT, gpg_filetypes[i].ext, 0, KEY_READ, &reg );  
             if( rc_ok( rc ) ) {  
                 RegCloseKey( reg );  
                 id = log_box( _("WinPT WARNING"), MB_YESNO|MB_INFO,  
                               _("It seems there was already a '%s' file type registered by another application.\n"  
                                 "Do you want to overwrite it?"), gpg_filetypes[i].ext );  
                 if( id == IDNO )  
                     continue;  
             }  
             regist_single_filetype( &gpg_filetypes[i] );  
             n++;  
         }  
     }  
           
 start:  
     rc = RegOpenKeyEx( HKEY_CURRENT_USER, WINPT_REG, 0, KEY_READ, &reg );  
     if( rc_ok( rc ) ) {  
         RegCloseKey( reg );  
         rc = RegOpenKeyEx( HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", 0, KEY_READ, &reg );  
         if( !rc_ok( rc ) ) {  
             RegCreateKey( HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", &reg );  
             RegCloseKey( reg );  
178          }          }
179          p = get_reg_entry_keyserver ("Default");          p = get_reg_entry_keyserver ("Default");
180          if (!p) {          if (!p) {
# Line 172  start: Line 183  start:
183              set_reg_entry_keyserver ("Default_Port", buf);              set_reg_entry_keyserver ("Default_Port", buf);
184              set_reg_entry_keyserver ("Default", DEF_HKP_KEYSERVER);              set_reg_entry_keyserver ("Default", DEF_HKP_KEYSERVER);
185          }          }
186          free_if_alloc( p );          free_if_alloc (p);
         if( n )  
             set_reg_entry( HKEY_CURRENT_USER, WINPT_REG, "Extensions", "1" );  
187          return 0;          return 0;
188      }      }
189      rc = RegCreateKey( HKEY_CURRENT_USER, WINPT_REG, &reg );      rc = RegCreateKey (HKEY_CURRENT_USER, WINPT_REG, &reg);
190      if( !rc_ok( rc ) )      if (!rc_ok (rc))
191          return WPTERR_REGISTRY;          return WPTERR_REGISTRY;
192      if( created )      if (created)
193          *created = 1;          *created = 1;
194      RegCloseKey( reg );      RegCloseKey (reg);
195      if( n )      if (with_ext) {
196          set_reg_entry( HKEY_CURRENT_USER, WINPT_REG, "Extensions", "1" );          id = msg_box (NULL, _("WinPT can register some GPG file types for you so they can "
197                                  "be processed with a double click in the explorer.\n"
198                                  "Do you want to continue?"), _("WinPT"), MB_YESNO|MB_INFO);
199            if (id == IDYES) {
200                for (i = 0; gpg_filetypes[i].ext; i++) {
201                    rc = RegOpenKeyEx (HKEY_CLASSES_ROOT, gpg_filetypes[i].ext, 0, KEY_READ, &reg);
202                    if (rc_ok (rc)) {
203                    RegCloseKey (reg);
204                        id = log_box (_("WinPT WARNING"), MB_YESNO|MB_INFO,
205                                      _("It seems there was already a '%s' file type registered by another application.\n"
206                                        "Do you want to overwrite it?"), gpg_filetypes[i].ext);
207                        if (id == IDNO)
208                            continue;
209                    }
210                    regist_single_filetype (&gpg_filetypes[i]);
211                }
212            }
213        }
214        if ((n=GetModuleFileName (NULL, modpath, MAX_PATH-1)) > 0) {
215            while (n-- > 0) {
216                if (modpath[n] == '\\') {
217                    modpath[n] = 0;
218                    break;
219                }
220            }
221            set_reg_entry (HKEY_CURRENT_USER, WINPT_REG, "Install Directory", modpath);
222        }
223      return 0;      return 0;
224  } /* regist_inst_winpt */  }
225    
226    
227  /* Create a new filetype in the W32 registry.  /* Create a new filetype in the W32 registry.
228     We should really care of errors! Otherwise we can damage the registry! */     We should really care of errors! Otherwise we can damage the registry! */
229  int  int
230  create_file_type( const char *exefile, const char *ext, const char *extname, char *iconfile )  create_file_type (const char *exefile, const char *ext,
231                      const char *extname, char *iconfile)
232  {  {
233      int rc;      int rc;
234      HKEY reg = NULL;      HKEY reg = NULL;
# Line 258  expand_path (const char *path) Line 294  expand_path (const char *path)
294          return NULL;          return NULL;
295      len += 1;      len += 1;
296      p = new char[len+1];      p = new char[len+1];
297      if( !p )      if (!p)
298          return NULL;          return NULL;
299      len = ExpandEnvironmentStrings (path, p, len);      len = ExpandEnvironmentStrings (path, p, len);
300      if (!len) {      if (!len) {
# Line 266  expand_path (const char *path) Line 302  expand_path (const char *path)
302          return NULL;          return NULL;
303      }      }
304      return p;      return p;
305  } /* expand_path */  }
306    
307    
308  /* Retrieve a registry entry with the directory given in @dir  /* Retrieve a registry entry with the directory given in @dir
# Line 277  get_reg_entry (HKEY root_key, const char Line 313  get_reg_entry (HKEY root_key, const char
313  {  {
314      int rc;      int rc;
315      char text[384] = {0};      char text[384] = {0};
316      DWORD nbytes, type, n1 = 0;      DWORD nbytes, type;
317      HKEY reg_key = NULL;      HKEY reg_key = NULL;
318      char * p = NULL, * tmp = NULL;      char * p = NULL;
319            
320      rc = RegOpenKeyEx (root_key, dir, 0, KEY_QUERY_VALUE, &reg_key);      rc = RegOpenKeyEx (root_key, dir, 0, KEY_QUERY_VALUE, &reg_key);
321      if( !rc_ok( rc ) )      if( !rc_ok( rc ) )
# Line 373  set_reg_entry_mo (const char * value) Line 409  set_reg_entry_mo (const char * value)
409  }  }
410    
411    
412  char *  char*
413  get_reg_entry_gpg (const char *key)  get_reg_entry_gpg (const char *key)
414  {  {
415      return get_reg_entry (HKEY_CURRENT_USER, "Software\\GNU\\GnuPG", key);      char *p;
416        p = get_reg_entry (HKEY_CURRENT_USER, "Software\\GNU\\GnuPG", key);
417        if (!p || strlen (p) == 0) {
418            free_if_alloc (p);
419            return NULL;
420        }
421        return p;
422  }  }
423    
424    
425  char *  /* Return if possible the GPG4Win installation directory concatenated
426  get_reg_entry_mo(void)     with the string in @path if given. */
427    char*
428    get_reg_entry_gpg4win (const char *path)
429    {
430        char *p, *pp;
431        p = get_reg_entry (HKEY_LOCAL_MACHINE,
432                           "Software\\GNU\\GnuPG", "Install Directory");
433        if (!p)
434            return NULL;
435        if (!path)
436            return p;
437        pp = new char[strlen (p) + strlen (path) + 4];
438        if (!pp)
439            BUG (NULL);
440        sprintf (pp, "%s\\%s", p, path);
441        free_if_alloc (p);
442        return pp;
443    }
444    
445        
446    char*
447    get_reg_entry_mo (void)
448  {        {      
449      return get_reg_entry(HKEY_CURRENT_USER,      char *p, *pp;
450                           "Control Panel\\Mingw32\\NLS", "MODir");      const char *lang;
451    
452        p = get_reg_entry (HKEY_CURRENT_USER,
453                           "Control Panel\\Mingw32\\NLS", "MODir");
454        if (p)
455            return p;
456    
457        lang = get_gettext_langid ();
458        if (!lang)    
459            return NULL;    
460        pp = new char[strlen ("share\\xxxxx\\locale\\LC_MESSAGES")+8];
461        if (!pp)    
462            BUG (NULL);
463        sprintf (pp, "share\\locale\\%s\\LC_MESSAGES", lang);
464        p = get_reg_entry_gpg4win (pp);
465        free_if_alloc (pp);
466        return p;
467  }  }
468    
469    
470  /* All valid configuration commands. */  /* All valid configuration commands. */
471  static const char * cfg [] = {  static const char *cfg [] = {
472          NULL,      NULL,      
473          "CacheTime",      "CacheTime",
474          "WordWrap",      "WordWrap",
475          "FastMode",      "FastMode",
476          "Viewer",      "Viewer",
477          "KeylistMode",      "WipeMode",
478          "WipeMode",      "AlwaysTrust",
479          "AlwaysTrust",      "AutoBackup",
480          "AutoBackup",      "BackupMode",
481          "BackupMode",      "DisableHotkeys",  
482          "DisableHotkeys",            "NoCompressMultiMedia",    
483          "NoCompressMultiMedia",      "Expert",
484          "Expert",      "FMProgressBar",
485          "FMProgressBar",  };
     };  
486    
487    
488  int  int
# Line 440  int Line 518  int
518  set_reg_winpt_prefs (winpt_reg_prefs_s * opt)  set_reg_winpt_prefs (winpt_reg_prefs_s * opt)
519  {  {
520      char buf[128];      char buf[128];
521      int rc = 0, i;      size_t i;
522        int rc = 0;
523    
524      for (i=1; i < DIM (cfg); i++) {      for (i=1; i < DIM (cfg); i++) {
525          switch (i) {          switch (i) {
# Line 462  set_reg_winpt_prefs (winpt_reg_prefs_s * Line 541  set_reg_winpt_prefs (winpt_reg_prefs_s *
541          case CFG_VIEWER:          case CFG_VIEWER:
542              sprintf (buf, "%d", opt->use_viewer);              sprintf (buf, "%d", opt->use_viewer);
543              break;              break;
         case CFG_KEYLISTMODE:  
             sprintf (buf, "%d", opt->keylist_mode);  
             break;  
544          case CFG_ALWAYSTRUST:          case CFG_ALWAYSTRUST:
545              sprintf (buf, "%d", opt->always_trust);              sprintf (buf, "%d", opt->always_trust);
546              break;              break;
# Line 496  set_reg_winpt_prefs (winpt_reg_prefs_s * Line 572  set_reg_winpt_prefs (winpt_reg_prefs_s *
572          if (rc)          if (rc)
573              goto leave;              goto leave;
574      }      }
     if (opt->kserv_conf) {  
         rc = set_reg_entry (HKEY_CURRENT_USER, WINPT_REG, "KeyserverConfig",  
                             opt->kserv_conf);  
         if (rc)  
             goto leave;  
     }  
575    
576      for (i=0; reg_hotkeys[i].reg_entry; i++) {      for (i=0; wpt_hotkeys[i].name; i++) {
577          strcpy (buf, " ");          if (wpt_hotkeys[i].enabled) {
578          if (reg_hotkeys[i].enabled)              buf[0] = wpt_hotkeys[i].key;
579              strcpy (buf, reg_hotkeys[i].key);              buf[1] = 0;
580            }
581            else
582                strcpy (buf, " ");
583          rc = set_reg_key (HKEY_CURRENT_USER, WINPT_REG,          rc = set_reg_key (HKEY_CURRENT_USER, WINPT_REG,
584                            reg_hotkeys[i].reg_entry, buf);                            wpt_hotkeys[i].name, buf);
585          if (rc)          if (rc)
586              break;              break;
587      }      }
# Line 549  get_reg_winpt_flag (const char * name) Line 622  get_reg_winpt_flag (const char * name)
622  int  int
623  get_reg_winpt_prefs (winpt_reg_prefs_s * opt)  get_reg_winpt_prefs (winpt_reg_prefs_s * opt)
624  {  {
625      char * val = NULL;      char *val = NULL;
626      int i;      size_t i;
627    
628      for (i=1; i < DIM (cfg); i++) {      for (i=1; i < DIM (cfg); i++) {
629          val = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, cfg[i]);          val = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, cfg[i]);
# Line 561  get_reg_winpt_prefs (winpt_reg_prefs_s * Line 634  get_reg_winpt_prefs (winpt_reg_prefs_s *
634          switch (i) {          switch (i) {
635          case CFG_CACHETIME:          case CFG_CACHETIME:
636              opt->cache_time = atol (val);              opt->cache_time = atol (val);
             /* We do NOT support passphrase caching for more than an hour.  
              * Perhaps we should allow it, but for now we silently drop this.  
              */  
             if (opt->cache_time > 3600)  
                 opt->cache_time = 3600;  
637              break;              break;
638          case CFG_WORDWRAP:          case CFG_WORDWRAP:
639              opt->word_wrap = atol (val);              opt->word_wrap = atol (val);
# Line 579  get_reg_winpt_prefs (winpt_reg_prefs_s * Line 647  get_reg_winpt_prefs (winpt_reg_prefs_s *
647          case CFG_VIEWER:          case CFG_VIEWER:
648              opt->use_viewer = atol (val);              opt->use_viewer = atol (val);
649              break;              break;
         case CFG_KEYLISTMODE:  
             opt->keylist_mode = atol (val);  
             break;  
650          case CFG_WIPEMODE:          case CFG_WIPEMODE:
651              opt->wipe_mode = atol (val);              opt->wipe_mode = atol (val);
652              break;              break;
# Line 600  get_reg_winpt_prefs (winpt_reg_prefs_s * Line 665  get_reg_winpt_prefs (winpt_reg_prefs_s *
665          case CFG_EXPERT:          case CFG_EXPERT:
666              opt->expert = atol (val);              opt->expert = atol (val);
667              break;              break;
   
668          case CFG_FM_PROGRESS:          case CFG_FM_PROGRESS:
669              opt->fm.progress = atol (val);              opt->fm.progress = atol (val);
670              break;              break;
# Line 612  get_reg_winpt_prefs (winpt_reg_prefs_s * Line 676  get_reg_winpt_prefs (winpt_reg_prefs_s *
676      if (val && val[0] != ' ')      if (val && val[0] != ' ')
677          opt->backup.path = m_strdup (val);          opt->backup.path = m_strdup (val);
678      free_if_alloc (val);      free_if_alloc (val);
   
     val = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, "KeyserverConfig");  
     if (val && val[0] != ' ')  
         opt->kserv_conf = m_strdup (val);  
     free_if_alloc (val);  
679            
680      for (i=0; reg_hotkeys[i].reg_entry; i++) {      for (i=0; wpt_hotkeys[i].name; i++) {
681          val = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, reg_hotkeys[i].reg_entry);          wpt_hotkeys[i].enabled = 0;
682            val = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG, wpt_hotkeys[i].name);
683          if (val && val[0] != ' ') {          if (val && val[0] != ' ') {
684              reg_hotkeys[i].key[0] = *val;              wpt_hotkeys[i].key = *val;
685              reg_hotkeys[i].enabled = 1;              wpt_hotkeys[i].enabled = 1;
686          }          }
         else  
             reg_hotkeys[i].enabled = 0;  
687          free_if_alloc (val);          free_if_alloc (val);
688      }      }
689      return 0;      return 0;
690  } /* get_reg_winpt_prefs */  }
691    
692    
693  char*  char*
694  get_reg_entry_keyserver (const char *name)  get_reg_entry_keyserver (const char *name)
695  {  {
696      char * p = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", name);      char *p = get_reg_entry (HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", name);
697      if (p && !strcmp (p, "")) {      if (p && (!strcmp (p, "") || strlen (p) == 0)) {
698          free_if_alloc (p);          free_if_alloc (p);
699          return NULL;          return NULL;
700      }      }
# Line 644  get_reg_entry_keyserver (const char *nam Line 702  get_reg_entry_keyserver (const char *nam
702  }  }
703    
704    
705    int
706    set_reg_entry_keyserver (const char * name, const char * val)
707    {
708        return set_reg_entry( HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", name, val );
709    }
710    
711    static int
712    get_reg_entry_keyserver_int (const char *key)
713    {
714        char *p;
715        int val = 0;
716    
717        p = get_reg_entry_keyserver (key);
718        if (p && *p)
719            val = atoi (p);
720        free_if_alloc (p);
721        return val;
722    }
723    
724    
725  void  void
726  get_reg_proxy_prefs (char ** host, int * port, char ** user, char ** pass)  get_reg_proxy_prefs (keyserver_proxy_t prox)
727  {  {
728      if (host)      if (!prox)
729          *host = get_reg_entry_keyserver ("Host");          return;
730      if (user)      
731          *user = get_reg_entry_keyserver ("User");      free_if_alloc (prox->host);
732      if (pass)      prox->host = get_reg_entry_keyserver ("Host");
733          *pass = get_reg_entry_keyserver ("Pass");      free_if_alloc (prox->user);
734      if (port) {      prox->user = get_reg_entry_keyserver ("User");
735          char * p = get_reg_entry_keyserver ("Port");      free_if_alloc (prox->pass);
736          if (p) {      prox->pass = get_reg_entry_keyserver ("Pass");
737              *port = atol (p);      prox->port = get_reg_entry_keyserver_int ("Port");
738              free_if_alloc (p);  }
         }  
     }  
 } /* get_reg_proxy_prefs */  
739    
740    
741  int  static int
742  set_reg_entry_keyserver( const char * name, const char * val )  set_reg_entry_keyserver_int (const char *key, int val)
743  {  {
744      return set_reg_entry( HKEY_CURRENT_USER, WINPT_REG"\\Keyserver", name, val );      char buf[32];
745  } /* set_reg_entry_keyserver */  
746        sprintf (buf, "%d", val);
747        return set_reg_entry_keyserver (key, buf);
748    }
749    
750    
751  int  int
752  set_reg_proxy_prefs( const char * host, int port, const char * user, const char * pass )  set_reg_proxy_prefs (keyserver_proxy_t prox)
753  {  {    
754      int rc;      int rc;
755            
756      rc = set_reg_entry_keyserver( "Host", host? host : "" );      rc = set_reg_entry_keyserver_int ("Proto", prox->proto);
757      if( !rc ) {      if (!rc)
758          char buf[32];          rc = set_reg_entry_keyserver ("Host", prox->host? prox->host : "");
759          sprintf( buf, "%d", port );      if (!rc)
760          rc = set_reg_entry_keyserver( "Port", buf );          rc = set_reg_entry_keyserver_int ("Port", prox->port);
761      }      if (!rc)
762      if( !rc )          rc = set_reg_entry_keyserver ("User", prox->user? prox->user : "");
763          rc = set_reg_entry_keyserver( "User", user? user : "" );      if (!rc)
764      if( !rc )          rc = set_reg_entry_keyserver ("Pass", prox->pass? prox->pass : "");
         rc = set_reg_entry_keyserver( "Pass", pass? pass : "" );  
765      return rc;      return rc;
766  } /* set_reg_proxy_prefs */  }

Legend:
Removed from v.48  
changed lines
  Added in v.181

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26