annotate bin/effecteval @ 1933:c81f86f3d65a

effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too) Ignore-this: c24e4c1c3ccd839e79b1b2fb19ee996a
author Drew Perttula <drewp@bigasterisk.com>
date Sun, 02 Jun 2019 11:37:14 +0000
parents 1a7e5b07bf17
children f29e26811206
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
1 #!bin/python
1593
6059de6659c3 move effects/ page into web/. fix homepage list. rm old subserver code.
Drew Perttula <drewp@bigasterisk.com>
parents: 1581
diff changeset
2
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
3 from run_local import log
1053
9937e2e3d17b effecteval faster loop, stats page
Drew Perttula <drewp@bigasterisk.com>
parents: 1052
diff changeset
4 from twisted.internet import reactor
9937e2e3d17b effecteval faster loop, stats page
Drew Perttula <drewp@bigasterisk.com>
parents: 1052
diff changeset
5 from twisted.internet.defer import inlineCallbacks, returnValue
1027
a38414bd3929 hacking on effecteval
Drew Perttula <drewp@bigasterisk.com>
parents: 1019
diff changeset
6 import cyclone.web, cyclone.websocket, cyclone.httpclient
1866
3c523c71da29 pyflakes cleanups and some refactors
Drew Perttula <drewp@bigasterisk.com>
parents: 1861
diff changeset
7 import sys, optparse, logging, json, itertools
1051
be016cd5e5c5 effecteval names its new curve after the sub you drop on it
Drew Perttula <drewp@bigasterisk.com>
parents: 1044
diff changeset
8 from rdflib import URIRef, Literal
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
9
1556
61f3f378cc62 move code for adding effect to current song to its own (testable) module
Drew Perttula <drewp@bigasterisk.com>
parents: 1548
diff changeset
10 from light9 import networking, showconfig
1079
fce46850ed8c consolidate the curve load/save rdf code more
Drew Perttula <drewp@bigasterisk.com>
parents: 1076
diff changeset
11 from light9.effecteval.effect import EffectNode
1560
e993c5e1df1a fix effecteval to drop notes into new-style timeline
Drew Perttula <drewp@bigasterisk.com>
parents: 1559
diff changeset
12 from light9.effect.edit import getMusicStatus, songNotePatch
1115
818275850003 effecteval screens for only the kinds of outputs that it can send, so i can run a second instance just for LEDs
Drew Perttula <drewp@bigasterisk.com>
parents: 1114
diff changeset
13 from light9.effecteval.effectloop import makeEffectLoop
1926
1a7e5b07bf17 use my greplin fork's stats/ code instead of an old local one
Drew Perttula <drewp@bigasterisk.com>
parents: 1877
diff changeset
14 from greplin.scales.cyclonehandler import StatsHandler
1556
61f3f378cc62 move code for adding effect to current song to its own (testable) module
Drew Perttula <drewp@bigasterisk.com>
parents: 1548
diff changeset
15 from light9.namespaces import L9
1692
6fa4288da8a6 rdfdb is its own package now
drewp@bigasterisk.com
parents: 1593
diff changeset
16 from rdfdb.patch import Patch
6fa4288da8a6 rdfdb is its own package now
drewp@bigasterisk.com
parents: 1593
diff changeset
17 from rdfdb.syncedgraph import SyncedGraph
1053
9937e2e3d17b effecteval faster loop, stats page
Drew Perttula <drewp@bigasterisk.com>
parents: 1052
diff changeset
18 from greplin import scales
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
19
1861
40cc863d2b63 start py3 and other dep fixes
drewp@bigasterisk.com
parents: 1860
diff changeset
20 from cycloneerr import PrettyErrorHandler
1866
3c523c71da29 pyflakes cleanups and some refactors
Drew Perttula <drewp@bigasterisk.com>
parents: 1861
diff changeset
21 from light9.coffee import StaticCoffee
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
22
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
23
1054
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
24 class EffectEdit(PrettyErrorHandler, cyclone.web.RequestHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
25
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
26 def get(self):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
27 self.set_header('Content-Type', 'text/html')
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
28 self.write(open("light9/effecteval/effect.html").read())
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
29
1054
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
30 def delete(self):
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
31 graph = self.settings.graph
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
32 uri = URIRef(self.get_argument('uri'))
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
33 with graph.currentState(tripleFilter=(None, L9['effect'], uri)) as g:
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
34 song = ctx = list(g.subjects(L9['effect'], uri))[0]
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
35 self.settings.graph.patch(
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
36 Patch(delQuads=[
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
37 (song, L9['effect'], uri, ctx),
1054
4595a82f5a90 effecteval has a delete button on effect rows
Drew Perttula <drewp@bigasterisk.com>
parents: 1053
diff changeset
38 ]))
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
39
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
40
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
41 @inlineCallbacks
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
42 def currentSong():
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
43 s = (yield getMusicStatus())['song']
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
44 if s is None:
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
45 raise ValueError("no current song")
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
46 returnValue(URIRef(s))
1187
102a456be7db refactor EE moving towards the ability to re-bump existing curves
drewp@bigasterisk.com
parents: 1181
diff changeset
47
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
48
1044
a2081b9adfe4 effecteval now takes dropped subs and makes new effects out of them
Drew Perttula <drewp@bigasterisk.com>
parents: 1043
diff changeset
49 class SongEffects(PrettyErrorHandler, cyclone.web.RequestHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
50
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
51 def wideOpenCors(self):
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
52 self.set_header('Access-Control-Allow-Origin', '*')
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
53 self.set_header('Access-Control-Allow-Methods',
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
54 'GET, PUT, POST, DELETE, OPTIONS')
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
55 self.set_header('Access-Control-Max-Age', '1000')
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
56 self.set_header('Access-Control-Allow-Headers',
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
57 'Content-Type, Authorization, X-Requested-With')
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
58
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
59 def options(self):
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
60 self.wideOpenCors()
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
61 self.write('')
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
62
1180
6c4981f61bf8 subserver inserts effects with envelope curves
Drew Perttula <drewp@bigasterisk.com>
parents: 1141
diff changeset
63 @inlineCallbacks
1044
a2081b9adfe4 effecteval now takes dropped subs and makes new effects out of them
Drew Perttula <drewp@bigasterisk.com>
parents: 1043
diff changeset
64 def post(self):
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
65 self.wideOpenCors()
1076
dc474426845d effecteval better logging. everyone put their curve files in the right place.
Drew Perttula <drewp@bigasterisk.com>
parents: 1064
diff changeset
66 dropped = URIRef(self.get_argument('drop'))
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
67
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
68 try:
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
69 song = URIRef(self.get_argument('uri'))
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
70 except Exception: # which?
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
71 song = yield currentSong()
1556
61f3f378cc62 move code for adding effect to current song to its own (testable) module
Drew Perttula <drewp@bigasterisk.com>
parents: 1548
diff changeset
72
1558
7eb3676b8fd6 more of the fixed add-to-song service
Drew Perttula <drewp@bigasterisk.com>
parents: 1557
diff changeset
73 event = self.get_argument('event', default='default')
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
74
1566
13e3cbe9071a momentary-add button support
Drew Perttula <drewp@bigasterisk.com>
parents: 1560
diff changeset
75 note = self.get_argument('note', default=None)
13e3cbe9071a momentary-add button support
Drew Perttula <drewp@bigasterisk.com>
parents: 1560
diff changeset
76 if note is not None:
13e3cbe9071a momentary-add button support
Drew Perttula <drewp@bigasterisk.com>
parents: 1560
diff changeset
77 note = URIRef(note)
13e3cbe9071a momentary-add button support
Drew Perttula <drewp@bigasterisk.com>
parents: 1560
diff changeset
78
1181
c677bf37a1b4 effect list has button to add to current song
Drew Perttula <drewp@bigasterisk.com>
parents: 1180
diff changeset
79 log.info("adding to %s", song)
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
80 note, p = yield songNotePatch(self.settings.graph,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
81 dropped,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
82 song,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
83 event,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
84 ctx=song,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
85 note=note)
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
86
1557
104ff4606565 cleanup. internal names in edit.py
Drew Perttula <drewp@bigasterisk.com>
parents: 1556
diff changeset
87 self.settings.graph.patch(p)
1581
30c79f1dc4f8 fix suggestPrefixes to send suggestions to rdfdb
Drew Perttula <drewp@bigasterisk.com>
parents: 1570
diff changeset
88 self.settings.graph.suggestPrefixes(song, {'song': URIRef(song + '/')})
1566
13e3cbe9071a momentary-add button support
Drew Perttula <drewp@bigasterisk.com>
parents: 1560
diff changeset
89 self.write(json.dumps({'note': note}))
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
90
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
91
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
92 class SongEffectsUpdates(cyclone.websocket.WebSocketHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
93
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
94 def connectionMade(self, *args, **kwargs):
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
95 self.graph = self.settings.graph
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
96 self.graph.addHandler(self.updateClient)
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
97
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
98 def updateClient(self):
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
99 # todo: abort if client is gone
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
100 playlist = self.graph.value(showconfig.showUri(), L9['playList'])
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
101 songs = list(self.graph.items(playlist))
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
102 out = []
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
103 for s in songs:
1933
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
104 out.append({'uri': s, 'label': self.graph.label(s), 'effects': []})
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
105 seen = set()
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
106 for n in self.graph.objects(s, L9['note']):
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
107 for uri in self.graph.objects(n, L9['effectClass']):
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
108 if uri in seen:
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
109 continue
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
110 seen.add(uri)
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
111 out[-1]['effects'].append({
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
112 'uri': uri,
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
113 'label': self.graph.label(uri)
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
114 })
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
115 out[-1]['effects'].sort(key=lambda e: e['uri'])
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
116
c81f86f3d65a effecteval is mostly obsolete, but now it can at least show a list of effects used in a song (which seq can too)
Drew Perttula <drewp@bigasterisk.com>
parents: 1926
diff changeset
117
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
118 self.sendMessage({'songs': out})
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
119
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
120
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
121 class EffectUpdates(cyclone.websocket.WebSocketHandler):
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
122 """
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
123 stays alive for the life of the effect page
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
124 """
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
125
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
126 def connectionMade(self, *args, **kwargs):
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
127 log.info("websocket opened")
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
128 self.uri = URIRef(self.get_argument('uri'))
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
129 self.sendMessage({'hello': repr(self)})
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
130
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
131 self.graph = self.settings.graph
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
132 self.graph.addHandler(self.updateClient)
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
133
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
134 def updateClient(self):
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
135 # todo: if client has dropped, abort and don't get any more
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
136 # graph updates
1108
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
137
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
138 # EffectNode knows how to put them in order. Somehow this is
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
139 # not triggering an update when the order changes.
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
140 en = EffectNode(self.graph, self.uri)
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
141 codeLines = [c.code for c in en.codes]
4b542d321c8f effectnode runs multiple lines of code in dependency order
Drew Perttula <drewp@bigasterisk.com>
parents: 1107
diff changeset
142 self.sendMessage({'codeLines': codeLines})
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
143
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
144 def connectionLost(self, reason):
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
145 log.info("websocket closed")
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
146
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
147 def messageReceived(self, message):
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
148 log.info("got message %s" % message)
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
149 # write a patch back to the graph
1101
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
150
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
151
1107
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
152 def replaceObjects(graph, c, s, p, newObjs):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
153 patch = graph.getObjectPatch(context=c,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
154 subject=s,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
155 predicate=p,
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
156 newObject=newObjs[0])
1107
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
157
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
158 moreAdds = []
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
159 for line in newObjs[1:]:
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
160 moreAdds.append((s, p, line, c))
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
161 fullPatch = Patch(delQuads=patch.delQuads,
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
162 addQuads=patch.addQuads + moreAdds)
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
163 graph.patch(fullPatch)
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
164
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
165
1101
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
166 class Code(PrettyErrorHandler, cyclone.web.RequestHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
167
1101
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
168 def put(self):
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
169 effect = URIRef(self.get_argument('uri'))
1107
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
170 codeLines = []
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
171 for i in itertools.count(0):
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
172 k = 'codeLines[%s][text]' % i
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
173 v = self.get_argument(k, None)
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
174 if v is not None:
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
175 codeLines.append(Literal(v))
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
176 else:
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
177 break
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
178 if not codeLines:
1111
8842f0c7a641 refactor effectloop
Drew Perttula <drewp@bigasterisk.com>
parents: 1108
diff changeset
179 log.info("no codelines received on PUT /code")
1107
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
180 return
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
181 with self.settings.graph.currentState(tripleFilter=(None, L9['effect'],
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
182 effect)) as g:
1859
f066d6e874db 2to3 with these fixers: all idioms set_literal
drewp@bigasterisk.com
parents: 1858
diff changeset
183 song = next(g.subjects(L9['effect'], effect))
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
184
1107
512381de45bd effectclasss in subserver. multiline code suppport (except for evaulation). add some old effect funcs to the new evaluator
Drew Perttula <drewp@bigasterisk.com>
parents: 1103
diff changeset
185 replaceObjects(self.settings.graph, song, effect, L9['code'], codeLines)
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
186
1103
771f50f19b4b single-line effect code now evals by changing <uri> into a suitable python object
Drew Perttula <drewp@bigasterisk.com>
parents: 1101
diff changeset
187 # right here we could tell if the code has a python error and return it
1101
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
188 self.send_error(202)
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
189
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
190
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
191 class EffectEval(PrettyErrorHandler, cyclone.web.RequestHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
192
1027
a38414bd3929 hacking on effecteval
Drew Perttula <drewp@bigasterisk.com>
parents: 1019
diff changeset
193 @inlineCallbacks
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
194 def get(self):
1033
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
195 # return dmx list for that effect
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
196 uri = URIRef(self.get_argument('uri'))
1027
a38414bd3929 hacking on effecteval
Drew Perttula <drewp@bigasterisk.com>
parents: 1019
diff changeset
197 response = yield cyclone.httpclient.fetch(
a38414bd3929 hacking on effecteval
Drew Perttula <drewp@bigasterisk.com>
parents: 1019
diff changeset
198 networking.musicPlayer.path('time'))
a38414bd3929 hacking on effecteval
Drew Perttula <drewp@bigasterisk.com>
parents: 1019
diff changeset
199 songTime = json.loads(response.body)['t']
1033
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
200
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
201 node = EffectNode(self.settings.graph, uri)
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
202 outSub = node.eval(songTime)
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
203 self.write(json.dumps(outSub.get_dmx_list()))
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
204
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
205
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
206 # Completely not sure where the effect background loop should
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
207 # go. Another process could own it, and get this request repeatedly:
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
208 class SongEffectsEval(PrettyErrorHandler, cyclone.web.RequestHandler):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
209
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
210 def get(self):
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
211 song = URIRef(self.get_argument('song'))
1877
d01e21621975 reformat
Drew Perttula <drewp@bigasterisk.com>
parents: 1866
diff changeset
212 effects = effectsForSong(self.settings.graph, song) # noqa
1033
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
213 raise NotImplementedError
1877
d01e21621975 reformat
Drew Perttula <drewp@bigasterisk.com>
parents: 1866
diff changeset
214 self.write(maxDict(effectDmxDict(e) for e in effects)) # noqa
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
215 # return dmx dict for all effects in the song, already combined
1033
b5ee7aa9341a effecteval now runs effects in the background, following the current song, and sends dmx output
Drew Perttula <drewp@bigasterisk.com>
parents: 1027
diff changeset
216
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
217
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
218 class App(object):
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
219
1114
a38955ba6f40 rdfdb port is now in the config
Drew Perttula <drewp@bigasterisk.com>
parents: 1111
diff changeset
220 def __init__(self, show, outputWhere):
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
221 self.show = show
1114
a38955ba6f40 rdfdb port is now in the config
Drew Perttula <drewp@bigasterisk.com>
parents: 1111
diff changeset
222 self.outputWhere = outputWhere
a38955ba6f40 rdfdb port is now in the config
Drew Perttula <drewp@bigasterisk.com>
parents: 1111
diff changeset
223 self.graph = SyncedGraph(networking.rdfdb.url, "effectEval")
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
224 self.graph.initiallySynced.addCallback(self.launch).addErrback(
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
225 log.error)
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
226
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
227 self.stats = scales.collection(
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
228 '/',
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
229 scales.PmfStat('sendLevels'),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
230 scales.PmfStat('getMusic'),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
231 scales.PmfStat('evals'),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
232 scales.PmfStat('sendOutput'),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
233 scales.IntStat('errors'),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
234 )
1053
9937e2e3d17b effecteval faster loop, stats page
Drew Perttula <drewp@bigasterisk.com>
parents: 1052
diff changeset
235
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
236 def launch(self, *args):
1535
04f2e93f04e3 effecteval log startup error
Drew Perttula <drewp@bigasterisk.com>
parents: 1237
diff changeset
237 log.info('launch')
1548
5d8009daea51 effecteval ok to run with no output (?)
Drew Perttula <drewp@bigasterisk.com>
parents: 1535
diff changeset
238 if self.outputWhere:
5d8009daea51 effecteval ok to run with no output (?)
Drew Perttula <drewp@bigasterisk.com>
parents: 1535
diff changeset
239 self.loop = makeEffectLoop(self.graph, self.stats, self.outputWhere)
5d8009daea51 effecteval ok to run with no output (?)
Drew Perttula <drewp@bigasterisk.com>
parents: 1535
diff changeset
240 self.loop.startLoop()
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
241
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
242 SFH = cyclone.web.StaticFileHandler
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
243 self.cycloneApp = cyclone.web.Application(handlers=[
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
244 (r'/()', SFH, {
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
245 'path': 'light9/effecteval',
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
246 'default_filename': 'index.html'
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
247 }),
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
248 (r'/effect', EffectEdit),
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
249 (r'/effect\.js', StaticCoffee, {
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
250 'src': 'light9/effecteval/effect.coffee'
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
251 }),
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
252 (r'/(effect-components\.html)', SFH, {
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
253 'path': 'light9/effecteval'
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
254 }),
1041
a4632a7b2e17 upgrade knockout and jquery, simplify the static/ dirs for all web services
Drew Perttula <drewp@bigasterisk.com>
parents: 1033
diff changeset
255 (r'/effectUpdates', EffectUpdates),
1101
3074f635ee23 effect page can write code edits back
Drew Perttula <drewp@bigasterisk.com>
parents: 1100
diff changeset
256 (r'/code', Code),
1041
a4632a7b2e17 upgrade knockout and jquery, simplify the static/ dirs for all web services
Drew Perttula <drewp@bigasterisk.com>
parents: 1033
diff changeset
257 (r'/songEffectsUpdates', SongEffectsUpdates),
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
258 (r'/effect/eval', EffectEval),
1044
a2081b9adfe4 effecteval now takes dropped subs and makes new effects out of them
Drew Perttula <drewp@bigasterisk.com>
parents: 1043
diff changeset
259 (r'/songEffects', SongEffects),
1019
5939fce98fad notes for next step
drewp@bigasterisk.com
parents: 1018
diff changeset
260 (r'/songEffects/eval', SongEffectsEval),
1926
1a7e5b07bf17 use my greplin fork's stats/ code instead of an old local one
Drew Perttula <drewp@bigasterisk.com>
parents: 1877
diff changeset
261 (r'/stats/(.*)', StatsHandler, {
1a7e5b07bf17 use my greplin fork's stats/ code instead of an old local one
Drew Perttula <drewp@bigasterisk.com>
parents: 1877
diff changeset
262 'serverName': 'effecteval'
1a7e5b07bf17 use my greplin fork's stats/ code instead of an old local one
Drew Perttula <drewp@bigasterisk.com>
parents: 1877
diff changeset
263 }),
1180
6c4981f61bf8 subserver inserts effects with envelope curves
Drew Perttula <drewp@bigasterisk.com>
parents: 1141
diff changeset
264 ],
6c4981f61bf8 subserver inserts effects with envelope curves
Drew Perttula <drewp@bigasterisk.com>
parents: 1141
diff changeset
265 debug=True,
6c4981f61bf8 subserver inserts effects with envelope curves
Drew Perttula <drewp@bigasterisk.com>
parents: 1141
diff changeset
266 graph=self.graph,
6c4981f61bf8 subserver inserts effects with envelope curves
Drew Perttula <drewp@bigasterisk.com>
parents: 1141
diff changeset
267 stats=self.stats)
1043
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
268 reactor.listenTCP(networking.effectEval.port, self.cycloneApp)
aa45e5379c5a effecteval improvements. displays current song+effect tree
Drew Perttula <drewp@bigasterisk.com>
parents: 1041
diff changeset
269 log.info("listening on %s" % networking.effectEval.port)
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
270
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
271
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
272 if __name__ == "__main__":
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
273 parser = optparse.OptionParser()
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
274 parser.add_option(
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
275 '--show',
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
276 help='show URI, like http://light9.bigasterisk.com/show/dance2008',
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
277 default=showconfig.showUri())
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
278 parser.add_option("-v",
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
279 "--verbose",
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
280 action="store_true",
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
281 help="logging.DEBUG")
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
282 parser.add_option("--twistedlog",
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
283 action="store_true",
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
284 help="twisted logging")
1115
818275850003 effecteval screens for only the kinds of outputs that it can send, so i can run a second instance just for LEDs
Drew Perttula <drewp@bigasterisk.com>
parents: 1114
diff changeset
285 parser.add_option("--output", metavar="WHERE", help="dmx or leds")
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
286 (options, args) = parser.parse_args()
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
287 log.setLevel(logging.DEBUG if options.verbose else logging.INFO)
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
288
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
289 if not options.show:
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
290 raise ValueError("missing --show http://...")
1858
7772cc48e016 reformat all python
drewp@bigasterisk.com
parents: 1692
diff changeset
291
1115
818275850003 effecteval screens for only the kinds of outputs that it can send, so i can run a second instance just for LEDs
Drew Perttula <drewp@bigasterisk.com>
parents: 1114
diff changeset
292 app = App(URIRef(options.show), options.output)
1018
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
293 if options.twistedlog:
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
294 from twisted.python import log as twlog
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
295 twlog.startLogging(sys.stderr)
e28a443bd153 initial effecteval that can propagate changes from the graph to a web page
drewp@bigasterisk.com
parents:
diff changeset
296 reactor.run()