view bin/ascoltami2 @ 789:ea8ca6502255

refactor to prepare for submasters to work out of the main graph Ignore-this: a5d4b63cf6b7daf52cce9bbfc3e0c5b3
author drewp@bigasterisk.com
date Mon, 18 Jun 2012 01:34:40 +0000
parents 8d87a3528369
children cbfed4e684ef
line wrap: on
line source

#!bin/python
import web, thread, gobject, sys, optparse, logging
from rdflib import URIRef
sys.path.append(".")
from light9.ascoltami.player import Player
from light9.ascoltami.playlist import Playlist, NoSuchSong
from light9.ascoltami.webapp import makeWebApp, songUri, songLocation
from light9 import networking, showconfig


import BaseHTTPServer
BaseHTTPServer.BaseHTTPRequestHandler.log_message = \
                     lambda self, format, *args: None

class App:
    def __init__(self, graph, show):
        self.graph = graph
        self.player = Player(onEOS=self.onEOS)
        self.show = show
        self.playlist = Playlist.fromShow(graph, show)

    def run(self, musicPort):
        # the cherrypy server would wedge when vidref pounds on it; this
        # one seems to run
        thread.start_new(web.httpserver.runbasic,
                         (makeWebApp(self).wsgifunc(),
                          ('0.0.0.0', musicPort)))

        mainloop = gobject.MainLoop()
        mainloop.run()

    def onEOS(self, song):
        self.player.pause()
        self.player.seek(0)

        thisSongUri = songUri(graph, URIRef(song))

        try:
            nextSong = self.playlist.nextSong(thisSongUri)
        except NoSuchSong: # we're at the end of the playlist
            return

        self.player.setSong(songLocation(graph, nextSong), play=False)

if __name__ == "__main__":
    logging.basicConfig()
    log = logging.getLogger()
    gobject.threads_init()

    parser = optparse.OptionParser()
    parser.add_option('--show',
        help='show URI, like http://light9.bigasterisk.com/show/dance2008', default=showconfig.showUri())
    parser.add_option("-v", "--verbose", action="store_true",
                      help="logging.DEBUG")
    (options, args) = parser.parse_args()

    log.setLevel(logging.DEBUG if options.verbose else logging.INFO)

    if not options.show:
        raise ValueError("missing --show http://...")
            
    graph = showconfig.getGraph()
    app = App(graph, URIRef(options.show))
    app.run(networking.musicPlayer.port)