diff options
| author | nulltoken <emeric.fermas@gmail.com> | 2010-12-17 10:41:56 +0100 |
|---|---|---|
| committer | nulltoken <emeric.fermas@gmail.com> | 2010-12-17 10:41:56 +0100 |
| commit | a67a096a9efdca1af66abc39c4bc276ebdaa8e47 (patch) | |
| tree | cb9836b72f40684e1560c18b12476180d1c91f17 | |
| parent | 58fcfc26e08b9b3ed607e32e5eb2fe8a95a8a19c (diff) | |
| download | libgit2-a67a096a9efdca1af66abc39c4bc276ebdaa8e47.tar.gz | |
Added creation of 'objects' and 'refs' directories.
| -rw-r--r-- | src/repository.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/repository.c b/src/repository.c index 6f1445dd6..4e5e7e699 100644 --- a/src/repository.c +++ b/src/repository.c @@ -35,6 +35,7 @@ #define GIT_FOLDER "/.git/" #define GIT_OBJECTS_FOLDER "objects/" +#define GIT_REFS_FOLDER "refs/" #define GIT_INDEX_FILE "index" #define GIT_HEAD_FILE "HEAD" @@ -742,9 +743,14 @@ int git_repository_init__create_structure(git_repository_init_results* results) { char temp_path[GIT_PATH_MAX]; int path_len; + const int mode = 0755; /* or 0777 ? */ char* git_dir = results->path_repository; + //TODO : Ensure the parent tree structure already exists by recursively building it through gitfo_mkdir_recurs(). + if (gitfo_mkdir_recurs(git_dir, mode)) + return GIT_ERROR; + path_len = strlen(git_dir); strcpy(temp_path, git_dir); @@ -755,6 +761,15 @@ int git_repository_init__create_structure(git_repository_init_results* results) return git_repository_init__reinit(results); } + strcpy(temp_path + path_len, GIT_OBJECTS_FOLDER); + if (gitfo_mkdir(temp_path, mode)) + return GIT_ERROR; + + strcpy(temp_path + path_len, GIT_REFS_FOLDER); + if (gitfo_mkdir(temp_path, mode)) + return GIT_ERROR; + + /* To be implemented */ return GIT_SUCCESS; |
