diff options
Diffstat (limited to 'abs/core/nuvexport')
-rwxr-xr-x | abs/core/nuvexport/MP4.pm | 316 | ||||
-rw-r--r-- | abs/core/nuvexport/PKGBUILD | 33 | ||||
-rwxr-xr-x | abs/core/nuvexport/XviD.pm | 197 | ||||
-rw-r--r-- | abs/core/nuvexport/nuvexport-ipod-disable.patch | 12 |
4 files changed, 0 insertions, 558 deletions
diff --git a/abs/core/nuvexport/MP4.pm b/abs/core/nuvexport/MP4.pm deleted file mode 100755 index e13d44b..0000000 --- a/abs/core/nuvexport/MP4.pm +++ /dev/null @@ -1,316 +0,0 @@ -#!/usr/bin/perl -w -# -# ffmpeg-based MP4 (iPod) video module for nuvexport. -# -# Many thanks to cartman in #ffmpeg, and for the instructions at -# http://rob.opendot.cl/index.php?active=3&subactive=1 -# http://videotranscoding.wikispaces.com/EncodeForIPodorPSP -# -# @url $URL: svn+ssh://xris@svn.mythtv.org/var/lib/svn/trunk/mythextras/nuvexport/export/ffmpeg/MP4.pm $ -# @date $Date: 2008-02-16 20:54:43 -0800 (Sat, 16 Feb 2008) $ -# @version $Revision: 16110 $ -# @author $Author: xris $ -# @copyright Silicon Mechanics -# - -package export::ffmpeg::MP4; - use base 'export::ffmpeg'; - -# Load the myth and nuv utilities, and make sure we're connected to the database - use nuv_export::shared_utils; - use nuv_export::cli; - use nuv_export::ui; - use mythtv::recordings; - -# Load the following extra parameters from the commandline - add_arg('quantisation|q=i', 'Quantisation'); - add_arg('a_bitrate|a=i', 'Audio bitrate'); - add_arg('v_bitrate|v=i', 'Video bitrate'); - add_arg('multipass!', 'Enable two-pass encoding.'); - add_arg('mp4_codec=s', 'Video codec to use for MP4/iPod video (mpeg4 or h264).'); - add_arg('mp4_fps=s', 'Framerate to use: auto, 25, 23.97, 29.97.'); - add_arg('ipod!', 'Produce ipod-compatible output.'); - - sub new { - my $class = shift; - my $self = { - 'cli' => qr/\b(?:mp4|ipod)\b/i, - 'name' => 'Export to MP4 (iPod)', - 'enabled' => 1, - 'errors' => [], - 'defaults' => {}, - }; - bless($self, $class); - - # Initialize the default parameters - $self->load_defaults(); - - # Verify any commandline or config file options - die "Audio bitrate must be > 0\n" unless (!defined $self->val('a_bitrate') || $self->{'a_bitrate'} > 0); - die "Video bitrate must be > 0\n" unless (!defined $self->val('v_bitrate') || $self->{'v_bitrate'} > 0); - die "Width must be > 0\n" unless (!defined $self->val('width') || $self->{'width'} =~ /^\s*\D/ || $self->{'width'} > 0); - die "Height must be > 0\n" unless (!defined $self->val('height') || $self->{'height'} =~ /^\s*\D/ || $self->{'height'} > 0); - - # VBR, multipass, etc. - if ($self->val('multipass')) { - $self->{'vbr'} = 1; - } - elsif ($self->val('quantisation')) { - die "Quantisation must be a number between 1 and 31 (lower means better quality).\n" if ($self->{'quantisation'} < 1 || $self->{'quantisation'} > 31); - $self->{'vbr'} = 1; - } - - # Initialize and check for ffmpeg - $self->init_ffmpeg(); - - # Can we even encode mp4? - if (!$self->can_encode('mp4')) { - push @{$self->{'errors'}}, "Your ffmpeg installation doesn't support encoding to mp4 file formats."; - } - if (!$self->can_encode('aac') && !$self->can_encode('libfaac')) { - push @{$self->{'errors'}}, "Your ffmpeg installation doesn't support encoding to aac audio."; - } - if (!$self->can_encode('mpeg4') && !$self->can_encode('h264') && !$self->can_encode('libx264')) { - push @{$self->{'errors'}}, "Your ffmpeg installation doesn't support encoding to either mpeg4 or h264 video."; - } - # Any errors? disable this function - $self->{'enabled'} = 0 if ($self->{'errors'} && @{$self->{'errors'}} > 0); - # Return - return $self; - } - -# Load default settings - sub load_defaults { - my $self = shift; - # Load the parent module's settings - $self->SUPER::load_defaults(); - # Default settings - $self->{'defaults'}{'v_bitrate'} = 384; - $self->{'defaults'}{'a_bitrate'} = 64; - $self->{'defaults'}{'width'} = 320; - $self->{'defaults'}{'mp4_codec'} = 'mpeg4'; - # Verify commandline options - if ($self->val('mp4_codec') !~ /^(?:mpeg4|h264)$/i) { - die "mp4_codec must be either mpeg4 or h264.\n"; - } - $self->{'mp4_codec'} =~ tr/A-Z/a-z/; - - } - -# Gather settings from the user - sub gather_settings { - my $self = shift; - # Load the parent module's settings - $self->SUPER::gather_settings(); - # Audio Bitrate - $self->{'a_bitrate'} = query_text('Audio bitrate?', - 'int', - $self->val('a_bitrate')); - # Video options - if (!$is_cli) { - # iPod compatibility mode? - $self->{'ipod'} = query_text('Enable iPod compatibility?', - 'yesno', - $self->val('ipod')); - # Video codec - if ($self->{'ffmpeg_vers'} eq 'svn') { - while (1) { - my $codec = query_text('Video codec (mpeg4 or h264)?', - 'string', - $self->{'mp4_codec'}); - if ($codec =~ /^m/) { - $self->{'mp4_codec'} = 'mpeg4'; - last; - } - elsif ($codec =~ /^h/) { - $self->{'mp4_codec'} = 'h264'; - last; - } - print "Please choose either mpeg4 or h264\n"; - } - } - else { - $self->{'mp4_codec'} = 'mpeg4'; - print "Using the mpeg4 codec (h.264 mp4/ipod encoding requires the svn version of ffmpeg.)\n"; - } - # Video bitrate options - $self->{'vbr'} = query_text('Variable bitrate video?', - 'yesno', - $self->val('vbr')); - if ($self->{'vbr'}) { - $self->{'multipass'} = query_text('Multi-pass (slower, but better quality)?', - 'yesno', - $self->val('multipass')); - if (!$self->{'multipass'}) { - while (1) { - my $quantisation = query_text('VBR quality/quantisation (1-31)?', - 'float', - $self->val('quantisation')); - if ($quantisation < 1) { - print "Too low; please choose a number between 1 and 31.\n"; - } - elsif ($quantisation > 31) { - print "Too high; please choose a number between 1 and 31\n"; - } - else { - $self->{'quantisation'} = $quantisation; - last; - } - } - } - } else { - $self->{'multipass'} = 0; - } - # Ask the user what video bitrate he/she wants - $self->{'v_bitrate'} = query_text('Video bitrate?', - 'int', - $self->val('v_bitrate')); - } - # Complain about h264 - if ($self->{'mp4_codec'} eq 'h264' && $self->{'ffmpeg_vers'} ne 'svn') { - die "h.264 mp4/ipod encoding requires the svn version of ffmpeg.\n"; - } - # Loop, in case we need to verify ipod compatibility - while (1) { - # Query the resolution - $self->query_resolution(); - # Warn about ipod resolution - if ($self->val('ipod') && ($self->{'height'} > 480 || $self->{'width'} > 640)) { - my $note = "WARNING: Video larger than 640x480 will not play on an iPod.\n"; - die $note if ($is_cli); - print $note; - next; - } - # Done looping - last; - } - } - - sub export { - my $self = shift; - my $episode = shift; - # Make sure this is set to anamorphic mode - $self->{'aspect_stretched'} = 1; - # Framerate - my $standard = ($episode->{'finfo'}{'fps'} =~ /^2(?:5|4\.9)/) ? 'PAL' : 'NTSC'; - if ($standard eq 'PAL') { - $self->{'out_fps'} = 25; - } - elsif ($self->val('mp4_fps') =~ /^23/) { - $self->{'out_fps'} = 23.97; - } - elsif ($self->val('mp4_fps') =~ /^29/) { - $self->{'out_fps'} = 29.97; - } - else { - $self->{'out_fps'} = ($self->{'width'} > 320 || $self->{'height'} > 288) ? 29.97 : 23.97; - } - # Embed the title - $safe_title = $episode->{'title'}; - if ($episode->{'subtitle'} ne 'Untitled') { - $safe_title .= ' - '.$episode->{'subtitle'}; - } - my $safe_title = shell_escape($safe_title); - # Codec name changes between ffmpeg versions - my $codec = $self->{'mp4_codec'}; - if ($codec eq 'h264' && $self->can_encode('libx264')) { - $codec = 'libx264'; - } - # Build the common ffmpeg string - my $ffmpeg_xtra = ' -vcodec '.$codec - .$self->param('bit_rate', $self->{'v_bitrate'}) - ;### ." -title $safe_title"; - # Options required for the codecs separately - if ($self->{'mp4_codec'} eq 'h264') { - $ffmpeg_xtra .= ' -level 30' - ### .' -loop 1' - .' -g 250 -keyint_min 25' - .' -sc_threshold 40' - ### .' -rc_eq \'blurCplx^(1-qComp)\'' - .$self->param('bit_rate_tolerance', $self->{'v_bitrate'}) - .$self->param('rc_max_rate', 1500 - $self->{'a_bitrate'}) - .$self->param('rc_buffer_size', 2000) - .$self->param('i_quant_factor', 0.71428572) - .$self->param('b_quant_factor', 0.76923078) - .$self->param('max_b_frames', 0) - ### .' -me umh' # this will eventually be me_method, but not all ffmpeg versions support it yet - ; - } - else { - $ffmpeg_xtra .= ' -flags +mv4' ## +trell+loop' - ### .' -aic 1' - .' -mbd 1' - .' -cmp 2 -subcmp 2' - ; - } - # Some shared options - if ($self->{'multipass'} || $self->{'vbr'}) { - $ffmpeg_xtra .= $self->param('qcompress', 0.6) - .$self->param('qmax', 51) - .$self->param('max_qdiff', 4) - ; - } - # Dual pass? - if ($self->{'multipass'}) { - # Apparently, the -passlogfile option doesn't work for h264, so we need - # to be aware of other processes that might be working in this directory - if ($self->{'mp4_codec'} eq 'h264' && (-e 'x264_2pass.log.temp' || -e 'x264_2pass.log')) { - die "ffmpeg does not allow us to specify the name of the multi-pass log\n" - ."file, and x264_2pass.log exists in this directory already. Please\n" - ."wait for the other process to finish, or remove the stale file.\n"; - } - # Add all possible temporary files to the list - push @tmpfiles, 'x264_2pass.log', - 'x264_2pass.log.temp', - 'ffmpeg2pass-0.log'; - # Build the ffmpeg string - print "First pass...\n"; - $self->{'ffmpeg_xtra'} = ' -pass 1' - .$ffmpeg_xtra - .' -f mp4'; - if ($self->{'mp4_codec'} eq 'h264') { - $self->{'ffmpeg_xtra'} .= ' -refs 1 -subq 1' - .' -trellis 0' - ; - } - $self->SUPER::export($episode, '', 1); - # Second Pass - print "Final pass...\n"; - $ffmpeg_xtra = ' -pass 2 ' - .$ffmpeg_xtra; - } - # Single Pass - else { - if ($self->{'vbr'}) { - $ffmpeg_xtra .= ' -qmin '.$self->{'quantisation'}; - } - } - # Single/final pass options - if ($self->{'mp4_codec'} eq 'h264') { - $ffmpeg_xtra .= ' -refs '.($self->val('ipod') ? 2 : 7) - .' -subq 7' - .' -partitions parti4x4+parti8x8+partp4x4+partp8x8+partb8x8' - .' -flags2 +bpyramid+wpred+mixed_refs+8x8dct' ##+brdo' - .' -me_range 21' - .' -trellis 2' - .' -chromaoffset 1' - ### .' -slice 2' - ### .' -cmp 1' - # These should match the defaults: - .' -deblockalpha 0 -deblockbeta 0' - ; - } - # Audio codec name changes between ffmpeg versions - my $acodec = $self->can_encode('libfaac') ? 'libfaac' : 'aac'; - # Don't forget the audio, etc. - $self->{'ffmpeg_xtra'} = $ffmpeg_xtra - ." -acodec $acodec -ar 48000 -async 1" - .$self->param('ab', $self->{'a_bitrate'}); - # Execute the (final pass) encode - $self->SUPER::export($episode, '.mp4'); - } - -1; #return true - -# vim:ts=4:sw=4:ai:et:si:sts=4 - diff --git a/abs/core/nuvexport/PKGBUILD b/abs/core/nuvexport/PKGBUILD deleted file mode 100644 index 27369de..0000000 --- a/abs/core/nuvexport/PKGBUILD +++ /dev/null @@ -1,33 +0,0 @@ -# $Id: PKGBUILD 356 2008-04-18 22:56:27Z aaron $ -# Contributor: Paul Mattal <paul@mattal.com> -# Maintainer: Paul Mattal <paul@archlinux.org> -pkgname=nuvexport -pkgver=20080311 -relnum=0.5 -pkgrel=3 -pkgdesc="Export for MythTV nuv files to other formats (DVD/SVCD/DivX,etc.)" -arch=(i686 x86_64) -url="http://forevermore.net/files/nuvexport" -license="" -depends=(perl perl-dbi 'ffmpeg>=20060920' perl-dbd-mysql perl-date-manip) -makedepends=() -conflicts=() -replaces=() -backup=() -install= -source=(http://forevermore.net/files/nuvexport/archive/$pkgname-$relnum-0.$pkgver.svn.tar.bz2 $pkgname-ipod-disable.patch MP4.pm XviD.pm) -md5sums=('2d0a99623f06394daf3bf8769536d3cd' 'acd2dad9987e68359ead8b0be5e5797c') - -build() { - cd $startdir/src/$pkgname-$relnum - - sed -i "s|prefix=/usr/local|prefix=$startdir/pkg/usr|g" Makefile || return 1 - sed -i "s|/usr/bin/install|/bin/install|g" Makefile || return 1 - sed -i "s|sysconfdir=/etc|sysconfdir=$startdir/pkg/etc|g" Makefile || return 1 - - mkdir $startdir/pkg/usr || return 1 - make install || return 1 - sed -i "s|/tmp/fifodir|/var/tmp/fifodir|g" $startdir/pkg/usr/share/nuvexport/export/*.pm || return 1 - cp $startdir/src/MP4.pm $startdir/pkg/usr/share/nuvexport/export/ffmpeg/MP4.pm - cp $startdir/src/XviD.pm $startdir/pkg/usr/share/nuvexport/export/ffmpeg/XviD.pm -} diff --git a/abs/core/nuvexport/XviD.pm b/abs/core/nuvexport/XviD.pm deleted file mode 100755 index c4700f5..0000000 --- a/abs/core/nuvexport/XviD.pm +++ /dev/null @@ -1,197 +0,0 @@ -# -# ffmpeg-based XviD export module for nuvexport. -# -# @url $URL: svn+ssh://xris@svn.mythtv.org/var/lib/svn/trunk/mythextras/nuvexport/export/ffmpeg/XviD.pm $ -# @date $Date: 2008-02-19 20:47:06 -0800 (Tue, 19 Feb 2008) $ -# @version $Revision: 16175 $ -# @author $Author: xris $ -# @copyright Silicon Mechanics -# - -package export::ffmpeg::XviD; - use base 'export::ffmpeg'; - -# Load the myth and nuv utilities, and make sure we're connected to the database - use nuv_export::shared_utils; - use nuv_export::cli; - use nuv_export::ui; - use mythtv::recordings; - -# Load the following extra parameters from the commandline - add_arg('quantisation|q=i', 'Quantisation'); - add_arg('a_bitrate|a=i', 'Audio bitrate'); - add_arg('v_bitrate|v=i', 'Video bitrate'); - add_arg('multipass!', 'Enable two-pass encoding.'); - - sub new { - my $class = shift; - my $self = { - 'cli' => qr/\bxvid\b/i, - 'name' => 'Export to XviD', - 'enabled' => 1, - 'errors' => [], - 'defaults' => {}, - }; - bless($self, $class); - - # Initialize the default parameters - $self->load_defaults(); - - # Verify any commandline or config file options - die "Audio bitrate must be > 0\n" unless (!defined $self->val('a_bitrate') || $self->{'a_bitrate'} > 0); - die "Video bitrate must be > 0\n" unless (!defined $self->val('v_bitrate') || $self->{'v_bitrate'} > 0); - die "Width must be > 0\n" unless (!defined $self->val('width') || $self->{'width'} =~ /^\s*\D/ || $self->{'width'} > 0); - die "Height must be > 0\n" unless (!defined $self->val('height') || $self->{'height'} =~ /^\s*\D/ || $self->{'height'} > 0); - - # VBR, multipass, etc. - if ($self->val('multipass')) { - $self->{'vbr'} = 1; - } - elsif ($self->val('quantisation')) { - die "Quantisation must be a number between 1 and 31 (lower means better quality).\n" if ($self->{'quantisation'} < 1 || $self->{'quantisation'} > 31); - $self->{'vbr'} = 1; - } - - # Initialize and check for ffmpeg - $self->init_ffmpeg(); - - # Can we even encode xvid? - if (!$self->can_encode('xvid') && !$self->can_encode('libxvid')) { - push @{$self->{'errors'}}, "Your ffmpeg installation doesn't support encoding to xvid.\n" - ." (It must be compiled with the --enable-libxvid option)"; - } - if (!$self->can_encode('mp3') && !$self->can_encode('libmp3lame')) { - push @{$self->{'errors'}}, "Your ffmpeg installation doesn't support encoding to mp3 audio."; - } - - # Any errors? disable this function - $self->{'enabled'} = 0 if ($self->{'errors'} && @{$self->{'errors'}} > 0); - # Return - return $self; - } - -# Load default settings - sub load_defaults { - my $self = shift; - # Load the parent module's settings - $self->SUPER::load_defaults(); - # Default bitrates and resolution - $self->{'defaults'}{'a_bitrate'} = 128; - $self->{'defaults'}{'v_bitrate'} = 960; - $self->{'defaults'}{'width'} = 624; - } - -# Gather settings from the user - sub gather_settings { - my $self = shift; - # Load the parent module's settings - $self->SUPER::gather_settings(); - # Audio Bitrate - $self->{'a_bitrate'} = query_text('Audio bitrate?', - 'int', - $self->val('a_bitrate')); - # VBR options - if (!$is_cli) { - $self->{'vbr'} = query_text('Variable bitrate video?', - 'yesno', - $self->val('vbr')); - if ($self->{'vbr'}) { - $self->{'multipass'} = query_text('Multi-pass (slower, but better quality)?', - 'yesno', - $self->val('multipass')); - if (!$self->{'multipass'}) { - while (1) { - my $quantisation = query_text('VBR quality/quantisation (1-31)?', - 'float', - $self->val('quantisation')); - if ($quantisation < 1) { - print "Too low; please choose a number between 1 and 31.\n"; - } - elsif ($quantisation > 31) { - print "Too high; please choose a number between 1 and 31\n"; - } - else { - $self->{'quantisation'} = $quantisation; - last; - } - } - } - } else { - $self->{'multipass'} = 0; - } - # Ask the user what video bitrate he/she wants - $self->{'v_bitrate'} = query_text('Video bitrate?', - 'int', - $self->val('v_bitrate')); - } - # Query the resolution - $self->query_resolution(); - } - - sub export { - my $self = shift; - my $episode = shift; - # Make sure we have the framerate - $self->{'out_fps'} = $episode->{'finfo'}{'fps'}; - # Embed the title - $safe_title = $episode->{'title'}; - if ($episode->{'subtitle'} ne 'Untitled') { - $safe_title .= ' - '.$episode->{'subtitle'}; - } - my $safe_title = shell_escape($safe_title); - # Codec name changes between ffmpeg versions - my $codec = $self->can_encode('libxvid') ? 'libxvid' : 'xvid'; - # Build the common ffmpeg string - my $ffmpeg_xtra = ' -vcodec '.$codec - .$self->param('bit_rate', $self->{'v_bitrate'}) - .($self->{'vbr'} - ? $self->param('rc_min_rate', 32) - . $self->param('rc_max_rate', (2 * $self->{'v_bitrate'})) - . $self->param('bit_rate_tolerance', 32) - . ' -bufsize 65535' - : '') - .' -flags +mv4+loop+cgop' - .' -trellis 1' - ### .' -aic 1' - .' -mbd 1' - .' -cmp 2 -subcmp 2' - ### .' -cgop 1' - .$self->param('b_quant_factor', 150) - .$self->param('b_quant_offset', 100) - .$self->param('max_b_frames', 1) - ; - # Dual pass? - if ($self->{'multipass'}) { - # Add the temporary file to the list - push @tmpfiles, "/tmp/xvid.$$.log"; - # First pass - print "First pass...\n"; - $self->{'ffmpeg_xtra'} = $ffmpeg_xtra - ." -pass 1 -passlogfile '/tmp/xvid.$$.log'" - .' -f avi'; - $self->SUPER::export($episode, '', 1); - # Second pass - print "Final pass...\n"; - $self->{'ffmpeg_xtra'} = $ffmpeg_xtra - . " -pass 2 -passlogfile '/tmp/xvid.$$.log'"; - } - # Single Pass - else { - $self->{'ffmpeg_xtra'} = $ffmpeg_xtra - .($self->{'vbr'} - ? ' -qmax 31 -qmin '.$self->{'quantisation'} - : ''); - } - # Don't forget the audio, etc. - $self->{'ffmpeg_xtra'} .= ' -acodec ' - .($self->can_encode('libmp3lame') ? 'libmp3lame' : 'mp3') - .' -async 1 ' - .$self->param('ab', $self->{'a_bitrate'}) - .' -f avi'; - # Execute the (final pass) encode - $self->SUPER::export($episode, '.avi'); - } - -1; #return true - -# vim:ts=4:sw=4:ai:et:si:sts=4 diff --git a/abs/core/nuvexport/nuvexport-ipod-disable.patch b/abs/core/nuvexport/nuvexport-ipod-disable.patch deleted file mode 100644 index dfb17a9..0000000 --- a/abs/core/nuvexport/nuvexport-ipod-disable.patch +++ /dev/null @@ -1,12 +0,0 @@ -diff -urN nuvexport-0.3/nuvexport nuvexport-0.3-fixed/nuvexport ---- nuvexport-0.3/nuvexport 2006-07-26 03:37:13.000000000 -0400 -+++ nuvexport-0.3-fixed/nuvexport 2006-07-27 20:58:41.000000000 -0400 -@@ -93,7 +93,7 @@ - push @Exporters, export::ffmpeg::ASF->new; - push @Exporters, export::ffmpeg::MP3->new; - push @Exporters, export::ffmpeg::PSP->new; -- push @Exporters, export::ffmpeg::iPod->new; -+# push @Exporters, export::ffmpeg::iPod->new; - } - elsif ($export_prog eq 'mencoder') { - push @Exporters, export::mencoder::XviD->new; |