mirror of
https://git.proxmox.com/git/libgit2
synced 2025-05-05 18:44:31 +00:00
revparse: only allow decimal specifiers in carete and tilde synatx
passing 0 to git_strol(32|64) let the implementation guess if it's dealing with an octal number or a decimal one. Let's make it safe and ensure that both 'HEAD@{010}' and 'HEAD@{10}' point at the same commit.
This commit is contained in:
parent
d1b7921a48
commit
5a6f31f28b
@ -482,7 +482,7 @@ static int handle_caret_syntax(git_object **out, git_repository *repo, git_objec
|
||||
if (movementlen == 0) {
|
||||
n = 1;
|
||||
} else {
|
||||
git__strtol32(&n, movement, NULL, 0);
|
||||
git__strtol32(&n, movement, NULL, 10);
|
||||
}
|
||||
commit = (git_commit*)obj;
|
||||
|
||||
@ -513,7 +513,7 @@ static int handle_linear_syntax(git_object **out, git_object *obj, const char *m
|
||||
/* "~" is the same as "~1" */
|
||||
if (*movement == '\0') {
|
||||
n = 1;
|
||||
} else if (git__strtol32(&n, movement, NULL, 0) < 0) {
|
||||
} else if (git__strtol32(&n, movement, NULL, 10) < 0) {
|
||||
return GIT_ERROR;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user