}
memcpy(path, git_dir, len);
+ path[len] = 0;
copy_templates_1(path, len,
template_path, template_len,
dir);
{
unsigned len = strlen(git_dir);
static char path[PATH_MAX];
+ unsigned char sha1[20];
if (len > sizeof(path)-50)
die("insane git directory %s", git_dir);
/*
* Create the default symlink from ".git/HEAD" to the "master"
- * branch
+ * branch, if it does not exist yet.
*/
strcpy(path + len, "HEAD");
- if (symlink("refs/heads/master", path) < 0) {
- if (errno != EEXIST) {
- perror(path);
+ if (read_ref(path, sha1) < 0) {
+ if (create_symref(path, "refs/heads/master") < 0)
exit(1);
- }
}
+ path[len] = 0;
copy_templates(path, len, template_path);
+
+ /*
+ * Find out if we can trust the executable bit.
+ */
+ safe_create_dir(path);
+ strcpy(path + len, "config");
+ if (access(path, R_OK) < 0) {
+ static const char contents[] =
+ "#\n"
+ "# This is the config file\n"
+ "#\n"
+ "\n"
+ "; core variables\n"
+ "[core]\n"
+ " ; Don't trust file modes\n"
+ " filemode = false\n"
+ "\n";
+ FILE *config = fopen(path, "w");
+ struct stat st;
+
+ if (!config)
+ die("Can not write to %s?", path);
+
+ fwrite(contents, sizeof(contents)-1, 1, config);
+
+ fclose(config);
+
+ if (!lstat(path, &st)) {
+ struct stat st2;
+ if (!chmod(path, st.st_mode ^ S_IXUSR) &&
+ !lstat(path, &st2) &&
+ st.st_mode != st2.st_mode)
+ unlink(path);
+ else
+ fprintf(stderr, "Ignoring file modes\n");
+ }
+ }
}
static const char init_db_usage[] =
memcpy(path, sha1_dir, len);
safe_create_dir(sha1_dir);
- for (i = 0; i < 256; i++) {
- sprintf(path+len, "/%02x", i);
- safe_create_dir(path);
- }
strcpy(path+len, "/pack");
safe_create_dir(path);
strcpy(path+len, "/info");