1 | #!/bin/sh |
---|
2 | |
---|
3 | # |
---|
4 | # Replaces given mpeg2 recording with avi transcoded using xvid codec. |
---|
5 | # |
---|
6 | # The script automatically rebuilds the seek table and updates the myth database |
---|
7 | # with the new filename. |
---|
8 | # |
---|
9 | |
---|
10 | MENCODER=/usr/local/bin/mencoder |
---|
11 | MYSQL=/usr/bin/mysql |
---|
12 | DBUSER=mythtv |
---|
13 | DBPASS=mythtv |
---|
14 | DBNAME=mythconverg |
---|
15 | |
---|
16 | # error checking |
---|
17 | if [ $# -ne 2 ]; then |
---|
18 | echo "Usage: $(basename $0) directory file.mpg" 1>&2 |
---|
19 | echo " directory - MythTV recordings storage directory" 1>&2 |
---|
20 | echo " file.mpg - MPEG recording file" 1>&2 |
---|
21 | exit 1 |
---|
22 | fi |
---|
23 | |
---|
24 | DIR=$1 |
---|
25 | FILE=$2 |
---|
26 | |
---|
27 | if [ ! -d $DIR ]; then |
---|
28 | echo "$(basename $0): Directory $DIR not found" 1>&2 |
---|
29 | exit 1 |
---|
30 | fi |
---|
31 | |
---|
32 | if ! echo $FILE | grep -q '.mpg'; then |
---|
33 | echo "$(basename $0): $FILE not recognized as an mpeg file (no .mpg extension)" 1>&2 |
---|
34 | exit 1 |
---|
35 | fi |
---|
36 | |
---|
37 | BASENAME=$(basename $FILE .mpg) |
---|
38 | LOGFILE=${BASENAME}.log |
---|
39 | |
---|
40 | cd $DIR |
---|
41 | |
---|
42 | # transcode mpg to avi using xvid codec |
---|
43 | /usr/bin/nice -n 17 $MENCODER -passlogfile $LOGFILE $FILE -o /dev/null -vf kerndeint,scale=720:576 -oac mp3lame -ovc xvid -xvidencopts pass=1 #:max_bframes=1:trellis:vhq=4:chroma_me:chroma_opt:hq_ac:bvhq=1 |
---|
44 | /usr/bin/nice -n 17 $MENCODER -passlogfile $LOGFILE $FILE -o ${BASENAME}.avi -vf kerndeint,scale=720:576 -oac mp3lame -ovc xvid -xvidencopts pass=2:bitrate=800 #:max_bframes=1:trellis:vhq=4:chroma_me:chroma_opt:hq_ac:bvhq=1 |
---|
45 | |
---|
46 | # remove xvid pass 1 log file |
---|
47 | rm -f $LOGFILE 2> /dev/null |
---|
48 | |
---|
49 | # Sanity check: verify avi file exists and has size greater than zero |
---|
50 | if [ ! -s ${BASENAME}.avi ]; then |
---|
51 | echo "$(basename $0): Transcoding of file $FILE failed" 1>&2 |
---|
52 | rm -f ${BASENAME}.avi 2> /dev/null |
---|
53 | exit 2 |
---|
54 | fi |
---|
55 | |
---|
56 | # Modify myth database file info |
---|
57 | FILEINFO="$(ls -l ${BASENAME}.avi)" |
---|
58 | FILESIZE="$(echo $FILEINFO | awk '{print $5}')" |
---|
59 | FILELASTMOD="$(echo $FILEINFO | awk '{print $6" "$7}')" |
---|
60 | |
---|
61 | echo "UPDATE recorded SET lastmodified='${FILELASTMOD}',filesize='${FILESIZE}',basename='${BASENAME}.avi' WHERE basename='$FILE';" | $MYSQL -u$DBUSER -p$DBPASS --batch $DBNAME |
---|
62 | |
---|
63 | # rebuild seek table for new avi file |
---|
64 | nice -n 17 mythcommflag -f ${BASENAME}.avi --rebuild |
---|
65 | |
---|
66 | # rename screenshot file |
---|
67 | if [ -f ${FILE}.png ]; then |
---|
68 | cp ${FILE}.png ${BASENAME}.avi.png |
---|
69 | fi |
---|
70 | |
---|
71 | # remove original .mpg files |
---|
72 | # rm -f $FILE |
---|
73 | # rm -f ${FILE}.png |
---|