Commit 9f0088c4 by Edward Thomson

fs_path: exit quickly in `dirname_r` failure

When we encounter a situation where we need to exit, simply `return -1`
instead of trying to set `len = -1` and then jumping to the exit
handler, which would erroneously do work based on the `len` value.
parent 043a87a0
...@@ -193,8 +193,7 @@ int git_fs_path_dirname_r(git_str *buffer, const char *path) ...@@ -193,8 +193,7 @@ int git_fs_path_dirname_r(git_str *buffer, const char *path)
if (endp - path + 1 > INT_MAX) { if (endp - path + 1 > INT_MAX) {
git_error_set(GIT_ERROR_INVALID, "path too long"); git_error_set(GIT_ERROR_INVALID, "path too long");
len = -1; return -1;
goto Exit;
} }
if ((len = win32_prefix_length(path, (int)(endp - path + 1))) > 0) { if ((len = win32_prefix_length(path, (int)(endp - path + 1))) > 0) {
...@@ -219,8 +218,7 @@ int git_fs_path_dirname_r(git_str *buffer, const char *path) ...@@ -219,8 +218,7 @@ int git_fs_path_dirname_r(git_str *buffer, const char *path)
if (endp - path + 1 > INT_MAX) { if (endp - path + 1 > INT_MAX) {
git_error_set(GIT_ERROR_INVALID, "path too long"); git_error_set(GIT_ERROR_INVALID, "path too long");
len = -1; return -1;
goto Exit;
} }
if ((len = win32_prefix_length(path, (int)(endp - path + 1))) > 0) { if ((len = win32_prefix_length(path, (int)(endp - path + 1))) > 0) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment