Commit 2dfc0887 by Vicent Martí

Merge pull request #284 from nulltoken/topic/hide-git-dir

Hide ".git" directory on Windows upon creation of a non bare repository
parents cfef5fb7 6ac91dfe
...@@ -746,4 +746,16 @@ int gitfo_readlink__w32(const char *link, char *target, size_t target_len) ...@@ -746,4 +746,16 @@ int gitfo_readlink__w32(const char *link, char *target, size_t target_len)
return dwRet; return dwRet;
} }
int gitfo_hide_directory__w32(const char *path)
{
int error;
error = SetFileAttributes(path, FILE_ATTRIBUTE_HIDDEN) != 0 ?
GIT_SUCCESS : GIT_ERROR; /* MSDN states a "non zero" value indicates a success */
if (error < GIT_SUCCESS)
error = git__throw(GIT_EOSERR, "Failed to hide directory '%s'", path);
return error;
}
#endif #endif
...@@ -99,6 +99,7 @@ extern int gitfo_mv_force(const char *from, const char *to); ...@@ -99,6 +99,7 @@ extern int gitfo_mv_force(const char *from, const char *to);
extern int gitfo_lstat__w32(const char *file_name, struct stat *buf); extern int gitfo_lstat__w32(const char *file_name, struct stat *buf);
extern int gitfo_readlink__w32(const char *link, char *target, size_t target_len); extern int gitfo_readlink__w32(const char *link, char *target, size_t target_len);
extern int gitfo_hide_directory__w32(const char *path);
#else #else
# define gitfo_lstat(p,b) lstat(p,b) # define gitfo_lstat(p,b) lstat(p,b)
# define gitfo_readlink(a, b, c) readlink(a, b, c) # define gitfo_readlink(a, b, c) readlink(a, b, c)
......
...@@ -648,6 +648,15 @@ static int repo_init_structure(repo_init *results) ...@@ -648,6 +648,15 @@ static int repo_init_structure(repo_init *results)
if (gitfo_mkdir_recurs(git_dir, mode)) if (gitfo_mkdir_recurs(git_dir, mode))
return git__throw(GIT_ERROR, "Failed to initialize repository structure. Could not mkdir"); return git__throw(GIT_ERROR, "Failed to initialize repository structure. Could not mkdir");
#ifdef GIT_WIN32
/* Hides the ".git" directory */
if (!results->is_bare) {
error = gitfo_hide_directory__w32(git_dir);
if (error < GIT_SUCCESS)
return git__rethrow(error, "Failed to initialize repository structure");
}
#endif
/* Creates the '/objects/info/' directory */ /* Creates the '/objects/info/' directory */
git__joinpath(temp_path, git_dir, GIT_OBJECTS_INFO_DIR); git__joinpath(temp_path, git_dir, GIT_OBJECTS_INFO_DIR);
error = gitfo_mkdir_recurs(temp_path, mode); error = gitfo_mkdir_recurs(temp_path, mode);
......
...@@ -127,6 +127,11 @@ static int ensure_repository_init( ...@@ -127,6 +127,11 @@ static int ensure_repository_init(
if (git__suffixcmp(repo->path_index, expected_path_index) != 0) if (git__suffixcmp(repo->path_index, expected_path_index) != 0)
goto cleanup; goto cleanup;
#ifdef GIT_WIN32
if ((GetFileAttributes(repo->path_repository) & FILE_ATTRIBUTE_HIDDEN) == 0)
goto cleanup;
#endif
if (git_repository_is_bare(repo) == 1) if (git_repository_is_bare(repo) == 1)
goto cleanup; goto cleanup;
} else if (git_repository_is_bare(repo) == 0) } else if (git_repository_is_bare(repo) == 0)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment