Files @ b15a2d8ef1ab
Branch filter:

Location: light9/light9/dmxclient.py - annotation

Drew Perttula
add homepage
Ignore-this: 74a121dfce614bfd3a83eadc18e18efa
""" module for clients to use for easy talking to the dmx
server. sending levels is now a simple call to
dmxclient.outputlevels(..)

client id is formed from sys.argv[0] and the PID.  """

import xmlrpclib, os, sys, socket, time, logging
from light9 import networking
_dmx=None
log = logging.getLogger('dmxclient')

procname = os.path.basename(sys.argv[0])
procname = procname.replace('.py', '')
_id = "%s-%s-%s" % (procname, socket.gethostname(), os.getpid())

def outputlevels(levellist,twisted=0,clientid=_id):
    """present a list of dmx channel levels, each scaled from
    0..1. list can be any length- it will apply to the first len() dmx
    channels.

    if the server is not found, outputlevels will block for a
    second."""

    global _dmx, _id

    if _dmx is None:
        url = networking.dmxServer.url
        if not twisted:
            _dmx = xmlrpclib.Server(url)
        else:
            from twisted.web.xmlrpc import Proxy
            _dmx = Proxy(url)

    if not twisted:
        try:
            _dmx.outputlevels(clientid, levellist)
        except socket.error, e:
            log.error("dmx server error %s, waiting" % e)
            time.sleep(1)
        except xmlrpclib.Fault,e:
            log.error("outputlevels had xml fault: %s" % e)
            time.sleep(1)
    else:
        def err(error):
            log.error("dmx server error talking to %s: %s",
                      networking.dmxServer.url, error.getErrorMessage())
            time.sleep(1)
        d = _dmx.callRemote('outputlevels', clientid, levellist)
        d.addErrback(err)
        return d

dummy = os.getenv('DMXDUMMY')
if dummy:
    print "dmxclient: DMX is in dummy mode."
    def outputlevels(*args, **kw):
        pass