Strip out gst stuff from localbackend and start using output

This commit is contained in:
Thomas Adamcik 2010-08-14 17:29:50 +02:00
parent 85100f2143
commit a094c66546

View File

@ -1,34 +1,17 @@
import gobject
gobject.threads_init()
# FIXME make sure we don't get hit by
# http://jameswestby.net/
# weblog/tech/14-caution-python-multiprocessing-and-glib-dont-mix.html
import pygst
pygst.require('0.10')
import gst
import logging
import os
import glob
import shutil
import threading
import multiprocessing
from mopidy.backends.base import *
from mopidy.models import Playlist, Track, Album
from mopidy import settings
from mopidy.utils import parse_m3u, parse_mpd_tag_cache
from mopidy.process import pickle_connection
logger = logging.getLogger(u'mopidy.backends.local')
class LocalMessages(threading.Thread):
def run(self):
gobject.MainLoop().run()
message_thread = LocalMessages()
message_thread.daemon = True
message_thread.start()
class LocalBackend(BaseBackend):
"""
A backend for playing music from a local music archive.
@ -49,71 +32,39 @@ class LocalBackend(BaseBackend):
class LocalPlaybackController(BasePlaybackController):
def __init__(self, backend):
super(LocalPlaybackController, self).__init__(backend)
self._bin = gst.element_factory_make("playbin", "player")
self._bus = self._bin.get_bus()
sink = gst.element_factory_make("fakesink", "fakesink")
# FIXME cleanup fakesink?
self._bin.set_property("video-sink", sink)
self._bus.add_signal_watch()
self._bus_id = self._bus.connect('message', self._message)
self.stop()
def _set_state(self, state):
self._bin.set_state(state)
(_, new, _) = self._bin.get_state()
return new == state
def _send_recv(self, message):
(my_end, other_end) = multiprocessing.Pipe()
message.update({'reply_to': pickle_connection(other_end)})
self.backend.output_queue.put(message)
my_end.poll(None)
return my_end.recv()
def _message(self, bus, message):
if message.type == gst.MESSAGE_EOS:
self.end_of_track_callback()
elif message.type == gst.MESSAGE_ERROR:
self._bin.set_state(gst.STATE_NULL)
error, debug = message.parse_error()
logger.error('%s %s', error, debug)
def _send(self, message):
self.backend.output_queue.put(message)
def _set_state(self, state):
return self._send_recv({'command': 'set_state', 'state': state})
def _play(self, track):
self._bin.set_state(gst.STATE_READY)
self._bin.set_property('uri', track.uri)
return self._set_state(gst.STATE_PLAYING)
return self._send_recv({'command': 'play_uri', 'uri': track.uri})
def _stop(self):
return self._set_state(gst.STATE_READY)
return self._set_state('READY')
def _pause(self):
return self._set_state(gst.STATE_PAUSED)
return self._set_state('PAUSED')
def _resume(self):
return self._set_state(gst.STATE_PLAYING)
return self._set_state('PLAYING')
def _seek(self, time_position):
self._bin.seek_simple(gst.Format(gst.FORMAT_TIME),
gst.SEEK_FLAG_FLUSH, time_position * gst.MSECOND)
self._set_state(gst.STATE_PLAYING)
pass
@property
def time_position(self):
try:
return self._bin.query_position(gst.FORMAT_TIME)[0] // gst.MSECOND
except gst.QueryError, e:
logger.error('time_position failed: %s', e)
return 0
def destroy(self):
playbin, self._bin = self._bin, None
bus, self._bus = self._bus, None
bus.disconnect(self._bus_id)
bus.remove_signal_watch()
playbin.get_state()
playbin.set_state(gst.STATE_NULL)
bus.set_flushing(True)
del bus
del playbin
pass
class LocalStoredPlaylistsController(BaseStoredPlaylistsController):