Johannes Schindelin, Wed, Oct 26, 2005 01:39:24 +0200: > When the HEAD symref could not be created, it is helpful for the user to > know that. > Not just that. It would be interesting to give the user an option to use the file references ("ref: refs/heads/master"). Something like that: Add --no-symref (make init-db use file references) --- cache.h | 1 + init-db.c | 11 +++++++++-- refs.c | 7 ++++++- 3 files changed, 16 insertions(+), 3 deletions(-) applies-to: dba443573167bb9b0023613428e6d1a69477fac6 097ca1bf9b21d19d425e8151986eb36f82cbeff3 diff --git a/cache.h b/cache.h index d776016..e410ce2 100644 --- a/cache.h +++ b/cache.h @@ -239,6 +239,7 @@ extern char *sha1_to_hex(const unsigned extern int read_ref(const char *filename, unsigned char *sha1); extern const char *resolve_ref(const char *path, unsigned char *sha1, int); extern int create_symref(const char *git_HEAD, const char *refs_heads_master); +extern int create_file_symref(const char *git_HEAD, const char *refs_heads_master); extern int validate_symref(const char *git_HEAD); /* General helper functions */ diff --git a/init-db.c b/init-db.c index aabc09f..2d2b705 100644 --- a/init-db.c +++ b/init-db.c @@ -161,6 +161,8 @@ static void copy_templates(const char *g closedir(dir); } +static int try_symref = 1; + static void create_default_files(const char *git_dir, char *template_path) { @@ -191,8 +193,11 @@ static void create_default_files(const c */ strcpy(path + len, "HEAD"); if (read_ref(path, sha1) < 0) { - if (create_symref(path, "refs/heads/master") < 0) - exit(1); + int err = 0; + if ( try_symref ) + err = create_symref(path, "refs/heads/master"); + if ( !err && create_file_symref(path, "refs/heads/master") < 0 ) + die("cannot create %s", path); } path[len] = 0; copy_templates(path, len, template_path); @@ -220,6 +225,8 @@ int main(int argc, char **argv) break; else if (!strncmp(arg, "--template=", 11)) template_dir = arg+11; + else if (!strcmp(arg, "--no-symref")) + try_symref = 0; else die(init_db_usage); } diff --git a/refs.c b/refs.c index 97506a4..8029667 100644 --- a/refs.c +++ b/refs.c @@ -120,6 +120,12 @@ int create_symref(const char *git_HEAD, unlink(git_HEAD); return symlink(refs_heads_master, git_HEAD); #else + return create_file_symref(git_HEAD, refs_heads_master); +#endif +} + +int create_file_symref(const char *git_HEAD, const char *refs_heads_master) +{ const char *lockpath; char ref[1000]; int fd, len, written; @@ -144,7 +150,6 @@ int create_symref(const char *git_HEAD, return -3; } return 0; -#endif } int read_ref(const char *filename, unsigned char *sha1) --- 0.99.8.GIT - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.htmlReceived on Thu Oct 27 05:46:09 2005
This archive was generated by hypermail 2.1.8 : 2005-10-27 05:46:12 EST