PLUMBER(4) PLUMBER(4) NAME plumber - file system for interprocess messaging SYNOPSIS plumber [ -p plumbing ] [ -s srvname ] DESCRIPTION The plumber is a user-level file server that receives, exam- ines, rewrites, and dispatches plumb(6) messages between programs. Its behavior is programmed by a plumbing file (default /usr/$user/lib/plumbing) in the format of plumb(6). Its services are mounted on the directory /mnt/plumb (/mnt/term/mnt/plumb on the CPU server) and consist of two pre-defined files, send and rules, and a set of output ports for dispatching messages to applications. The service is also published as a srv(4) file, srvname, for mounting elsewhere. By default, its name is a dot-separated concatenation of the program's name and a process id. A different one can be specified via the -s option. Programs use write (see read(2)) to deliver messages to the send file, and read(2) to receive them from the correspond- ing port. For example, sam(1)'s plumb menu item or the B command cause a message to be sent to /mnt/plumb/send; sam in turn reads from, by convention, /mnt/plumb/edit to receive messages about files to open. A copy of each message is sent to each client that has the corresponding port open. If none has it open, and the rule has a plumb client or plumb start rule, that rule is applied. A plumb client rule causes the specified command to be run and the message to be held for delivery when the port is opened. A plumb start rule runs the command but discards the message. If neither start or client is speci- fied and the port is not open, the message is discarded and a write error is returned to the sender. The set of output ports is determined dynamically by the specification in the plumbing rules file: a port is created for each unique destination of a plumb to rule. The set of rules currently active may be examined by reading the file /mnt/plumb/rules; appending to this file adds new rules to the set, while creating it (opening it with OTRUNC) clears the rule set. Thus the rule set may be edited dynam- ically with a traditional text editor. However, ports are never deleted dynamically; if a new set of rules does not include a port that was defined in earlier rules, that port Page 1 Plan 9 (printed 1/22/25) PLUMBER(4) PLUMBER(4) will still exist (although no new messages will be delivered there). FILES /usr/$user/lib/plumbing default rules file /sys/lib/plumb directory to search for files in include statements /mnt/plumb mount point for plumber(4). SOURCE /sys/src/cmd/plumb SEE ALSO plumb(1), plumb(2), plumb(6) BUGS Plumber's file name space is fixed, so it is difficult to plumb messages that involve files in newly mounted services. Page 2 Plan 9 (printed 1/22/25)