File: eci.py

package info (click to toggle)
ecasound 2.9.1-7
  • links: PTS, VCS
  • area: main
  • in suites: buster, stretch
  • size: 5,652 kB
  • ctags: 6,128
  • sloc: cpp: 39,403; sh: 10,512; ansic: 2,040; lisp: 1,918; makefile: 909; python: 611; ruby: 202
file content (109 lines) | stat: -rw-r--r-- 2,886 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
"""
# eci.ECI -- A higher-level interface to pyeca.
# Copyright 2001 Eric S. Tiedemann (est@hyperreal.org)
# GPLed

some updates by Janne Halttunen
"""

import pyeca as _pyeca
import types as _types

class ECIError(Exception):
    def __init__(self, what):
        Exception.__init__(self, what)
        self.what = what

    def __str__(self):
        return '<ECIException %s>' % self.what

class ECI:
    """An ECI is and ECA Control Interface object.

    It can be called with ECI command strings (and an optional
    float value) as arguments.  A list or tuple of command
    strings is also accepted and commands can be separated
    by newlines within a single string.

    The value of a command (or of the last command in a sequence)
    if returned as a value of the appropriate Python type
    (possibly None).
    
    On errors, an ECIException is raised that has a `what'
    member with the exception message.  These exceptions also
    stringify prettily.
    """
    
    def __init__(self, *args):
        self.e = apply(_pyeca.ECA_CONTROL_INTERFACE, args)

    def __call__(self, cmd, f=None):
        if f != None:
            self.e.command_float_arg(cmd, f)
        else:
            if type(cmd) == _types.ListType or type(cmd) == _types.TupleType:
                v = None
                for c in cmd:
                    v = self(c)
                return v
            else:
                cmds = cmd.split('\n')
                if len(cmds) > 1:
                    v = None
                    for c in cmds:
                        v = self(c)
                    return v
                else:
                    self.e.command(cmd)
            
        t = self.e.last_type()
        if not t or t == '-':
            return None
        elif t == 'S':
            return self.e.last_string_list()
        elif t == 's':
            return self.e.last_string()
        elif t == 'f':
            return self.e.last_float()
        elif t == 'i':
            return self.e.last_integer()
        elif t == 'li':
            return self.e.last_long_integer()
	elif t == 'e' or self.e.error():
	    raise ECIError, '%s: %s' % (self.e.last_error(), cmd)
        else:
            raise ECIError, "unknown return type '%s'!" % t

if __name__ == '__main__':
    import time, sys

    file = sys.argv[1]
    e = ECI()

    # uncomment to raise an error :)
    #e('foo')
    
    e("""
    cs-add play_chainsetup
    c-add 1st_chain
    ai-add %s
    ao-add /dev/dsp
    cop-add -efl:100
    cop-select 1
    copp-select 1
    cs-connect
    start"""
      % file)

    cutoff_inc = 500.0

    while 1:
        time.sleep(1)
        if e("engine-status") != "running" or e("get-position") > 15:
            break
        e("copp-set", cutoff_inc + e("copp-get"))

    e("""stop
         cs-disconnect""")

    print "Chain operator status: ", e("cop-status")