Bug 367649 - Adjusting File Last Modified timestamps makes 0-byte files out of MP4 video
Summary: Adjusting File Last Modified timestamps makes 0-byte files out of MP4 video
Status: RESOLVED FIXED
Alias: None
Product: digikam
Classification: Applications
Component: Plugin-Bqm-TimeAdjust (show other bugs)
Version: 5.1.0
Platform: openSUSE Linux
: NOR major
Target Milestone: ---
Assignee: Digikam Developers
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2016-08-21 15:58 UTC by Roger Foss
Modified: 2016-08-21 19:02 UTC (History)
0 users

See Also:
Latest Commit:
Version Fixed In: 5.2.0
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Roger Foss 2016-08-21 15:58:02 UTC
(Using Digikam 5.1.0 and exiv2 v0.25 on OpenSUSE LEAP 42.2 alpha.
My workflow includes renaming imported picture files to the yyy-mm-dd_hhmmss_camera.jpg format, and using the batch tool to ensure the last modified file timestamp equals the exif data.  I do the latter to ensure that when exporting albums to Google Photos, the albums sort correctly (if some pictures have modified file stamps with a later date, Google Photos will use those dates in the date-range the album, resulting in incorrect album sorting).

When using the Batch tool to update the File Last Modified timestamp, it will make zero-byte files out of MP4 files in the selection - effectively deleting them.

Steps to reproduce:

1. Goto an Album folder that include both JPEG files and MP4 video files
2. Select all files in the album (I usually click the album header in the main panel)
3. Click the Batch Queue Manager button in the tool bar
4. Select the Time Adjust tool in Metadata in Base Tools
5. Choose settings for target folder and behaviour if target file name already exists
6. Click run

The effect is  that all JPEG files get their File Last Modified timestamp updated, however any MP4 files processed end up being a 0-byte file.   This happens whether you chose Overwrite or Rename as behaviour.  However, I usually choose Overwrite behaviour because I want to update the timestamps of existing files.
This results in the ORIGINAL MP4 files being zeroed out and thus gone forever!

I have tested this with MP4 files created by an Panasonic FZ220 camera and a Samsung Galaxy S4 phone, the result is the same.

Proposal:
I propose that if digikam is unable to read the created/original timestamp EXIF info (via exiv2 tool), then it should not attempt to update the file at all.  Processing should skip the MP4 files.
Comment 1 Maik Qualmann 2016-08-21 19:02:50 UTC
Git commit cf80e48ac726a74d9765e50ca0ba21c8d53a53fc by Maik Qualmann.
Committed on 21/08/2016 at 19:01.
Pushed by mqualmann into branch 'master'.

if metadata loading fails, use custom or modification date/time
FIXED-IN: 5.2.0

M  +2    -1    NEWS
M  +9    -6    utilities/queuemanager/tools/metadata/timeadjust.cpp

http://commits.kde.org/digikam/cf80e48ac726a74d9765e50ca0ba21c8d53a53fc