fixed bulk processing file output issues

This commit is contained in:
K4YT3X 2020-09-13 12:42:55 -04:00
parent 16389fc8a6
commit 9389511d2d

View File

@ -478,6 +478,8 @@ class Upscaler:
input_file_type = input_file_mime_type.split('/')[0] input_file_type = input_file_mime_type.split('/')[0]
input_file_subtype = input_file_mime_type.split('/')[1] input_file_subtype = input_file_mime_type.split('/')[1]
Avalon.debug_info(_('File MIME type: {}').format(input_file_mime_type))
# set default output file suffixes # set default output file suffixes
# if image type is GIF, default output suffix is also .gif # if image type is GIF, default output suffix is also .gif
if input_file_mime_type == 'image/gif': if input_file_mime_type == 'image/gif':
@ -694,71 +696,74 @@ class Upscaler:
Avalon.info(_('Upscaling completed')) Avalon.info(_('Upscaling completed'))
Avalon.info(_('Average processing speed: {} seconds per frame').format(self.total_frames / (time.time() - upscale_begin_time))) Avalon.info(_('Average processing speed: {} seconds per frame').format(self.total_frames / (time.time() - upscale_begin_time)))
# start handling output # start handling output
# output can be either GIF or video # output can be either GIF or video
if input_file_type == 'image' and input_file_subtype != 'gif': if input_file_type == 'image' and input_file_subtype != 'gif':
# resize and output image to output_path Avalon.info(_('Exporting image'))
self.process_pool.append(self.ffmpeg_object.resize_image([f for f in self.upscaled_frames.iterdir() if f.is_file()][0], output_path, output_width, output_height))
self._wait()
elif input_file_mime_type == 'image/gif' or input_file_type == 'video': # resize and output image to output_path
self.process_pool.append(self.ffmpeg_object.resize_image([f for f in self.upscaled_frames.iterdir() if f.is_file()][0], output_path, output_width, output_height))
# if the desired output is gif file
if output_path.suffix.lower() == '.gif':
Avalon.info(_('Converting extracted frames into GIF image'))
gifski_object = Gifski(self.gifski_settings)
self.process_pool.append(gifski_object.make_gif(self.upscaled_frames, output_path, framerate, self.extracted_frame_format))
self._wait() self._wait()
Avalon.info(_('Conversion completed'))
# if the desired output is video # elif input_file_mime_type == 'image/gif' or input_file_type == 'video':
else: else:
# frames to video
Avalon.info(_('Converting extracted frames into video'))
self.process_pool.append(self.ffmpeg_object.assemble_video(framerate, self.upscaled_frames))
# f'{scale_width}x{scale_height}'
self._wait()
Avalon.info(_('Conversion completed'))
try: # if the desired output is gif file
# migrate audio tracks and subtitles if output_path.suffix.lower() == '.gif':
Avalon.info(_('Migrating audio, subtitles and other streams to upscaled video')) Avalon.info(_('Converting extracted frames into GIF image'))
self.process_pool.append(self.ffmpeg_object.migrate_streams(self.current_input_file, gifski_object = Gifski(self.gifski_settings)
output_path, self.process_pool.append(gifski_object.make_gif(self.upscaled_frames, output_path, framerate, self.extracted_frame_format))
self.upscaled_frames))
self._wait() self._wait()
Avalon.info(_('Conversion completed'))
# if failed to copy streams # if the desired output is video
# use file with only video stream else:
except subprocess.CalledProcessError: # frames to video
traceback.print_exc() Avalon.info(_('Converting extracted frames into video'))
Avalon.error(_('Failed to migrate streams')) self.process_pool.append(self.ffmpeg_object.assemble_video(framerate, self.upscaled_frames))
Avalon.warning(_('Trying to output video without additional streams')) # f'{scale_width}x{scale_height}'
self._wait()
Avalon.info(_('Conversion completed'))
if input_file_mime_type == 'image/gif': try:
# copy will overwrite destination content if exists # migrate audio tracks and subtitles
shutil.copy(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_path) Avalon.info(_('Migrating audio, subtitles and other streams to upscaled video'))
self.process_pool.append(self.ffmpeg_object.migrate_streams(self.current_input_file,
output_path,
self.upscaled_frames))
self._wait()
else: # if failed to copy streams
# construct output file path # use file with only video stream
output_file_name = f'{output_path.stem}{self.ffmpeg_object.intermediate_file_name.suffix}' except subprocess.CalledProcessError:
output_video_path = output_path.parent / output_file_name traceback.print_exc()
Avalon.error(_('Failed to migrate streams'))
Avalon.warning(_('Trying to output video without additional streams'))
# if output file already exists if input_file_mime_type == 'image/gif':
# create temporary directory in output folder # copy will overwrite destination content if exists
# temporary directories generated by tempfile are guaranteed to be unique shutil.copy(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_path)
# and won't conflict with other files
if output_video_path.exists():
Avalon.error(_('Output video file exists'))
temporary_directory = pathlib.Path(tempfile.mkdtemp(dir=output_path.parent)) else:
output_video_path = temporary_directory / output_file_name # construct output file path
Avalon.info(_('Created temporary directory to contain file')) output_file_name = f'{output_path.stem}{self.ffmpeg_object.intermediate_file_name.suffix}'
output_video_path = output_path.parent / output_file_name
# move file to new destination # if output file already exists
Avalon.info(_('Writing intermediate file to: {}').format(output_video_path.absolute())) # create temporary directory in output folder
shutil.move(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_video_path) # temporary directories generated by tempfile are guaranteed to be unique
# and won't conflict with other files
if output_video_path.exists():
Avalon.error(_('Output video file exists'))
temporary_directory = pathlib.Path(tempfile.mkdtemp(dir=output_path.parent))
output_video_path = temporary_directory / output_file_name
Avalon.info(_('Created temporary directory to contain file'))
# move file to new destination
Avalon.info(_('Writing intermediate file to: {}').format(output_video_path.absolute()))
shutil.move(self.upscaled_frames / self.ffmpeg_object.intermediate_file_name, output_video_path)
# increment total number of files processed # increment total number of files processed
self.cleanup_temp_directories() self.cleanup_temp_directories()