diff options
Diffstat (limited to 'doc/info')
-rw-r--r-- | doc/info/mds.texinfo | 1127 |
1 files changed, 758 insertions, 369 deletions
diff --git a/doc/info/mds.texinfo b/doc/info/mds.texinfo index e45fa77..a16b4b0 100644 --- a/doc/info/mds.texinfo +++ b/doc/info/mds.texinfo @@ -1,67 +1,184 @@ \input texinfo @c -*-texinfo-*- +@copying +Copyright @copyright{} 2014, 2015 Mattias Andrée (@email{maandree@@member.fsf.org}) + +@quotation +Permission is granted to copy, distribute and/or modify this document +under the terms of the GNU Free Documentation License, Version 1.3 or +any later version published by the Free Software Foundation; with no +Invariant Sections, with no Front-Cover Texts, and with no Back-Cover +Texts. A copy of the license is included in the section entitled +``GNU Free Documentation License''. +@end quotation +@end copying + @c %**start of header @setfilename mds.info -@settitle mds +@settitle mds -- The avant-garde micro-display server +@documentencoding UTF-8 +@documentlanguage en_GB +@finalout +@iftex +@c @set USLETTER @c @set AFIVEPAPER @c @set SMALLBOOK -@c This document does not look too good on A5-paper -@c This document looks best on A4-paper, but smallbook format is acceptable + +@c @set HARDCOPY +@c @set CROPMARKS +@c @set SKIPCHAPTERNEWPAGE +@c @set SKIPFONTTEXTSIZE +@end iftex +@c @set LOGO +@c @set DOUBLE_HEADINGS +@c @set SINGLE_HEADINGS +@c @set AMERICANSPACING + +@ignore + + This document does not look too good on A5-paper. + This document looks best on A4-paper, but smallbook + format and US Letter is acceptable. + + CROPMARKS has no effect unless HARDCOPY is set. + CROPMARKS and AFIVEPAPER (or actually @cropmarks + and @afivepaper) does not play well together. + + You can configure how TeX output files should look by + uncommenting @set commands above. Do not uncomment more + than one of the paper sizes (USLETTER, AFIVEPAPER and + SMALLBOOK); if none is uncomment AFOURPAPER will be set. + However, if you do not want to modify this source file, + you can run `make` with for example `TEXIFLAGS='-D HARDCOPY'` + or `TEXIFLAGS='--texinfo="@set HARDCOPY"'`. + +@end ignore + +@ifclear SINGLE_HEADINGS +@ifclear DOUBLE_HEADINGS +@ifclear HARDCOPY +@set SINGLE_HEADINGS +@end ifclear +@ifset HARDCOPY +@set DOUBLE_HEADINGS +@end ifset +@end ifclear +@end ifclear @ifset AFIVEPAPER @afivepaper @end ifset -@ifclear AFIVEPAPER @ifset SMALLBOOK @smallbook @end ifset +@ifclear AFIVEPAPER @ifclear SMALLBOOK +@ifclear USLETTER @afourpaper @set AFOURPAPER @end ifclear @end ifclear - -@documentencoding UTF-8 -@documentlanguage en - -@c @set HARDCOPY -@c @set LOGO +@end ifclear @ifset HARDCOPY +@ifset CROPMARKS @cropmarks +@end ifset +@ifclear SKIPCHAPTERNEWPAGE @setchapternewpage odd +@end ifclear @end ifset -@finalout -@c %**end of header +@ifclear SKIPFONTTEXTSIZE +@ifset SMALLBOOK +@set SMALLFONT +@end ifset +@ifset AFIVEPAPER +@set SMALLFONT +@end ifset +@end ifclear +@ifset SMALLFONT +@fonttextsize 10 +@end ifset +@ifclear SMALLFONT +@fonttextsize 11 +@end ifclear + +@ifclear AMERICANSPACING +@frenchspacing on +@end ifclear +@c @paragraphindent asis +@c @firstparagraphindent none +@c @exampleindent asis +@c @kbdinputstyle distinct @dircategory Graphics environment @direntry -* mds: (mds). The avant-garde micro-display server +* mds: (mds). The avant-garde micro-display server. @end direntry +@documentdescription +User and developer manual for mds, the avant-garde +micro-display server, and servers, protocols, +libraries and concepts. +@end documentdescription +@c %**end of header + + + +@ifset AFIVEPAPER +@set AFIVEPAPER_OR_USLETTER +@set SMALLBOOK_OR_AFIVEPAPER +@set AFOURPAPER_OR_AFIVEPAPER +@end ifset +@ifset USLETTER +@set AFIVEPAPER_OR_USLETTER +@set AFOURPAPER_OR_USLETTER +@end ifset +@ifset AFOURPAPER +@set AFOURPAPER_OR_USLETTER +@set AFOURPAPER_OR_AFIVEPAPER +@end ifset +@ifset SMALLBOOK +@set SMALLBOOK_OR_AFIVEPAPER +@end ifset + +@ifset SMALLFONT +@set AFOURPAPER_OR_USLETTER_OR_SMALLFONT +@ifset SMALLBOOK +@set SMALLBOOK_WITH_SMALLFONT +@set AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@set AFIVEPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@end ifset +@ifset AFIVEPAPER +@set AFIVEPAPER_WITH_SMALLFONT +@end ifset +@ifset AFOURPAPER +@set AFOURPAPER_WITH_SMALLFONT +@set AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT +@end ifset +@ifset USLETTER +@set USLETTER_WITH_SMALLFONT +@end ifset +@end ifset +@ifset AFOURPAPER_OR_USLETTER +@set AFOURPAPER_OR_USLETTER_OR_SMALLFONT +@set AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@end ifset +@ifset AFIVEPAPER_OR_USLETTER +@set AFIVEPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@set AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT +@end ifset + + @defindex op @defindex sg -@ifclear HARDCOPY -@copying -Copyright @copyright{} 2014, 2015 Mattias Andrée - -@quotation -Permission is granted to copy, distribute and/or modify this document -under the terms of the GNU Free Documentation License, Version 1.3 or -any later version published by the Free Software Foundation; with no -Invariant Sections, with no Front-Cover Texts, and with no Back-Cover -Texts. A copy of the license is included in the section entitled -``GNU Free Documentation License''. -@end quotation -@end copying -@end ifclear @ifset HARDCOPY @include hardcopy-copying.texinfo @end ifset @@ -99,6 +216,14 @@ Texts. A copy of the license is included in the section entitled @insertcopying @end titlepage +@ifset DOUBLE_HEADINGS +@headings double +@end ifset +@ifset SINGLE_HEADINGS +@headings single +@end ifset + +@shortcontents @contents @@ -120,8 +245,10 @@ Texts. A copy of the license is included in the section entitled * Specifications:: Specifications. * New Concepts:: Discussion of new display server concepts. * Discussion:: Discussion on display server-architecture. + * GNU General Public License:: Copying and sharing @command{mds}. * GNU Free Documentation License:: Copying and sharing this manual. + * Program index:: Index of servers, clients and utilities. * Variable index:: Index of environment variables. * Option index:: Index of command line options. @@ -130,7 +257,7 @@ Texts. A copy of the license is included in the section entitled * Function index:: Index of functions. * Data type index:: Index of data types. @end menu -@c TODO @detailmenu +@c TODO @detailmenu (`C-c C-u m`) @@ -282,7 +409,7 @@ things: @itemize @item -Request assignment of a unique ID. +Request assignment of a unique ID@. @item Multicast a message. @@ -486,7 +613,7 @@ environment variable @env{DISPLAY} to @code{<host>:<display index>}, where @code{<host>} is empty if the display is one the local machine. In this tradition @command{mds} does the same thing -with the environment variable @env{MDS_DISPLAY}. +with the environment variable @env{MDS_DISPLAY}@. @cpindex Environment variables @vrindex @env{MDS_PGROUP} @@ -494,7 +621,7 @@ with the environment variable @env{MDS_DISPLAY}. @cpindex Process group, display server @command{mds} also creates a new process group and export the new process group ID to the environment -variable @command{MDS_PGROUP}. This process group +variable @command{MDS_PGROUP}@. This process group can be used to send signals to all @command{mds} servers collectively. @@ -533,7 +660,7 @@ If you need servers to free up allocated memory that they do not use, send the signal @code{SIGDANGER}, or if not defined @code{SIGRTMIN + 1}. Unimportant servers -may choose to die on @code{SIGDANGER}. +may choose to die on @code{SIGDANGER}@. @sgindex @code{SIGINFO} @sgindex @code{SIGRTMIN + 2} @@ -546,7 +673,7 @@ that server do support this signal, but thay must not die when received. @code{SIGINFO} is send by a user to the server, if she wants the server to dump information about the -server's state or statistics to the TTY. +server's state or statistics to the TTY@. @sgindex @code{SIGRTMIN} @cpindex No-operation signal @@ -643,9 +770,11 @@ is seldom a reason for servers to do this.} To do this the client sends @example +@group Command: assign-id\n Message ID: 0\n \n +@end group @end example where @code{\n} is an LF-line break. @@ -691,9 +820,11 @@ and the value that was in the For example: @example +@group ID assignment: 0:1\n In response to: 0\n \n +@end group @end example Notice that the master server never @@ -720,8 +851,10 @@ and contain ID of the client that closed. For example: @example +@group Client closed: 0:1\n \n +@end group @end example Be aware that if a server or client @@ -729,18 +862,20 @@ closes and does not have a unique client ID, this message will be: @example +@group Client closed: 0:0\n \n +@end group @end example Once a client has an unique client ID assigned to it, it should always include the header @code{Client ID} in its messages. The value of @code{Client ID} -should be the client's ID. If a server +should be the client's ID@. If a server wants to address this client, it should include the header @code{To} with the -value set to the recipient's client ID. +value set to the recipient's client ID@. Be aware that such message may not be sent to that recipient uniquely, any server or client is free to sign up @@ -780,9 +915,11 @@ the display server, simply sign up for all messages: @example +@group Command: intercept\n Message ID: 0\n \n +@end group @end example But if you only want messages contain @@ -1039,7 +1176,7 @@ integer would overflow. Native endianness when a endianness is choosen. Do not assume big endianness, but the same endianness that appear on the same machine when -using C. +using C@. @item @cpindex UTF-8, portability @@ -1117,9 +1254,11 @@ its own argument. For example: @opindex @option{--initial-spawn} @example +@group mds-respawn --interval=5 \ @{ mds-foo --initial-spawn @} \ @{ mds-bar --initial-spawn @} & +@end group @end example @cpindex Server supervision @@ -1137,7 +1276,7 @@ respawned. @sgindex @code{SIGTERM} A server is considered to exit with a failure status unless it exits with the return value 0 or is terminated -by the signal @code{SIGTERM}. +by the signal @code{SIGTERM}@. @@ -1280,7 +1419,7 @@ be used to select monitor. @opindex @option{--monitor} Take screenshot of the monitor whose root window's window ID is @var{WINDOW_ID} or has another window -in it whose window ID is @var{WINDOW_ID}. +in it whose window ID is @var{WINDOW_ID}@. @item --embed @opindex @option{--embed} @@ -1290,7 +1429,7 @@ The rat will be used to select window. @item --embed=WINDOW_ID @opindex @option{--monitor} Take a screenshot of an embedded window whose -window ID is @var{WINDOW_ID}. +window ID is @var{WINDOW_ID}@. @item --window @opindex @option{--window} @@ -1300,7 +1439,7 @@ The rat will be used to select window. @item --window=WINDOW_ID @opindex @option{--window} Take a screenshot of a window whose -window ID is @var{WINDOW_ID}. +window ID is @var{WINDOW_ID}@. @item --decoration @opindex @option{--decoration} @@ -1373,7 +1512,7 @@ The rat will be used to select window. @item --embed=WINDOW_ID @opindex @option{--embed} Kill an embedded window whose -window ID is @var{WINDOW_ID}. +window ID is @var{WINDOW_ID}@. @item --window @opindex @option{--window} @@ -1383,7 +1522,7 @@ The rat will be used to select window. @item --window=WINDOW_ID @opindex @option{--window} Kill a window whose -window ID is @var{WINDOW_ID}. +window ID is @var{WINDOW_ID}@. @item --signal=SIGNAL @opindex @option{--signal} @@ -1424,7 +1563,7 @@ recognises the following options: @table @option @item --switch=VT @opindex @option{--switch} -Switch to the virtual terminal with the index @var{VT}. +Switch to the virtual terminal with the index @var{VT}@. @end table @@ -1459,8 +1598,10 @@ can be initialised, you can in @file{$@{XDG_CONFIG_HOME@}/mdsinitrc} write: @example +@group mds-foo --on-init-fork mds-bar & +@end group @end example @opindex @option{--on-init-fork} @@ -1492,6 +1633,21 @@ mds-respawn @{ mds-bar @} & # Spawn `mds-bar`. @end example @end ifset @ifclear AFOURPAPER +@ifset USLETTER +@example +S=$(cmdipc -Scx set 1 | cut -d ' ' -f 2) +# Create a System V semaphore with the value 1. + +mds-respawn @{ mds-foo --on-init-sh="cmdipc -Sk $S p" @} & +# Spawn `mds-foo` and decrease the semaphore with 1 when initialised. + +cmdipc -Sk $S z # Wait for the semaphore's + # value to become 0. +cmdipc -Srk $S # Remove the semaphore. +mds-respawn @{ mds-bar @} & # Spawn `mds-bar`. +@end example +@end ifset +@ifclear USLETTER @example S=$(cmdipc -Scx set 1 | cut -d ' ' -f 2) # Create a System V semaphore with the value 1. @@ -1506,6 +1662,7 @@ cmdipc -Srk $S # Remove the semaphore. mds-respawn @{ mds-bar @} & # Spawn `mds-bar`. @end example @end ifclear +@end ifclear @pgindex @command{mds-reg} This is however seldom necessary as @command{mds-reg} can @@ -1657,7 +1814,7 @@ mode to graphical mode or text mode. By default @command{mds-vt} will select the next available virtual terminal for the display server. You can override this behaviour by exporting a value -to the environment variable @env{XDG_VTNR}. The value +to the environment variable @env{XDG_VTNR}@. The value must be a decimal integer of a valid virtual terminal index@footnote{Which is the same thing as a valid TTY index.}. To select the virtual terminal the display @@ -2303,7 +2460,7 @@ It creates a window that emulates a monitor. @command{mds-meta} is a metadisplay server. It creates or joins a named metadisplay server, and creates an alternative value for -@env{MDS_DISPLAY}. Any server connecting to +@env{MDS_DISPLAY}@. Any server connecting to this alternative @env{MDS_DISPLAY} connects to this metadisplay server. This can be used to make servers shared between display server @@ -2583,7 +2740,7 @@ simple, reference implementation of a, status icon tray. @section Infrastructure Protocols @menu -* assign-id:: Assign new ID to client, or fetch current ID. +* assign-id:: Assign new ID to client, or fetch current ID@. * intercept:: Sign up for reception of message. * register:: Register availability of a command for which you implement a service. * reregister:: Request for reregistration for available commands. @@ -2600,7 +2757,7 @@ simple, reference implementation of a, status icon tray. @code{Command: assign-id} @item Action: -Assign new ID to client, or fetch current ID. +Assign new ID to client, or fetch current ID@. @item Purpose: Assigning ID to clients so server can respond to that client. @@ -2833,7 +2990,7 @@ Allow programs to be aware of which VT the server is running on. @item Purpose: Allow programs to gain access of the TTY associated with the -VT such that they can use ioctl and similar calls on that TTY. +VT such that they can use ioctl and similar calls on that TTY@. @item Compulsivity: Required. @@ -2868,9 +3025,9 @@ Set the TTY text mode if the value of the header @code{Graphical} is @code{no}. @end table The server implementing this protocol should not set the -TTY to text mode temporarily when switching TTY. It is +TTY to text mode temporarily when switching TTY@. It is up to the server that set the request for graphical mode -to temporarily switch to text mode when switching TTY. +to temporarily switch to text mode when switching TTY@. @item Optional header: @code{Exclusive} @table @code @@ -2894,7 +3051,7 @@ Allow presentation servers to enter and leave graphical mode. @item Purpose: Allow programs to gain access of the TTY associated with the -VT such that they can use ioctl and similar calls on that TTY. +VT such that they can use ioctl and similar calls on that TTY@. @item Compulsivity: Required. @@ -2938,7 +3095,7 @@ let the message pass to the next server by telling the master server that it is no modification to do. Once all servers are read for the switch the server that emitted this message should signal the kernel -that it may switch VT. The server should detect +that it may switch VT@. The server should detect this by setting up secondary contection to the display that intercepts this message. This connection should intercept this message with priority @math{-2^{62}}, @@ -3027,36 +3184,36 @@ bit zeroed out. This may not be remapped. Single blank space separated list of active modifiers: @table @code @item shift -Shift (level 2) +@key{Shift} (level 2) @item ctrl -Control +@key{Control} @item alt -Alternative/Option +@key{Alternative}/@key{Option} @item altgr -Alternative Graphic (level 3) +@key{Alternative Graphic} (level 3) @item lvl* @code{*} may be any @math{2^n + 1} integer with @math{1 < n < 20}. @item super -Super +@key{Super} @item hyper -Hyper +@key{Hyper} @item ultra -Ultra +@key{Ultra} @item caps -Caps (usually a lock key) +@key{Caps} (usually a lock key) @item num -Num (usually a lock key) +@key{Num} (usually a lock key) @item scrl -Scroll (usually a lock key) +@key{Scroll} (usually a lock key) @item top -Top (historical) +@key{Top} (historical) @item front -Front (historical) +@key{Front} (historical) @item greek -Greek (historical) +@key{Greek} (historical) @item compose -Compose (rare, it is usually a dead key) +@key{Compose} (rare, it is usually a dead key) @end table Any key that has been locked should be prefix with @code{+}, if the key has been locked by nullified @@ -3069,93 +3226,93 @@ A textual representation of the key that has been typed or released, as mapped by the keyboard layout. @table @code @item esc -Escape +@key{Escape} @item f* -F@code{*} where @code{*} is any integer. +@key{F*} where @code{*} is any integer. @item sysrq -System Request/Print Screen +@key{System Request}/@key{Print Screen} @item scrl -Scroll (lock) +@key{Scroll} (lock) @item break -Break/Pause +@key{Break}/@key{Pause} @item backspace -Backspace +@key{Backspace} @item tab -Tab +@key{Tab} @item return -Return/Enter +@key{Return}/@key{Enter} @item space -Blank Space +@key{Blank Space} @item menu -Application Menu +@key{Application Menu} @item ins -Insert +@key{Insert} @item home -Home +@key{Home} @item pgup -Page Up +@key{Page Up} @item del -Delete +@key{Delete} @item end -End +@key{End} @item pgdown -Page Down +@key{Page Down} @item up -Up Arrow +@key{Up} arrow @item left -Left Arrow +@key{Left} arrow @item down -Down Arrow +@key{Down} arrow @item right -Right Arrow +@key{Right} arrow @item shift -Shift (level 2) +@key{Shift} (level 2) @item begin -Begin (keypad 5 in nagivation mode) +@key{Begin} (keypad @key{5} in nagivation mode) @item ctrl -Control +@key{Control} @item alt -Alternative/Option +@key{Alternative}/@key{Option} @item altgr -Alternative Graphic (level 3) +@key{Alternative Graphic} (level 3) @item lvl* @code{*} may be any @math{2^n + 1} integer with @math{1 < n < 20}. @item super -Super +@key{Super} @item hyper -Hyper +@key{Hyper} @item ultra -Ultra +@key{Ultra} @item caps -Caps (usually a lock key) +@key{Caps} (usually a lock key) @item num -Num (usually a lock key) +@key{Num} (usually a lock key) @item scrl -Scroll (usually a lock key) +@key{Scroll} (usually a lock key) @item top -Top (historical) +@key{Top} (historical) @item front -Front (historical) +@key{Front} (historical) @item greek -Greek (historical) +@key{Greek} (historical) @item compose -Compose (usually a dead key) +@key{Compose} (usually a dead key) @item hexcompose -Hex-Compose (usually a dead key) +@key{Hex-Compose} (usually a dead key) (Used to create aribitrary characters.) @item longhexcompose -Long Hex-Compose (usually a dead key) -(Variant of hexcompose for longer codepoints.) +@key{Long Hex-Compose} (usually a dead key) +(Variant of @code{hexcompose} for longer codepoints.) @item modelock -Mode Lock +@key{Mode Lock} @item letter * @code{*} may be any UTF-8 encoded letter. @end table Keys that lock/unlock a modifer should be suffixed with a blank space and a @code{lock}. If the key is a dead key -(even the compose key) should use @code{dead} instead. A -position, either @code{left}, @code{right}, @code{keypad} +(even the @key{Compose} key) should use @code{dead} instead. +A position, either @code{left}, @code{right}, @code{keypad} or an index, followed by a blank space, should prefix any key that occurs on multiple position on the keyboard, unless it only appears on the keypad once and once not on @@ -3279,13 +3436,13 @@ it is off, and turned off if it is on. The value is a single blank space separated list of LED:s: @table @code @item num -Num lock +@key{Num lock} @item caps -Caps lock +@key{Caps lock} @item scroll -Scroll lock +@key{Scroll lock} @item compose -Compose +@key{Compose} @end table Unsupported LED:s should be silently ignored. @@ -3531,13 +3688,15 @@ is included in the headers. Each line contains contains two single space delimited numbers, the first number is the keycode as determined by the scancode, the second number is keycode that scancode should generate. -For example, @code{1 1} resets Escape to be mapped to Escape, -and @code{1 59} remaps Escape to F1, while +For example, @code{1 1} resets @key{Escape} to be mapped to +@key{Escape}, and @code{1 59} remaps @key{Escape} to @key{F1}, while @example +@group 1 59 59 1 +@end group @end example -swaps Escape and F1. +swaps @key{Escape} and @key{F1}. @item Purpose: Enable the user to swap or replace keys on the keyboard. @@ -3995,49 +4154,61 @@ Alpha channel should be included but ignored if @code{Has alpha: no}, in such as it is best to set it to full. -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER Example image with @code{Bytes: 2}, @code{Has alpha: no} and @code{Size: 3}: @example +@group sRGB(x0102, 0, 0), sRGB(0, x0304, 0), sRGB(0, 0, x0506) sRGB(x0708, 0, 0), sRGB(0, x090A, 0), sRGB(0, 0, x0B0C) sRGB(x0D0E, 0, 0), sRGB(0, x0F10, 0), sRGB(0, 0, x1112) +@end group @end example Encoding of example image in hexadecimal representation: @example +@group FFFF 0102 0000 0000 FFFF 0000 0304 0000 FFFF 0000 0000 0506 FFFF 0708 0000 0000 FFFF 0000 090A 0000 FFFF 0000 0000 0B0C FFFF 0D0E 0000 0000 FFFF 0000 0F10 0000 FFFF 0000 0000 1112 +@end group @end example Note that on a big-endian system this would be: @footnote{x86_64 computers are big-endian.} @example +@group FF FF 02 01 0 0 0 0 FF FF 0 0 04 03 0 0 FF FF 0 0 0 0 06 05 FF FF 08 07 0 0 0 0 FF FF 0 0 0A 09 0 0 FF FF 0 0 0 0 0C 0B FF FF 0E 0D 0 0 0 0 FF FF 0 0 10 0F 0 0 FF FF 0 0 0 0 12 11 +@end group @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER Example image with @code{Bytes: 2}, @code{Has alpha: no} and @code{Size: 2}: @example +@group sRGB(x0102, 0, 0), sRGB(0, x0304, 0) sRGB(x0708, 0, 0), sRGB(0, x090A, 0) +@end group @end example Encoding of example image in hexadecimal representation: @example +@group FFFF 0102 0000 0000 FFFF 0000 0304 0000 FFFF 0708 0000 0000 FFFF 0000 090A 0000 +@end group @end example Note that on a big-endian system this would be: @footnote{x86_64 computers are big-endian.} @example +@group FF FF 02 01 0 0 0 0 FF FF 0 0 04 03 0 0 FF FF 08 07 0 0 0 0 FF FF 0 0 0A 09 0 0 +@end group @end example @end ifclear @@ -4235,16 +4406,20 @@ ramp is (17, 18, 19, 20, 21, 22, 23) and the blue ramp is (33, 34, 35, 36, 37, 38, 39, 40) then the message will be (hexadecimal representation): @example +@group 0001 0002 0003 0004 0005 0006 0011 0012 0013 0014 0015 0016 0017 0021 0022 0023 0024 0025 0026 0027 0028 +@end group @end example On a big-endian system this would be: @example +@group 01 00 02 00 03 00 04 00 05 00 06 00 11 00 12 00 13 00 14 00 15 00 16 00 17 00 21 00 22 00 23 00 24 00 25 00 26 00 27 00 28 00 +@end group @end example However if @code{Coalesce: no} was used in the query, @@ -4331,17 +4506,21 @@ is (1, 2, 3, 4, 5, 6), the green ramp is (17, 18, 19, 37, 38, 39, 40) then the message will be (hexadecimal representation): @example +@group 0001 0002 0003 0004 0005 0006 0011 0012 0013 0014 0015 0016 0017 0021 0022 0023 0024 0025 0026 0027 0028 +@end group @end example Note that on a big-endian system this would be: @footnote{x86_64 computers are big-endian.} @example +@group 01 00 02 00 03 00 04 00 05 00 06 00 11 00 12 00 13 00 14 00 15 00 16 00 17 00 21 00 22 00 23 00 24 00 25 00 26 00 27 00 28 00 +@end group @end example It is up to the networking servers to translate @@ -4664,7 +4843,7 @@ this is however dependent on the operating system. The server will respond with a @command{Command: error} message. In this message the server all include an -ad-hoc header: @code{Process ID}. Its value +ad-hoc header: @code{Process ID}@. Its value will be the ID of the process that owns the window. @@ -4887,8 +5066,10 @@ Decreases the pointer @code{buffer} by the size of @cpindex Marshalling macros @sgindex @code{SIGUPDATE} @example +@group buf_set(buffer, type, 0, variable), buf_next(buffer, type, 1); +@end group @end example @item @code{buf_get_next} [(@code{char* buffer, type, type variable}) @arrow{} @code{type}] @@ -4901,22 +5082,24 @@ buf_next(buffer, type, 1); @cpindex Marshalling macros @sgindex @code{SIGUPDATE} @example +@group buf_get(buffer, type, 0, variable), buf_next(buffer, type, 1); +@end group @end example @item @code{strequals} [(@code{const char* a, const char* b}) @arrow{} @code{int}] @fnindex @code{strequals} @cpindex String comparison Evaluates whether the strings @code{a} and @code{b} -are equals, neither may be @code{NULL}. +are equals, neither may be @code{NULL}@. @item @code{startswith} [(@code{const char* haystack, const char* needle}) @arrow{} @code{int}] @fnindex @code{startswith} @cpindex String comparison Evaluates whether the string @code{haystack} starts with the string @code{needle}, neither -may be @code{NULL}. +may be @code{NULL}@. @item @code{drop_privileges} [(void) @arrow{} @code{int}] @fnindex @code{drop_privileges} @@ -5240,7 +5423,7 @@ may not even refer to the program, and @code{chdir} could also hinter its use. @item -The kernel appends ` (deleted)' to +The kernel appends @samp{ (deleted)} to @file{/proc/self/exe} once it has been removed, so it cannot be replaced. @end enumerate @@ -5586,7 +5769,7 @@ a list, reads its variable @code{size_t size}. The variable @code{uint64_t* clients} is used to retrieve stored elements. -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT @example void print_elements(client_list_t* this) @{ @@ -5596,7 +5779,7 @@ void print_elements(client_list_t* this) @} @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT @example void print_elements(client_list_t* this) @{ @@ -5939,7 +6122,7 @@ be stored to the variable @code{entry} and the bucket index will be stored to the variable @code{i}. -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT @example void print_hash_table(hash_table_t* table) @{ @@ -5950,7 +6133,7 @@ void print_hash_table(hash_table_t* table) @} @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT @example void print_hash_table(hash_table_t* table) @{ @@ -5972,7 +6155,7 @@ is not a popinter. @vrindex @code{fd_table_t.value_comparator} The structures @code{hash_table_t} and @code{fd_table_t} contain the variable @code{value_comparator} which by -default is @code{NULL}. If this variable is set to @code{NULL}, +default is @code{NULL}@. If this variable is set to @code{NULL}, two values will be considered equal if and only if they are numerically identical; otherwise two values will be considered equal if and only if @code{value_comparator} returned a @@ -6217,7 +6400,7 @@ the server has been initialised. @item --on-init-sh=COMMAND @opindex @option{--on-init-sh} When the server has been initialised, run the -command @var{COMMAND}. +command @var{COMMAND}@. @item --immortal @opindex @option{--immortal} @@ -6364,7 +6547,7 @@ Calculate and returns the number of bytes that will be stored by @code{marshal_server}. On failure the server should call @code{abort} or exit with failure status by other means. However it should not be possible for this function to fail. -@code{marshal_server_size} must be pure.@footnote{That is, +@code{marshal_server_size} must be pure@footnote{That is, define with and conforming to @code{__attribute__((pure))}.}. @item @code{marshal_server} [(@code{char* state_buf}) @arrow{} @code{int}] @@ -6633,119 +6816,119 @@ for reference. @table @asis @item @code{1} -@kbd{Escape} key +@key{Escape} key @item @code{2}--@code{11} -Keys: @kbd{1}, @kbd{2}, @kbd{3}, @kbd{4}, @kbd{5}, @kbd{6}, @kbd{7}, @kbd{8}, @kbd{9}, @kbd{0} +Keys: @key{1}, @key{2}, @key{3}, @key{4}, @key{5}, @key{6}, @key{7}, @key{8}, @key{9}, @key{0} @item @code{12} -Key right of @kbd{0}. +Key right of @key{0}. @item @code{13} -Key left of @kbd{backspace} +Key left of @key{Backspace} @item @code{14} -@kbd{Backspace} key +@key{Backspace} key @item @code{15} -@kbd{Tab} key +@key{Tab} key @item @code{16}--@code{25} -Keys: @kbd{q}, @kbd{w}, @kbd{e}, @kbd{r}, @kbd{t}, @kbd{y}, @kbd{u}, @kbd{i}, @kbd{o}, @kbd{p} +Keys: @key{q}, @key{w}, @key{e}, @key{r}, @key{t}, @key{y}, @key{u}, @key{i}, @key{o}, @key{p} @item @code{26} -Key right of @kbd{p}, once removed +Key right of @key{p}, once removed @item @code{27} -Key right of @kbd{p}, twice removed +Key right of @key{p}, twice removed @item @code{28} -@kbd{Return} key +@key{Return} key @item @code{29} -Left @kbd{control} key +Left @key{Control} key @item @code{30}--@code{38} -Keys: @kbd{a}, @kbd{s}, @kbd{d}, @kbd{f}, @kbd{g}, @kbd{h}, @kbd{j}, @kbd{k}, @kbd{l} +Keys: @key{a}, @key{s}, @key{d}, @key{f}, @key{g}, @key{h}, @key{j}, @key{k}, @key{l} @item @code{39} -Key right of @kbd{l}, once removed +Key right of @key{l}, once removed @item @code{40} -Key right of @kbd{l}, twice removed +Key right of @key{l}, twice removed @item @code{41} -Key left of @kbd{1} +Key left of @key{1} @item @code{42} -Left @kbd{shift} key +Left @key{Shift} key @item @code{43} -Key right of @kbd{l}, three times removed +Key right of @key{l}, three times removed @item @code{44}--@code{50} -Keys: @kbd{z}, @kbd{x}, @kbd{c}, @kbd{v}, @kbd{b}, @kbd{n}, @kbd{m} +Keys: @key{z}, @key{x}, @key{c}, @key{v}, @key{b}, @key{n}, @key{m} @item @code{51} -Key right of @kbd{m}, once removed +Key right of @key{m}, once removed @item @code{52} -Key right of @kbd{m}, twice removed +Key right of @key{m}, twice removed @item @code{53} -Key right of @kbd{m}, three times removed +Key right of @key{m}, three times removed @item @code{54} -Right @kbd{shift} key +Right @key{Shift} key @item @code{55} -@kbd{Multiply} key on the keypad +@key{Multiply} key on the keypad @item @code{56} -@kbd{Alternative} key +@key{Alternative} key @item @code{57} -@kbd{Space} key +@key{Space} key @item @code{58} -@kbd{Caps lock} key +@key{Caps Lock} key @item @code{59}--@code{68} -Keys: @kbd{F1} through @kbd{F10} +Keys: @key{F1} through @key{F10} @item @code{69} -@kbd{Num lock} key +@key{Num Lock} key @item @code{70} -@kbd{Scroll lock} key +@key{Scroll Lock} key @item @code{71}--@code{73} -@kbd{7}, @kbd{8}, @kbd{9} keys on the keypad +@key{7}, @key{8}, @key{9} keys on the keypad @item @code{74} -@kbd{Minus} key on the keypad +@key{Minus} key on the keypad @item @code{75}--@code{77} -@kbd{4}, @kbd{5}, @kbd{6} keys on the keypad +@key{4}, @key{5}, @key{6} keys on the keypad @item @code{78} -@kbd{Plus} key on the keypad +@key{Plus} key on the keypad @item @code{79}--@code{82} -@kbd{1}, @kbd{2}, @kbd{3}, @kbd{0} keys on the keypad +@key{1}, @key{2}, @key{3}, @key{0} keys on the keypad @item @code{83} -@kbd{Comma} key on the keypad +@key{Comma} key on the keypad @item @code{86} -Key left of @kbd{z} +Key left of @key{z} @item @code{87} -@kbd{F11} key +@key{F11} key @item @code{88} -@kbd{F12} key +@key{F12} key @item @code{96} -@kbd{Return} key on the keypad +@key{Return} key on the keypad @item @code{97} -Right @kbd{control} key +Right @key{control} key @item @code{98} -@kbd{Divide} key on the keypad +@key{Divide} key on the keypad @item @code{99} -@kbd{System Request/Print Screen} key +@key{System Request}/@key{Print Screen} key @item @code{100} -@kbd{Alternative graphic} key +@key{Alternative Graphic} key @item @code{102} -@kbd{Home} key +@key{Home} key @item @code{103} -@kbd{Up} arrow key +@key{Up} arrow key @item @code{104} -@kbd{Page up} key +@key{Page up} key @item @code{105} -@kbd{Left} arrow key +@key{Left} arrow key @item @code{106} -@kbd{Right} arrow key +@key{Right} arrow key @item @code{107} -@kbd{End} key +@key{End} key @item @code{108} -@kbd{Down} arrow key +@key{Down} arrow key @item @code{109} -@kbd{Page down} down +@key{Page down} down @item @code{110} -@kbd{Insert} key +@key{Insert} key @item @code{111} -@kbd{Delete} key +@key{Delete} key @item @code{119} -@kbd{Pause/Break} key +@key{Pause}/@key{Break} key @item @code{125} -Left @kbd{super} key +Left @key{Super} key @item @code{126} -Right @kbd{super} key +Right @key{Super} key @item @code{127} -@kbd{Application menu} key +@key{Application Menu} key @end table @@ -6799,7 +6982,7 @@ other, does not matter. Additionally, the layout files are parsed line by line, and leading whitespace is ignored. Comment can be started with a #-character and end at the end of the line. It is important to know that modifiers -like @kbd{shift} and @kbd{control} needs to be mapped from +like @key{Shift} and @key{Control} needs to be mapped from a keycode, this and similar that many keyboards have in common, except dead key composition and compose sequences, is already available in the @file{layout/common} directory @@ -6844,27 +7027,33 @@ space when we are writting so we add giving us @example +@group <keycode 57> : <space> <space> : " " +@end group @end example Because the order of the mapping statements does not matter we can just as well write @example +@group <space> : " " <keycode 57> : <space> +@end group @end example @code{" "} represents a text string with one blank space, but it is possible to have multiple characters. -We want to extend this to @kbd{altgr+space} producing +If we want to extend this to @kbd{altgr+space} producing a no-break space, we can add either of the lines @example +@group <altgr space> : "\u00A0" # no-break space (# comment) <altgr keycode 57> : "\u00A0" # no-break space +@end group @end example However, we also need a mapping to @kbd{altgr}: @@ -6877,8 +7066,10 @@ If we want to add a mapping to @kbd{ultra} from @kbd{altgr+menu} we can write @example +@group <keycode 127> : <menu> <altgr menu> : <-altgr ultra> +@end group @end example @code{-altgr} means that @kbd{altgr} should @@ -6901,7 +7092,7 @@ are lock keys or not. To map the keycode But if you do not want it be a lock key, but instead be required to be held down, -similar to how is normal for @kbd{shift}, +similar to how is normal for @key{Shift}, instead write @example @@ -6911,14 +7102,14 @@ instead write Any modifier may be a lock key. Another, just as important, use of mappings -to is map letter keys. Unlike control keys -like space and shift, there are no predefined -letters@footnote{With letters with mean any -character other than space.}. Therefore the -letter is prefixed with the word `letter'. +to is map letter keys. Unlike @key{Control} keys +like @key{Space} and @key{Shift}, there are no +predefined letters@footnote{With letters with +mean any character other than space.}. Therefore +the letter is prefixed with the word `letter'. For example: -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER @example <keycode 16> : <letter q> # The Q-key has keycode 16 (on QWERTY) <letter q> : "q" # The Q-key should produce a `q' @@ -6927,7 +7118,7 @@ For example: <shift caps letter q> : "q" # but not when both are used @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER @example # The Q-key has keycode 16 (on QWERTY) <keycode 16> : <letter q> @@ -6962,15 +7153,17 @@ To define @kbd{´}, with keycode 13, @kbd{compose}, with keycode 125, as a dead keys write @example +@group <keycode 13> : <dead letter ´> <keycode 125> : <dead compose> +@end group @end example @cpindex Duplicate keys @cpindex Keys, duplicates Some may appear on multiple locations on the keyboard, -for example, there may be a left and a right shift key, -and a normal return key and one on the keypad: +for example, there may be a left and a right @key{Shift} +key, and a normal @key{Return} key and one on the keypad: @example <keycode 42> : <left shift> @@ -6985,9 +7178,9 @@ Because @code{<left>} and @code{<right>} are valid keys --- they are arrow keys --- it is importatn to place them directly before the key, and not after. For instance @code{<left shift>} -denotes the left @kbd{shift} key, whilst -@code{<shift left>} denotes the left-arrow key -with a @kbd{shift} key held down. Modifiers +denotes the left @key{Shift} key, whilst +@code{<shift left>} denotes the @key{Left} arrow +key with a @key{Shift} key held down. Modifiers goes first. @@ -7024,8 +7217,8 @@ a sequence: <super tab> : <tab> <tab> <tab> <tab> @end example -An alternative to @kbd{compose} as a dead key, -is @kbd{compose} as a modifier. If you use this, +An alternative to @key{Compose} as a dead key, +is @key{Compose} as a modifier. If you use this, the compose table need to be written for just that. There two ways do this this. Either you can write for example @@ -7035,7 +7228,7 @@ can write for example @end example This maps two `s':es to a `ß', but requires that -@kbd{compose} is held down during both key-presses. +@key{Compose} is held down during both key-presses. The other way is to write @example @@ -7050,8 +7243,10 @@ where it does not matter in which order you press some of the keys. For example, instead of @example +@group <dead compose> "S" "|" : "$" <dead compose> "|" "S" : "$" +@end group @end example you can write @@ -7070,8 +7265,10 @@ You can also use @code{[ ]} for alternation. For example, instead of @example +@group <dead compose> ("S" "|") : "$" <dead compose> ("s" "|") : "$" +@end group @end example you can write @@ -7085,8 +7282,10 @@ for specify that no key press is needed. For example, instead of @example +@group <dead compose> "|" "S" : "$" <dead compose> "|" "|" "S" : "$" +@end group @end example you can write @@ -7108,8 +7307,8 @@ subsequence inside unordered subsequence because of readability issues. Unordered subsequences longer than 5 elements -cannot compile under normal circumstances. This -is eliminiation of unordered subsequences grows +cannot compile under normal circumstances. +Eliminiation of unordered subsequences grows superexponentially, and thus is probably an error than can cause memory exhaustion and unrealistic compilation-time. Therefore, if an unordered @@ -7118,7 +7317,7 @@ compiler required that the @option{--force} flag is used and that the unordered subsequences uses double brackets: -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER @example <dead compose> ("1" "2" "3" "4" "5") : "120" <dead compose> (("1" "2" "3" "4" "5" "6")) : "720" @@ -7127,13 +7326,25 @@ double brackets: <dead compose> (("1" "2" "3" "4" "5" "6" "7" "8" "9")) : "362880" @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER +@ifset SMALLBOOK_WITH_SMALLFONT +@example +<dead compose> ("1" "2" "3" "4" "5") : "120" +<dead compose> (("1" "2" "3" "4" "5" "6")) : "720" +<dead compose> (("1" "2" "3" "4" "5" "6" "7")) : "5040" +<dead compose> (("1" "2" "3" "4" "5" "6" "7" "8")) : "40320" +@end example +@end ifset +@ifclear SMALLBOOK_WITH_SMALLFONT @example +@group <dead compose> ("1" "2" "3" "4" "5") : "120" <dead compose> (("1" "2" "3" "4" "5" "6")) : "720" <dead compose> (("1" "2" "3" "4" "5" "6" "7")) : "5040" +@end group @end example @end ifclear +@end ifclear @@ -7237,9 +7448,9 @@ is compile by itself. If this is done, the compiler can warn when one of the compositions cannot be reached from those basic keys. -If we want to make the compiler assume that @kbd{compose} -is available as a dead key, that @kbd{shift}, @kbd{altgr} -and @kbd{space} are available and that the ASCII letter, +If we want to make the compiler assume that @key{compose} +is available as a dead key, that @key{shift}, @key{altgr} +and @key{space} are available and that the ASCII letter, digits and some basic special characters are available we can write. @@ -7279,8 +7490,10 @@ For instance @file{layout/sv/qwerty} has two include statements to implement its basics: @example +@group include "../common/qwerty" include "../common/base" +@end group @end example @@ -7292,7 +7505,7 @@ include "../common/base" @cpindex Macros, keyboard layout There is a lot of repetitive work in layouts, for instance all letters need mapping for any combination of use of -@kbd{shift} and @kbd{compose}. To reduce this, you can +@key{shift} and @key{compose}. To reduce this, you can define macros. For example instead of writing @@ -7326,9 +7539,9 @@ letter("b" "B") # and so on ... @end example -The name of this macro is `letter/2', -but it is called with the name `letter' -and two arguments. The `/2'-suffix means +The name of this macro is @code{letter/2}, +but it is called with the name @code{letter} +and two arguments. The @code{/2}-suffix means that it is invoked with exactly two arguments. You can use this do define multiple version of the same macro, with the same invocation @@ -7355,45 +7568,48 @@ letter("ö" "Ö") @end example @code{\add( )} and @code{\sub( )} are calls to two -built-in functions named `add/2' and `sub/2'. +built-in functions named @code{add/2} and @code{sub/2}. @cpindex Alternation, keys @cpindex Key alternations Alternation can be used to invoke a macro: -@ifset AFOURPAPER +@ifset AFOURPAPER_OR_USLETTER_OR_SMALLFONT @example +@group letter(["a" "b" "c" "d" "e" "f" "g" "h" "i" "j" "k" "l" "m"]) letter(["n" "o" "p" "q" "r" "s" "t" "u" "v" "w" "x" "y" "z"]) +@end group @end example @end ifset -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER_OR_SMALLFONT @example +@group letter(["a" "b" "c" "d" "e" "f" "g" "h" "i" "j"]) letter(["k" "l" "m" "n" "o" "p" "q" "r" "s" "t"]) letter(["u" "v" "w" "x" "y" "z"]) +@end group @end example @end ifclear @cpindex Alternation, keys @cpindex Key alternations -You may use `.' in an alternation, in that case +You may use @code{.} in an alternation, in that case macro is called once with the argument, causing it -to invoke for example `letter/0' instead of -`letter/1'. +to invoke for example @code{letter/0} instead of +@code{letter/1}. -A related issue are for-loops. If we for -example want to call the macro `letter/1' for -all letters betweeh and including `a' and `z' +A related issue are for-loops. If we for example +want to call the macro @code{letter/1} for all +letters between and including `a' and `z' we can just write -@ifclear AFOURPAPER -@page -@end ifclear @example +@group for "a" to "z" as \1 letter(\1) end for +@end group @end example instead of using the alternation-trick. @@ -7451,7 +7667,6 @@ to or greater than 2 to the power of 31 not allowed and can either cause compile-time error or erroneous compiled files. - @cpindex Keyboard layout, macros @cpindex Macros, keyboard layout Functions are similar to function macros, @@ -7462,13 +7677,15 @@ to the last value it evaluted before it returned. For example instead of @code{\not(\greater(\1 "z"))} you can write @code{\less_eq(\1 "z")} after you -have defined the function `less_eq/2' with the +have defined the function @code{less_eq/2} with the following code: @example +@group function less_eq/2 \not(\greater(\1 \2)) end function +@end group @end example A final construct to make layout code less @@ -7518,16 +7735,20 @@ them, may span multiple lines. For example you may write @example +@group let \1 : @{ "å" "ä" "ö" "à" "é" "ü" @} +@end group @end example but not @example +@group let \1 : @{ "å" "ä" "ö" "à" "é" "ü" @} +@end group @end example See @ref{Builtin Functions} for how they are used. @@ -7572,13 +7793,13 @@ a @code{< >}. But `\' can also be used to specify characters by their code point, for example if you want an `æ' you can write @code{"\u00E6"} or @code{"\uE6"}, instead of @code{"æ"}. You can also write @code{"\0346"}, -the difference between `\0' and `\u' is that `\0' uses -octal whereas `\u' uses hexadecimal. A noteworthy -side-effect of this is that function names cannot start -with a lower case `u'. +the difference between @code{\0} and @code{\u} is that +@code{\0} uses octal whereas @code{\u} uses hexadecimal. +A noteworthy side-effect of this is that function names +cannot start with a lower case `u'. `\' can also be used to access variables and parameters. -For example `\1' in +For example @code{\1} in @example macro letter/2 @@ -7590,19 +7811,20 @@ end macro letter("å" "Å") @end example -is expanded to an `å', where as `\2' is expanded to an `Å'. +is expanded to an `å', where as @code{\2} is expanded +to an `Å'. `\' is also used to call functions, for example if -you want to call the function `f/0' you write +you want to call the function @code{f/0} you write @code{\f()}. Because numerical (possibly prefixed with an `u') are of variable length, it is possible to specify the escape's -termination point with a dot. For instance, if you -want the value of the first variable (\1) followed by -two zeroes, you do not write `\100' as that would expand -to the value of the hundredth variable. Instead you -write `\1.00'. +termination point with a dot. For instance, if you want +the value of the first variable (@code{\1}) followed by +two zeroes, you do not write @code{\100} as that would +expand to the value of the hundredth variable. Instead +you write @code{\1.00}. Use of function calls and variables inside @code{include}-statments invokes undefined behaviour. @@ -7624,74 +7846,73 @@ of basic functions: @table @code @item add/2 @fnindex @code{add/2} -The code points in \1 plus the code points of the -corresponding characters in \2. If \1 and \2 are -not of the same length, the returned string will -be of the length of the longer of the parameters, -and modulo is used to map to the corresponing -character. +The code points in @code{\1} plus the code points +of the corresponding characters in @code{\2}. If +@code{\1} and @code{\2} are not of the same length, +the returned string will be of the length of the +longer of the parameters, and modulo is used to map +to the corresponing character. @item sub/2 @fnindex @code{sub/2} -Like `add/2' but subtraction. +Like @code{add/2} but subtraction. @item mul/2 @fnindex @code{mul/2} -Like `add/2' but multiplication. +Like @code{add/2} but multiplication. @item div/2 @fnindex @code{div/2} -Like `add/2' but division. +Like @code{add/2} but division. @item mod/2 @fnindex @code{mod/2} -Like `add/2' but modulo. +Like @code{add/2} but modulo. @item rsh/2 @fnindex @code{rsh/2} -Like `add/2' but rightward bitwise shift. -If a character in \2 is has a code point -greater than 30, undefined behaviour is -invoked. +Like @code{add/2} but rightward bitwise shift. +If a character in @code{\2} is has a code point +greater than 30, undefined behaviour is invoked. @item lsh/2 @fnindex @code{lsh/2} -Like `add/2' but leftward bitwise shift. -If a character in \2 is has a code point -greater than 30, undefined behaviour is -invoked. +Like @code{add/2} but leftward bitwise shift. +If a character in @code{\2} is has a code point +greater than 30, undefined behaviour is invoked. @item or/2 @fnindex @code{or/2} -Like `add/2' but bitwise OR. +Like @code{add/2} but bitwise OR@. @item and/2 @fnindex @code{and/2} -Like `add/2' but bitwise AND. +Like @code{add/2} but bitwise AND@. @item xor/2 @fnindex @code{xor/2} -Like `add/2' but bitwise XOR. +Like @code{add/2} but bitwise XOR@. @item not/1 @fnindex @code{not/1} -For each character in \1, evaluate to -zero if the character is not zero, and +For each character in @code{\1}, evaluate +to zero if the character is not zero, and one if the character is zero. @item equals/2 @fnindex @code{equals/2} For each character, evalute to one if -the characters in \1 and \2 are equal -and zero otherwise. +the characters in @code{\1} and @code{\2} +are equal and zero otherwise. @item greater/2 @fnindex @code{greater/2} -Like `equals/2' but \1 greater than \2 -rather than \1 equals \2. +Like @code{equals/2} but @code{\1} greater +than @code{\2} rather than @code{\1} equals +@code{\2}. @item less/2 @fnindex @code{less/2} -Like `equals/2' but \1 less than \2 -rather than \1 equals \2. +Like @code{equals/2} but @code{\1} less than +@code{\2} rather than @code{\1} equals @code{\2}. @item set/3 @fnindex @code{set/3} -Set the element with index \2, in the -array with variable index \1, to \3, -and return \3. +Set the element with index @code{\2}, in +the array with variable index @code{\1}, to +@code{\3}, and return @code{\3}. For example @code{\set(1 0 4)} sets the -first element in \1 to 4. +first element in @code{\1} to 4. @item get/2 @fnindex @code{get/2} -Return the element with index \2 in the -array with variable index \1. +Return the element with index @code{\2} in +the array with variable index @code{\1}. For example after @code{\set(1 0 4)} or @code{let \1 : @{ 4 3 2 1 0 @}} has been used, @code{\get(1 0)} evaluates to 4. @@ -7726,10 +7947,10 @@ the compose key. @c * Ancient Greek Numbers:: Ancient Greek Numbers. @c * Ancient Symbols:: Ancient Symbols. @c * Arabic:: Arabic. -@c * Arabic Extended-A:: Arabic Extended-A. +@c * Arabic Extended-A:: Arabic Extended-A@. @c * Arabic Mathematical Alphabetic Symbols:: Arabic Mathematical Alphabetic Symbols. -@c * Arabic Presentation Forms-A:: Arabic Presentation Forms-A. -@c * Arabic Presentation Forms-B:: Arabic Presentation Forms-B. +@c * Arabic Presentation Forms-A:: Arabic Presentation Forms-A@. +@c * Arabic Presentation Forms-B:: Arabic Presentation Forms-B@. @c * Arabic Supplement:: Arabic Supplement. @c * Armenian:: Armenian. * Arrows:: Arrows. @@ -7765,10 +7986,10 @@ the compose key. @c * CJK Strokes:: CJK Strokes. @c * CJK Symbols and Punctuation:: CJK Symbols and Punctuation. @c * CJK Unified Ideographs:: CJK Unified Ideographs. -@c * CJK Unified Ideographs Extension A:: CJK Unified Ideographs Extension A. -@c * CJK Unified Ideographs Extension B:: CJK Unified Ideographs Extension B. -@c * CJK Unified Ideographs Extension C:: CJK Unified Ideographs Extension C. -@c * CJK Unified Ideographs Extension D:: CJK Unified Ideographs Extension D. +@c * CJK Unified Ideographs Extension A:: CJK Unified Ideographs Extension A@. +@c * CJK Unified Ideographs Extension B:: CJK Unified Ideographs Extension B@. +@c * CJK Unified Ideographs Extension C:: CJK Unified Ideographs Extension C@. +@c * CJK Unified Ideographs Extension D:: CJK Unified Ideographs Extension D@. @c * Combining Diacritical Marks:: Combining Diacritical Marks. @c * Combining Diacritical Marks Extended:: Combining Diacritical Marks Extended. @c * Combining Diacritical Marks for Symbols:: Combining Diacritical Marks for Symbols. @@ -7784,8 +8005,8 @@ the compose key. @c * Currency Symbols:: Currency Symbols. @c * Cypriot Syllabary:: Cypriot Syllabary. @c * Cyrillic:: Cyrillic. -@c * Cyrillic Extended-A:: Cyrillic Extended-A. -@c * Cyrillic Extended-B:: Cyrillic Extended-B. +@c * Cyrillic Extended-A:: Cyrillic Extended-A@. +@c * Cyrillic Extended-B:: Cyrillic Extended-B@. @c * Cyrillic Supplement:: Cyrillic Supplement. @c * Deseret:: Deseret. @c * Devanagari:: Devanagari. @@ -7802,7 +8023,7 @@ the compose key. @c * Enclosed CJK Letters and Months:: Enclosed CJK Letters and Months. @c * Ethiopic:: Ethiopic. @c * Ethiopic Extended:: Ethiopic Extended. -@c * Ethiopic Extended-A:: Ethiopic Extended-A. +@c * Ethiopic Extended-A:: Ethiopic Extended-A@. @c * Ethiopic Supplement:: Ethiopic Supplement. * General Punctuation:: General Punctuation. * Geometric Shapes:: Geometric Shapes. @@ -7819,8 +8040,8 @@ the compose key. @c * Halfwidth and Fullwidth Forms:: Halfwidth and Fullwidth Forms. @c * Hangul Compatibility Jamo:: Hangul Compatibility Jamo. @c * Hangul Jamo:: Hangul Jamo. -@c * Hangul Jamo Extended-A:: Hangul Jamo Extended-A. -@c * Hangul Jamo Extended-B:: Hangul Jamo Extended-B. +@c * Hangul Jamo Extended-A:: Hangul Jamo Extended-A@. +@c * Hangul Jamo Extended-B:: Hangul Jamo Extended-B@. @c * Hangul Syllables:: Hangul Syllables. @c * Hanunoo:: Hanunoo. @c * Hebrew:: Hebrew. @@ -7846,16 +8067,16 @@ the compose key. @c * Khudawadi:: Khudawadi. @c * Lao:: Lao. @c * Latin Extended Additional:: Latin Extended Additional. -* Latin Extended-A:: Latin Extended-A. -* Latin Extended-B:: Latin Extended-B. -* Latin Extended-C:: Latin Extended-C. -@c * Latin Extended-D:: Latin Extended-D. -@c * Latin Extended-E:: Latin Extended-E. +* Latin Extended-A:: Latin Extended-A@. +* Latin Extended-B:: Latin Extended-B@. +* Latin Extended-C:: Latin Extended-C@. +@c * Latin Extended-D:: Latin Extended-D@. +@c * Latin Extended-E:: Latin Extended-E@. * Latin-1 Supplement:: Latin-1 Supplement. @c * Lepcha:: Lepcha. @c * Letterlike Symbols:: Letterlike Symbols. @c * Limbu:: Limbu. -@c * Linear A:: Linear A. +@c * Linear A:: Linear A@. @c * Linear B Ideograms:: Linear B Ideograms. @c * Linear B Syllabary:: Linear B Syllabary. @c * Lisu:: Lisu. @@ -7874,8 +8095,8 @@ the compose key. @c * Meroitic Cursive:: Meroitic Cursive. @c * Meroitic Hieroglyphs:: Meroitic Hieroglyphs. @c * Miao:: Miao. -* Miscellaneous Mathematical Symbols-A:: Miscellaneous Mathematical Symbols-A. -* Miscellaneous Mathematical Symbols-B:: Miscellaneous Mathematical Symbols-B. +* Miscellaneous Mathematical Symbols-A:: Miscellaneous Mathematical Symbols-A@. +* Miscellaneous Mathematical Symbols-B:: Miscellaneous Mathematical Symbols-B@. @c * Miscellaneous Symbols:: Miscellaneous Symbols. * Miscellaneous Symbols and Arrows:: Miscellaneous Symbols and Arrows. @c * Miscellaneous Symbols and Pictographs:: Miscellaneous Symbols and Pictographs. @@ -7886,8 +8107,8 @@ the compose key. @c * Mro:: Mro. @c * Musical Symbols:: Musical Symbols. @c * Myanmar:: Myanmar. -@c * Myanmar Extended-A:: Myanmar Extended-A. -@c * Myanmar Extended-B:: Myanmar Extended-B. +@c * Myanmar Extended-A:: Myanmar Extended-A@. +@c * Myanmar Extended-B:: Myanmar Extended-B@. @c * Nabataean:: Nabataean. @c * New Tai Lue:: New Tai Lue. @c * NKo:: NKo. @@ -7932,9 +8153,9 @@ the compose key. @c * Sundanese:: Sundanese. @c * Sundanese Supplement:: Sundanese Supplement. * Superscripts and Subscripts:: Superscripts and Subscripts. -* Supplemental Arrows-A:: Supplemental Arrows-A. -* Supplemental Arrows-B:: Supplemental Arrows-B. -* Supplemental Arrows-C:: Supplemental Arrows-C. +* Supplemental Arrows-A:: Supplemental Arrows-A@. +* Supplemental Arrows-B:: Supplemental Arrows-B@. +* Supplemental Arrows-C:: Supplemental Arrows-C@. * Supplemental Mathematical Operators:: Supplemental Mathematical Operators. @c * Syloti Nagri:: Syloti Nagri. @c * Syriac:: Syriac. @@ -7994,11 +8215,11 @@ the compose key. @subsection Box Drawing Most of the box drawing glyphs can be composed by -typing @kbd{<dead compose>} followed by two -glyphs that should be combined to form the desired -glyphs. If the two glyphs are identical the glyph -becomes heavy. More general, common parts of the -glyphs become heavy. +typing @kbd{<dead compose>} followed by two glyphs +that should be combined to form the desired glyphs. +If the two glyphs are identical the glyph becomes +heavy. More general, common parts of the glyphs +become heavy. Glyphs that contain a heavy part be transformed so that the heavy parts become double stroked. @@ -8698,7 +8919,7 @@ the cursor should transition from @code{X} to @code{X-hold}. @code{X-hold} is the version of @code{X} that should be used if any rat button is held down. @code{X} is an animation from @code{X-release} to @code{X} and is used when the cursor should -transition from @code{X-release} to @code{X}. Clients should +transition from @code{X-release} to @code{X}@. Clients should not set the cursor to either of them, it is up to the server to do this based on events from the rat device. @@ -8721,6 +8942,7 @@ This cursor is usually a north-west or north-north-west pointing arrow. For left-handed themes this cursor is usually a north-east or north-north-east pointing arrow. @example +@group ## #### ###### @@ -8737,6 +8959,7 @@ usually a north-east or north-north-east pointing arrow. ###### #### #### +@end group @end example @page @@ -8749,6 +8972,7 @@ context menu. This cursor is typically @command{default} combined with a small menu. @example +@group ## ############ #### ############ ###### ## ## @@ -8765,8 +8989,9 @@ small menu. ###### #### #### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifset AFIVEPAPER @page @@ -8777,6 +9002,7 @@ an horizontal text that can be selected and possibly edited. This cursor is usually a vertical I-beam. @example +@group ############## ## ## @@ -8793,10 +9019,13 @@ This cursor is usually a vertical I-beam. ## ## ############## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear AFOURPAPER_WITH_SMALLFONT @page +@end ifclear @item vertical-text This cursor should be used when the rat pointers is above an vertical text that can be selected and possibly edited. @@ -8806,6 +9035,7 @@ the first fallback. This cursor is usually a horizontal I-beam. @example +@group ## ## ## ## ## ## @@ -8813,9 +9043,13 @@ This cursor is usually a horizontal I-beam. ## ## ## ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item progress This cursor indicates that the interface can be used as when @command{default} is used. @@ -8825,6 +9059,7 @@ with command the user previously issued. This cursor is usually rendered as a combination of @command{default} and @command{wait}. @example +@group ## ############ #### ############ ###### ######## @@ -8841,10 +9076,13 @@ of @command{default} and @command{wait}. ###### #### #### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear AFOURPAPER_WITH_SMALLFONT @page +@end ifclear @item wait This cursor indicates that the interface cannot be used because it is working or is blocked by @@ -8854,6 +9092,7 @@ This cursor is typically rendered as a hourglass, watch, sundial or some sort of animated ring. @example +@group #################### #################### ################ @@ -8870,10 +9109,11 @@ of animated ring. ################ #################### #################### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifset @item pointer @@ -8886,6 +9126,7 @@ apparent by design that the object is clickable. This cursor is usually a right hand (left hand if left-handed) pointing with the index-finger. @example +@group #### #### #### @@ -8902,10 +9143,13 @@ left-handed) pointing with the index-finger. ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear AFOURPAPER_WITH_SMALLFONT @page +@end ifclear @item help This cursor indicates that the interface is in context help mode. This is usually activated by @@ -8915,6 +9159,7 @@ question mark on it --- on the titlebar. This cursor is typically renderas as @code{default} with a question mark next to it. @example +@group ## ###### #### ########## ###### #### #### @@ -8931,8 +9176,9 @@ with a question mark next to it. ###### #### #### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @item drag This cursor indicates that an object is @@ -8941,6 +9187,7 @@ being dragged. This cursor is usually a closed right hand, or closed left hand if left-handed. @example +@group #### #### #### ################ #### ############################ @@ -8951,8 +9198,9 @@ or closed left hand if left-handed. ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @page @item copy @@ -8965,6 +9213,7 @@ be used as the first fallback. This cursor is usually rendered as @code{drag} with a plus-sign next to it. @example +@group ## ## ########## @@ -8981,8 +9230,9 @@ This cursor is usually rendered as ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifset AFIVEPAPER @page @@ -9000,6 +9250,7 @@ This cursor is usually rendered as The arrow is usually point north east, or north west if left-handed. @example +@group ###### #### ## ## @@ -9016,8 +9267,9 @@ or north west if left-handed. ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @page @item alias @@ -9032,6 +9284,7 @@ This cursor is usually rendered as @code{drag} with an two or three linked links next to it, or an arced arrow. @example +@group #### #### ## ## ## ######## ## @@ -9048,12 +9301,17 @@ links next to it, or an arced arrow. ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear AFOURPAPER +@ifclear SMALLBOOK_WITH_SMALLFONT +@ifclear USLETTER_WITH_SMALLFONT @page @end ifclear +@end ifclear +@end ifclear @item no-drop This cursor indicates that the dragged object cannot be release where the rat pointer is @@ -9068,6 +9326,7 @@ should be used as the first fallback, and This cursor is typically rendered as a combination of @code{drag} and @code{not-allowed}. @example +@group ######## ## #### ## ## ## @@ -9084,8 +9343,9 @@ combination of @code{drag} and @code{not-allowed}. ######################## #################### ################ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @page @item not-allowed @@ -9096,6 +9356,7 @@ operation. This cursor is often rendered as a circle with a diagonal line through it. @example +@group ######## #### #### ## ## @@ -9112,8 +9373,9 @@ a diagonal line through it. ## ## #### #### ######## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifset AFIVEPAPER @page @@ -9126,6 +9388,7 @@ below the cursor This cursor is often rendered as a combined vertical and horizontal twin-headed arrow. @example +@group ## ###### ########## @@ -9141,10 +9404,11 @@ vertical and horizontal twin-headed arrow. ########## ###### ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifclear AFIVEPAPER +@ifclear AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifclear @item up-arrow @@ -9153,6 +9417,7 @@ insertion point. It is often rendered an upwards pointing arrow. @example +@group ## ###### ########## @@ -9164,15 +9429,20 @@ It is often rendered an upwards pointing arrow. ###### ###### ###### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item cell This cursor is often used in spread-sheet applications -when selecting cells +when selecting cells. It is typically rendered as a thick plus-sign. @example +@group ###### ###### ###### @@ -9186,10 +9456,13 @@ It is typically rendered as a thick plus-sign. ###### ###### ###### +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear AFOURPAPER_WITH_SMALLFONT @page +@end ifclear @item col-resize This cursor is used to indicate the the cursor is within a region that allows it rat to be used to resize a column. @@ -9203,6 +9476,7 @@ with an arrow from the left side pointing horizontally towards it and an arrow from the right side pointing horizontally towards it. @example +@group ## ## ## @@ -9218,12 +9492,18 @@ horizontally towards it. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear AFOURPAPER +@ifclear USLETTER_WITH_SMALLFONT @page @end ifclear +@end ifclear +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item row-resize This cursor is used to indicate the the cursor is within a region that allows it rat to be used to resize a column. @@ -9237,6 +9517,7 @@ with an arrow from the left side pointing vertically towards it and an arrow from the right side pointing vertically towards it. @example +@group ## ## ## @@ -9252,16 +9533,27 @@ vertically towards it. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear USLETTER +@ifclear SMALLBOOK_WITH_SMALLFONT +@ifclear AFOURPAPER_WITH_SMALLFONT +@page +@end ifclear +@end ifclear +@end ifclear +@ifset USLETTER_WITH_SMALLFONT @page +@end ifset @item crosshair This cursor is used for precision drawing or precision manipulation of an area. This cursor typically a thin crosshair. @example +@group ## ## ## @@ -9277,8 +9569,9 @@ This cursor typically a thin crosshair. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @item w-resize If this cursor is missing, @code{w-select} @@ -9293,6 +9586,7 @@ This cursor is typically rendered as a west pointing arrow, optionally with a wall at the arrow head. @example +@group ## ## ## ## ## ## @@ -9300,9 +9594,13 @@ wall at the arrow head. ## ## ## ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item w-select If this cursor is missing, @code{w-resize} should be used as the first fallback, @@ -9315,6 +9613,7 @@ the fourth fallback. This cursor is typically rendered as a west pointing arrow. @example +@group ## ## ## @@ -9322,12 +9621,18 @@ west pointing arrow. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifclear AFIVEPAPER +@ifclear AFIVEPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear +@ifset USLETTER_WITH_SMALLFONT +@page +@end ifset @item e-resize If this cursor is missing, @code{e-select} should be used as the first fallback, @@ -9341,6 +9646,7 @@ This cursor is typically rendered as a east pointing arrow, optionally with a wall at the arrow head. @example +@group ## ## ## ## ## ## @@ -9348,11 +9654,14 @@ wall at the arrow head. ## ## ## ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT +@ifclear USLETTER_WITH_SMALLFONT @page +@end ifclear @end ifset @item e-select If this cursor is missing, @code{e-resize} @@ -9366,6 +9675,7 @@ the fourth fallback. This cursor is typically rendered as a east pointing arrow. @example +@group ## ## ## @@ -9373,10 +9683,16 @@ east pointing arrow. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifset SMALLBOOK +@ifclear SMALLFONT +@page +@end ifclear +@end ifset +@ifset AFOURPAPER_WITH_SMALLFONT @page @end ifset @item n-resize @@ -9392,6 +9708,7 @@ This cursor is typically rendered as a north pointing arrow, optionally with a wall at the arrow head. @example +@group ############## ## @@ -9408,12 +9725,18 @@ wall at the arrow head. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear +@ifset SMALLBOOK_WITH_SMALLFONT +@page +@end ifset @item n-select If this cursor is missing, @code{n-resize} should be used as the first fallback, @@ -9426,6 +9749,7 @@ the fourth fallback. This cursor is typically rendered as a north pointing arrow. @example +@group ## ###### ## ## ## @@ -9440,12 +9764,16 @@ north pointing arrow. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifclear AFOURPAPER +@ifclear AFOURPAPER_OR_USLETTER_OR_SMALLBOOK_WITH_SMALLFONT @page @end ifclear +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item s-resize If this cursor is missing, @code{s-select} should be used as the first fallback, @@ -9459,6 +9787,7 @@ This cursor is typically rendered as a south pointing arrow, optionally with a wall at the arrow head. @example +@group ## ## ## @@ -9475,12 +9804,15 @@ wall at the arrow head. ## ############## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear @item s-select If this cursor is missing, @code{s-resize} should be used as the first fallback, @@ -9493,6 +9825,7 @@ the fourth fallback. This cursor is typically rendered as a south pointing arrow. @example +@group ## ## ## @@ -9507,10 +9840,11 @@ south pointing arrow. ## ## ## ###### ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifset @item nw-resize @@ -9526,6 +9860,7 @@ This cursor is typically rendered as a north-west pointing arrow, optionally with a corner at the arrow head. @example +@group ################## ## ## @@ -9542,12 +9877,15 @@ with a corner at the arrow head. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear @item nw-select If this cursor is missing, @code{nw-resize} should be used as the first fallback, @@ -9560,6 +9898,7 @@ the fourth fallback. This cursor is typically rendered as a north-west pointing arrow. @example +@group ############ #### ## ## @@ -9573,10 +9912,11 @@ north-west pointing arrow. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifset @item se-resize @@ -9592,6 +9932,7 @@ This cursor is typically rendered as a south-east pointing arrow, optionally with a corner at the arrow head. @example +@group ## ## ## @@ -9608,12 +9949,15 @@ with a corner at the arrow head. ## ## ################## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear @item se-select If this cursor is missing, @code{se-resize} should be used as the first fallback, @@ -9626,6 +9970,7 @@ the fourth fallback. This cursor is typically rendered as a south-east pointing arrow. @example +@group ## ## ## @@ -9639,10 +9984,11 @@ south-east pointing arrow. ## ## #### ############ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifset @item ne-resize @@ -9658,6 +10004,7 @@ This cursor is typically rendered as a north-east pointing arrow, optionally with a corner at the arrow head. @example +@group ################## ## ## @@ -9674,12 +10021,15 @@ with a corner at the arrow head. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear @item ne-select If this cursor is missing, @code{ne-resize} should be used as the first fallback, @@ -9692,6 +10042,7 @@ the fourth fallback. This cursor is typically rendered as a north-east pointing arrow. @example +@group ############ #### ## ## @@ -9705,10 +10056,11 @@ north-east pointing arrow. ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifset AFIVEPAPER +@ifset AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifset @item sw-resize @@ -9724,6 +10076,7 @@ This cursor is typically rendered as a south-west pointing arrow, optionally with a corner at the arrow head. @example +@group ## ## ## @@ -9740,12 +10093,15 @@ with a corner at the arrow head. ## ## ################## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifclear SMALLBOOK +@ifclear AFOURPAPER_WITH_SMALLFONT @page @end ifclear +@end ifclear @item sw-select If this cursor is missing, @code{sw-resize} should be used as the first fallback, @@ -9758,6 +10114,7 @@ the fourth fallback. This cursor is typically rendered as a south-west pointing arrow. @example +@group ## ## ## @@ -9771,8 +10128,9 @@ south-west pointing arrow. ## ## #### ############ +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @item ew-resize If this cursor is missing, @code{ew-select} @@ -9784,6 +10142,7 @@ This cursor is typically rendered as a east and west pointing twin-arrow, optionally with a wall at the arrow heads. @example +@group ## ## ## ## ## ## ## ## ## ## ## ## @@ -9791,9 +10150,15 @@ optionally with a wall at the arrow heads. ## ## ## ## ## ## ## ## ## ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifset SMALLFONT +@ifset AFOURPAPER_OR_AFIVEPAPER +@page +@end ifset +@end ifset @item ew-select If this cursor is missing, @code{ew-resize} should be used as the first fallback, and @@ -9803,6 +10168,7 @@ second fallback. This cursor is typically rendered as a east and west pointing twin-arrow. @example +@group ## ## ## ## ## ## @@ -9810,10 +10176,11 @@ east and west pointing twin-arrow. ## ## ## ## ## ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll -@ifclear AFIVEPAPER +@ifclear AFIVEPAPER_OR_AFOURPAPER_WITH_SMALLFONT @page @end ifclear @item ns-resize @@ -9826,6 +10193,7 @@ This cursor is typically rendered as a north and south pointing twin-arrow, optionally with a wall at the arrow heads. @example +@group ############## ## @@ -9842,8 +10210,9 @@ optionally with a wall at the arrow heads. ## ############## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @item ns-select If this cursor is missing, @code{ns-resize} @@ -9854,6 +10223,7 @@ second fallback. This cursor is typically rendered as a north and south pointing twin-arrow. @example +@group ## ###### ## ## ## @@ -9866,10 +10236,21 @@ north and south pointing twin-arrow. ## ## ## ###### ## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll +@ifclear SMALLFONT +@ifclear AFIVEPAPER @page +@end ifclear +@end ifclear +@ifset USLETTER_WITH_SMALLFONT +@page +@end ifset +@ifset AFOURPAPER_WITH_SMALLFONT +@page +@end ifset @item nwse-resize If this cursor is missing, @code{all-resize} should be used as the first fallback. @@ -9878,6 +10259,7 @@ This cursor is typically rendered as a north-west and south-east pointing twin-arrow, optionally with a corner at the arrow heads. @example +@group ################## ## ## @@ -9894,8 +10276,9 @@ optionally with a corner at the arrow heads. ## ## ################## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @ifset AFIVEPAPER @page @@ -9908,6 +10291,7 @@ This cursor is typically rendered as a north-east and south-west pointing twin-arrow, optionally with a corner at the arrow heads. @example +@group ################## ## ## @@ -9924,8 +10308,9 @@ optionally with a corner at the arrow heads. ## ## ################## +@end group @end example -@vskip 0pt plus 2filll +@vskip 0pt plus 1filll @page @item all-resize @@ -9935,6 +10320,7 @@ twin-arrow and a north-west and south-east pointing twin-arrow, optionally with a corner at the arrow heads. @example +@group ########## ########## #### #### ## ## ## ## @@ -9950,6 +10336,7 @@ at the arrow heads. ## ## ## ## #### #### ########## ########## +@end group @end example @end table @@ -9971,7 +10358,7 @@ the windows ID of the socket that the application should be embedded in. All @command{mds} applications must be aware -of the environment variable @env{MDS_EMBED}. +of the environment variable @env{MDS_EMBED}@. The application may choose not to embed itself in the announced socket, however it should have good reason for not doing this. @@ -10012,7 +10399,7 @@ if and only if @env{PREFERRED_DISPLAY} lists any other display protocol. If a compatibility server is successfully started, -it shoul be listed in @env{PREFERRED_DISPLAY}. +it shoul be listed in @env{PREFERRED_DISPLAY}@. Be sure to keep the list ordered by preference. @table @code @@ -10077,7 +10464,7 @@ to run them across any number of computers. @pgindex @code{@command{mds-host}} @pgindex @command{mds-remote} -@pgindex Networking +@cpindex Networking If a hosting server, like @command{mds-host}, runs inside a metadisplay, any number of computers can connect to the metadisplay using a server like @@ -10695,7 +11082,7 @@ Development of @command{mds} started out of concern that Wayland would not meet our needs, and the knowledge that X does not. We are now however aware that Wayland meets our needs even -less than X.@footnote{Not even counting that +less than X@.@footnote{Not even counting that the documentation for Wayland is way more lacking that X's documentation.} @@ -11027,31 +11414,31 @@ backgrund. @include fdl.texinfo @node Program index -@appendix Program index +@unnumbered Program index @printindex pg @node Variable index -@appendix Variable index +@unnumbered Variable index @printindex vr @node Option index -@appendix Option index +@unnumbered Option index @printindex op @node Concept index -@appendix Concept index +@unnumbered Concept index @printindex cp @node Signal index -@appendix Signal index +@unnumbered Signal index @printindex sg @node Function index -@appendix Function index +@unnumbered Function index @printindex fn @node Data type index -@appendix Data type index +@unnumbered Data type index @printindex tp @bye @@ -11096,7 +11483,7 @@ TODO protocol: workspace TODO protocol: ping TODO notifications (balloons, bubbles) -TODO virtual resultion (the screen is larger than the output) +TODO virtual resolution (the screen is larger than the output) TODO taskbar features: progress bars (any number) with colours @@ -11111,3 +11498,5 @@ TODO application menu features: different ways to start an program, for example, browers may include a safe-browsing mode. +In `Rat Cursors` use anchors and references to hyperlink names. + |