summaryrefslogtreecommitdiff
path: root/src/sysutils.c
diff options
context:
space:
mode:
authorWerner Koch <wk@gnupg.org>2017-11-28 16:36:12 +0100
committerWerner Koch <wk@gnupg.org>2017-11-28 16:36:12 +0100
commit513415c71781ab400ebb01f6b4cf2984ec6b1757 (patch)
tree6f9cb0358004276c092d97423c615428579fdef1 /src/sysutils.c
parent930d27ba6b1205395add0c79139e62355a1d5b62 (diff)
downloadlibgpg-error-513415c71781ab400ebb01f6b4cf2984ec6b1757.tar.gz
core: Change new functions to return gpg_err_code_t.
* src/gpg-error.h.in (gpgrt_sentenv, gpgrt_mkdir, gpgrt_chdir): Change return type to gpg_err_code_t. * src/sysutils.c (_gpgrt_setenv): Implement that. (_gpgrt_mkdir): Ditto. (_gpgrt_chdir): Ditto. * gpgscm/ffi.c (do_setenv, do_mkdir): Adjust for this change. -- The functions are already a bit different and thus it is useful to let them return a gpg-error style error code and don't let the user implement that for each call. Signed-off-by: Werner Koch <wk@gnupg.org>
Diffstat (limited to 'src/sysutils.c')
-rw-r--r--src/sysutils.c67
1 files changed, 38 insertions, 29 deletions
diff --git a/src/sysutils.c b/src/sysutils.c
index 70c2dc3..1f2c293 100644
--- a/src/sysutils.c
+++ b/src/sysutils.c
@@ -118,14 +118,11 @@ _gpgrt_getenv (const char *name)
/* Wrapper around setenv so that we can have the same function in
* Windows and Unix. In contrast to the standard setenv passing a
* VALUE as NULL and setting OVERWRITE will remove the envvar. */
-int
+gpg_err_code_t
_gpgrt_setenv (const char *name, const char *value, int overwrite)
{
if (!name || !*name || strchr (name, '='))
- {
- _gpg_err_set_errno (EINVAL);
- return -1;
- }
+ return GPG_ERR_EINVAL;
#ifdef HAVE_W32_SYSTEM
/* Windows maintains (at least) two sets of environment variables.
@@ -143,34 +140,30 @@ _gpgrt_setenv (const char *name, const char *value, int overwrite)
if (!value && overwrite)
{
if (!SetEnvironmentVariable (name, NULL))
- {
- _gpg_err_set_errno (EINVAL);
- return -1;
- }
+ return GPG_ERR_EINVAL;
if (getenv (name))
{
/* Ugly: Leaking memory. */
buf = _gpgrt_strdup (name);
if (!buf)
- return -1;
- return putenv (buf);
+ return _gpg_err_code_from_syserror ();
+ if (putenv (buf))
+ return _gpg_err_code_from_syserror ();
}
return 0;
}
exists = GetEnvironmentVariable (name, tmpbuf, sizeof tmpbuf);
if ((! exists || overwrite) && !SetEnvironmentVariable (name, value))
- {
- _gpg_err_set_errno (EINVAL); /* (Might also be ENOMEM.) */
- return -1;
- }
+ return GPG_ERR_EINVAL; /* (Might also be ENOMEM.) */
if (overwrite || !getenv (name))
{
/* Ugly: Leaking memory. */
buf = _gpgrt_strconcat (name, "=", value, NULL);
if (!buf)
- return -1;
- return putenv (buf);
+ return _gpg_err_code_from_syserror ();
+ if (putenv (buf))
+ return _gpg_err_code_from_syserror ();
}
return 0;
}
@@ -181,9 +174,17 @@ _gpgrt_setenv (const char *name, const char *value, int overwrite)
{
if (!value && overwrite)
- return unsetenv (name);
+ {
+ if (unsetenv (name))
+ return _gpg_err_code_from_syserror ();
+ }
else
- return setenv (name, value, overwrite);
+ {
+ if (setenv (name, value, overwrite))
+ return _gpg_err_code_from_syserror ();
+ }
+
+ return 0;
}
# else /*!HAVE_SETENV*/
@@ -200,16 +201,18 @@ _gpgrt_setenv (const char *name, const char *value, int overwrite)
{
buf = _gpgrt_strdup (name);
if (!buf)
+ return _gpg_err_code_from_syserror ();
+ if (putenv (buf))
return -1;
- return putenv (buf);
}
}
else if (overwrite || !getenv (name))
{
buf = _gpgrt_strconcat (name, "=", value, NULL);
if (!buf)
- return -1;
- return putenv (buf);
+ return _gpg_err_code_from_syserror ();
+ if (putenv (buf))
+ return _gpg_err_code_from_syserror ();
}
return 0;
@@ -264,7 +267,7 @@ modestr_to_mode (const char *modestr)
* the second for the group and the third for all others. If the
* string is shorter than above the missing mode characters are meant
* to be not set. */
-int
+gpg_err_code_t
_gpgrt_mkdir (const char *name, const char *modestr)
{
#ifdef HAVE_W32CE_SYSTEM
@@ -273,11 +276,11 @@ _gpgrt_mkdir (const char *name, const char *modestr)
wname = utf8_to_wchar (name);
if (!wname)
- return -1;
+ return _gpg_err_code_from_syserror ();
if (!CreateDirectoryW (wname, NULL))
{
xfree (wname);
- return -1; /* ERRNO is automagically provided by gpg-error.h. */
+ return _gpg_err_code_from_syserror ();
}
xfree (wname);
return 0;
@@ -286,19 +289,25 @@ _gpgrt_mkdir (const char *name, const char *modestr)
/* Note: In the case of W32 we better use CreateDirectory and try to
set appropriate permissions. However using mkdir is easier
because this sets ERRNO. */
- return mkdir (name);
+ if (mkdir (name))
+ return _gpg_err_code_from_syserror ();
+ return 0;
#else
- return mkdir (name, modestr_to_mode (modestr));
+ if (mkdir (name, modestr_to_mode (modestr)))
+ return _gpg_err_code_from_syserror ();
+ return 0;
#endif
}
/* A simple wrapper around chdir. NAME is expected to be utf8
* encoded. */
-int
+gpg_err_code_t
_gpgrt_chdir (const char *name)
{
- return chdir (name);
+ if (chdir (name))
+ return _gpg_err_code_from_syserror ();
+ return 0;
}