1 from __future__
import unicode_literals
5 from .common
import PostProcessor
6 from ..compat
import compat_shlex_split
16 process_communicate_or_kill
,
20 # Deprecated in favor of the native implementation
21 class SponSkrubPP(PostProcessor
):
23 _exe_name
= 'sponskrub'
25 def __init__(self
, downloader
, path
='', args
=None, ignoreerror
=False, cut
=False, force
=False):
26 PostProcessor
.__init
__(self
, downloader
)
29 self
.args
= str_or_none(args
) or '' # For backward compatibility
30 self
.path
= self
.get_exe(path
)
32 if not ignoreerror
and self
.path
is None:
34 raise PostProcessingError('sponskrub not found in "%s"' % path
)
36 raise PostProcessingError('sponskrub not found. Please install or provide the path using --sponskrub-path')
38 def get_exe(self
, path
=''):
39 if not path
or not check_executable(path
, ['-h']):
40 path
= os
.path
.join(path
, self
._exe
_name
)
41 if not check_executable(path
, ['-h']):
45 @PostProcessor._restrict_to(images
=False)
46 def run(self
, information
):
48 return [], information
50 filename
= information
['filepath']
51 if not os
.path
.exists(encodeFilename(filename
)): # no download
52 return [], information
54 if information
['extractor_key'].lower() != 'youtube':
55 self
.to_screen('Skipping sponskrub since it is not a YouTube video')
56 return [], information
57 if self
.cutout
and not self
.force
and not information
.get('__real_download', False):
59 'Skipping sponskrub since the video was already downloaded. '
60 'Use --sponskrub-force to run sponskrub anyway')
61 return [], information
63 self
.to_screen('Trying to %s sponsor sections' % ('remove' if self
.cutout
else 'mark'))
65 self
.report_warning('Cutting out sponsor segments will cause the subtitles to go out of sync.')
66 if not information
.get('__real_download', False):
67 self
.report_warning('If sponskrub is run multiple times, unintended parts of the video could be cut out.')
69 temp_filename
= prepend_extension(filename
, self
._temp
_ext
)
70 if os
.path
.exists(encodeFilename(temp_filename
)):
71 os
.remove(encodeFilename(temp_filename
))
76 cmd
+= cli_option(self
._downloader
.params
, '-proxy', 'proxy')
77 cmd
+= compat_shlex_split(self
.args
) # For backward compatibility
78 cmd
+= self
._configuration
_args
(self
._exe
_name
, use_compat
=False)
79 cmd
+= ['--', information
['id'], filename
, temp_filename
]
80 cmd
= [encodeArgument(i
) for i
in cmd
]
82 self
.write_debug('sponskrub command line: %s' % shell_quote(cmd
))
83 pipe
= None if self
.get_param('verbose') else subprocess
.PIPE
84 p
= subprocess
.Popen(cmd
, stdout
=pipe
)
85 stdout
= process_communicate_or_kill(p
)[0]
88 os
.replace(temp_filename
, filename
)
89 self
.to_screen('Sponsor sections have been %s' % ('removed' if self
.cutout
else 'marked'))
90 elif p
.returncode
== 3:
91 self
.to_screen('No segments in the SponsorBlock database')
93 msg
= stdout
.decode('utf-8', 'replace').strip() if stdout
else ''
94 msg
= msg
.split('\n')[0 if msg
.lower().startswith('unrecognised') else -1]
95 raise PostProcessingError(msg
if msg
else 'sponskrub failed with error code %s' % p
.returncode
)
96 return [], information