Advertisement
Guest User

Untitled

a guest
Mar 30th, 2017
62
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.10 KB | None | 0 0
  1. #!/bin/sh
  2.  
  3. src=$1
  4. dst=${1%.*}.mp4
  5. bak=${1%.*}.orig.${1##*.}
  6.  
  7. sqldb=convert.db
  8.  
  9. sqlinit() {
  10. [ -f "$1" ] || sqlite3 "$1" 'CREATE TABLE encodings(path TEXT PRIMARY KEY NOT NULL, orig TEXT, backup TEXT, origsize INT, newsize INT)'
  11. }
  12.  
  13. restore() {
  14. mv "$bak" "$src"
  15. }
  16.  
  17. sqlinit "$sqldb"
  18.  
  19. [ -f "$src" ] || exec echo "fail to open $dst"
  20. [ -f "$bak" ] && exec echo "backup $bak already exists"
  21.  
  22. exist=$(sqlite3 "$sqldb" "SELECT count(*) FROM encodings WHERE path = '$dst' OR orig = '$src'")
  23.  
  24. [ "$exist" -gt 0 ] && exec echo "$dst already converted"
  25.  
  26. mv "$src" "$bak"
  27.  
  28. echo "Converting \"$dst\""
  29. if ffmpeg -v 16 -y -i "$bak" -crf 22 -preset:v slow -c:a libfdk_aac -vbr 4 "$dst"; then
  30. origsize=$(stat "$bak" -c %s)
  31. newsize=$(stat "$dst" -c %s)
  32. save=$((newsize * 100 / origsize))
  33.  
  34. echo "$((origsize >> 20)) => $((newsize >> 20)) MB, $save %"
  35.  
  36. if [ $save -le 90 ]; then
  37. sqlite3 "$sqldb" "INSERT INTO encodings VALUES('$dst', '$src', '$bak', $origsize, $newsize)"
  38. else
  39. echo 'restoring old file'
  40. sqlite3 "$sqldb" "INSERT INTO encodings VALUES('$src', NULL, NULL, NULL, NULL)"
  41. restore
  42. fi
  43. else
  44. echo 'error, restoring'
  45. restore
  46. fi
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement