From 45018d64564d7e4c97ac3f796c7cff7e4db49efd Mon Sep 17 00:00:00 2001 From: "Alan J. Pippin" <ajp@dec.(none)> Date: Sat, 2 Feb 2013 19:40:53 -0700 Subject: [PATCH] Added new eject_opts option for greater flexibility. Fixed auto title naming algorithm. --- rip_dvd | 41 ++++++++++++++++++++++++++++++++--------- rip_dvd.conf.dist | 3 +++ 2 files changed, 35 insertions(+), 9 deletions(-) diff --git a/rip_dvd b/rip_dvd index 3b846fb..8a8c2fa 100755 --- a/rip_dvd +++ b/rip_dvd @@ -48,6 +48,7 @@ typeset mkvpropedit="" typeset mkvmerge="" typeset mp4box="" typeset dvdxchap="" +typeset eject_opts="-T" typeset -i default_aid=128 typeset -i aid_override=-1 typeset -i force_onepass_mode=0 @@ -1151,11 +1152,20 @@ function make_dvd_mkv_image { echo "\n" | tee -a "$ddrescuelog" dstfile=${dstmkv%.[^.]*} typeset -i num=0 + typeset -i titles=0 for i in `/bin/ls -1 "$dstdir"/*.mkv`; do - echo -e " Moving $i -> $dstfile.$num.mkv" | tee -a "$ddrescuelog" - mv "$i" "$dstfile.$num.mkv" - ((num = num + 1 )) + ((titles = titles + 1)) done + if [[ $titles > 1 ]]; then + for i in `/bin/ls -1 "$dstdir"/*.mkv`; do + echo -e " Moving $i -> $dstfile.$num.mkv" | tee -a "$ddrescuelog" + mv "$i" "$dstfile.$num.mkv" + ((num = num + 1 )) + done + else + echo -e " Moving $dstdir/*.mkv -> $dstfile.mkv" | tee -a "$ddrescuelog" + mv "$dstdir"/*.mkv "$dstfile.mkv" + fi echo "\n" | tee -a "$ddrescuelog" fi @@ -1835,14 +1845,27 @@ if [ $mirror_mode -eq 1 ]; then if [[ "$ripper" == "makemkv" ]]; then # use makemkv to make an MKV file of the disk make_dvd_mkv_image "$tmpdir/$dvdname.mkv" "disc" "$makemkv_disc_id" - echo " Moving $tmpdir/$dvdname.mkv -> $dest/$dvdname.mkv" - mv "$tmpdir/$dvdname.mkv" "$dest/$dvdname.mkv" + # move the ripped movies into place + typeset -i num=0 + for i in `/bin/ls -1 "$tmpdir/$dvdname"*.mkv`; do + if [[ "$i" =~ .[[:digit:]].mkv ]]; then + finaldest="$dest/$dvdname.$num.mkv" + else + finaldest="$dest/$dvdname.mkv" + fi + while [[ -e "$finaldest" ]]; do + ((num = num + 1 )) + finaldest="$dest/$dvdname.$num.mkv" + done + echo " Moving $i -> $finaldest" + mv "$i" "$finaldest" + done # add this video data to the mythtv DB fill_mythvideo_metadata "$dest_filename" else # use ddrescue to make an ISO image of the disk make_dvd_iso_image "$tmpdir/$dvdname.iso" - echo " Moving $tmpdir/$dvdname.mkv -> $dest/$dvdname.mkv" + echo " Moving $tmpdir/$dvdname.iso -> $dest/$dvdname.iso" mv "$tmpdir/$dvdname.iso" "$dest/$dvdname.iso" # add this video data to the mythtv DB fill_mythvideo_metadata "$dest_filename" @@ -1850,7 +1873,7 @@ if [ $mirror_mode -eq 1 ]; then # eject the disk upon completion if [ $eject_disk -ne 0 ]; then - eject -T $dev + eject $eject_opts $dev fi date=`date` @@ -1970,7 +1993,7 @@ if [ $mirror_mode -eq 0 ]; then fi # eject the DVD disk since we are finished with it - [ $eject_disk -eq 2 ] && eject -T $dev + [ $eject_disk -eq 2 ] && eject $eject_opts $dev # encode the VOB file to a compressed file format if [ $make_final_dest_comp -eq 1 ]; then @@ -2056,7 +2079,7 @@ if [ $mirror_mode -eq 0 ]; then remove_intermediate_dvdbackup_folder # eject the DVD disk upon completion - [ $eject_disk -eq 1 ] && eject -T $dev + [ $eject_disk -eq 1 ] && eject $eject_opts $dev date=`date` echo "$date DVD rip completed" | tee -a "$logfile" diff --git a/rip_dvd.conf.dist b/rip_dvd.conf.dist index 808ee25..a9c865a 100644 --- a/rip_dvd.conf.dist +++ b/rip_dvd.conf.dist @@ -28,6 +28,9 @@ mailto=root # Setup the path to the tools needed by this ripper PATH=/etc/mythtv/bin:/usr/local/bin:/usr/sbin:/sbin:/usr/bin:/usr/share/tovid:.:$PATH +# Specify the options to use with the eject command +eject_opts="-T" + # Use mplayer dumpstream to create the main VOB file # If set to 0, cat and other utils will be used to make it instead. # Using mplayer dumpstream is by far the best way to create the main VOB file -- 2.34.1