Re: [FFmpeg-devel] [PATCH v1 1/2] avformat/ftp: Fix for invalid use of av_strtok

2020-05-09 Thread lance . lmwang
On Sat, Apr 18, 2020 at 12:19:30PM +0800, lance.lmw...@gmail.com wrote:
> From: Limin Wang 
> 
> By the av_strtok() description:
>  * On the first call to av_strtok(), s should point to the string to
>  * parse, and the value of saveptr is ignored. In subsequent calls, s
>  * should be NULL, and saveptr should be unchanged since the previous
>  * call.
> 
> Signed-off-by: Limin Wang 
> ---
>  libavformat/ftp.c | 14 --
>  1 file changed, 8 insertions(+), 6 deletions(-)
> 
> diff --git a/libavformat/ftp.c b/libavformat/ftp.c
> index e3d194d..caeea42 100644
> --- a/libavformat/ftp.c
> +++ b/libavformat/ftp.c
> @@ -333,15 +333,15 @@ static int ftp_passive_mode(FTPContext *s)
>  *end  = '\0';
>  /* skip ip */
>  if (!av_strtok(start, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
>  
>  /* parse port number */
> -start = av_strtok(end, ",", &end);
> +start = av_strtok(NULL, ",", &end);
>  if (!start) goto fail;
>  s->server_data_port = atoi(start) * 256;
> -start = av_strtok(end, ",", &end);
> +start = av_strtok(NULL, ",", &end);
>  if (!start) goto fail;
>  s->server_data_port += atoi(start);
>  ff_dlog(s, "Server data port: %d\n", s->server_data_port);
> @@ -963,8 +963,10 @@ static int ftp_parse_entry_nlst(char *line, AVIODirEntry 
> *next)
>  static int ftp_parse_entry_mlsd(char *mlsd, AVIODirEntry *next)
>  {
>  char *fact, *value;
> +char *saveptr = NULL, *p = mlsd;
>  ff_dlog(NULL, "%s\n", mlsd);
> -while(fact = av_strtok(mlsd, ";", &mlsd)) {
> +while(fact = av_strtok(p, ";", &saveptr)) {
> +p = NULL;
>  if (fact[0] == ' ') {
>  next->name = av_strdup(&fact[1]);
>  continue;
> -- 
> 2.9.5
> 

will apply the patchset tomorrow if no more comments.

-- 
Thanks,
Limin Wang
___
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".

Re: [FFmpeg-devel] [PATCH v1 1/2] avformat/ftp: Fix for invalid use of av_strtok

2020-05-06 Thread lance . lmwang
On Sat, Apr 18, 2020 at 12:19:30PM +0800, lance.lmw...@gmail.com wrote:
> From: Limin Wang 
> 
> By the av_strtok() description:
>  * On the first call to av_strtok(), s should point to the string to
>  * parse, and the value of saveptr is ignored. In subsequent calls, s
>  * should be NULL, and saveptr should be unchanged since the previous
>  * call.
> 
> Signed-off-by: Limin Wang 
> ---
>  libavformat/ftp.c | 14 --
>  1 file changed, 8 insertions(+), 6 deletions(-)
> 
> diff --git a/libavformat/ftp.c b/libavformat/ftp.c
> index e3d194d..caeea42 100644
> --- a/libavformat/ftp.c
> +++ b/libavformat/ftp.c
> @@ -333,15 +333,15 @@ static int ftp_passive_mode(FTPContext *s)
>  *end  = '\0';
>  /* skip ip */
>  if (!av_strtok(start, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> -if (!av_strtok(end, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
> +if (!av_strtok(NULL, ",", &end)) goto fail;
>  
>  /* parse port number */
> -start = av_strtok(end, ",", &end);
> +start = av_strtok(NULL, ",", &end);
>  if (!start) goto fail;
>  s->server_data_port = atoi(start) * 256;
> -start = av_strtok(end, ",", &end);
> +start = av_strtok(NULL, ",", &end);
>  if (!start) goto fail;
>  s->server_data_port += atoi(start);
>  ff_dlog(s, "Server data port: %d\n", s->server_data_port);
> @@ -963,8 +963,10 @@ static int ftp_parse_entry_nlst(char *line, AVIODirEntry 
> *next)
>  static int ftp_parse_entry_mlsd(char *mlsd, AVIODirEntry *next)
>  {
>  char *fact, *value;
> +char *saveptr = NULL, *p = mlsd;
>  ff_dlog(NULL, "%s\n", mlsd);
> -while(fact = av_strtok(mlsd, ";", &mlsd)) {
> +while(fact = av_strtok(p, ";", &saveptr)) {
> +p = NULL;
>  if (fact[0] == ' ') {
>  next->name = av_strdup(&fact[1]);
>  continue;
> -- 
> 2.9.5
> 

ping the patchset. Please see the discussion of  av_strtok from here:
https://patchwork.ffmpeg.org/project/ffmpeg/patch/20200417141315.17560-1-lance.lmw...@gmail.com/



-- 
Thanks,
Limin Wang
___
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".

[FFmpeg-devel] [PATCH v1 1/2] avformat/ftp: Fix for invalid use of av_strtok

2020-04-17 Thread lance . lmwang
From: Limin Wang 

By the av_strtok() description:
 * On the first call to av_strtok(), s should point to the string to
 * parse, and the value of saveptr is ignored. In subsequent calls, s
 * should be NULL, and saveptr should be unchanged since the previous
 * call.

Signed-off-by: Limin Wang 
---
 libavformat/ftp.c | 14 --
 1 file changed, 8 insertions(+), 6 deletions(-)

diff --git a/libavformat/ftp.c b/libavformat/ftp.c
index e3d194d..caeea42 100644
--- a/libavformat/ftp.c
+++ b/libavformat/ftp.c
@@ -333,15 +333,15 @@ static int ftp_passive_mode(FTPContext *s)
 *end  = '\0';
 /* skip ip */
 if (!av_strtok(start, ",", &end)) goto fail;
-if (!av_strtok(end, ",", &end)) goto fail;
-if (!av_strtok(end, ",", &end)) goto fail;
-if (!av_strtok(end, ",", &end)) goto fail;
+if (!av_strtok(NULL, ",", &end)) goto fail;
+if (!av_strtok(NULL, ",", &end)) goto fail;
+if (!av_strtok(NULL, ",", &end)) goto fail;
 
 /* parse port number */
-start = av_strtok(end, ",", &end);
+start = av_strtok(NULL, ",", &end);
 if (!start) goto fail;
 s->server_data_port = atoi(start) * 256;
-start = av_strtok(end, ",", &end);
+start = av_strtok(NULL, ",", &end);
 if (!start) goto fail;
 s->server_data_port += atoi(start);
 ff_dlog(s, "Server data port: %d\n", s->server_data_port);
@@ -963,8 +963,10 @@ static int ftp_parse_entry_nlst(char *line, AVIODirEntry 
*next)
 static int ftp_parse_entry_mlsd(char *mlsd, AVIODirEntry *next)
 {
 char *fact, *value;
+char *saveptr = NULL, *p = mlsd;
 ff_dlog(NULL, "%s\n", mlsd);
-while(fact = av_strtok(mlsd, ";", &mlsd)) {
+while(fact = av_strtok(p, ";", &saveptr)) {
+p = NULL;
 if (fact[0] == ' ') {
 next->name = av_strdup(&fact[1]);
 continue;
-- 
2.9.5

___
ffmpeg-devel mailing list
ffmpeg-devel@ffmpeg.org
https://ffmpeg.org/mailman/listinfo/ffmpeg-devel

To unsubscribe, visit link above, or email
ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".