Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/libgit2.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRussell Belfer <rb@github.com>2013-08-17 01:34:51 +0400
committerRussell Belfer <rb@github.com>2013-08-17 02:04:15 +0400
commitce23330fd636a99a25b3a6b7c81e63c424ae7d7c (patch)
treee1c6bfef45e49d9add6150e59b6bb27902c86f63 /src/signature.c
parent68458e422a6070d8f445eb6a4bfaac3310c330a3 (diff)
Add new git_signature_default API using config
This adds a new API for creating a signature that uses the config to look up "user.name" and "user.email".
Diffstat (limited to 'src/signature.c')
-rw-r--r--src/signature.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/signature.c b/src/signature.c
index 0a34ccfaa..52ca2b375 100644
--- a/src/signature.c
+++ b/src/signature.c
@@ -74,7 +74,7 @@ int git_signature_new(git_signature **sig_out, const char *name, const char *ema
git_signature_free(p);
return signature_error("Signature cannot have an empty name");
}
-
+
p->when.time = time;
p->when.offset = offset;
@@ -129,6 +129,23 @@ int git_signature_now(git_signature **sig_out, const char *name, const char *ema
return 0;
}
+int git_signature_default(git_signature **out, git_repository *repo)
+{
+ int error;
+ git_config *cfg;
+ const char *user_name, *user_email;
+
+ if ((error = git_repository_config(&cfg, repo)) < 0)
+ return error;
+
+ if (!(error = git_config_get_string(&user_name, cfg, "user.name")) &&
+ !(error = git_config_get_string(&user_email, cfg, "user.email")))
+ error = git_signature_now(out, user_name, user_email);
+
+ git_config_free(cfg);
+ return error;
+}
+
int git_signature__parse(git_signature *sig, const char **buffer_out,
const char *buffer_end, const char *header, char ender)
{