!H      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRS T U V W X Y Z [ \ ] ^ _ ` a b c!d!e!f!g!h!i!j!k!l!m!n!o!p!q!r!s!t!u!v!w!x!y!z!{!|!}!~!!!!!!!!!!!!!!!!!!!!!!!!!!!!""""""""""""""""""""""""""#$$$$$$$$$%%%%%%%%%%%%%&''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' ' ' ' ' ''''''''''''''''''( (!("(#($(%(&('((()(*(+(,(-(.(/(0(1(2(3(4(5(6(7(8(9(:(;(<(=(>(?(@(A(B(C(D(E(F(G(H(I(J(K(L(M(N(O(P(Q(R(S(T(U(V(W(X(Y(Z([(\(](^(_(`(a(b(c(d(e(f(g(h(i(j(k(l(m(n(o(p(q(r(s(t(u(v(w(x(y(z({(|(}(~(((((((()**+,-./0112333333333333333333333333345677899::::::::::::::::::::::::::::::A;*Dynamically generated configuration moduleSafe4NglircCTransitive dependencies for this package computed at configure-timeglircpackage name, version numberBinding to ecdsatool(c) Eric Mertens, 2016ISCemertens@gmail.comSafe=FglircRIdentifier for SASL ECDSA challenge response authentication using curve NIST256P. ECDSA-NIST256P-CHALLENGEglirc;Encode a username as specified in this authentication mode.glirc5Compute the response for a given challenge using the  ecdsatool( executable which must be available in PATH.glircusername glircbase-64 encoded username glirc!private key file glirc!challenge string glirc!error message or response string Marshaling support for C API(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#YAglirc struct glirc_stringglirc struct glirc_commandglirc struct glirc_message glirc struct glirc_messageglircarrayglirc array lengthglircarrayglircarrayglirc array lengthglirc struct glirc_extension;glircOptional startup callbackglircOptional shutdown callbackglirc"Optional message received callbackglircOptional message send callbackglirc Optional client command callback glircNull-terminated name!glircextension version"glircextension version#glirc*Type of dynamic function pointer wrappers.glirc Ktypedef void process_chat(void *glirc, void *S, const struct glirc_chat *);$glirc Qtypedef void process_command(void *glirc, void *S, const struct glirc_command *);%glirc `typedef enum process_result process_message(void *glirc, void *S, const struct glirc_message *);&glirc (typedef void stop(void *glirc, void *S);'glirc 3typedef void *start(void *glirc, const char *path);*glircLTag for describing the kind of message to display in the client as used in  glirc_print. enum message_code;2glircIResult used to determine what to do after processing a message with the % callback. enum process_result;5glircLike  except it doesn't write to NULL6glirc7Marshal a text as a malloced null-terminated CStringLen7glirc8Marshal a text as a temporary null-terminated CStringLenglircapi token glircextension state glircchat info $glircapi token glircextension state glirccommand %glircapi token glircextention state glircmessage to send &glircapi token glircextension state 'glircapi token glircpath to extension glircinitialized extension state 5  !"#$%&'()*+,-./012345675 !"'&%$  #0/.-,*+12()34765 Dynamically loaded extension API(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#KQVOglirc.Continuation-passing style bracked IO actions.?glircInformation about a loaded extension including the handle to the loaded shared object, and state value returned by the startup callback, and the loaded extension record.Aglirc$Struct of callback function pointersBglirc&Handle of dynamically linked extensionCglirc'State value generated by start callbackGglirc3The symbol that is loaded from an extension object."Extensions are expected to export: "struct galua_extension extension; HglircLoad the extension from the given path and call the start callback. The result of the start callback is saved to be passed to any subsequent calls into the extension.IglircWCall the stop callback of the extension if it is defined and unload the shared object.JglircCall all of the process message callbacks in the list of extensions. This operation marshals the IRC message once and shares that across all of the callbacks.Returns < to pass message to client. Returns 'False to drop message.KglircCall all of the process chat callbacks in the list of extensions. This operation marshals the IRC message once and shares that across all of the callbacks.Returns < to pass message to client. Returns 'False to drop message.LglircBNotify an extension of a client command with the given parameters.glirc Marshal a  into a  ; which will be valid for the remainder of the computation.glircReturn the bracket IO action.glircIWrap up a bracketing IO operation where the continuation takes 1 argumentglircIWrap up a bracketing IO operation where the continuation takes 2 argumentHglircpath to extension Jglircclientstate stable pointer glircnetwork glirccurrent message glircall active extensions glircshould pass message Kglircclientstate stable pointer glircnetwork glirctarget (channel or user) glircmessage body glircall active extensions glircshould pass message Lglircclient state stableptr glirccommand glircextension to command glirc network glirc message glircnetwork glirctarget glircmessage glirccommand ?@ABCDEFGHIJKL?@ABCDEFGHIJLK3Argument specifications used within client commands(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'FS^glircrequired names glircoptional names QTRSUVWXYZ[\]^X\YZ^][UVWQTRS-Interpret argument specifications as a parser(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'v__ Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNone3 dglirc Settings for /exec command.RWhen no network or channel are specified the output is sent to the client window.YWhen only a network is specified the output is sent as raw IRC commands to that network.mWhen only a channel is specified the output is sent as messages on the current network to the given channel.uWhen the network and channel are specified the output is sent as messages to the given channel on the given network.fglircoutput networkgglircoutput channelhglirccommand filenameiglirc stdin sourcejglirccommand argumentsglircDefault values for /exec to be overridden by flags.tglircParse the arguments to /exec> looking for various flags and the command and its arguments.uglircCExecute the requested command synchronously and return the output.glircPower words is similar to ? except that when it encounters a word formatted as a Haskell B literal it parses it as such. Only space is used as a delimiter.tglircexec arguments glircerror or parsed command uglircexec configuration glircerror lines or output lines `abcdefghijrstudefghij`abcsrtu9Parser and evaluator for string interpolation in commands(c) Eric Mertens, 2016ISCemertens@gmail.comSafe&'QV|glirc%Parsed chunk of an expandable command}glirc regular text~glircinline variable $x or ${x y}glircinline variable $1 or ${1}glirc bracketed variable with default ${x|lit}glirc2Specification used when unspecified, no arguments.glircParse a / searching for the expansions as specified in |. $$ is used to escape a single $.glircAttempt to expand all of the elements in the given list using the two expansion functions. If the expansion of any chunk fails the whole expansion fails.glircvariable resolution glircargument index resolution glircchunks glircconcatenated, expanded chunks vwxyz{|}~|}~xyz{vwTrie for recognizing commands(c) Dan Doel, 2016ISCemertens@gmail.comSafe3glirc%Possible results of recognizing text.glirc.text matched exactly, yielding the given valueglirc8text would be recognized if joined to the given suffixesglirc%text could not possibly be recognizedglirc A map from  values to au values that is capable of yielding more detailed information when looking up keys that are not actually in the map.glircTMatch common prefixes of two strings in a more convenient form than available from <=glirc*Attempt to recognize a string, yielding a  result.glircCreate a singleton  associating the given  and value.glirc Union two  RecognizersR. The stored values in the result are biased to the left if there is key overlap.glircUnion an arbitrary number of  Recognizers as with .glirc Create a _ from an association list. If a key appears twice, the earliest associated value will be used.glircAdd a key-value pair to a >. This will override the value already present if one exists.glirc1Compute all strings that will be recognized by a .glircAuxiliary function for . *Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone/glircAParse a text attribute. This value should be a sections with the fg and/or bg attributes. Otherwise it should be a color entry that will be used for the foreground color. An empty sections value will result in glirc#Parse a color. Support formats are:Number between 0-255 Name of colorRGB values of color as a listglirc4Match integers between 0 and 255 as Terminal colors.glirckConfiguration section that matches 3 integers in the range 0-255 representing red, green, and blue values. Configuration schema for macros(c) Eric Mertens, 2017ISCemertens@gmail.comNone/b Programmable keyboard actions(c) Eric Mertens, 2016ISCemertens@gmail.comNoneQVnglircCLookup table for keyboard events to actions. Use with keyToAction.glirc/Actions that can be invoked using the keyboard.glirc/Names and default key bindings for each action.bNote that Jump, Insert and Ignored are excluded. These will be computed on demand by keyToAction.glirc%Render action as human-readable text.glircCLookup the action to perform in response to a particular key event.glirc&Bind a keypress event to a new action.glirc(Unbind the action associated with a key.glircDefault key bindingsglircactions glircjump modifier glircwindow names glircactual modifier glirckey glircaction glirc modifiers glirc key glirc action glirc actions glirc modifiers glirc key glirc actions 22 -Human-readable versions of connection failure(c) Eric Mertens, 2016ISCemertens@gmail.comNone1glircBCompute the message message text to be used for a connection errorglircnetwork error glircclient lines glircnetwork error glircclient lines  'Hooks into the operation of the client.(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglircIdentifying name for the hookglirc0Whether the remapping should affect client stateglirc"(Partial) message remapping actionglircThe possible results of a 2 action. A hook can decline to handle a message (), filter out a message (9), or change a message into an arbitrary other message ().glirc$Apply the given message hooks to an A. The hooks are tried in order until one handles the message. A 9 result means the message was filtered out by a hook. A  result contains the actual  to be processed. %Hook to remap znc buffextras messages(c) Dan Doel, 2016ISCdan.doel@gmail.comNone glircMap ZNC's buffextras messages to native client messages. Set debugging to pass through buffextras messages that the hook doesn't understand.glircenable debugging glircenable debugging Available hooks(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglirc All the available message hooks.Packed vty Image type(c) Eric Mertens, 2016ISCemertens@gmail.comNone=glircPacked, strict version of & used for long-term storage of images.glirc"Width in terms of terminal columnsglirc image width *Parser for mIRC's text formatting encoding(c) Eric Mertens, 2016ISCemertens@gmail.comNoneIglircEParse mIRC encoded format characters and hide the control characters.glircParse mIRC encoded format characters and render the control characters explicitly. This view is useful when inputting control characters to make it clear where they are in the text.glirc"Safely render a control character.glirc Render a  with default attributes and replacing all of the control characters with reverse-video letters corresponding to caret notation.Chat message view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneglircTrailing space with default attributes deals with bug in VTY where the formatting will continue past the end of chat messages. This adds an extra space if a line doesn't end on the terminal edge.glircCThis version of line wrap wraps without regard for word boundaries.glircXList of image widths suitable for breaking the image on that correspond to word breaks.glirc%Drop the leading spaces from an imageglircterminal width glircunwrapped image glircwrapped image glircterminal width glircunwrapped image glircwrapped image glircterminal width glircprefix image glircunwrapped image glircwrapped image glircfirst line length glircimage glircsplits glircfirst line length glircimage glircsplits 'Palette of colors used to render the UI(c) Eric Mertens, 2016ISCemertens@gmail.comNone `glirc.Color palette used for rendering the client UIglirchighlighting nicknamesglircown nickname(s)glircown nickname(s) in mentionsglircmessage timestampsglirccoalesced metadataglircsigils (e.g. @+)glircinformation labelsglirc ping latencyglirc window nameglircerror messagesglirctextbox markersglircwindow name with activity glircwindow name with mention glirc known command glirc%known command with complete arguments glircprefix of known command glircunknown commandglirccommand argument placeholderglircDivider between split windowsglirc$Divider between new and old messages&glircBDefault UI colors that look nice in my dark solarized color schemeglircSDefault nick highlighting colors that look nice in my dark solarized color scheme.'glircTList of palette entry names and lenses for accessing that component of the palette.,      !"#$%&',      #!%"$'&6Interpretation of argument specification as a renderer(c) Eric Mertens, 2017ISCemertens@gmail.comNone&'(glircpalette glircenvironment glircrender placeholders glircspecification glircuser input ((None$5*glirc4Compile a list of masks down to a single, reuseable )% value suitable for being used with +.7Masks can match zero-to-many arbitrary characters with *.-Masks can match one arbitrary character with ?.Literal * ? and |$ can be matched with a preceding @@.ZMissing host or username components of a mask will automatically be treated as wildcards.+glircDetermine if a given ) matches a given glirccParse a mask into the nick, user, and hostname components while replacing omitted components with "*".glircLTranslate from the languge of masks to the language of regular expressions.Masks support the * (many) and ?! (one) wildcards. Wildcards and *@ can be escaped by preceding them with a G@. All other uses of @@ are treated as matching the literal backslash.glircGreturns True iff the charactr is a regular expression meta character: ^$\.|*?+()[]{}*glircmasks )*+)+*Messages to be added to buffers(c) Eric Mertens, 2016ISCemertens@gmail.comNone&Dglirc7Compute a searchable text representation of the message,-./0123456789:;<=>?@ABCDE01234BAC,-./56789:;<=>?@EDIRC channel session state(c) Eric Mertens, 2016ISCemertens@gmail.comNone0#Pglirc5Dynamic information about the state of an IRC channelRglirc topic textSglircauthor and timestamp for topicTglirc channel URLUglircuser list and sigilsVglircchannel settings and parametersWglircmode, mask, setter, set timeXglirccreation time of channelYglircdelayed op messagesiglircConstruct an empty PjglircAdd a user to the user listkglirc Remove a user from the user listlglircRename a user in the user listmglircSet the channel topic#HIJKLMNOPQRSTUVWXY]^_`abcdefghijklm#PQRSTUVWXYabcd_^]`HIJKghLMNOefimjkl9Types for representing the current window being displayed(c) Eric Mertens, 2016ISCemertens@gmail.comNone@?nglircCurrently focused windowoglirc No networkpglircNetworkqglircNetwork Channel/NicktglircFilter argument for ~uglirc no filtervglirconly network windowswglirconly channel windowsxglirconly user windowsyglirc Subfocus viewzglirc Show messages{glircShow channel metadata|glircShow channel user list}glirc%Show channel mask list for given mode~glircShow client windowsglircShow current paletteglircShow all mentionsglircShow all digraphsglircShow key bindingsglirc&Show help window with optional commandglircShow GHC RTS statisticsglircShow ignored masksglirc4Return the network associated with the current focusglircUnfocused first, followed by focuses sorted by network. Within the same network the network focus comes first and then the channels are ordered by channel identifierglircnetwork nopqtuvwxyz{|}~nopqyz{|}~tuvwx2Types and operations for managing message buffers.(c) Eric Mertens, 2016ISCemertens@gmail.comNone>?Xglirc;Flag for the important of a message being added to a windowglircDon't update unread countglircIncrement unread countglirc-Increment unread count and set important flagglircA J tracks all of the messages and metadata for a particular message buffer.glirc!Messages to display, newest firstglirc1Location of line drawn to indicate newer messagesglirc'Messages added since buffer was visibleglircMessages in bufferglirc&Indicates an important event is unreadglircHide metadata messagesglircA single message to be displayed in a window. The normal message line consists of the image prefix and the image. This allows line wrapping to be applied separately to the image and prefix so that wrapped messages can fall to the right side of the prefix.glirc Summary valueglircNormal rendered image prefixglircNormal rendered imageglircDetailed rendered imageglircImportance of messageglircA window with no messagesglirc~Adds a given line to a window as the newest message. Window's unread count will be updated according to the given importance.glirc?Update the window clearing the unread count and important flag.glirc8Update the window when it first becomes active. If only boringE messages have been added since last time the marker will be hidden.glirciUpdate the window when it becomes inactive. This resets the activity marker to the bottom of the window.**3View current palette and to see all terminal colors(c) Eric Mertens, 2016ISCemertens@gmail.comNone^rglircGenerate lines used for /palettet. These lines show all the colors used in the current palette as well as the colors available for use in palettes.>/Template Haskell quasi-quoter for digraph table(c) Eric Mertens, 2017ISCemertens@gmail.comSafe`?Character mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comSafefglirc+States for the digraph lookup state machineglirc!ready to match two-character nameglirc)first character matched, ready for secondglirc(both characters matched, return the nextglircskip the next two charactersglircskip the next characterglirc[Find the entry in the digraph table give a two-character key and return the matched value.$Multiline text container with cursor(c) Eric Mertens, 2016ISCemertens@gmail.comNone{dglirc0Zipper-ish view of the multi-line content of an EditBox . Lines  the  are stored in reverse order.glircDefault  valueglirc Single line .glirc!Shifts the first line off of the =, yielding the text of the line and the rest of the content.glirclWhen at beginning of line, jump to beginning of previous line. Otherwise jump to beginning of current line.glircVWhen at end of line, jump to end of next line. Otherwise jump to end of current line.glirc0Move the cursor left, across lines if necessary.glirc1Move the cursor right, across lines if necessary.glirc3Move the cursor left to the previous word boundary.glirc0Move the cursor right to the next word boundary.glirc'Delete the character before the cursor.glirc,Delete the character after/under the cursor.glirc/Insert character at cursor, cursor is advanced.glircSmarter version of  that removes spurious newlines.glircOInsert string at cursor, cursor is advanced to the end of the inserted string.glirc)Advance to the beginning of the next lineglirc'Retreat to the end of the previous lineglircmUse the two characters preceeding the cursor as a digraph and replace them with the corresponding character.Console-mode text box(c) Eric Mertens, 2016ISCemertens@gmail.comNone: glircDefault  valueglircDSets the given string to the yank buffer unless the string is empty.glircIndicate that the contents of the text box were successfully used by the program. This clears the first line of the contents and updates the history.glircAUpdate the editbox to reflect the earlier element in the history.glirc?Update the editbox to reflect the later element in the history.glirc.Jump the cursor to the beginning of the input.glirc(Jump the cursor to the end of the input.glircLDelete all text from the cursor to the end and store it in the yank buffer.glircRDelete all text from the cursor to the beginning and store it in the yank buffer.glirc%Insert the yank buffer at the cursor.glircKKill the content from the cursor back to the previous word boundary. When yank( is set the yank buffer will be updated.glircJKill the content from the curser forward to the next word boundary. When yank' is set the yank buffer will be updatedglirc8Insert a character at the cursor and advance the cursor.glircyank glircyank ))Tab-completion logic(c) Eric Mertens, 2016ISCemertens@gmail.comNone glirc'Class for types that are isomorphic to > and which can support a total order and a prefix predicate. @A ( x) == x  (@A x) == x @B x y ==> x  y glircDCheck if the first argument is a lexicographic prefix of the second.glirc Convert to a .glirc!Word completion prefix and suffixglirc3Word completion without adding any prefix or suffix glirc>Word completion adding a ": " suffix at the beginning of lines glirc+Word completion using a "@" prefix intended glirc&Perform word completion on a text box.The leading update operation is applied to the result of tab-completion when tab completing from the beginning of the text box. This is useful when auto-completing a nick and including a trailing colon.The reversed parameter indicates that tab-completion should return the previous entry. When starting a fresh tab completion the priority completions will be considered in order before resorting to the set of possible completions.glircFind the word preceeding the cursor skipping over any characters that can be found in the prefix and suffix for the current completion mode. glircRFind the next entry in a list of possible choices using an alphabetical ordering. glircleading update operation glirc reversed glircpriority completions glircpossible completions  glircreversed glircsearch prefix glircprevious result glircposibilities       )Settings for an individual IRC connection(c) Eric Mertens, 2016ISCemertens@gmail.comNone/#glirc'Security setting for network connectionglircTLS connectionglirc+TLS connection without certificate checkingglircPlain connectionglircStatic server-level settingsglircconnection nicknamesglircconnection usernameglircconnection realname / GECOSglirc CTCP userinfoglircserver passwordglirc SASL usernameglircSASL plain passwordglircSASL ecdsa private keyglircserver hostnameglirc server portglircuse TLS to connect glircpath to client TLS certificate!glircpath to client TLS key"glirc0additional CA certificates for validating server#glircOpenSSL cipher suite$glirc.commands to execute upon successful connection%glirchostname of SOCKS proxy&glircport of SOCKS proxy'glirc"Channels with chanserv permissions(glircFlood limiter penalty (seconds))glirc!Flood limited threshold (seconds)*glircInitial message hooks+glirc+The name referencing the server in commands,glirc1The number of reconnect attempts to make on error-glirc)Connect to this network on server startup.glirc$Nick completion mode for this server/glircDirectory to save logs of chat0glircProtocol family to connect withOglircJLoad the defaults for server settings based on the environment variables.Environment variables USER,  IRCPASSSWORD, and  SASLPASSWORD are used. glirc%Specification for IP protocol family.A !"#$%&'()*+,-./03456789:;<=>?@ABCDEFGHIJKLMNOPQA !"#$%&'()*+,-./0PQ=MAN>EDC8?HJKLI5FG467:;B3<9@O#Interface to the connection package(c) Eric Mertens, 2016ISCemertens@gmail.comNoneŠRglirc Create a new  6 which will be closed when the continuation finishes.RR Event-based network IO(c) Eric Mertens, 2016ISCemertens@gmail.comNone֪ Sglirc-Exceptions used to kill connections manually.Tglircsent when ping timer expiresUglirc*sent when client commands force disconnectVglircThe sum of incoming events from a network connection. All events are annotated with a network ID matching that given when the connection was created as well as the time at which the message was recieved.Wglirc'Event for successful connection to hostXglirc/Event for a new recieved line (newline removed)Yglirc6Final message indicating the network connection failedZglirc8Final message indicating the network connection finished[glircHandle for a network connection\glirc:Identifier used to match connection events to connections.]glircSchedule a message to be transmitted on the network connection. These messages are sent unmodified. The message should contain a newline terminator.^glirc(Force the given connection to terminate._glirc9Initiate a new network connection according to the given R. All events on this connection will be added to the given queue. The resulting [^ value can be used for sending outgoing messages and for early termination of the connection._glircdelay in seconds glirc)Identifier to be used on incoming events STUVWXYZ[\]^_ [\VWXYZ_]^STU!*Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#/ .dglirc/Vertically stack all windows in a single columneglirc1Vertically stack extra windows in a second columnfglirc*Setting for how to pad the message prefix.gglirc.Whitespace add to the left side of chat prefixhglirc/Whitespace add to the right side of chat prefixiglircNo whitespace addedjglirc\Top-level client configuration information. When connecting to a server configuration from m$ is used where possible, otherwise l is used.lglircDefault connection settingsmglircHost-specific settingsnglircUser-customized color paletteoglirc(Names of windows, used when alt-jumping)pglircExtra highlight nicks/termsqglircPadding of nicks in messagesrglirccommand macrossglircpaths to shared librarytglircpaths to url opening executableuglircinitial ignore mask listvglirc(initially visibility of the activity barwglircnotify terminal on mentionxglirc+default setting for hidemeta on new windowsyglirckeyboard bindingszglircDefault layout on startup{glircvisibility of ping time|glirc!Modifier used for jumping windowsglirc0Failure cases when loading a configuration file.glirc-Error message from reading configuration fileglirc"Error message from parser or lexerglirc/Error message from loading parsed configuration glircThe default client behavior for naming windows is to use the first two rows of a QWERTY keyboard followed by the first two rows combined with SHIFT. glircUses  to find ~.glircconfigglircUses   to find ~.config glirc/configglirc_Empty configuration file used when no path is specified and the configuration file is missing.glircYAttempt to read a file using the given handler when a file does not exist. On failure a  exception is throw.glircEither read a configuration file from one of the default locations, in which case no configuration found is equivalent to an empty configuration, or from the specified file where no configuration found is an error.glirc*Load the configuration file defaulting to ~.glircconfig.glirchGenerate a human-readable explanation of an error arising from an attempt to load a configuration file.glircIResolve all the potentially relative file paths in the configuration fileglirc<The default nick padding side if padding is going to be usedglirc5Either full or abbreviated nick-padding configuration nick-padding: 10 'nick-padding: side: right width: 16glirc Full nick padding specification: &nick-padding: side: left width: 15glirc@Parse either a single modifier key or a list of modifier keys: meta, alt, ctrlglirc Parse either  one-column or  two-column and return the corresponding c value.glirckParse a single key binding. This can be an action binding, command binding, or an unbinding specification.glircYParse a single action key binding. Action bindings are a map specifying a binding using  and an action: $bind: "M-a" action: jump-to-activityglircCCustom configuration specification for emacs-style key descriptionsglircdefault instanceglirc file to read glirc!error handler for not found case glirc&just file or use default search paths glircpath to configuration file glirc defaults glircconfiguration file path 2cdefighjklmnopqrstuvwxyz{|2jklmnopqrstuvwxyz{|cdefigh"Renderer for message lines(c) Eric Mertens, 2016ISCemertens@gmail.comNoneC "glircAn identifier in a PRIVMSGglircAn identifier somewhere elseglirc%Level of detail to use when renderingglirconly render nicknamesglircrender full user infoglirc'Parameters used when rendering messagesglircrestricted message sigilsglirc sender sigilsglircnicknames to highlightglircnicknames to highlight in redglircnick color paletteglircDefault & with no sigils or nicknames specifiedglircWConstruct a message given the time the message was received and its render parameters. glirc+Render the sigils for a restricted message.!glirc Render a ,; given the sender's sigils and the nicknames to highlight."glirc Render a ,; given the sender's sigils and the nicknames to highlight.glirc Render a # as time using quiet attributes 23:15 $glirc Render a #A as full date and time user quiet attributes. Excludes the year. 07-24 23:15:10 glircOptionally add padding to an input image according to the specified mode. If the input image is already wider than the specified padding mode, the image is returned unmodified.%glircQRender the sender of a message in normal mode. This is typically something like  @nickname:&glircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.'glircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.(glircProcess list of } as individual IRC formatted words separated by a special separator to distinguish parameters from words within parameters.)glircProcess list of " as individual IRC formatted words*glircETransform string representing seconds in POSIX time to pretty format.+glircJRender string representing seconds into days, hours, minutes, and seconds.glirc*Render a nickname in its hash-based color.glircRender an a full user. In normal mode only the nickname will be rendered. If detailed mode the full user info including the username and hostname parts will be rendered. The nickname will be colored.glircGRender an identifier without using colors. This is useful for metadata.glircParse message text to construct an image. If the text has formatting control characters in it then the text will be rendered according to the formatting codes. Otherwise the nicknames in the message are highlighted.,glircGiven a list of nicknames and a chat message, this will generate an image where all of the occurrences of those nicknames are colored.glircKReturns image and identifier to be used when collapsing metadata messages.glirc:Image used when treating ignored chat messages as metadataglircARender the normal view of a chat message line padded and wrapped.glirctime of message glircmessage body glircprefix, image, full  glircsigils glirc padding mode glirc input image glirc padded image glirccolor palette glircdraw mode glircmy nicknames glircidentifier to draw glirccolor palette glircmode glircmy nicks glircuserinfo to drawglirc palette glirc my nicks glirc other nicks glircexplicit controls rendering glirc input text glirc colored text ,glirc my nicks glirc other nicks glircpalette glircdraw columns glircnick padding glircwindow line glircwrapped lines #(Line renderers for ignore mask list view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneHglirc-Render the lines used in a channel mask list.-glirc7Render a summary describing the number of ignore masks.glirc ignore masks glirc palette -glirc ignore masks glirc palette $Support for logging IRC traffic(c) Eric Mertens, 2016ISCemertens@gmail.comNoneQ<glirc:Log entry queued in client to be written by the event loopglirc"log directory from server settingsglirc localtime dayglircchannel or nicknameglircformatted log message textglirc,Write the given log entry to the filesystem.glirc Ignore all IOErrorsglirc Construct a  for the given 0< when appropriate. Only chat messages result in a log line.glirc log line glircmessage glirclog directory glirctarget  CSafeQ./012345%"Processing of command-line options(c) Eric Mertens, 2016ISCemertens@gmail.comNone^\Z glircCommand-line optionsglircconfiguration file pathglircinitial networksglircdisable autoconnectglircshow help messageglircshow version messageglirc+show version of ALL transitive dependenciesglircshow configuration file format6glircDefault values for 7glircOption descriptionsglircuLoad command line options. This action will terminate early in the case of the version flag, help flag, or an error.8glircReturns  "-SOMEHASH" when in a git repository, "" otherwise.9glircReturns "-dirty"! when in a dirty git repository, "" otherwise.  D:Compatibility layer for GHC RTS statistics across versions(c) Eric Mertens, 2017ISCemertens@gmail.comSafe^:;<&View current GHC RTS statistics(c) Eric Mertens, 2017ISCemertens@gmail.comNone`glircGenerate lines used for  /rtsstats.EStrict unit type(c) Eric Mertens, 2016ISCemertens@gmail.comSafec=glircUnit data type with a strict > and ? instances.@glircA is strictBglircC is strict, D is O(1)=EFLens utility functions(c) Eric Mertens, 2016ISCemertens@gmail.comSafej#FglircModify the target of a Gd with a function. The result is strict in the results of applying the function. Strict version of HIglirc9Set a value strictly in the set value. Strict version of J.KglircL to the M component of a #NglircL" to the 'TimeOfDay component of a M.OglircL" to the 'TimeOfDay component of a M.FIKNO'IRC network session state(c) Eric Mertens, 2016ISCemertens@gmail.comNone3glircTimer-based eventsglirc'terminate the connection due to timeoutglirctransmit a ping to the serverglirc#erase latency (when it is outdated)glircStatus of the ping timerglirc)ping sent at given time, waiting for pongglircnot waiting for a pongglirc.number of attempts, last known connection timeglircKPair of username and hostname. Empty strings represent missing information.glircusername hostnameglirc'State of the authentication transactionglircno active transactionglircPLAIN mode initiatedglircECDSA-NIST mode initiatedglirc*ECDSA-NIST user sent waiting for challengeglirc%State tracked for each IRC connectionglircnetwork connection identifierglircjoined channelsglircnetwork socketglircchannel mode meaningsglircchannel identifier prefixesglirc!state for multi-message sequencesglircmodes for the connected userglirc)modes that prefix statusmsg channel namesglirc!settings used for this connectionglirc/usermask used by the server for this connectionglirc!user and hostname for other nicksglirc%maximum mode changes per MODE commandglircname of network connectionglirc2names of message hooks to apply to this connectionglirctime for next ping eventglirc%latency calculated from previous pongglircstate of ping timerglirctime of last message receivedglirc Transmit a ; on the connection associated with the given network. For PRIVMSG and NOTICEF overlong commands are detected and transmitted as multiple messages.glircqConstruct a new network state using the given settings and default values as specified by the IRC specification.PglircUsed for updates to a  that require no reply. noReply x = ([], x)Qglirc Restrict A to only users are in a channel that the client is connected to.Rglirc001 S is the first message received when transitioning from the initial handshake to a connected state. At this point we know what nickname the server is using for our connection, and we can start scheduling PINGs.TglircHandle U errors when connecting.Vglirc'Add an entry to a mode list transactionWglircKSave a completed ban, quiet, invex, or exempt list into the channel state.Xglirc[These replies are interpreted by the client and should only be shown in the detailed view.glircReturn  for messages that should be hidden outside of full detail view. These messages are interpreted by the client so the user shouldn't need to see them directly to get the relevant information.glirc>Predicate to test if the connection has op in a given channel.YglircProcess a list of WHO repliesglirc:Compute the earliest timed action for a connection, if anyZglircCompute the timed action for forgetting the ping latency. The client will wait for a multiple of the current latency for the next pong response in order to reduce jitter in the rendered latency when everything is fine.[glirc9Compute the next action needed for the client ping logic.glircApply the given  to a connection state.glircUsed to send commands that require ops to perform. If this channel is one that the user has chanserv access and ops are needed then ops are requested and the commands are queued, otherwise send them directly. glircunique network ID glircnetwork name glircserver settings glircactive network connection glircinitial ping status glircnew network state Rglircmessage received glircmy nickname Tglirc bad nickname glircreplies, updated state Vglircmask glircset by glirc set time Wglircmode glircchannel \glirctime of message glircsender glircchannel glircmode flags glircmode parameters ]glirc  "key=value"glircchannel glirccommands glircnetwork state glircchannel glircnetwork state glircchanserv available glircchannel glirctopic glircnetwork state K     K     (/Primary client state type and update operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone XglircState of the extension API including loaded extensions and the mechanism used to support reentry into the Haskell runtime from the C API.^glircactive extensions_glirc` used to with [aglircb used with [ glirc(All state information for the IRC client"glircclient message buffers#glircpreviously focused buffer$glirc"focus prior to jumping to activity%glirccurrently focused buffer&glirccurrent view mode'glircextra messages windows to view(glircstate of active connections)glircincoming network event queue*glircnetwork name to connection ID+glircclient configuration,glircclient configuration file path-glircprimary text box.glirc"size to crop from left of text box/glirccurrent terminal width0glirccurrent terminal height1glircbuffer scroll lines2glircuse detailed rendering mode3glircvisible activity bar4glircvisible ping time5glircoptional persistent filter6glirclayout mode for split screen7glircsound a bell next draw8glirc ignored masks9glirc,precomputed ignore regular expression (lazy):glircstate of loaded extensions;glirclog lines ready to write<glirctransient error box text=glircmost recent GHC RTS statscglircSelection function used in d[glirc=Prepare the client to support reentry from the extension API.\glirce for finding the I associated with a given network if that connection is currently active.]glirc-The full top-most line that would be executed^glirc*The line under the cursor in the edit box._glircConstruct an initial   using default values.`glircTForcefully terminate the connection currently associated with a given network name.aglirc;Add a message to the window associated with a given channelfglirc5Extract the status mode sigils from a message target.gglircbCompute the importance of a message to be used when computing change notifications in the client.hglircTPredicate for messages that should be ignored based on the configurable ignore listbglircCPredicate for nicknames to determine if messages should be ignored.cglircARecord a message in the windows corresponding to the given targetiglirc2Compute the sigils of the user who sent a message.jglirc&Compute sigils for a user on a channelkglircDetect error messages and add the message text to the transient error display. The transient message will not be generated if the user is focused on the window where the message is going to be rendered, anyway.dglirc$Record a message on a network windowlglircFRecord window line at the given focus creating the window if necessarymglircn& but with mostly defaulted parameters.eglirc2Function applied to the client state every redraw.oglircAMark the messages on the current window (and any splits) as seen.fglirc@Add the textbox input to the edit history and clear the textbox.gglircCReturns the current network's channels and current channel's users.hglirc Returns the % associated with the current network.jglirc9Returns the current filtering predicate if one is active.kglircStrict version of jlglircFConstruct a text matching predicate used to filter the message window.mglirc;Compute the command and arguments currently in the textbox.nglirc=Regular expression for matching HTTP/HTTPS URLs in chat text.oglircFind all the URL matches using n in a given ) suitable for being opened. Surrounding < and > are removed.pglircRemove a network connection and unlink it from the network map. This operation assumes that the network connection exists and should only be applied once per connection.qglirc<Start a new connection. The delay is used for reconnections.pglirc6Find the first unused key in the intmap starting at 0.qglircWhen a nick change happens and there is an open query window for that nick and there isn't an open query window for the new nick, rename the window.sglirc*Actions to be run when exiting the client.rglircUnload all active extensions.tglirc9Start extensions after ensuring existing ones are stoppeduglirc0Scroll the current buffer to show newer messagesvglirc1List of extra focuses to display as split windowswglircJump the focus of the client to a buffer that has unread activity. Some events like errors or chat messages mentioning keywords are considered important and will be jumped to first.xglircBJump the focus directly to a window based on its zero-based index.yglircChange the window focus to the given value, reset the subfocus to message view, reset the scroll, remember the previous focus if it changed.zglirciUnified logic for assigning to the extra focuses field that activates and deactivates windows as needed.{glircNChange the subfocus to the given value, preserve the focus, reset the scroll.|glirc$Return to previously focused window.}glircVStep focus to the next window when on message view. Otherwise switch to message view.~glircZStep focus to the previous window when on message view. Otherwise switch to message view.glircVStep focus to the next window when on message view. Otherwise switch to message view.dglircStep focus to the next window when on message view. Otherwise switch to message view. Reverse the step order when argument is .glircbCompute the set of extra identifiers that should be highlighted given a particular network state.glirc\Compute the set of extra identifiers that should be highlighted given a particular network.glirc;Produce the list of window names configured for the client.glirc;Produce the list of window names configured for the client.glirc@Returns the list of network names that requested autoconnection.glirc Toggle the  hide metadata setting for the focused window.cglircwindows before current window glircwindows after current window glircwindow to focus [glirc4client state glirc4continuation using the stable pointer to the client \glircnetwork ^glircline number, line content `glircnetwork aglircnetwork glircchannel sglirc message glirc target glirc client state fglircpossible modes glirctarget glircactual modes, actual target bglirc target user glirc client state glirc is ignored cglircnetwork iglircnetwork glircchannel glircsigils jglircnetwork glircchannel glircuser glircsigils tglircnetwork glirc channels iglircnetwork glircchannel glircnicks jglircclient state glircoptional predicate kglircclient state glircoptional predicate mglirc!client state glirc!command name and argument string qglircattempts glircoptional disconnect time glircnetwork name rglirctimestamp glircmessage received glircmessage network glircnetwork connection state glircclient state glircresponse , updated state qglircnetwork xglirczero-based window index yglirc new focus glirc client state {glirc new subfocus glirc client state dglircselection function glircclient state glircnetwork state glircclient state glircextra highlight identifiers glircnetwork glircclient state glircextra highlight identifiers g !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~g !"#$%&'()*+,-./0123456789:;<=YVWCXJFIPHASD>TUOLK\@GQN?EMRB_ts[jklifgb]^`qpermvhadcy{|}~wxzuZno) View of the list of open windows(c) Eric Mertens, 2016ISCemertens@gmail.comNone&Gglirc)Draw the image lines associated with the /windows command.*)Line renderers for channel user list view(c) Eric Mertens, 2016ISCemertens@gmail.comNone.glircRender the lines used by the /users command in normal mode. These lines show the count of users having each channel mode in addition to the nicknames of the users.glircRender lines for the /usersu command in detailed view. Each user will be rendered on a separate line with username and host visible when known.glircnetwork glircchannel glircnetwork glircchannel +URL selection module(c) Eric Mertens, 2016ISCemertens@gmail.comNone7glirc1Generate the lines used for the view when typing /urluglircRender one line of the url listglircrender width glircwindow to search glircargument to command glircclient state glircimage lines uglircrendered width glircmy nick glircpalette glircnick render padding glircselected index glircurl index glircsender and url text glircrendered lines ,Chat message view(c) Eric Mertens, 2016ISCemertens@gmail.comNone@0vglirc-Classify window lines for metadata coalesencewglirc current nick glirc metadata glirc palette xglircclient state glircdraw width glirchide metadata glircwindow lines glircimage lines yglircmetadata image glircpossible nick transition zglircimage accumulator glircpossible nick transition {glircmetadata entries are reversedvglirc;Image, incoming identifier, outgoing identifier if changed -)Line renderers for channel mask list view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneCglirc,Render the lines used in a channel mask listglirc Mask mode glirc network glirc channel glirc draw width .List of the current key map(c) Eric Mertens, 2017ISCemertens@gmail.comNoneG(glircHRender the lines of a table showing all of the available digraph entriesglirc client state glirc output lines /Character mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comNoneKglircHRender the lines of a table showing all of the available digraph entriesglirc draw width glirc client state glirc output lines |glirc3-character entry 0Channel information renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNoneMglirc,Render the lines used in a channel mask listglircnetwork glircchannel 1Renderer for status line(c) Eric Mertens, 2016ISCemertens@gmail.comNonef glirc9Renders the status line between messages and the textbox.glirc1The minor status line is used when rendering the /splits and  /mentions* views to show the associated window name.}glircGIndicate when the client is scrolling and old messages are being shown.~glircYIndicate when the client is potentially showing a subset of the available chat messages.glircIndicate the current connection health. This will either indicate that the connection is being established or that a ping has been sent or long the previous ping round-trip was.glircTWrap some text in parentheses to make it suitable for inclusion in the status line.glirc#Indicate that the client is in the detailed view.glirc=Indicate that the client isn't showing the metadata lines in normal view.glirc.Image for little box with active window names: -[15p]glirc-Multi-line activity information enabled by F3glirc+Pack a list of images into a single image spanning possibly many lines. The images will stack upward with the first element of the list being in the bottom left corner of the image. Each line will have at least one of the component images in it, which might truncate that image in extreme cases.glirc draw width glirc client state glirc status bar glirc  error-messageglirc %[error: error-message]glircwindow name glircdraw width glircshow hidemeta status glirc client state glircwindow width glirccomponents to pack 2 Mentions view(c) Eric Mertens, 2016ISCemertens@gmail.comNonetglircmessage timestamp for sortingglircwindow names shortcutglircassociated windowglircwrapped rendered linesglircGenerate the list of message lines marked important ordered by time. Each run of lines from the same channel will be grouped together. Messages are headed by their window, network, and channel.glircDInsert channel name markers between messages from different channelsglirc]Merge a list of sorted lists of mention lines into a single sorted list in descending order.glirc"draw width glirc"client state glirc"list of mentions in time order glirc"mention images and channel labels glircpalette glircdraw columns glircnick padding glircdetailed view glircwindow name glircwindow focus glircwindow 3 Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNoneCVLglircuA command section is a logical grouping of commands. This allows for showing more structure in the help menu system.glircA command is a list of aliases, an argument specification, implementation, and documentation. The arguments and implementation must match so that the parsed arguments will match what the implementation expects.glirc>Names of this command, first in the list is the "primary" nameglirc-Specification of the arguments of the commandglirc5Multi-line IRC-formatted documentation text used for /helpglircCImplementation of the command for both execution and tab completionglircPair of implementations for executing a command and tab completing one. The tab-completion logic is extended with a bool indicating that tab completion should be reversedglircno requirementsglircrequires an active networkglircrequires an active chat windowglirc!requires an active channel windowglirc=Type of commands that require an active channel to be focusedglirc=Type of commands that require an active network to be focusedglirc!Type of commands that always workglirc%Possible results of running a commandglircDContinue running the client, consume input if command was from inputglirc,Continue running the client, report an errorglircClient should closeglirc8Consider the text entry successful and resume the clientglirc7Consider the text entry a failure and resume the clientglirc>Command failure with an error message printed to client windowglirc5Interpret the given chat message or command. Leading /d indicates a command. Otherwise if a channel or user query is focused a chat message will be sent.glirc?Execute command provided by user, resolve aliases if necessary.The last disconnection time is stored in text form and is available for substitutions in macros. It is only provided when running startup commands during a reconnect event.glirc?Compute the replacement value for the given expansion variable.glircRespond to the TAB key being pressed. This can dispatch to a command specific completion mode when relevant. Otherwise this will complete input based on the users of the channel related to the current buffer.glirc;Treat the current text input as a chat message and send it.glircParse and execute the given command. When the first argument is Nothing the command is executed, otherwise the first argument is the cursor position for tab-completionglirc@Expands each alias to have its own copy of the command callbacksglirciMap of built-in client commands to their implementations, tab completion logic, and argument structures.glirc+Raw list of commands in the order used for /helpglirc.Provides no tab completion for client commandsglirc/Provides no tab completion for network commandsglirc/Provides no tab completion for channel commandsglirc:Provides nickname based tab completion for client commandsglirc;Provides nickname based tab completion for network commandsglirc;Provides nickname based tab completion for channel commandsglircImplementation of /exit command.glircWhen used on a channel that the user is currently joined to this command will clear the messages but preserve the window. When used on a window that the user is not joined to this command will delete the window.glircImplementation of /quoteJ. Parses arguments as a raw IRC command and sends to the current network.glircImplementation of /meglircImplementation of /ctcpglircImplementation of /noticeglircImplementation of /msgglircCommon logic for /msg and /noticeglircCommon logic for /msg and /notice returning the client stateglircImplementation of /windows" command. Set subfocus to Windows.glircImplementation of  /mentions# command. Set subfocus to Mentions.glircImplementation of /palette" command. Set subfocus to Palette.glircImplementation of  /digraphs# command. Set subfocus to Digraphs.glircImplementation of /keymap! command. Set subfocus to Keymap.glircImplementation of  /rtsstatsM command. Set subfocus to RtsStats. Update cached rts stats in client state.glircImplementation of /help command. Set subfocus to Help.glircTab completion for  /splits[+]. When given no arguments this populates the current list of splits, otherwise it tab completes all of the currently available windows.glircTab completion for /splits-J. This completes only from the list of active entries in the splits list.glirc3Parses a single focus name given a default network./The default is parameterized over an arbitrary 7 instance so that if you know the network you can use $ and if you might not, you can use glirc6Render a entry from splits back to the textual format.glircImplementation of /splitsglircImplementation of /splits+B. When no focuses are provided the current focus is used instead.glircImplementation of /splits-B. When no focuses are provided the current focus is used instead.glirc/connect! tab completes known server namesglirc\When tab completing the first parameter of the focus command the current networks are used.glircyThis command is equivalent to chatting without a command. The primary use at the moment is to be able to send a leading / to chat easily.glirc/query` command. Takes a channel or nickname and switches focus to that target on the current network.glirc/channel` command. Takes a channel or nickname and switches focus to that target on the current network.glircTab completion for /channel,. Tab completion uses pre-existing windows.glircSReturn the list of identifiers for open channel windows on the given network name.glircReconnect to the currently focused network. It's possible that we're not currently connected to a network, so this is implemented as a client command.glircsComplete the nickname at the current cursor position using the userlist for the currently focused channel (if any)glircImplementation of /reload(Attempt to reload the configuration fileglircSSupport file name tab completion when providing an alternative configuration file.NOT IMPLEMENTEDglircwThis function computes the list of required and optional parameters corresponding to the flags that have been entered.glircIUse the *!*@host masks of users for channel lists when setting list modes.Use the channel's mask list for removing modesUse the nick list otherwiseglirc=Predicate for mode commands that can be performed without opsglircsComplete the nickname at the current cursor position using the userlist for the currently focused channel (if any)glircImplementation of /exec command.glircImplementation of /grep and /grepiglircfocused channel glirccurrent network glirc arguments glircchat or command glircclient state glirccommand result glircdisconnection time glirccommand glircclient state glirccommand result glircdisconnect time glircclient state glircexpansion variable glircexpansion value glircreversed glircclient state glirccommand result glircchat message glircclient state glirccommand result glirctab-completion direction glirccommand glircclient state glirccommand result glirctarget glirctarget glircdefault network glirc [network:]targetglircword completion mode glirchints glircall completions glircreversed order glircclient state glirc reversed glircreversed order glircnetwork glircclient state glircopen channel windows glirc reversed glirc reversed glirc&network's mode behaviors glirc&polarity mode-letter unused-parameter glirc&required-names optional-names glirc&required-names optional-names glircmode polarity glircmode glircchannel glirc(hint, complete) glirc reversed glirccase sensitive 4Renderer for help lines(c) Eric Mertens, 2016ISCemertens@gmail.comNoneeglircGenerate either the list of all commands and their arguments, or when given a command name generate the detailed help text for that command.glircAGenerate detailed help lines for the command with the given name.glirc]Generate an explanation of the context where the given command implementation will be valid.glirc<Generate the lines for the help window showing all commands.glircdGenerate the help line for the given command and its specification for use in the list of commands.glircclient state glircoptional command name glircpalette glirchelp lines glirc client state glirc command name glirc palette glirc lines glirccommand implementation glirchelp line glircclient state glircpalette glirchelp lines glircclient state glircpalette glirccommand section glirchelp lines glircclient state glircpalette glirccommand name and aliases glircargument specification glircsummary help line 5View selection module(c) Eric Mertens, 2016ISCemertens@gmail.comNone6Textbox renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNoneSglircCompute the UI image for the text input box. This computes the logical cursor position on the screen to compensate for VTY's cursor placement behavior.glirc5Renders the whole, uncropped text box as well as the  corresponding to the rendered image which can be used for computing the logical cursor position of the cropped version of the text box.glirc Version of wcwidth7 that accounts for how control characters are renderedglirc Version of wcswidth7 that accounts for how control characters are renderedglirc}Render the active text box line using command highlighting and placeholders, and WYSIWYG mIRC formatting control characters.glirc cursor column, new offset, imageglirc&client state glirc&my nicknames glirc&other nicknames glirc&macro completions glirc&palette glirc&content glirc&plain text rendering, image rendering glirc commands glirc focused glirc input text glirc output image 7'Layout code for the multi-window splits(c) Eric Mertens, 2016ISCemertens@gmail.comNone7uglirc?Compute the combined image for all the visible message windows.glirc4Layout algorithm for all windows in a single column.glirc4Layout algorithm for all windows in a single column.glirc#Draw one of the extra windows from /splitsglircGenerate an image corresponding to the image lines of the given focus and subfocus. Returns the number of lines overscrolled to assist in clamping scroll to the lines available in the window.glircConstructs a list of numbers with the length of the divisor and that sums to the dividend. Each element will be within one of the quotient.glirc@Compute the number of lines in a page at the current window size glirc1client state glirc1overscroll, cursor pos, next offset, final image glircclient state glircextra window names glircoverscroll and final image glirc,client state glirc,extra window names glirc,overscroll, cursor pos, offset, final image glircdraw width glircdraw height glircscroll amount glircclient state glircclient state glircdraw width glircdraw height glircfocus glircimage lines glircrendered window glircclient width glircavailable rows glirccurrent scroll glircfocused window glircoverscroll, rendered messages glirc"screen rows to fill glirc"number of extra windows glirc"list of heights for each division glirc dividend glirc divisor glircclient state glircscroll amount 8 UI renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNone?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghhijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./@BA00123456789:;<<=>??@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|} ~               !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!""""""""""""""""""""""""""#$$$$$$$$$%%%%%%%%%%%%%&''''''''''''''''''''''''' ' ' ' ' ''''''''''''''''''' '!'"'#'$'%'&'''(')'*'+','-'.'/'0'1'2'3'4'5'6'7'8'9':';'<'='>'?'@'A'B'C(D(E(E(F(G(H(I(J(K(L(M(N(O(P(Q(R(S(T(U(V(W(X(Y(Z([(\(](^(_(`(a(b(c(d(e(f(g(h(i(j(k(l(m(n(o(p(q(r(s(t(u(v(w(x(y(z({(|(}(~((((((((((((((((((((((((((((((((((((((((((()**+,-./0112333333333333333333333333345677899::::::::::::::::::::::::::::::;    =        !"#$%&'(>)?*?+?,?-?.?/?0?123456789:;<=>?!@!ABCDBCEBCF!G!H!I!J!K!L!M!N!O!P!Q!R!S!T!U"V"W"XYZ["\"]"^"_"`"a"b"c"d#eCfCgChCiCjCkClCm%n%o%p%qDrDsDtEE u vEw xEy z {EEF|}~}F}F}~YFF''''''''''''(((((}~(((((((((((((((+,,,,,,/111111111122222223333333333333333333333333333333333  3333333333333333333333344444 6 6 6 6 777777789999999999 9!9"9#9$9%9&9'9(9)9*9+9,9-9.:/:0:12!glirc-2.27-Lp1dFRps0FwFOqYj2jKk6cClient.Authentication.EcdsaClient.CApi.Types Client.CApiClient.Commands.Arguments.Spec Client.Commands.Arguments.ParserClient.Commands.ExecClient.Commands.InterpolationClient.Commands.RecognizerClient.Configuration.ColorsClient.Configuration.MacrosClient.EventLoop.ActionsClient.EventLoop.Errors Client.HookClient.Hook.Znc.Buffextras Client.HooksClient.Image.PackedImageClient.Image.MircFormattingClient.Image.LineWrapClient.Image.Palette"Client.Commands.Arguments.Renderer Client.MaskClient.MessageClient.State.ChannelClient.State.FocusClient.State.WindowClient.View.PaletteClient.State.EditBox.ContentClient.State.EditBoxClient.Commands.WordCompletion#Client.Configuration.ServerSettingsClient.Network.ConnectClient.Network.AsyncClient.ConfigurationClient.Image.MessageClient.View.IgnoreList Client.LogClient.OptionsClient.View.RtsStatsClient.State.Network Client.StateClient.View.WindowsClient.View.UserListClient.View.UrlSelectionClient.View.MessagesClient.View.MaskListClient.View.KeyMapClient.View.DigraphsClient.View.ChannelInfoClient.Image.StatusLineClient.View.MentionsClient.CommandsClient.View.Help Client.ViewClient.Image.TextboxClient.Image.Layout Client.ImageClient.EventLoopClient.CApi.Exports Build_glircDataText DigraphQuoteDigraphsPrefixtoStringisPrefix Paths_glircRtsStats StrictUnit LensUtilsauthenticationModeencodeUsernamecomputeResponse FgnStringLenFgnCmd fcCommandFgnChat fhNetworkfhTarget fhMessageFgnMsg fmNetwork fmPrefixNick fmPrefixUser fmPrefixHost fmCommandfmParamsfmParamN fmTagKeys fmTagValsfmTagN FgnExtensionfgnStartfgnStop fgnMessagefgnChat fgnCommandfgnNamefgnMajorVersionfgnMinorVersionDynamicProcessCommandProcessMessage StopExtensionStartExtension MessageResult MessageCoderunProcessChatrunProcessCommandrunProcessMessagerunStopExtensionrunStartExtension normalMessage errorMessage passMessage dropMessagepoke' exportText withText0$fStorableFgnStringLen$fStorableFgnCmd$fStorableFgnChat$fStorableFgnMsg$fStorableFgnExtension$fEqMessageCode$fEqMessageResultActiveExtensionaeFgnaeDL aeSessionaeNameaeMajorVersionaeMinorVersionextensionSymbolactivateExtensiondeactivateExtensionnotifyExtensions chatExtensioncommandExtension$fFunctorNestedIO$fApplicativeNestedIO$fMonadNestedIO$fMonadIONestedIOArgArgumentOptional Extension ArgumentShape TokenArgumentRemainingArgumentArgs remainingArg optionalArg extensionArg simpleToken numberArg tokenListparseTarget UnspecifiedCurrent SpecifiedExecCmd_execOutputNetwork_execOutputChannel _execCommand _execStdIn_execArguments $fShowTarget $fReadTarget $fEqTarget $fOrdTarget$fFunctorTarget $fReadExecCmd $fShowExecCmdexecOutputChannelexecOutputNetwork parseExecCmd runExecCmd MacroSpecMacro macroSpec macroCommandsExpansionChunk LiteralChunk VariableChunk IntegerChunk DefaultChunknoMacroArgumentsparseMacroSpecsparseExpansionresolveMacroExpansions$fShowMacroSpec$fShowExpansionChunk $fShowMacro RecognitionExactInvalid Recognizer recognize fromCommands addCommandkeys$fSemigroupRecognizer$fMonoidRecognizer$fShowRecognizer$fFunctorRecognizer$fShowRecognition$fFunctorRecognitionattrSpec colorSpec macroMapSpecmacroCommandSpecKeyMapAction ActBackspace ActDeleteActLeftActRightActHomeActEnd ActOlderLine ActNewerLine ActScrollUp ActScrollDown ActBackWordActForwardWordActYank ActKillHome ActKillEndActKillWordBackActKillWordForward ActToggleActBoldActColor ActItalic ActUnderlineActReverseVideoActClearFormatActInsertEnter ActDigraphActRetreatFocusActAdvanceFocusActAdvanceNetworkActJumpToActivityActJumpPreviousActJumpActTabCompleteActTabCompleteBackActEnterActReset ActRefresh ActCommand ActInsert ActIgnored keyMapEntries actionName keyToAction addKeyBindingremoveKeyBinding initialKeyMapparseKeyprettyModifierKey $fSpecAction $fEqAction $fOrdAction $fReadAction $fShowAction $fShowKeyMapexceptionToLines MessageHook_messageHookName_messageHookStateful_messageHookAction PassMessage OmitMessage RemapMessage$fMonoidMessageResult$fSemigroupMessageResultmessageHookActionmessageHookNamemessageHookStatefulapplyMessageHooksbuffextrasHook messageHooksImage' unpackImagetext'charstring splitImage imageWidth imageText resizeImage$fIsStringImage'$fSemigroupImage'$fMonoidImage' $fShowImage' parseIrcText parseIrcText' mircColor controlImage plainText terminate fullLineWraplineWrapPrefixlineWrapPalette _palNicks_palSelf_palSelfHighlight_palTime_palMeta _palSigil _palLabel _palLatency_palWindowName _palError _palTextBox _palActivity _palMention _palCommand_palCommandReady_palCommandPrefix_palCommandError_palCommandPlaceholder_palWindowDivider_palLineMarker $fShowPalette palActivity palCommandpalCommandErrorpalCommandPlaceholderpalCommandPrefixpalCommandReadypalErrorpalLabel palLatency palLineMarker palMentionpalMetapalNickspalSelfpalSelfHighlightpalSigil palTextBoxpalTimepalWindowDivider palWindowNamedefaultPalette paletteMaprenderMask buildMask matchMask MessageBodyIrcBody ErrorBody NormalBody ClientMessage _msgNetwork_msgBody_msgTime_IrcBody _ErrorBody _NormalBody IrcSummary JoinSummary QuitSummary PartSummary NickSummary ReplySummary ChatSummary CtcpSummary NoSummarymsgBody msgNetworkmsgTimemsgText msgSummary$fEqIrcSummary$fShowIrcSummary MaskListEntry_maskListSetter _maskListTimeTopicProvenance _topicAuthor _topicTime ChannelState _chanTopic_chanTopicProvenance_chanUrl _chanUsers _chanModes _chanLists _chanCreation_chanQueuedModeration$fShowTopicProvenance$fShowMaskListEntry$fShowChannelState chanCreation chanLists chanModeschanQueuedModeration chanTopicchanTopicProvenancechanUrl chanUsers topicAuthor topicTimemaskListSetter maskListTime newChannel joinChannel partChannel nickChangesetTopicFocus Unfocused NetworkFocus ChannelFocus $fEqFocus $fShowFocus WindowsFilter AllWindowsNetworkWindowsChannelWindows UserWindowsSubfocus FocusMessages FocusInfo FocusUsers FocusMasks FocusWindows FocusPalette FocusMentions FocusDigraphs FocusKeyMap FocusHelp FocusRtsStatsFocusIgnoreList _Unfocused _NetworkFocus _ChannelFocus focusNetwork $fOrdFocus$fEqWindowsFilter$fShowWindowsFilter $fEqSubfocus$fShowSubfocusWindowLineImportanceWLBoringWLNormal WLImportantWindow _winMessages _winMarker _winUnread _winTotal _winMention _winHideMeta PackedTime WindowLine _wlSummary _wlPrefix_wlImage _wlFullImage _wlImportance _wlTimestamp$fEqActivityLevel$fOrdActivityLevel$fReadActivityLevel$fShowActivityLevel$fEqWindowLineImportance$fOrdWindowLineImportance$fShowWindowLineImportance$fReadWindowLineImportance winHideMeta winMarker winMention winMessageswinTotal winUnread wlFullImagewlImage wlImportancewlPrefix wlSummary wlTimestampwlText emptyWindow addToWindow windowSeenwindowActivatewindowDeactivate packZonedTimeunpackTimeOfDay unpackUTCTime0$fEachWindowLinesWindowLinesWindowLineWindowLinepaletteViewLinesLine_pos_text $fReadLine $fShowLineContentHasLinelinepostextendLine $fHasLineLine $fReadContent $fShowContentabovebelow noContent singleLineshiftjumpLeft jumpRightleftrightleftWord rightWord backspacedelete insertCharinsertPastedString insertStringtoggledigraph$fHasLineContent LastOperation TabOperation KillOperationOtherOperationEditBox$fReadLastOperation$fShowLastOperation $fReadEditBox $fShowEditBoxcontent lastOperationdefaultEditBoxsuccessearlierlaterhomeendkillEndkillHomeyankkillWordBackwardkillWordForwardinsert insertPaste insertDigraph$fHasLineEditBoxWordCompletionModewcmStartPrefixwcmStartSuffixwcmMiddlePrefixwcmMiddleSuffixplainWordCompleteModedefaultNickWordCompleteModeslackNickWordCompleteMode wordComplete $fPrefixText$fPrefixIdentifier$fShowWordCompletionModeUseTlsUseInsecureTls UseInsecureServerSettings_ssNicks_ssUser_ssReal _ssUserInfo _ssPassword_ssSaslUsername_ssSaslPassword_ssSaslEcdsaFile _ssHostName_ssPort_ssTls_ssTlsClientCert_ssTlsClientKey_ssTlsServerCert _ssTlsCiphers_ssConnectCmds _ssSocksHost _ssSocksPort_ssChanservChannels_ssFloodPenalty_ssFloodThreshold_ssMessageHooks_ssName_ssReconnectAttempts_ssAutoconnect_ssNickCompletion _ssLogDir_ssProtocolFamily $fShowUseTls$fShowServerSettings ssAutoconnectssChanservChannels ssConnectCmdsssFloodPenaltyssFloodThreshold ssHostNamessLogDirssMessageHooksssNamessNickCompletionssNicks ssPasswordssPortssProtocolFamilyssRealssReconnectAttemptsssSaslEcdsaFilessSaslPasswordssSaslUsername ssSocksHost ssSocksPortssTls ssTlsCiphersssTlsClientCertssTlsClientKeyssTlsServerCertssUser ssUserInfoloadDefaultServerSettings serverSpecidentifierSpecwithConnectionTerminationReason PingTimeoutForcedDisconnect NetworkEvent NetworkOpen NetworkLine NetworkError NetworkCloseNetworkConnection NetworkIdsendabortConnectioncreateConnection$fShowNetworkConnection$fExceptionTerminationReason$fShowTerminationReason LayoutMode OneColumn TwoColumn PaddingMode LeftPadding RightPadding NoPadding Configuration_configDefaults_configServers_configPalette_configWindowNames_configExtraHighlights_configNickPadding _configMacros_configExtensions_configUrlOpener_configIgnores_configActivityBar_configBellOnMention_configHideMeta _configKeyMap _configLayout_configShowPing_configJumpModifier$fShowPaddingMode$fShowLayoutMode$fShowConfigurationConfigurationFailureConfigurationReadFailedConfigurationParseFailedConfigurationMalformedconfigActivityBarconfigBellOnMentionconfigDefaultsconfigExtensionsconfigExtraHighlightsconfigHideMeta configIgnoresconfigJumpModifier configKeyMap configLayout configMacrosconfigNickPadding configPalette configServersconfigShowPingconfigUrlOpenerconfigWindowNamesgetNewConfigPathloadConfigurationconfigurationSpec$fExceptionConfigurationFailure$fShowConfigurationFailureIdentifierColorModePrivmsgIdentifierNormalIdentifier RenderMode NormalRenderDetailedRenderMessageRendererParams rendStatusMsgrendUserSigils rendNicks rendMyNicks rendPalettedefaultRenderParamsmsgImage cleanChar cleanText timeImagenickPadcoloredIdentifiercoloredUserInfoquietIdentifierparseIrcTextWithNicks metadataImg ignoreImagedrawWindowLineignoreListLinesLogLine logBaseDirlogDay logTargetlogLine writeLogLineignoreProblems renderLogLineOptions_optConfigFile_optInitialNetworks _optNoConnect _optShowHelp_optShowVersion_optShowFullVersion_optShowConfigFormat optConfigFileoptInitialNetworks optNoConnect getOptions rtsStatsLines Transaction NoTransactionNamesTransactionBanTransactionWhoTransaction TimedActionTimedDisconnect TimedSendPingTimedForgetLatency PingStatusPingSentPingNonePingConnecting UserAndHostAuthenticateStateAS_NoneAS_PlainStartedAS_EcdsaStartedAS_EcdsaWaitChallenge NetworkState _csNetworkId _csChannels _csSocket _csModeTypes_csChannelTypes_csTransaction_csModes _csStatusMsg _csSettings _csUserInfo_csUsers _csModeCount _csNetwork_csMessageHooks_csAuthenticationState_csNextPingTime _csLatency _csPingStatus_csLastReceived$fShowAuthenticateState$fShowUserAndHost$fShowPingStatus$fEqTimedAction$fOrdTimedAction$fShowTimedAction$fShowTransaction$fShowNetworkStatecsAuthenticationStatecsChannelTypes csChannelscsLastReceived csLatencycsMessageHooks csModeCount csModeTypescsModes csNetwork csNetworkIdcsNextPingTime csPingStatus csSettingscsSocket csStatusMsg csTransaction csUserInfocsUsers_PingConnectingcsNicksendMsgnewNetworkState applyMessage squelchIrcMsgiHaveOpinitialMessagesisChannelIdentifiercsUsernextTimedActionapplyTimedActionsendModeration useChanServ sendTopicExtensionState ClientState_clientWindows_clientPrevFocus_clientActivityReturn _clientFocus_clientSubfocus_clientExtraFocus_clientConnections _clientEvents_clientNetworkMap _clientConfig_clientConfigPath_clientTextBox_clientTextBoxOffset _clientWidth _clientHeight _clientScroll_clientDetailView_clientActivityBar_clientShowPing _clientRegex _clientLayout _clientBell_clientIgnores_clientIgnoreMask_clientExtensions_clientLogQueue_clientErrorMsg_clientRtsStatsclientActivityBarclientActivityReturn clientBell clientConfigclientConfigPathclientConnectionsclientDetailViewclientErrorMsg clientEventsclientExtensionsclientExtraFocus clientFocus clientHeightclientIgnoreMask clientIgnores clientLayoutclientLogQueueclientNetworkMapclientPrevFocus clientRegexclientRtsStats clientScrollclientShowPingclientSubfocus clientTextBoxclientTextBoxOffset clientWidth clientWindowsesActive clientParkclientConnectionclientFirstLine clientLinewithClientState abortNetworkrecordChannelMessage identIgnoredrecordIrcMessagerecordNetworkMessage clientTick consumeInputcurrentCompletionListcurrentNickCompletionModechannelUserList clientMatcherclientMatcher'clientActiveRegexclientActiveCommand urlPattern urlMatches removeNetwork addConnectionapplyMessageToClientStateclientShutdownclientStartExtensions scrollClientclientExtraFocusesjumpToActivity jumpFocus changeFocus setExtraFocuschangeSubfocus returnFocus advanceFocus retreatFocusadvanceNetworkFocusclientHighlightsclientHighlightsNetworkclientWindowNames clientPaletteclientAutoconnectsclientToggleHideMeta windowsImagesuserListImagesuserInfoImagesurlSelectionViewchatMessageImagesmaskListImages keyMapLines digraphLineschannelInfoImagesstatusLineImageminorStatusLineImagementionsViewLinesCommandSectioncmdSectionNamecmdSectionCmdsCommandcmdNamescmdArgumentSpeccmdDocumentationcmdImplementation CommandImpl ClientCommandNetworkCommand ChatCommandChannelCommand CommandResultCommandSuccessCommandFailure CommandQuitexecuteexecuteUserCommandcommandExpansion tabCompletioncommands commandsListhelpImageLines viewLines textboxImage drawLayout scrollAmount clientPicture eventLoopupdateTerminalSizeGlirc_is_logged_onGlirc_is_channelGlirc_current_focusGlirc_free_stringsGlirc_free_stringGlirc_clear_windowGlirc_mark_seen Glirc_my_nickGlirc_list_channel_usersGlirc_list_channelsGlirc_identifier_cmpGlirc_list_networksGlirc_inject_chat Glirc_printGlirc_send_messageglirc_send_message glirc_printglirc_inject_chatglirc_list_networksglirc_identifier_cmpglirc_list_channelsglirc_list_channel_users glirc_my_nickglirc_mark_seenglirc_clear_windowglirc_free_stringglirc_free_stringsglirc_current_focusglirc_is_channelglirc_is_logged_ondeps ProcessChatbaseForeign.StorablepokeNestedIOghc-prim GHC.TypesTrue withRawIrcMsg%irc-core-2.4.0-37D612KuIniBs9R1k7WCt0 Irc.RawIrcMsg RawIrcMsg evalNestedIOnest1nest2withChat withCommand emptyExecCmd powerWords Data.OldListwordsGHC.BaseString text-1.2.3.0Data.Text.Internal splitCommonsinglebothall childKeys!vty-5.23.1-GGSqROVutSMCGVj9LS25FxGraphics.Vty.AttributesdefAttrcolorNumberSpecrgbSpec actionInfosexceptionToLines' Irc.MessageIrcMsgNothingJustremapGraphics.Vty.Image.InternalImage splitOptions dropSpaces lineWrap'defaultNickColorPalette Irc.UserInfoUserInfoparseMaskComponents translate isMetaChar digraphTableStReadyMatchFoundSkip2Skip1 lookupDigraphdigraphs currentLine forwardLine backwardLineupdateYankBuffer Data.String fromString GHC.Classes<= currentWord tabSearchprotocolFamilySpec#hookup-0.2.2-AFcVlNxxKYAGEiTLr5ZY9JHookup ConnectiondefaultWindowNamesgetOldConfigPathdirectory-1.3.1.5System.DirectorygetAppUserDataDirectorygetXdgDirectory XdgConfigemptyConfigFilereadFileCatchNotFoundreadConfigurationFileexplainLoadError resolvePathsdefaultPaddingSidenickPaddingSpecfullNickPaddingSpec modifierSpec layoutSpeckeyBindingSpecactBindingSpeckeySpecbuildServerMapnewFilePathContextstatusMsgImage prefixImage bodyImage time-1.8.0.2&Data.Time.LocalTime.Internal.ZonedTime ZonedTime datetimeImage ircLinePrefix ircLineImagefullIrcLineImageseparatedParamsircWordsprettyUnixTime prettySecondshighlightNicks summaryLineversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNamedefaultOptionsoptions gitHashTxt gitDirtyTxtStatsgetStatsstatsToEntries SemigroupMonoid$fMonoidStrictUnitmappend$fSemigroupStrictUnit<>stimes overStrict lens-4.17-628bk3VBrYQ7Vqh3Mqjes7Control.Lens.TypeSetterControl.Lens.Setterover setStrictsetzonedTimeLocalTimeLens&Data.Time.LocalTime.Internal.LocalTime LocalTimelocalTimeTimeOfDay localTimeDaynoReply pruneUsers doWelcome Irc.Codes RPL_WELCOME doBadNickERR_NICKNAMEINUSErecordListEntrysaveList squelchReplymassRegistrationnextForgetActionnextPingActiondoModeisupport _esActive_esMVarGHC.MVarMVar _esStablePtr GHC.Stable StablePtr FocusSelector stepFocus TraversalsplitStatusMsgModes msgImportance ircIgnorablecomputeMsgLineSigilscomputeUserSigilsupdateTransientErrorrecordWindowLine toWindowLine' toWindowLinemarkSeennextAvailableKeyapplyWindowRenamesclientStopExtensions recordLogLinenetworkChannelListdrawmetadataWindowLine MetadataStatewindowLinesToImages startMetadatatransitionMetadatagatherMetadataLines drawEntry scrollImage filterImage latencyImage infoBubble detailImage nometaImageactivitySummaryactivityBarImages makeLinestransientErrorImage mlTimestamp mlWindowNamemlFocusmlImage addMarkersmerge windowEntriescommandSuccesscommandFailurecommandFailureMsg executeChatexecuteCommand expandAliases noClientTab noNetworkTab noChannelTabsimpleClientTabsimpleNetworkTabsimpleChannelTabcmdExitcmdClearcmdQuotecmdMecmdCtcp cmdNoticecmdMsg chatCommand chatCommand' cmdWindows cmdMentions cmdPalette cmdDigraphs cmdKeyMap cmdRtsStatscmdHelp tabSplitstabActiveSplits parseFocus ApplicativeData.Functor.IdentityIdentityMayberenderSplitFocus cmdSplits cmdSplitsAdd cmdSplitsDel tabConnecttabFocuscmdSaycmdQuery cmdChannel tabChannelchannelWindowsOnNetwork cmdReconnect tabIgnore cmdReload tabReload countFlagscomputeModeCompletionisPublicChannelModenickTabCompletioncmdExeccmdGrepsimpleTabCompletiontabTopiccommandHelpLinesexplainContextlistAllCommandscommandSummarylistCommandSection renderContent myWcwidth myWcswidth renderLine drawLayoutOne drawLayoutTwo drawExtra messagePane divisionsdrawMain splitHeightsGraphics.Vty.PicturePicture clientImage ClientEventVtyEvent TimerEventgetEvent earliestEventbeep doNetworkOpendoNetworkClosedoNetworkError doNetworkLineclientResponsecomputeEffectiveTime parseZncTimelookups doVtyEventdoActiondoCommandResult executeInput doTimerEventreconnectLogicprocessSaslEcdsaprocessConnectCmd recordError derefToken peekFgnMsgpeekFgnStringLen