Files
dss/core/utils/waveform.py
Fergal Moran 5d0612e037 Change to SOX
2014-03-13 19:42:09 +00:00

45 lines
1.9 KiB
Python
Executable File

import subprocess
import traceback
import uuid
import os
from dss import settings
def generate_waveform(input_file, output_file):
print "Generating waveform"
try:
working_file = "%s%s.wav" % (settings.DSS_TEMP_PATH, uuid.uuid1())
try:
print "Starting decode : %s\nInput File: %s\nOutput File: %s" % \
(settings.DSS_LAME_PATH, input_file, working_file)
#sox f679a81a-ea14-4385-a677-c663559d1e4b.mp3 -c 1 -t wav -
#| /srv/dss/bin/wav2png -w 800 -h 120 -o song.png /dev/stdin
convert = subprocess.Popen("%s %s -c 1 -t wav" % (settings.DSS_LAME_PATH, input_file),
shell=True, stdout=subprocess.PIPE)
waveform = subprocess.Popen("%s -w 800 -h 120 -o %s" % (settings.DSS_WAVE_PATH, working_file),
shell=True, stdout=subprocess.PIPE)
print "Finished decode"
if os.path.exists(working_file):
print "Starting waveform generation"
ret = subprocess.call([
settings.DSS_WAVE_PATH, "-w", "800", "-h", "120", "-o",
output_file,
working_file], stderr=subprocess.PIPE, stdout=subprocess.PIPE)
if os.path.isfile(output_file):
os.remove(working_file)
print "Generated waveform"
return output_file
else:
print "Failed generating waveform: %s" % output_file
print "Subprocess returned: %s" % ret
else:
print "Unable to find working file, did LAME succeed?"
return ""
except Exception, ex:
print "Error generating waveform %s" % (ex)
except:
print "Error generating waveform"
traceback.print_exc()