File: jack.plumbing.text

package info (click to toggle)
jack-tools 20101210-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 504 kB
  • sloc: ansic: 4,678; makefile: 122; lisp: 48; sh: 16
file content (96 lines) | stat: -rw-r--r-- 2,819 bytes parent folder | download
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
JACK.PLUMBING(1)
===============
Rohan Drape <rd@slavepianos.org>


NAME
----
jack.plumbing - JACK Plumbing Daemon

SYNOPSIS
--------
jack.plumbing [options] [rule-files]

OPTIONS
-------
*-d*
:   Do not operate as a daemon.

*-o*
:   Do not load ordinary rule files.

*-q*
:   Quiet operation.

*-u*
:   Set the time, in micro-seconds, that must elapse after a
    connection notification to indicate the end of a notification set
    (default=30000).  This is an optimization switch.

DESCRIPTION
-----------
jack.plumbing maintains a set of port connection rules and manages
these as clients register ports with JACK.  Port names are implicitly
bounded regular expressions and support sub-expression patterns.

There are four rules: connect, disconnect, also-connect and
connect-exclusive.


    (connect "SuperCollider:out_(.*)" "system:playback_\1")

This connect rule ensures that whenever scsynth(1) is running any
output ports it registers are connected to appropriate ALSA playback
ports.  The connect rule only makes a connection if none already
exist.

    (also-connect "system:playback_1" "jack.udp-[0-9]*:in_1")

This also-connect rule ensures that when jack.udp(1) is running in
send mode all signals that are ordinarily sent to the local audio
interface will also be sent to the network destination.  The
also-connect aliasing applies to both the left and right hand side of
connect rules.

    (connect-exclusive "SuperCollider:out_(.*)" "ardour:sc3_in_\1/in 1")

This connect-exclusive rule ensures that if SuperCollider and an
ardour(1) session with appropriate tracks are both running that
SuperCollider gets connected to ardour and disconnected from
everything else.

This type of connection daemon has the following advantages over both
environment variables and command line arguments: 

* it does not require any client connection support or logic at all
* it provides a uniform user interface to all clients
* it has a somewhat declarative style

This type of daemon is very lightweight and non-intrusive: it requires
no arguments, it runs from an unprivileged thread, if the rule set is
empty it is a no-op, it does not write any files, it does not require
any modification to clients or to how clients are started.

When a set of port registrations is made it checks the modification
time of the rule set files, '/etc/jack.plumbing' and
'~/.jack.plumbing', and any files specified by the user, rereads the
rule set if it has been updated, then makes the JACK graph obey the
rules.

Any lines beginning with a semi-colon are ignored.

The rule set is sorted, disconnect rules are applied first, then
connect rules, then connect-exclusive rules.

FILES
-----
* /etc/jack.plumbing
* ~/.jack.plumbing

AUTHOR
------
Written by Rohan Drape <http://slavepianos.org/rd/>

SEE ALSO
--------
jackd(1)