Avoid the " map_to_assuan_status called with no error source" diagnostic.
[gnupg.git] / common / asshelp.c
1 /* asshelp.c - Helper functions for Assuan
2  * Copyright (C) 2002, 2004 Free Software Foundation, Inc.
3  *
4  * This file is part of GnuPG.
5  *
6  * GnuPG is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * GnuPG is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
19  */
20
21 #include <config.h>
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <string.h>
25 #include <unistd.h>
26 #include <errno.h>
27 #ifdef HAVE_LOCALE_H
28 #include <locale.h>
29 #endif
30
31 #include "util.h"
32
33 #include "asshelp.h"
34
35
36 static gpg_error_t
37 send_one_option (assuan_context_t ctx, gpg_err_source_t errsource,
38                  const char *name, const char *value)
39 {
40   gpg_error_t err;
41   char *optstr;
42
43   if (!value || !*value)
44     err = 0;  /* Avoid sending empty strings.  */
45   else if (asprintf (&optstr, "OPTION %s=%s", name, value ) < 0)
46     err = gpg_error_from_errno (errno);
47   else
48     {
49       assuan_error_t ae;
50
51       ae = assuan_transact (ctx, optstr, NULL, NULL, NULL, NULL, NULL, NULL);
52       err = ae? map_assuan_err_with_source (errsource, ae) : 0;
53       free (optstr);
54     }
55
56   return err;
57 }
58
59
60 /* Send the assuan commands pertaining to the pinenry environment.  The
61    OPT_* arguments are optional and may be used to override the
62    defaults taken from the current locale. */
63 gpg_error_t
64 send_pinentry_environment (assuan_context_t ctx,
65                            gpg_err_source_t errsource,
66                            const char *opt_display,
67                            const char *opt_ttyname,
68                            const char *opt_ttytype,
69                            const char *opt_lc_ctype,
70                            const char *opt_lc_messages)
71 {
72   gpg_error_t err = 0;
73   char *dft_display = NULL;
74   char *dft_ttyname = NULL;
75   char *dft_ttytype = NULL;
76   char *old_lc = NULL; 
77   char *dft_lc = NULL;
78
79   /* Send the DISPLAY variable.  */
80   dft_display = getenv ("DISPLAY");
81   if (opt_display || dft_display)
82     {
83       err = send_one_option (ctx, errsource, "display", 
84                              opt_display ? opt_display : dft_display);
85       if (err)
86         return err;
87     }
88
89   /* Send the name of the TTY.  */
90   if (!opt_ttyname)
91     {
92       dft_ttyname = getenv ("GPG_TTY");
93       if ((!dft_ttyname || !*dft_ttyname) && ttyname (0))
94         dft_ttyname = ttyname (0);
95     }
96   if (opt_ttyname || dft_ttyname)
97     {
98       err = send_one_option (ctx, errsource, "ttyname", 
99                              opt_ttyname ? opt_ttyname : dft_ttyname);
100       if (err)
101         return err;
102     }
103
104   /* Send the type of the TTY.  */
105   dft_ttytype = getenv ("TERM");
106   if (opt_ttytype || (dft_ttyname && dft_ttytype))
107     {
108       err = send_one_option (ctx, errsource, "ttytype", 
109                              opt_ttyname ? opt_ttytype : dft_ttytype);
110       if (err)
111         return err;
112     }
113
114   /* Send the value for LC_CTYPE.  */
115 #if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
116   old_lc = setlocale (LC_CTYPE, NULL);
117   if (old_lc)
118     {
119       old_lc = strdup (old_lc);
120       if (!old_lc)
121         return gpg_error_from_errno (errno);
122     }
123   dft_lc = setlocale (LC_CTYPE, "");
124 #endif
125   if (opt_lc_ctype || (dft_ttyname && dft_lc))
126     {
127       err = send_one_option (ctx, errsource, "lc-ctype", 
128                              opt_lc_ctype ? opt_lc_ctype : dft_lc);
129     }
130 #if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
131   if (old_lc)
132     {
133       setlocale (LC_CTYPE, old_lc);
134       free (old_lc);
135     }
136 #endif
137   if (err)
138     return err;
139
140   /* Send the value for LC_MESSAGES.  */
141 #if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
142   old_lc = setlocale (LC_MESSAGES, NULL);
143   if (old_lc)
144     {
145       old_lc = strdup (old_lc);
146       if (!old_lc)
147         return gpg_error_from_errno (errno);
148     }
149   dft_lc = setlocale (LC_MESSAGES, "");
150 #endif
151   if (opt_lc_messages || (dft_ttyname && dft_lc))
152     {
153       err = send_one_option (ctx, errsource, "display", 
154                              opt_lc_messages ? opt_lc_messages : dft_lc);
155     }
156 #if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
157   if (old_lc)
158     {
159       setlocale (LC_MESSAGES, old_lc);
160       free (old_lc);
161     }
162 #endif
163   if (err)
164     return err;
165
166   return 0;
167 }
168