From 9561716cb4b0b2812755889d3899cc8ac53359f9 Mon Sep 17 00:00:00 2001
From: "Alan J. Pippin" <alan@pippins.net>
Date: Thu, 20 Dec 2012 14:08:29 -0700
Subject: [PATCH] Added new moviedir option and makemkv only copy largest mkv
 option. Added support to get volnames from BluRay disks using makemkv.

---
 rip_dvd           | 46 +++++++++++++++++++++++++++++-----------------
 rip_dvd.conf.dist |  6 ++++++
 rip_dvd.wrap      | 14 +++++++-------
 3 files changed, 42 insertions(+), 24 deletions(-)

diff --git a/rip_dvd b/rip_dvd
index 24d881e..3b846fb 100755
--- a/rip_dvd
+++ b/rip_dvd
@@ -78,6 +78,7 @@ typeset -i custom_audio_2ch=0
 typeset -i custom_audio_6ch=0
 typeset -i minimum_feature_title_length=60
 typeset -i lsdvd_timeout=10
+typeset -i makemkv_copy_largest_title_only=1
 
 ##############################################################################
 # Local Machine Settings:
@@ -336,9 +337,18 @@ if [ -z "$dvdname" ]; then
     echo "-E- Can't access the DVD device $dev"
     exit 1
   fi
+
   # now capture the volume name from the device
   dvdname=`volname $dev | awk '{ print $1 }'`
   ripdvd=1
+ 
+  # if the dvdname is still blank, go about it a different way (for BluRays)
+  if [[ -z "$dvdname" ]]; then
+    echo "-> Using makemkv to obtain disk label"
+    dvdname=`$makemkv info --noscan --robot disc:$makemkv_disc_id | grep "CINFO:2," | awk -F "," '{ print $3; }' | tr ' ' '_' | sed 's/\"//g'`
+    echo "   Found disk label: $dvdname"
+    ripdvd=1
+  fi
 
 else 
 
@@ -1121,7 +1131,7 @@ function make_dvd_mkv_image {
     dstdir=${dstmkv%.[^.]*}
     ((min_length = minimum_feature_title_length * 60))
 
-    echo -e "\n   Ripping: $makemkv --minlength=$min_length --decrypt --progress=-same $srctype:$srcname all $dstdir"
+    echo -e "\n   Ripping: $makemkv mkv --minlength=$min_length --decrypt --progress=-same $srctype:$srcname all $dstdir"
     mkdir -p "$dstdir"
     $makemkv mkv --minlength=$min_length --decrypt --progress=-same $srctype:$srcname all $dstdir 2>&1 | tee -a "$ddrescuelog"
     makemkv_retval=$?
@@ -1130,22 +1140,24 @@ function make_dvd_mkv_image {
 	fatal_and_exit "-E- Unhandled makemkv error"
     fi
 
-    # Move the largest created MKV file into place
-    # There might be multiple ones, so just grab the largest one
-    largest_mkv_file=`/bin/ls -1S "$dstdir"/*.mkv | head -1`
-    echo -e "\n   Moving largest mkv file $largest_mkv_file -> $dstmkv\n" | tee -a "$ddrescuelog"
-    mv "$largest_mkv_file" "$dstmkv"
-
-    # Move all of the created MKV file into place
-    #echo "\n" | tee -a "$ddrescuelog"
-    #dstfile=${dstmkv%.[^.]*}
-    #typeset -i num=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 ))
-    #done
-    #echo "\n" | tee -a "$ddrescuelog"
+    if [ $makemkv_copy_largest_title_only -eq 1 ]; then
+      # Move the largest created MKV file to destination
+      # There might be multiple ones, so just grab the largest one
+      largest_mkv_file=`/bin/ls -1S "$dstdir"/*.mkv | head -1`
+      echo -e "\n   Moving largest mkv file $largest_mkv_file -> $dstmkv\n" | tee -a "$ddrescuelog"
+      mv "$largest_mkv_file" "$dstmkv"
+    else
+      # Move all of the created MKV files to destination
+      echo "\n" | tee -a "$ddrescuelog"
+      dstfile=${dstmkv%.[^.]*}
+      typeset -i num=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 ))
+      done
+      echo "\n" | tee -a "$ddrescuelog"
+    fi
 
     if [ $? != 0 ]; then
 	fatal_and_exit "-E- Unhandled mv error"
diff --git a/rip_dvd.conf.dist b/rip_dvd.conf.dist
index 658edda..808ee25 100644
--- a/rip_dvd.conf.dist
+++ b/rip_dvd.conf.dist
@@ -19,6 +19,9 @@ logdir=/var/log/ripdvd
 # Specify the path to the tmp rip directory
 tmpdir=/myth/video/DVDs/.ripdvd
 
+# Specify the path to the base destination dir for ripped movies
+moviedir=/myth/video/Movies
+
 # Specify the email address to send job notifications to
 mailto=root
 
@@ -78,6 +81,9 @@ mp4box="MP4Box"
 # Set the disc_id option to be the ID of the DVD drive in your system
 makemkv="makemkvcon"
 makemkv_disc_id="0"
+makemkv_copy_largest_title_only=1
+
+# MKV Tools
 # http://www.bunkus.org/videotools/mkvtoolnix/
 mkvextract="mkvextract"
 mkvpropedit="mkvpropedit"
diff --git a/rip_dvd.wrap b/rip_dvd.wrap
index 95af1e9..3dc8f3a 100755
--- a/rip_dvd.wrap
+++ b/rip_dvd.wrap
@@ -97,27 +97,27 @@ dvdname=${dvdname%.} # remove trailing '.' character
 #   since these are only kept around until we watch them,
 #   there is no need to do anything less than full iso.
 # - collection = Only DVD main feature is ripped
-# - childrens = Only DVD main feature is ripped
+# - children = Only DVD main feature is ripped
 # - church = Only DVD main feature is ripped
 rip_opts="$* -j 2"
 if [ "$dvdtype" == "netflix" ]; then
   echo "-> Ripping Netflix DVD"
-  dest=/myth/video/Movies/Netflix
+  dest="$moviedir/Netflix"
   rip_opts="$rip_opts"
 elif [ "$dvdtype" == "collection" ]; then
   echo "-> Ripping Personal Collection DVD"
-  dest=/myth/video/Movies/Collection
+  dest="$moviedir/Collection"
   rip_opts="$rip_opts"
-elif [ "$dvdtype" == "childrens" ]; then
+elif [ "$dvdtype" == "children" ]; then
   echo "-> Ripping Children's DVD"
-  dest=/myth/video/Movies/Childrens
+  dest="$moviedir/Children"
   rip_opts="$rip_opts"
 elif [ "$dvdtype" == "church" ]; then
   echo "-> Ripping Church DVD"
-  dest=/myth/video/Movies/Church
+  dest="$moviedir/Church"
   rip_opts="$rip_opts"
 else
-  echo '-E- Must specify dvdtype as "netflix" or "collection" or "childrens" or "church"'
+  echo '-E- Must specify dvdtype as "netflix" or "collection" or "children" or "church"'
   exit 1
 fi
 
-- 
2.34.1