Mercurial > code > home > repos > light9
view bin/effectsequencer @ 1758:887eb43b389a
properly clear adjs on narrow notes
Ignore-this: 175b1c2b7ffdcccadfd49d8f81d9f3ad
author | Drew Perttula <drewp@bigasterisk.com> |
---|---|
date | Mon, 28 May 2018 00:25:46 +0000 |
parents | f140153c087c |
children | b680d6f50a93 |
line wrap: on
line source
#!bin/python """ plays back effect notes from the timeline """ from __future__ import division from run_local import log from twisted.internet import reactor from light9.greplin_cyclone import StatsForCyclone from rdfdb.syncedgraph import SyncedGraph from light9 import networking, showconfig from greplin import scales import optparse, sys, logging import cyclone.web from rdflib import URIRef from light9.effect.sequencer import Sequencer, sendToCollector from light9 import clientsession class App(object): def __init__(self, show, session): self.show = show self.session = session self.graph = SyncedGraph(networking.rdfdb.url, "effectSequencer") self.graph.initiallySynced.addCallback(self.launch) self.stats = scales.collection('/', scales.PmfStat('sendLevels'), scales.PmfStat('getMusic'), scales.PmfStat('evals'), scales.PmfStat('sendOutput'), scales.IntStat('errors'), ) def launch(self, *args): self.seq = Sequencer( self.graph, lambda settings: sendToCollector('effectSequencer', self.session, settings)) self.cycloneApp = cyclone.web.Application(handlers=[ (r'/stats', StatsForCyclone), ], debug=True, graph=self.graph, stats=self.stats) reactor.listenTCP(networking.effectSequencer.port, self.cycloneApp) log.info("listening on %s" % networking.effectSequencer.port) if __name__ == "__main__": 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") parser.add_option("--twistedlog", action="store_true", help="twisted logging") clientsession.add_option(parser) (options, args) = parser.parse_args() log.setLevel(logging.DEBUG if options.verbose else logging.INFO) if not options.show: raise ValueError("missing --show http://...") session = clientsession.getUri('effectSequencer', options) app = App(URIRef(options.show), session) if options.twistedlog: from twisted.python import log as twlog twlog.startLogging(sys.stderr) reactor.run()