diff options
author | Jeremie Guichard <djebrest@gmail.com> | 2017-02-24 14:06:48 +0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2017-02-24 01:10:22 -0800 |
commit | 5ed93a9d9e7d35ab680ba763aa0c2e8302ef6b08 (patch) | |
tree | bcee6fd3501bc44a06a5856c864f4bfbbc8be7f0 /core/git-access.c | |
parent | 5640a6a83951faefda0f22594044a34cb385e9fd (diff) | |
download | subsurface-5ed93a9d9e7d35ab680ba763aa0c2e8302ef6b08.tar.gz |
Fix "Load/Save to cloudstorage" for non-ASCII user names
On Windows that would fail because stat() doesn't deal well with our
utf8 strings.
Added new subsurface_stat() portability function to replace stat().
Added Windows implementation of subsurface_stat() using wstat(),
with conversion to ut16 of the inputed path.
Other platform implementations (linux, android) make use of the normal stat().
Added non ASCII test case in TestGitStorage::testGitStorageLocal()
Signed-off-by: Jeremie Guichard <djebrest@gmail.com>
Diffstat (limited to 'core/git-access.c')
-rw-r--r-- | core/git-access.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/core/git-access.c b/core/git-access.c index 458a7dd9a..b95606d86 100644 --- a/core/git-access.c +++ b/core/git-access.c @@ -768,7 +768,7 @@ static struct git_repository *get_remote_repo(const char *localdir, const char * } git_storage_update_progress(false, "start git interaction"); /* Do we already have a local cache? */ - if (!stat(localdir, &st)) { + if (!subsurface_stat(localdir, &st)) { if (!S_ISDIR(st.st_mode)) { if (is_subsurface_cloud) (void)cleanup_local_cache(remote, branch); @@ -934,7 +934,7 @@ struct git_repository *is_git_repository(const char *filename, const char **bran return repo; } - if (stat(loc, &st) < 0 || !S_ISDIR(st.st_mode)) { + if (subsurface_stat(loc, &st) < 0 || !S_ISDIR(st.st_mode)) { free(loc); free(branch); return dummy_git_repository; |