mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-03 22:56:33 +02:00
Replace all calls to access by gnupg_access
* common/sysutils.c (gnupg_access): New. Replace all calls to access
by this wrapper.
* common/homedir.c (w32_shgetfolderpath): Change to return UTF-8
directory name.
(standard_homedir): Adjust for change.
(w32_commondir, gnupg_cachedir): Ditto.
--
Also use SHGetFolderPathW instead of SHGetFolderPathA on Windows.
This is required to correctly handle non-ascii filenames on Windows.
GnuPG-bug-id: 5098
(cherry picked from commit c94ee1386e
)
This commit is contained in:
parent
25bec16d0b
commit
dd5fd4a760
28 changed files with 163 additions and 115 deletions
|
@ -1707,7 +1707,7 @@ main ( int argc, char **argv)
|
|||
|
||||
filelist[0] = make_filename (gnupg_datadir (),"com-certs.pem", NULL);
|
||||
filelist[1] = NULL;
|
||||
if (!access (filelist[0], F_OK))
|
||||
if (!gnupg_access (filelist[0], F_OK))
|
||||
{
|
||||
log_info (_("importing common certificates '%s'\n"),
|
||||
filelist[0]);
|
||||
|
|
|
@ -113,6 +113,7 @@ try_make_homedir (const char *fname)
|
|||
static gpg_error_t
|
||||
maybe_create_keybox (char *filename, int force, int *r_created)
|
||||
{
|
||||
gpg_err_code_t ec;
|
||||
dotlock_t lockhd = NULL;
|
||||
FILE *fp;
|
||||
int rc;
|
||||
|
@ -124,8 +125,8 @@ maybe_create_keybox (char *filename, int force, int *r_created)
|
|||
*r_created = 0;
|
||||
|
||||
/* A quick test whether the filename already exists. */
|
||||
if (!access (filename, F_OK))
|
||||
return !access (filename, R_OK)? 0 : gpg_error (GPG_ERR_EACCES);
|
||||
if (!gnupg_access (filename, F_OK))
|
||||
return !gnupg_access (filename, R_OK)? 0 : gpg_error (GPG_ERR_EACCES);
|
||||
|
||||
/* If we don't want to create a new file at all, there is no need to
|
||||
go any further - bail out right here. */
|
||||
|
@ -160,9 +161,9 @@ maybe_create_keybox (char *filename, int force, int *r_created)
|
|||
tried = 1;
|
||||
try_make_homedir (filename);
|
||||
}
|
||||
if (access (filename, F_OK))
|
||||
if ((ec = gnupg_access (filename, F_OK)))
|
||||
{
|
||||
rc = gpg_error_from_syserror ();
|
||||
rc = gpg_error (ec);
|
||||
*last_slash_in_filename = save_slash;
|
||||
goto leave;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue