diff options
author | Russell Belfer <rb@github.com> | 2013-07-01 10:21:14 -0700 |
---|---|---|
committer | Russell Belfer <rb@github.com> | 2013-07-01 10:21:14 -0700 |
commit | 55ededfd398b783fa4fbe54b8aa406c19228fbc6 (patch) | |
tree | f997dae60490ef1c91b6126b9428ab1b490c83fe /src/refspec.c | |
parent | 278ce7468d3870bb18d69bd8177bae406d6cede4 (diff) | |
download | libgit2-55ededfd398b783fa4fbe54b8aa406c19228fbc6.tar.gz |
Make refspec_transform paranoid about arguments
Diffstat (limited to 'src/refspec.c')
-rw-r--r-- | src/refspec.c | 34 |
1 files changed, 20 insertions, 14 deletions
diff --git a/src/refspec.c b/src/refspec.c index a907df84c..492c6ed3f 100644 --- a/src/refspec.c +++ b/src/refspec.c @@ -225,25 +225,31 @@ int git_refspec_rtransform(char *out, size_t outlen, const git_refspec *spec, co return refspec_transform_internal(out, outlen, spec->dst, spec->src, name); } -static int refspec_transform(git_buf *out, const char *from, const char *to, const char *name) +static int refspec_transform( + git_buf *out, const char *from, const char *to, const char *name) { - if (git_buf_sets(out, to) < 0) - return -1; + size_t to_len = to ? strlen(to) : 0; + size_t from_len = from ? strlen(from) : 0; + size_t name_len = name ? strlen(name) : 0; - /* - * No '*' at the end means that it's mapped to one specific - * branch, so no actual transformation is needed. - */ - if (git_buf_len(out) > 0 && out->ptr[git_buf_len(out) - 1] != '*') - return 0; + if (git_buf_set(out, to, to_len) < 0) + return -1; - git_buf_truncate(out, git_buf_len(out) - 1); /* remove trailing '*' */ - git_buf_puts(out, name + strlen(from) - 1); + if (to_len > 0) { + /* No '*' at the end of 'to' means that refspec is mapped to one + * specific branch, so no actual transformation is needed. + */ + if (out->ptr[to_len - 1] != '*') + return 0; + git_buf_shorten(out, 1); /* remove trailing '*' copied from 'to' */ + } - if (git_buf_oom(out)) - return -1; + if (from_len > 0) /* ignore trailing '*' from 'from' */ + from_len--; + if (from_len > name_len) + from_len = name_len; - return 0; + return git_buf_put(out, name + from_len, name_len - from_len); } int git_refspec_transform_r(git_buf *out, const git_refspec *spec, const char *name) |