diff options
author | Vicent Martà <tanoku@gmail.com> | 2012-04-02 17:25:05 -0700 |
---|---|---|
committer | Vicent Martà <tanoku@gmail.com> | 2012-04-02 17:25:05 -0700 |
commit | 2ec83ff09de3448b5439b2bc63e90398992ae8ca (patch) | |
tree | 8934ccfc5ca281cf3b05fa1d0955ddd03c39d21f /src/fileops.c | |
parent | 9273399bdb8f17ba6561de193fd1e518b9691a9a (diff) | |
parent | 09719c500ca798fea989867f50cf29d4dbed0c89 (diff) | |
download | libgit2-2ec83ff09de3448b5439b2bc63e90398992ae8ca.tar.gz |
Merge pull request #596 from nulltoken/fix/non-7bit-ascii-reference-names
Allow references to bear non-7bit-ascii names on Windows
Diffstat (limited to 'src/fileops.c')
-rw-r--r-- | src/fileops.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/src/fileops.c b/src/fileops.c index f1f820ab7..b3bb3890e 100644 --- a/src/fileops.c +++ b/src/fileops.c @@ -62,7 +62,18 @@ int git_futils_creat_withpath(const char *path, const mode_t dirmode, const mode int git_futils_creat_locked(const char *path, const mode_t mode) { - int fd = open(path, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY | O_EXCL, mode); + int fd; + +#ifdef GIT_WIN32 + wchar_t* buf; + + buf = gitwin_to_utf16(path); + fd = _wopen(buf, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY | O_EXCL, mode); + git__free(buf); +#else + fd = open(path, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY | O_EXCL, mode); +#endif + if (fd < 0) { giterr_set(GITERR_OS, "Failed to create locked file '%s'", path); return -1; |