Opened 7 weeks ago

Closed 7 weeks ago

Last modified 7 weeks ago

#11320 closed defect (invalid)

ffmpeg DESTROYS input files

Reported by: ffmpeg.pete Owned by:
Priority: normal Component: undetermined
Version: unspecified Keywords:
Cc: Blocked By:
Blocking: Reproduced by developer: no
Analyzed by developer: no

Description

Summary of the bug:

Sorry, unable to append gdb output. Followed the instructions, didn't work for me. ???

I'm creating a video from jpegs. This has never failed for me. Always works.

Today, I'm using really crappy input, i.e. the jpegs are not all of uniform height and width, so I was expecting a problem.

But I did not expect ffmpeg to DESTROY the input files.

So, I'll correct my input files and re-run. No problem.

But I wanted to give you guys the heads up! on this.

No way should the input files ever be overwritten.

How to reproduce:

  1. Unzip the attached files (bunch of very small jpegs).
  1. Then run the command below
% ffmpeg -y -i 00/* -r 25 result.mp4
ffmpeg version
built on ...
ffmpeg version 4.4.2-0ubuntu0.22.04.1 Copyright (c) 2000-2021 the FFmpeg developers
built with gcc 11 (Ubuntu 11.2.0-19ubuntu1)

Patches should be submitted to the ffmpeg-devel mailing list and not this bug tracker.

Attachments (1)

00.zip (1.5 MB ) - added by ffmpeg.pete 7 weeks ago.
File contains around 1,600 small jpegs of non-uniform height and width.

Download all attachments as: .zip

Change History (4)

by ffmpeg.pete, 7 weeks ago

Attachment: 00.zip added

File contains around 1,600 small jpegs of non-uniform height and width.

comment:1 by elenril, 7 weeks ago

Resolution: invalid
Status: newclosed

-i 00/* -r 25 result.mp4

Considering for simplicity that directory 00 contains just two files named 0 and 1, your shell would expands this part of the commandline to -i 00/0 00/1 -r 25 result.mp4, which means

  • one input: 00/0
  • two outputs: 00/1 and result.mp4

In other words, this is not a bug, has nothing to do with input files being corrupted, and did not ever do what you want unless the directory had just one file.

comment:2 by ffmpeg.pete, 7 weeks ago

Update: I made all the files uniform in height and width using imagemagick command

  • resize all input files to 64x64
  • set background black
  • pad as necessary
  • center resulting

mogrify -path 64x64/ -resize 64x64 -background black -gravity center -extent 64x64 *.jpg

I confirm the output file size in the directory 64x64/ to be 64x64 in size:

...
00001_00.jpg: JPEG image data, JFIF standard 1.01, aspect ratio, density 1x1, segment length 16, baseline, precision 8, 64x64, components 1
...

Same result. So maybe I'm not allowed to create such a small mp4?

But!!! The input files are DESTROYED.

Even for stupid users like me. This should never happen.

Noticing lots of messages like this:

[swscaler @ 0x55a8763ab600] deprecated pixel format used, make sure you did set range correctly

But the images look fine on inspection.

comment:3 by ffmpeg.pete, 7 weeks ago

SORRY !!! MY BAD. REALISED MY MISTAKE.

Note: See TracTickets for help on using tickets.