diff options
author | Emil Engler <me@emilengler.com> | 2021-04-01 18:24:53 +0200 |
---|---|---|
committer | Jay Satiro <raysatiro@yahoo.com> | 2021-04-05 23:21:19 -0400 |
commit | c1abc6624d8fb1bd2286feeb8b623dd4850fadbe (patch) | |
tree | b1fd28effb6637d87365cbae1651b38be04f7d2c | |
parent | 605aa03ac198e049e6779df5ccc433b0934e40aa (diff) | |
download | curl-c1abc6624d8fb1bd2286feeb8b623dd4850fadbe.tar.gz |
libssh: get rid of PATH_MAX
This removes the last occurrence of PATH_MAX inside our libssh
implementation by calculating the path length from the string length of
the two components.
Closes #6829
-rw-r--r-- | lib/vssh/libssh.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/lib/vssh/libssh.c b/lib/vssh/libssh.c index 1bb644eed..4644f4cb9 100644 --- a/lib/vssh/libssh.c +++ b/lib/vssh/libssh.c @@ -1453,16 +1453,15 @@ static CURLcode myssh_statemach_act(struct Curl_easy *data, bool *block) if((sshc->readdir_attrs->flags & SSH_FILEXFER_ATTR_PERMISSIONS) && ((sshc->readdir_attrs->permissions & S_IFMT) == S_IFLNK)) { - sshc->readdir_linkPath = malloc(PATH_MAX + 1); + sshc->readdir_linkPath = aprintf("%s%s", protop->path, + sshc->readdir_filename); + if(sshc->readdir_linkPath == NULL) { state(data, SSH_SFTP_CLOSE); sshc->actualcode = CURLE_OUT_OF_MEMORY; break; } - msnprintf(sshc->readdir_linkPath, PATH_MAX, "%s%s", protop->path, - sshc->readdir_filename); - state(data, SSH_SFTP_READDIR_LINK); break; } |