mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
424 lines
6.6 KiB
Groff
424 lines
6.6 KiB
Groff
|
.TH ACME 3
|
||
|
.SH NAME
|
||
|
Event, Win,
|
||
|
eventfmt,
|
||
|
newwin,
|
||
|
pipetowin,
|
||
|
pipewinto,
|
||
|
sysrun,
|
||
|
winaddr,
|
||
|
winclosefiles,
|
||
|
winctl,
|
||
|
windel,
|
||
|
windeleteall,
|
||
|
windows,
|
||
|
wineventchan,
|
||
|
winfd,
|
||
|
winfree,
|
||
|
winmread,
|
||
|
winname,
|
||
|
winopenfd,
|
||
|
winprint,
|
||
|
winread,
|
||
|
winreadaddr,
|
||
|
winreadevent,
|
||
|
winseek,
|
||
|
winwrite,
|
||
|
winwriteevent \- acme client library
|
||
|
.SH SYNOPSIS
|
||
|
.ft L
|
||
|
.nf
|
||
|
#include <u.h>
|
||
|
#include <libc.h>
|
||
|
#include <thread.h>
|
||
|
#include <9pclient.h>
|
||
|
#include <acme.h>
|
||
|
.fi
|
||
|
.PP
|
||
|
.ft L
|
||
|
.ta +\w'\fLxxxx'u +\w'\fLxxxxx'u
|
||
|
.nf
|
||
|
struct Event
|
||
|
{
|
||
|
int c1;
|
||
|
int c2;
|
||
|
int q0;
|
||
|
int q1;
|
||
|
int oq0;
|
||
|
int oq1;
|
||
|
int flag;
|
||
|
int nb;
|
||
|
int nr;
|
||
|
char text[];
|
||
|
char arg[];
|
||
|
char loc[];
|
||
|
};
|
||
|
.PP
|
||
|
.ta +\w'\fLxxxxxxxxxx'u
|
||
|
.B
|
||
|
int eventfmt(Fmt *fmt)
|
||
|
.PP
|
||
|
.B
|
||
|
Win* newwin(void)
|
||
|
.PP
|
||
|
.B
|
||
|
Win* openwin(int id, CFid *ctlfid)
|
||
|
.PP
|
||
|
.B
|
||
|
int pipetowin(Win *w, char *file, int fderr, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
int pipewinto(Win *w, char *file, int fdout, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
char* sysrun(char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
int winaddr(Win *w, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
void winclosefiles(Win *w)
|
||
|
.PP
|
||
|
.B
|
||
|
int winctl(Win *w, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
int windel(Win *w, int sure)
|
||
|
.PP
|
||
|
.B
|
||
|
void windeleteall(void)
|
||
|
.PP
|
||
|
.B
|
||
|
Channel* wineventchan(Win *w)
|
||
|
.PP
|
||
|
.B
|
||
|
int winfd(Win *w, char *name, int mode)
|
||
|
.PP
|
||
|
.B
|
||
|
void winfree(Win *w)
|
||
|
.PP
|
||
|
.B
|
||
|
char* winmread(Win *w, char *file)
|
||
|
.PP
|
||
|
.B
|
||
|
int winname(Win *w, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
int winopenfd(Win *w, char *name, int mode)
|
||
|
.PP
|
||
|
.B
|
||
|
int winprint(Win *w, char *file, char *fmt, ...)
|
||
|
.PP
|
||
|
.B
|
||
|
int winread(Win *w, char *file, void *a, int n)
|
||
|
.PP
|
||
|
.B
|
||
|
int winreadaddr(Win *w, uint *q1)
|
||
|
.PP
|
||
|
.B
|
||
|
int winreadevent(Win *w, Event *e)
|
||
|
.PP
|
||
|
.B
|
||
|
int winseek(Win *w, char *file, int off, int type)
|
||
|
.PP
|
||
|
.B
|
||
|
int winwrite(Win *w, char *file, void *a, int n)
|
||
|
.PP
|
||
|
.B
|
||
|
int winwriteevent(Win *w, Event *e)
|
||
|
.PP
|
||
|
.B
|
||
|
void* emalloc(uint n)
|
||
|
.PP
|
||
|
.B
|
||
|
void* erealloc(void *v, uint n)
|
||
|
.PP
|
||
|
.B
|
||
|
char* estrdup(char *s)
|
||
|
.PP
|
||
|
.B
|
||
|
char* evsmprint(char *fmt, va_list arg)
|
||
|
.SH DESCRIPTION
|
||
|
.I Libacme
|
||
|
provides a simple C interface for interacting with
|
||
|
.IR acme (1)
|
||
|
windows.
|
||
|
.PP
|
||
|
A
|
||
|
.B Win
|
||
|
structure represents a single window and its control files.
|
||
|
The contents of the structure should not be accessed directly.
|
||
|
.I Newwin
|
||
|
creates a new window and returns a structure corresponding to that window.
|
||
|
.I Openwin
|
||
|
allocates a structure corresponding to the existing window with the given
|
||
|
.IR id .
|
||
|
If
|
||
|
.I ctlfid
|
||
|
is non-nil,
|
||
|
.I openwin
|
||
|
assumes it is a file descriptor open for writing to the window's
|
||
|
.B ctl
|
||
|
file.
|
||
|
Ownership of
|
||
|
.I ctlfid
|
||
|
passes to the library.
|
||
|
.PP
|
||
|
Most of the library routines access files in the window's
|
||
|
.I acme
|
||
|
directory.
|
||
|
See
|
||
|
.IR acme (4)
|
||
|
for details.
|
||
|
Many library routines take a format string
|
||
|
.I fmt
|
||
|
followed by a variable list of arguments.
|
||
|
In the discussion below, the notation
|
||
|
.I fmt\fR, \fP...
|
||
|
denotes the result of formatting the string and arguments
|
||
|
using
|
||
|
.I smprint
|
||
|
(see
|
||
|
.IR print (3)).
|
||
|
.PP
|
||
|
.I Pipetowin
|
||
|
runs the
|
||
|
.IR rc (1)
|
||
|
command line
|
||
|
.I fmt\fR, \fP...
|
||
|
with
|
||
|
.B /dev/null
|
||
|
on standard input and the window's
|
||
|
.I file
|
||
|
on standard output.
|
||
|
If
|
||
|
.I fderr
|
||
|
is non-zero (sic),
|
||
|
it is used as standard error.
|
||
|
Otherwise the command inherits the caller's standard error.
|
||
|
.PP
|
||
|
.I Pipewinto
|
||
|
runs the
|
||
|
.IR rc (1)
|
||
|
command line
|
||
|
.I fmt\fR, \fP...
|
||
|
with the window's
|
||
|
.I file
|
||
|
on standard input.
|
||
|
The command runs with
|
||
|
.I fdout
|
||
|
as its standard output and standard error.
|
||
|
.PP
|
||
|
.I Sysrun
|
||
|
runs the
|
||
|
.I rc
|
||
|
command line
|
||
|
.I fmt\fR, \fP...
|
||
|
and returns a pointer to the first kilobyte of output, NUL-terminated.
|
||
|
The buffer holding the output is reused on each call.
|
||
|
.PP
|
||
|
.I Winaddr
|
||
|
writes
|
||
|
.I fmt\fR, \fP...
|
||
|
to the window's
|
||
|
.B addr
|
||
|
file.
|
||
|
.PP
|
||
|
.I Winclosefiles
|
||
|
closes all the open file descriptors associated with the window.
|
||
|
(These file descriptors are maintained from the library and
|
||
|
cached across calls to
|
||
|
.IR winctl ,
|
||
|
.IR etc .)
|
||
|
.PP
|
||
|
.I Winctl
|
||
|
writes
|
||
|
.I fmt\fR, \fP...
|
||
|
to the window's
|
||
|
.B ctl
|
||
|
file.
|
||
|
.PP
|
||
|
.I Windel
|
||
|
deletes the window,
|
||
|
writing
|
||
|
.B del
|
||
|
(or, if
|
||
|
.I sure
|
||
|
is set,
|
||
|
.B delete)
|
||
|
to the window's
|
||
|
.B ctl
|
||
|
file.
|
||
|
.PP
|
||
|
.I Winfd
|
||
|
returns a file descriptor for the window's
|
||
|
.I file
|
||
|
opened for
|
||
|
.IR mode .
|
||
|
The caller is responsible for closing the file descriptor.
|
||
|
.PP
|
||
|
.I Winmread
|
||
|
reads the contents of the window's
|
||
|
.I file
|
||
|
into a dynamically allocated buffer
|
||
|
and returns it.
|
||
|
The caller is responsible for freeing the buffer.
|
||
|
.PP
|
||
|
.I Winname
|
||
|
sets the name of the window to
|
||
|
.I fmt\fR, \fP...
|
||
|
by writing to the
|
||
|
.B ctl
|
||
|
file.
|
||
|
.PP
|
||
|
.I Winprint
|
||
|
prints
|
||
|
.I fmt\fR, \fP...
|
||
|
to the window's
|
||
|
.IR file .
|
||
|
.PP
|
||
|
.I Winread
|
||
|
reads at most
|
||
|
.I n
|
||
|
bytes from the window's
|
||
|
.IR file
|
||
|
into the buffer pointed at by
|
||
|
.IR a .
|
||
|
.PP
|
||
|
.I Winreadaddr
|
||
|
reads the window's
|
||
|
.B addr
|
||
|
file, which contains two integers.
|
||
|
It returns the first and stores the second in
|
||
|
.BI * q1 \fR.
|
||
|
.PP
|
||
|
.I Winseek
|
||
|
seeks the file descriptor for the window's
|
||
|
.I file
|
||
|
to position
|
||
|
.I off
|
||
|
relative to
|
||
|
.I type
|
||
|
(see
|
||
|
.IR seek (3)).
|
||
|
.PP
|
||
|
.I Winwrite
|
||
|
writes the
|
||
|
.I n
|
||
|
bytes pointed at by
|
||
|
.I a
|
||
|
to the window's
|
||
|
.IR file .
|
||
|
.PP
|
||
|
An
|
||
|
.B Event
|
||
|
structure represents an event originating in a particular window.
|
||
|
The fields correspond to the fields in
|
||
|
.IR acme 's
|
||
|
event messages.
|
||
|
See
|
||
|
.IR acme (4)
|
||
|
for detailed explanations.
|
||
|
The fields are:
|
||
|
.TP
|
||
|
.BR c1 ", " c2
|
||
|
The two event characters, indicating origin and type of action.
|
||
|
.TP
|
||
|
.BR q0 ", " q1
|
||
|
The character addresses of the action.
|
||
|
If the original event had an empty selection
|
||
|
.RB ( q0 = q1 )
|
||
|
and was accompanied by an expansion
|
||
|
(the 2 bit is set in the flag), then
|
||
|
.B q0
|
||
|
and
|
||
|
.B q1
|
||
|
will indicate the expansion rather than original event.
|
||
|
.TP
|
||
|
.BR oq0 ", " oq1
|
||
|
The
|
||
|
.B q0
|
||
|
and
|
||
|
.B q1
|
||
|
of the original event, even if it was expanded.
|
||
|
If there was no expansion,
|
||
|
.BR oq0 = q0
|
||
|
and
|
||
|
.BR oq1 = q1 .
|
||
|
.TP
|
||
|
.B flag
|
||
|
The flag.
|
||
|
.TP
|
||
|
.B nr
|
||
|
The number of characters (UTF sequences) included in the optional text.
|
||
|
.TP
|
||
|
.B text
|
||
|
The optional text itself, encoded in UTF.
|
||
|
.TP
|
||
|
.B nb
|
||
|
The number of bytes included in the optional text.
|
||
|
.TP
|
||
|
.B arg
|
||
|
The chorded argument, if present
|
||
|
(the 8 bit is set in the flag).
|
||
|
.TP
|
||
|
.B loc
|
||
|
The chorded location, if present
|
||
|
(the 8 bit is set in the flag).
|
||
|
.PD
|
||
|
.PP
|
||
|
.I Winreadevent
|
||
|
reads the next event (q.v.)
|
||
|
from the window's
|
||
|
.B event
|
||
|
file.
|
||
|
.PP
|
||
|
.I Winwriteevent
|
||
|
writes an event back to the window's
|
||
|
.B event
|
||
|
file, indicating to
|
||
|
.I acme
|
||
|
that it should be handled internally.
|
||
|
.PP
|
||
|
.I Wineventchan
|
||
|
returns a pointer to a
|
||
|
.B Channel
|
||
|
(see
|
||
|
.IR thread (3))
|
||
|
on which event structures (not pointers) can be read.
|
||
|
The first call to
|
||
|
.I wineventchan
|
||
|
allocates a channel and
|
||
|
starts a new thread that loops calling
|
||
|
.I winreadevent
|
||
|
and copying the events into the channel.
|
||
|
Subsequent calls return the same channel.
|
||
|
Clients should not call
|
||
|
.I winreadevent
|
||
|
after calling
|
||
|
.IR wineventchan .
|
||
|
.PP
|
||
|
.IR Emalloc ,
|
||
|
.IR erealloc ,
|
||
|
.IR estrdup ,
|
||
|
and
|
||
|
.I evsmprint
|
||
|
are like
|
||
|
.IR malloc (3),
|
||
|
.IR realloc ,
|
||
|
.IR strdup
|
||
|
(see
|
||
|
.IR strcat (3)),
|
||
|
and
|
||
|
.IR vsmprint
|
||
|
(see
|
||
|
.IR print (3)),
|
||
|
but they call
|
||
|
.IR sysfatal (3)
|
||
|
on error rather than returning nil.
|
||
|
.SH SOURCE
|
||
|
.B \*9/src/libacme
|
||
|
.SH SEE ALSO
|
||
|
.IR acme (1),
|
||
|
.IR acme (4)
|