!L "      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdef 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*{*|*}*~*******************************************************************+,,-./0123333334456666666666666666666666666789::;<<===================== = = = = =================== =!=F>*Dynamically generated configuration moduleSafe8k"glircCTransitive dependencies for this package computed at configure-time"glircpackage name, version number"Binding to ecdsatool(c) Eric Mertens, 2016ISCemertens@gmail.comSafeAcglircRIdentifier 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"#pI-glircPointer to UTF-8 encoded string and as string length. Strings are null-terminated. The null-terminator is not counted in the length.glircUsed to pass arguments from /extension EXT_NAME# client command into an extension.glircRChat message data containing the source network, window target, and message body. glirc struct glirc_messageglircarrayglirc array lengthglircarrayglircarrayglirc array lengthglirc@Information describing an extension's entry-points and metadata.glircOptional startup callbackglircOptional shutdown callbackglirc"Optional message received callbackglircOptional message send callbackglirc Optional client command callback glircNull-terminated name!glircextension version"glircextension version#glirceType of dynamic function pointer wrappers. These convert C function-pointers into Haskell functions.$glirc%Callback function when timer triggers%glircInteger type of timer IDs&glirc Jtypedef void process_chat(void *glirc, void *S, const struct glirc_chat *)'glirc Ptypedef 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 2typedef void *start(void *glirc, const char *path)+glircIResult used to determine what to do after processing a message with the ( callback.| enum process_result-glircLTag for describing the kind of message to display in the client as used in  glirc_print. See 5 and 6. enum message_code;/glirc!Dynamic import for timer callback0glircDynamic import for &.1glircDynamic import for '.2glircDynamic import for (.3glircDynamic import for ).4glircDynamic import for *.5glirc]Normal client message. Unread counter increments, but no client bell or error status update.6glirc[Important client message. Unread counter increments, bell rings, and error status updates.7glirc6Allow the message to proceed through the client logic.8glirc)Drop the message from further processing.9glircLike # except it doesn't write to NULL:glirc7Marshal a text as a malloced null-terminated CStringLen;glirc8Marshal a text as a temporary null-terminated CStringLen<glirc struct glirc_string=glirc struct glirc_command>glirc struct glirc_message@glirc struct glirc_extension$glircapi token glircextension state glirctimer state glirctimer ID &glircapi 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 glircarray of arguments glircnumber of arguments glircinitialized extension state 9  !"#$%&'()*+,-./0123456789:;9 !"*)('&$%  #43210/-.56+,78;:93Argument specifications used within client commands(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'HtPglircrequired names glircoptional names CFDEGHIJKLMNOPJNKLPOMGHICFDE-Interpret argument specifications as a parser(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'vQQ Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNone4d Vglirc 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.Xglircoutput networkYglircoutput channelZglirccommand filename[glirc stdin source\glirccommand arguments$glircDefault values for /exec to be overridden by flags.fglircParse the arguments to /exec> looking for various flags and the command and its arguments.gglircCExecute 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.fglircexec arguments glircerror or parsed command gglircexec configuration glircerror lines or output lines RSTUVWXYZ[\defgVWXYZ[\RSTUedfg9Parser and evaluator for string interpolation in commands(c) Eric Mertens, 2016ISCemertens@gmail.comSafe&'SXBnglirc%Parsed chunk of an expandable commandoglirc regular textpglircinline variable $x or ${x y}qglircinline variable $1 or ${1}rglirc bracketed variable with default ${x|lit}sglirc2Specification used when unspecified, no arguments.uglircParse a (/ searching for the expansions as specified in n. $$ is used to escape a single $.vglircAttempt 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.vglircvariable resolution glircargument index resolution glircchunks glircconcatenated, expanded chunks hijklmnopqrstuvnopqruvjklmhitsTrie for recognizing commands(c) Dan Doel, 2016ISCemertens@gmail.comSafe4zglirc%Possible results of recognizing text.{glirc.text matched exactly, yielding the given value|glirc8text would be recognized if joined to the given suffixes}glirc%text could not possibly be recognized~glirc 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 z 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 . z|{}~ ~z|{}*Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone0aglircAParse 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 list/glirc4Match integers between 0 and 255 as Terminal colors.0glirckConfiguration 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.comNone0 STS policy configuration(c) Eric Mertens, 2019ISCemertens@gmail.comNone0[ Programmable keyboard actions(c) Eric Mertens, 2016ISCemertens@gmail.comNoneSX×glircCLookup table for keyboard events to actions. Use with keyToAction.glirc/Actions that can be invoked using the keyboard.1glirc/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.comNoneZglircBCompute the message message text to be used for a connection errorglircnetwork error glircclient lines 2glircnetwork 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 ().glirccontinue processingglirc stop processing and drop messageglirc&stop processing and return new messageglirc$Apply the given message hooks to an 3A. The hooks are tried in order until one handles the message. A 49 result means the message was filtered out by a hook. A 5 result contains the actual 3 to be processed. %Hook to remap znc buffextras messages(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglircMap ZNC's buffextras messages to native client messages. Set debugging to pass through buffextras messages that the hook doesn't understand.glircenable debugging 6glircenable debugging Packed vty Image type(c) Eric Mertens, 2016ISCemertens@gmail.comNonecglircPacked, strict version of 7& 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.comNoneoglircEParse 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.8glircXList of image widths suitable for breaking the image on that correspond to word breaks.9glirc%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 activityglircwindow name with mentionglirc known commandglirc%known command with complete argumentsglircprefix of known commandglircunknown command glirccommand argument placeholder glircDivider between split windows glirc$Divider between new and old messages!glircBDefault UI colors that look nice in my dark solarized color scheme;glircSDefault 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 ##Nonec%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;glircChghost command<glircAccount commandAglirc7Compute a searchable text representation of the message'()*+,-./0123456789:;<=>?@AB+,-./?>@'()*0123456789:;<=BAIRC channel session state(c) Eric Mertens, 2016ISCemertens@gmail.comNone%Mglirc5Dynamic information about the state of an IRC channelOglirc topic textPglircauthor and timestamp for topicQglirc channel URLRglircuser list and sigilsSglircchannel settings and parametersTglircmode, mask, setter, set timeUglirccreation time of channelVglircdelayed op messagesfglircConstruct an empty MgglircAdd a user to the user listhglirc Remove a user from the user listiglircRename a user in the user listjglircSet the channel topic#EFGHIJKLMNOPQRSTUVZ[\]^_`abcdefghij#MNOPQRSTUV^_`a\[Z]EFGHdeIJKLbcfjghi9Types for representing the current window being displayed(c) Eric Mertens, 2016ISCemertens@gmail.comNone51kglircCurrently focused windowlglirc No networkmglircNetworknglircNetwork Channel/NickqglircFilter argument for {rglirc no filtersglirconly network windowstglirconly channel windowsuglirconly user windowsvglirc Subfocus viewwglirc Show messagesxglircShow channel metadatayglircShow channel user listzglirc%Show channel mask list for given mode{glircShow client windows|glircShow current palette}glircShow all mentions~glircShow 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 klmnqrstuvwxyz{|}~klmnvwxyz{|}~qrstu2Types and operations for managing message buffers.(c) Eric Mertens, 2016ISCemertens@gmail.comNone@AMglirc;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.comNoneSdglircGenerate 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.ASafeU@glirccontext before glirccontext after glircpredicate glircinputs glircmatches with context @B/Template Haskell quasi-quoter for digraph table(c) Eric Mertens, 2017ISCemertens@gmail.comSafeWACCharacter mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comSafe^kBglirc+States for the digraph lookup state machineCglirc!ready to match two-character nameDglirc)first character matched, ready for secondEglirc(both characters matched, return the nextFglircskip the next two charactersGglircskip the next characterHglirc[Find the entry in the digraph table give a two-character key and return the matched value.HI$Multiline text container with cursor(c) Eric Mertens, 2016ISCemertens@gmail.comNonerglirc0Zipper-ish view of the multi-line content of an EditBox . Lines  the J 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.Kglirc)Advance to the beginning of the next lineLglirc'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  valueMglircDSets 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.comNonen glirc'Class for types that are isomorphic to '> and which can support a total order and a prefix predicate. DE (N x) == x N (DE x) == x DF x y ==> x O 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 suffixglirc>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.PglircFind the word preceeding the cursor skipping over any characters that can be found in the prefix and suffix for the current completion mode.QglircRFind the next entry in a list of possible choices using an alphabetical ordering. glircleading update operation glirc reversed glircpriority completions glircpossible completions Qglircreversed glircsearch prefix glircprevious result glircposibilities     )Settings for an individual IRC connection(c) Eric Mertens, 2016ISCemertens@gmail.comNone0$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 connectglircpath 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 chat/glircProtocol family to connect with0glircHonor STS policies when truePglircJLoad the defaults for server settings based on the environment variables.Environment variables USER,  IRCPASSSWORD, and  SASLPASSWORD are used.Rglirc%Specification for IP protocol family.C !"#$%&'()*+,-./03456789:;<=>?@ABCDEFGHIJKLMNOPQRC !"#$%&'()*+,-./0QR=NAO>EDC8?IKLMJ5FG467:;B3<9@HP#Interface to the connection package(c) Eric Mertens, 2016ISCemertens@gmail.comNoneTglirc Create a new S6 which will be closed when the continuation finishes.STTSEvent-based network IO(c) Eric Mertens, 2016ISCemertens@gmail.comNoneUglirc-Exceptions used to kill connections manually.Vglircsent when ping timer expiresWglirc*sent when client commands force disconnectXglirc2sent when the client disconnects due to sts policyYglircThe 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.Zglirc'Event for successful connection to host[glirc/Event for a new recieved line (newline removed)\glirc6Final message indicating the network connection failed]glirc8Final 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.aglirc(Force the given connection to terminate.bglirc9Initiate 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.bglircdelay in seconds glirc)Identifier to be used on incoming events UVWXYZ[\]^_`ab^_YZ[\]b`aUVWX *Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#0`5fglircJConfiguration information for run-time loaded dynamic library extensions.hglircpath to shared objectiglircdynamic linker flagsjglirc%arguments to the extension on startupkglirc0Failure cases when loading a configuration file.lglirc-Error message from reading configuration filemglirc"Error message from parser or lexernglirc/Error message from loading parsed configurationpglirc/Vertically stack all windows in a single columnqglirc1Vertically stack extra windows in a second columnrglirc*Setting for how to pad the message prefix.sglirc.Whitespace add to the left side of chat prefixtglirc/Whitespace add to the right side of chat prefixuglircNo whitespace addedvglirc\Top-level client configuration information. When connecting to a server configuration from y$ is used where possible, otherwise x is used.xglircDefault connection settingsyglircHost-specific settingszglircUser-customized color palette{glirc(Names of windows, used when alt-jumping)|glircExtra highlight nicks/terms}glircPadding of nicks in messages~glirccommand macrosglircextensions to loadglircpaths to url opening executableglircinitial ignore mask listglirc(initially visibility of the activity barglircnotify terminal on mentionglirc+default setting for hidemeta on new windowsglirckeyboard bindingsglircDefault layout on startupglircvisibility of ping timeglirc!Modifier used for jumping windowsglircdefault instanceTglircThe 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.UglircUses V to find ~.glircconfigglircUses W X to find ~.config glirc/configYglirc_Empty configuration file used when no path is specified and the configuration file is missing.ZglircYAttempt to read a file using the given handler when a file does not exist. On failure a l 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.UGiven configuration path is optional and actual path used will be returns on success\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 file^glirc<The default nick padding side if padding is going to be used_glirc5Either full or abbreviated nick-padding configuration nick-padding: 10 'nick-padding: side: right width: 16`glirc Full nick padding specification: &nick-padding: side: left width: 15aglirc@Parse either a single modifier key or a list of modifier keys: meta, alt, ctrlbglirc Parse either  one-column or  two-column and return the corresponding o value.cglirckParse a single key binding. This can be an action binding, command binding, or an unbinding specification.dglircYParse a single action key binding. Action bindings are a map specifying a binding using e and an action: $bind: "M-a" action: jump-to-activityeglircCCustom configuration specification for emacs-style key descriptionsfglircDefault dynamic linker flags:  RTLD_LOCAL and RTLD_NOWgglirc[Given only a filepath build an extension configuration that loads the extension using the f and no arguments.hglircFull extension configuration allows the RTLD flags to be manually specified. This can be useful if the extension defines symbols that need to be visible to libraries that the extension is linked against.Zglirc file to read glirc!error handler for not found case [glirc&just file or use default search paths glircpath to configuration file iglirc defaults glircconfiguration file path =fghijklmnopqrustvwxyz{|}~=vwxyz{|}~klmnopqrustfghij!Renderer for message lines(c) Eric Mertens, 2016ISCemertens@gmail.comNoneF"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.jglirc+Render the sigils for a restricted message.kglirc Render a '; given the sender's sigils and the nicknames to highlight.lglirc Render a '; given the sender's sigils and the nicknames to highlight.glirc Render a m as time using quiet attributes 23:15 nglirc Render a mA 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.oglircQRender the sender of a message in normal mode. This is typically something like  @nickname:pglircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.qglircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.rglircProcess list of (} as individual IRC formatted words separated by a special separator to distinguish parameters from words within parameters.sglircProcess list of (" as individual IRC formatted wordstglircETransform string representing seconds in POSIX time to pretty format.uglircJRender 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.vglircGiven 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 jglircsigils 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 vglirc 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.comNoneLoglirc-Render the lines used in a channel mask list.wglirc7Render a summary describing the number of ignore masks.glirc ignore masks glirc palette wglirc ignore masks glirc palette #Support for logging IRC traffic(c) Eric Mertens, 2016ISCemertens@gmail.comNoneTglirc: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 +< when appropriate. Only chat messages result in a log line.glirc log line glircmessage glirclog directory glirctarget  $ Dynamically loaded extension API(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#MSX8xglirc.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.glirc$Struct of callback function pointersglirc&Handle of dynamically linked extensionglirc'State value generated by start callbackglirc3The symbol that is loaded from an extension object."Extensions are expected to export: "struct galua_extension extension; glirc:Find the earliest timer ready to run if any are available.glirc2Schedue a new timer event for the given extension.glirc&Remove a timer from the schedule by IDglircLoad 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.glircWCall the stop callback of the extension if it is defined and unload the shared object.glircCall 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 y< to pass message to client. Returns 'False to drop message.glircCall 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 y< to pass message to client. Returns 'False to drop message.glircBNotify an extension of a client command with the given parameters.glirc Marshal a z 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 argument|glircIWrap up a bracketing IO operation where the continuation takes 2 argument glirc extension glirc:earlier time, callback, callback state, updated extension glircactivation time glirccallback function glirccallback state glircextension glirc timer ID glirc extension glircextension configuration glircclient stable pointer glircextension configuration glircactive extension glircextension state glircclient callback handle glircextension glircserialized chat message glircallow message glircclientstate stable pointer glircextension glircserialized IRC message glircallow message glircclient state stableptr glirccommand glircextension to command glirc network glirc message glircnetwork glirctarget glircmessage }glirccommand GSafe.~%"Processing of command-line options(c) Eric Mertens, 2016ISCemertens@gmail.comNone` glircCommand-line optionsglircconfiguration file pathglircinitial networksglircdisable autoconnectglircshow help messageglircshow version messageglirc+show version of ALL transitive dependenciesglircshow configuration file formatglircDefault values for glircOption descriptionsglircuLoad command line options. This action will terminate early in the case of the version flag, help flag, or an error.glircReturns  "-SOMEHASH" when in a git repository, "" otherwise.glircReturns "-dirty"! when in a dirty git repository, "" otherwise.  H.Human readable interface to GHC RTS statistics(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&View current GHC RTS statistics(c) Eric Mertens, 2017ISCemertens@gmail.comNoneglircGenerate lines used for  /rtsstats.I1Template Haskell quasi-quoter for string literals(c) Eric Mertens, 2017ISCemertens@gmail.comSafe'<Hook for sorting some service notices into separate windows.(c) Eric Mertens 2019ISCemertens@gmail.comNone(Available hooks(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneVglirc All the available message hooks.JStrict unit type(c) Eric Mertens, 2016ISCemertens@gmail.comSafe6glircUnit data type with a strict  and  instances.glirc is strictglirc is strict,  is O(1)KLens utility functions(c) Eric Mertens, 2016ISCemertens@gmail.comSafeglircModify the target of a d with a function. The result is strict in the results of applying the function. Strict version of glirc9Set a value strictly in the set value. Strict version of .glirc to the  component of a mglirc" to the 'TimeOfDay component of a .glirc" to the 'TimeOfDay component of a .)IRC network session state(c) Eric Mertens, 2016ISCemertens@gmail.comNone8glircTimer-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 glirchostname glircservices account glirc'State of the authentication transaction glircno active transactionglircPLAIN mode initiatedglircECDSA-NIST mode initiatedglirc*ECDSA-NIST user sent waiting for challengeglircEXTERNAL mode initiatedglirc%State tracked for each IRC connectionglircnetwork connection identifierglircjoined channelsglircnetwork socketglircchannel mode meaningsglircuser 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 nicks glirc%maximum mode changes per MODE command!glircname of network connection"glirc2names of message hooks to apply to this connection$glirctime for next ping event%glirc%latency calculated from previous pong&glircstate of ping timer'glirctime of last message receivedHglirc Transmit a z; on the connection associated with the given network. For PRIVMSG and NOTICEF overlong commands are detected and transmitted as multiple messages.IglircqConstruct a new network state using the given settings and default values as specified by the IRC specification.glircUsed for updates to a  that require no reply. noReply x = ([], x)glirc Restrict BA to only users are in a channel that the client is connected to.glirc001  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.glircHandle  errors when connecting.glirc'Add an entry to a mode list transactionglircKSave a completed ban, quiet, invex, or exempt list into the channel state.glirc[These replies are interpreted by the client and should only be shown in the detailed view.KglircReturn y 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.Lglirc>Predicate to test if the connection has op in a given channel.glirc7Process a CHGHOST command, updating a users informationglircProcess a list of WHO repliesPglirc:Compute the earliest timed action for a connection, if anyglircCompute 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.QglircApply the given  to a connection state.RglircUsed 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. Iglircunique network ID glircnetwork name glircserver settings glircactive network connection glircinitial ping status glircnew network state glircmessage received glircmy nickname glirc bad nickname glircreplies, updated state glircmask glircset by glirc set time glircmode glircchannel glirctime of message glircsender glircchannel glircmode flags glircmode parameters glircnetwork state glircserver caps glirccaps to enable glirc  "key=value"glirc nickname glirc new username glirc new hostname Rglircchannel glirccommands glircnetwork state Sglircchannel glircnetwork state glircchanserv available Tglircchannel glirctopic glircnetwork state U      !"#$%&'0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTU !"#$%&'  IG2>71@8?=ABO6:9;<4350   EDCNLHMJKFPQSRT*/Primary client state type and update operations(c) Eric Mertens, 2016ISCemertens@gmail.comNoneUTglirc.ID of active extension and stored client stateUglircState of the extension API including loaded extensions and the mechanism used to support reentry into the Haskell runtime from the C API.oWhen executing inside an extension the mvar will contain the client state and the ID of the running extension.glircactive extensionsglirc used to with  clientParkglirc used with  clientPark[glirc(All state information for the IRC client]glircclient message buffers^glircpreviously focused buffer_glirc"focus prior to jumping to activity`glirccurrently focused bufferaglirccurrent view modebglircextra messages windows to viewcglircstate of active connectionsdglircincoming network event queueeglircnetwork name to connection IDfglircclient configurationgglircclient configuration file pathhglircprimary text boxiglirc"size to crop from left of text boxjglirccurrent terminal widthkglirccurrent terminal heightlglircbuffer scroll linesmglircuse detailed rendering modenglircvisible activity baroglircvisible ping timepglircoptional persistent filterqglirclayout mode for split screenrglircsound a bell next drawsglirc ignored maskstglirc,precomputed ignore regular expression (lazy)uglircstate of loaded extensionsvglirclog lines ready to writewglirctransient error box textxglircmost recent GHC RTS statsyglircSTS policy entriesglircSelection function used in glirc for finding the I associated with a given network if that connection is currently active.glirc-The full top-most line that would be executedglirc*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.glirc;Add a message to the window associated with a given channelglirc5Extract the status mode sigils from a message target.glircbCompute the importance of a message to be used when computing change notifications in the client.glircTPredicate for messages that should be ignored based on the configurable ignore listglircCPredicate for nicknames to determine if messages should be ignored.glircARecord a message in the windows corresponding to the given targetglirc2Compute the sigils of the user who sent a message.glirc&Compute sigils for a user on a channelglircDetect 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.glirc$Record a message on a network windowglircFRecord window line at the given focus creating the window if necessaryglirc& but with mostly defaulted parameters.glirc2Function applied to the client state every redraw.glircAMark the messages on the current window (and any splits) as seen.glirc@Add the textbox input to the edit history and clear the textbox.glircCReturns the current network's channels and current channel's users.glirc Returns the % associated with the current network.glirc9Returns the current filtering predicate if one is active.glirc;Compute the command and arguments currently in the textbox.glirc=Regular expression for matching HTTP/HTTPS URLs in chat text.glircFind all the URL matches using  in a given () suitable for being opened. Surrounding < and > are removed.glircRemove 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.glirc<Start a new connection. The delay is used for reconnections.glirc6Find the first unused key in the intmap starting at 0.glircWhen 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.glirc0Scroll the current buffer to show newer messagesglirc1List of extra focuses to display as split windowsglircJump 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.glircBJump the focus directly to a window based on its zero-based index.glircChange the window focus to the given value, reset the subfocus to message view, reset the scroll, remember the previous focus if it changed.glirciUnified 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.glircStep focus to the next window when on message view. Otherwise switch to message view. Reverse the step order when argument is y.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.glircwindows before current window glircwindows after current window glircwindow to focus glircnetwork glircline number, line content glircnetwork glircnetwork glircchannel glirc message glirc target glirc client state glircpossible modes glirctarget glircactual modes, actual target glirc target user glirc client state glirc is ignored glircnetwork glircnetwork glircchannel glircsigils glircnetwork glircchannel glircuser glircsigils glircnetwork glirc channels glircnetwork glircchannel glircnicks glircclient state glircoptional predicate glirc!client state glirc!command name and argument string glircattempts glircoptional disconnect time glircSTS upgrade port glircnetwork name glirctimestamp glircmessage received glircmessage network glircnetwork connection state glircclient state glircresponse , updated state glircnetwork glirczero-based window index glirc new focus glirc client state glirc new subfocus glirc client state glircselection function glircclient state glircnetwork state glircclient state glircextra highlight identifiers glircnetwork glircclient state glircextra highlight identifiers lUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~l[\]^_`abcdefghijklmnopqrstuvwxy}z|{~VWXYZU+ View of the list of open windows(c) Eric Mertens, 2016ISCemertens@gmail.comNone[glirc)Draw the image lines associated with the /windows command.,)Line renderers for channel user list view(c) Eric Mertens, 2016ISCemertens@gmail.comNonecglircRender 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.comNonelglirc1Generate the lines used for the view when typing /urlglircRender one line of the url listglircrender width glircwindow to search glircargument to command glircclient state glircimage lines glircrendered 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.comNoneuglirc-Classify window lines for metadata coalesenceglirc current nick glirc metadata glirc palette glircclient state glircdraw width glirchide metadata glircwindow lines glircimage lines glircmetadata image glircpossible nick transition glircimage accumulator glircpossible nick transition glircmetadata entries are reversedglirc;Image, incoming identifier, outgoing identifier if changed /)Line renderers for channel mask list view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneyDglirc,Render the lines used in a channel mask listglirc Mask mode glirc network glirc channel glirc draw width 0List of the current key map(c) Eric Mertens, 2017ISCemertens@gmail.comNone|glircHRender the lines of a table showing all of the available digraph entriesglirc client state glirc output lines 1Character mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comNoneglircHRender the lines of a table showing all of the available digraph entriesglirc draw width glirc client state glirc output lines glirc3-character entry 2Channel information renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNoneSglirc,Render the lines used in a channel mask listglircnetwork glircchannel 36Integration between the client and external extensions(c) Eric Mertens, 2018ISCemertens@gmail.comNoneglirc9Start extensions after ensuring existing ones are stoppedglircVStart a single extension and register it with the client or record the error message.glircUnload all active extensions.glircCDispatch chat messages through extensions before sending to server.glirc0Dispatch incoming IRC message through extensionsglirc Dispatch  /extension( command to correct extension. Returns 4) when no matching extension is available.glirc=Prepare the client to support reentry from the extension API.glirc=Run the next available timer event on a particular extension. glirc!client state glirc!client state with new extensions glirc&client state glirc&client state with extensions unloaded glircnetwork glirctarget glircmessage glircclient state, allow message glircserialized chat message glircclient state glircextensions needing callback glircnew state and allow glircnetwork glircincoming message glircclient state glircdrop message when false glircserialized IRC message glircclient state glircextensions needing callback glircnew state and allow glircextension name glirccommand glircclient state glircnew client state on success glirc4extension ID glirc4client state glirc4continuation using the stable pointer to the client glirc extension ID glirc client state 4Renderer for status line(c) Eric Mertens, 2016ISCemertens@gmail.comNone 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 5 Mentions view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneglircmessage 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 glircfilter glircpalette glircdraw columns glircnick padding glircdetailed view glircwindow name glircwindow focus glircwindow 6 Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNoneEXFLglircuA 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 / indicates a command. Otherwise if a channel or user query is focused a chat message will be sent. Leading spaces before the /) are ignored when checking for commands.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 /splits glircImplementation 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 7Renderer for help lines(c) Eric Mertens, 2016ISCemertens@gmail.comNoneZgglircGenerate 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 8View selection module(c) Eric Mertens, 2016ISCemertens@gmail.comNone[9Textbox renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNonenUglircCompute 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 rendered(glirc Version of wcswidth7 that accounts for how control characters are rendered)glirc}Render the active text box line using command highlighting and placeholders, and WYSIWYG mIRC formatting control characters.glirc cursor column, new offset, image&glirc&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 :'Layout code for the multi-window splits(c) Eric Mertens, 2016ISCemertens@gmail.comNonewglirc?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 /splits-glircGenerate 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 0glirc"screen rows to fill glirc"number of extra windows glirc"list of heights for each division .glirc dividend glirc divisor glircclient state glircscroll amount ; UI renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNone|glirc Generate a 1u for the current client state. The resulting client state is updated for render specific information like scrolling.2glircPrimary UI render logic2glirc client state glirc/text box cursor position, image, updated state <Event loop for IRC client(c) Eric Mertens, 2016ISCemertens@gmail.comNone\3glirc<Sum of the three possible event types the event loop handles4glircKey presses and resizing5glircIncoming network events6glirc'Timed action and the applicable network7glirc extension ID8glircBlock waiting for the next 3V. This function will compute an appropriate timeout based on the current connections.9glirc:Compute the earliest scheduled timed action for the clientglirc"Apply this function to an initial [ to launch the client.:glirc*Sound the terminal bell assuming that the BEL control code is supported.;glirc8Respond to a network connection successfully connecting.<glirc1Respond to a network connection closing normally.=glirc3Respond to a network connection closing abnormally.>glircRespond to an IRC protocol line. This will parse the message, updated the relevant connection state and update the UI buffers.?glircqClient-level responses to specific IRC messages. This is in contrast to the connection state tracking logic in Client.NetworkState@glirc!Find the ZNC provided server timeAglirc6Parses the time format used by ZNC for buffer playbackBglircgReturns the list of values that were stored at the given indexes, if a value was stored at that index.glirc6Update the height and width fields of the client stateCglircRespond to a VTY event.Dglirc,Map keyboard inputs to actions in the clientEglircProcess  and update the [0 textbox and error state. When quitting return 4.Fglirc*Actions to be run when exiting the client.Gglirc9Execute the the command on the first line of the text boxHglircRespond to a timer event.8glirc vty handle glirc client state ;glirc network id glirc event time glirc client state <glirc network id glirc event time glirc client state =glircfailed network glirccurrent time glirctermination reason glircclient state Iglircthread failure reason glircfailed network glircclient state >glirc!Network ID of message glirc!current time glirc!Raw IRC message without newlines glirc!client state JglircSTS parameter string glircnetwork state glircclient state Kglircmessage time glircchallenge glircnetwork state glircclient state Lglircnow glirccurrent network glircclient state glirccommand Mglircnow glirccurrent network glircerror message glircclient state Cglircvty handle glircvty event glircclient state glircnothing when finished Dglircvty handle glircaction glircclient state Eglircclear on success glirccommand result Gglirc client state HglircNetwork related to event glircAction to perform glircclient state =9Foreign exports which expose functionality for extensions(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#J1glircType of ! extension entry-pointglircType of   extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of  extension entry-pointglircType of   extension entry-point. glircType of   extension entry-point glircType of   extension entry-pointNglirc<Dereference the stable pointer passed to extension callbacksOglirc Import a   into an zPglircPeek a  as UTF-8 encoded bytes. glircfEntry-point into the client when an extern extension wants send an IRC command to a connected server. glircJEntry-point for extensions to append a message to the client buffer. The  message_codeq can be used to render the message normally or to cause the client to draw attention to the message as an error. glircAdd a message to a chat window as if it was received directly from the IRC server. This is useful when implementing extensions that intercept incoming chat messages and transform them before showing the user.glirckThis extension entry-point allocates a list of all the identifiers for the active networks on the client. NULLU returned on failure. The caller is responsible for freeing successful result with glirc_free_strings.glircCase insensitive comparison suitable for use on channels and nicknames. Returns -1 if the first identifier is less than the second Returns 0 if the first identifier is equal to the second Returns 1 if the first identifier is greater than the secondglircTGenerate a list of connected channels for the network identified in the arguments. NULLP returned on failure. Caller is responsible for freeing successful result with glirc_free_strings.glirckGenerate a list of IRC nicknames currently connected to the identified channel on the identified network. NULLQ returned on failure. Caller is responsible for freeing successful result with glirc_free_strings.glircdReturn the IRC nickname associated with the active network connection identified in the arguments. NULLQ returned on failure. Caller is responsible for freeing successful result with glirc_free_string.glircReturn the services account name associated with a nickname on a server as tracked by the client. Caller is responsible for freeing successful result with glirc_free_string. If no account is known, NULL is returned.glircReturn the sigils associated with a nickname on a particular channel. Caller is responsible for freeing successful result with glirc_free_stringc. If user is on channel without any sigils an empty string is returned. If user is not on channel NULL is returned.glircReturn all of the modes of a given channel. The first letter of each string returned is the mode. Any remaining characters are the mode argument. Caller is responsible for freeing successful result with glirc_free_strings". If the user is not on a channel NULL is returned. The modes might not be known to the client for a particular channel which can result in an empty list of modes being returned.glircReturn all of the modes of a given channel. The first letter of each string returned is the mode. Any remaining characters are the mode argument. Caller is responsible for freeing successful result with glirc_free_strings". If the user is not on a channel NULL is returned. The modes might not be known to the client for a particular channel which can result in an empty list of modes being returned.glircMark a window as being seen, clearing the new message counter. To specify the client window send an empty network name. To specify a network window send an empty channel name.glircClear contents of a specified window. To specify the client window send an empty network name. To specify a network window send an empty channel name.glircgFree one of the heap allocated strings found as a return value from the extension API. If argument is NULL, nothing happens.glirchFree an array of heap allocated strings found as a return value from the extension API. If argument is NULL, nothing happens.glircUFind the network and target identifier associated with the currently focused window. Free the allocated strings with glirc_free_string.Strings set to NULL6 if there is no current network or no current target.glirc#Assign window focus to a new value.)Set to client window if network is empty.*Set to network window if channel is empty.Set to chat window otherwise.glircReturns 1R when the given target on the given network is a channel name, otherwise returns 0.:If the given network is not currently active this returns 0.glircReturns 1M when the given target on the given network shares a channel with the user, 0 otherwise.:If the given network is not currently active this returns 0.glirc;Resolve the given string to an absolute path. This expands ~P for the home directory and computes paths relative to the configuration file.Free the allocated string with glirc_free_string. glircRegister a function to be called after a given number of milliseconds of delay. The returned timer ID can be used to cancel the timer.!glircRegister a function to be called after a given number of milliseconds of delay. The returned timer ID can be used to cancel the timer.glircapi token glirctimer ID glircapi token glircmilliseconds delay glircfunction glirccallback state glirctimer ID glircapi token glircpath glircpath length glircresolved path glircapi token glircnetwork name glircnetwork length glirctarget name glirctarget length glircboolean glircapi token glircnetwork name glircnetwork length glirctarget name glirctarget length glircboolean glircapi token glircnetwork glircnetwork length glirctarget glirctarget length glirc$api token glirc$OUT: newly allocated network string glirc$OUT: network length glirc$OUT: newly allocated target string glirc$OUT: target length glirc)glirc allocated strings, null-terminated glircglirc allocated string glircapi token glircnetwork name glircnetwork name length glircchannel name glircchannel name length glircapi token glircnetwork name glircnetwork name length glircchannel name glircchannel name length glircapi token glircnetwork name glircnetwork name length glircchannel glircchannel length glircmode glircapi token glircnetwork name glircnetwork name length glircchannel glircchannel length glircapi token glircnetwork name glircnetwork name length glircchannel glircchannel length glircnickname glircnickname length glircapi token glircnetwork name glircnetwork name length glircnickname glircnickname length glircapi token glircnetwork name glircnetwork name length glirc api token glirc network glirc network len glirc channel glirc channel len glirc1null terminated array of null terminated strings glirc api token glirc network glirc network len glirc1null terminated array of null terminated strings glircidentifier 1 glircidentifier 1 len glircidentifier 2 glircidentifier 2 len glirc1api token glirc1null terminated array of null terminated strings  glircapi token glircnetwork glircnetwork length glircsource glircsource length glirctarget glirctarget length glircmessage glircmessage length glirc0 on success  glircapi token glircenum message_code glircmessage glircmessage length glirc0 on success  glircapi token glircpointer to message glirc0 on success .      !.      !QLMNOOPPQRRSTUVVWXYZ[\]^_`aabcdefghijklmnopqrrsstuvwxyz{|}~D                                                                           !"#$%&'()*+,-./01234556789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghiijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./01234DFE556789:;<=>?@AABCDDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                                                   !!!!!!!!!!!!!!!!!!!!!!!!!!"#########$$$$$$$$$$$$$$$$$ $ $ $ $ $$$$$$%%%%%%%%%%%%%& '!(")#)$)%)&)')()))*)+),)-).)/)0)1)2)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){)|)}*~***********************************************************************************************************+,,-./012333333445666666666666666666 6 6 6 6 666789::;<<======== =!="=#=$=%=&='=(=)=*=+=,=-=.=/=0=1=2=3=4=5=6=7=8=9=:=;=<===>=?=@=A=B=C=D=E=F>GHIJKLHMNHOPQR@STUVWXYZ[\ ] ^_`aHbcHbdeXfghijk_lmnopAqBrCsCtCuCvCwCxCyCz{|}~H                   !!!!!!!!!!!!"$_$$$GGGGGGGG%%%%HHHIJJHOHOJHOJHOHOJJKKKKK)))_)_))))))))))***H*H**************** - . . . ...1333344444444445 5!5"5#5$5%5&6666'6(6)6*6+6,6-6.6/606162636465666768696:6;6<6=6>6?6@6A6B6C6D6EHOFHGHHbI6J6K6L6M6N6O6P6Q6R6S6T6U6V6W6X6Y6Z6[6\6]6^6_6`7a7b7c7d7e9f9g9h9i:j:k:l:m:n:o:pXqr;s<t<u<<v<w<x<y<z<{<|<}<~<<<<<<<<<<<<<<<===!glirc-2.30-70pd65eor962WFQ09HQOVWClient.Authentication.EcdsaClient.CApi.TypesClient.Commands.Arguments.Spec Client.Commands.Arguments.ParserClient.Commands.ExecClient.Commands.InterpolationClient.Commands.RecognizerClient.Configuration.ColorsClient.Configuration.MacrosClient.Configuration.StsClient.EventLoop.ActionsClient.EventLoop.Errors Client.HookClient.Hook.Znc.BuffextrasClient.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.Log Client.CApiClient.OptionsClient.View.RtsStatsClient.Hook.Snotice Client.HooksClient.State.Network Client.StateClient.View.WindowsClient.View.UserListClient.View.UrlSelectionClient.View.MessagesClient.View.MaskListClient.View.KeyMapClient.View.DigraphsClient.View.ChannelInfoClient.State.ExtensionsClient.Image.StatusLineClient.View.MentionsClient.CommandsClient.View.Help Client.ViewClient.Image.TextboxClient.Image.Layout Client.ImageClient.EventLoopClient.CApi.Exports Build_glircDataText ContextFilter DigraphQuoteDigraphsPrefixtoStringisPrefix Paths_glircRtsStatsStrQuote StrictUnit LensUtilsauthenticationModeencodeUsernamecomputeResponse FgnStringLenFgnCmd fcCommandFgnChat fhNetworkfhTarget fhMessageFgnMsg fmNetwork fmPrefixNick fmPrefixUser fmPrefixHost fmCommandfmParamsfmParamN fmTagKeys fmTagValsfmTagN FgnExtensionfgnStartfgnStop fgnMessagefgnChat fgnCommandfgnNamefgnMajorVersionfgnMinorVersionDynamic TimerCallbackTimerId ProcessChatProcessCommandProcessMessage StopExtensionStartExtension ProcessResult MessageCoderunTimerCallbackrunProcessChatrunProcessCommandrunProcessMessagerunStopExtensionrunStartExtension normalMessage errorMessage passMessage dropMessagepoke' exportText withText0$fStorableFgnStringLen$fStorableFgnCmd$fStorableFgnChat$fStorableFgnMsg$fStorableFgnExtension$fEqMessageCode$fEqProcessResultArgArgumentOptional 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 macroMapSpecmacroCommandSpec StsPolicy_stsExpiration_stsPort$fShowStsPolicy stsExpirationstsPortreadPolicyFilesavePolicyFileKeyMapAction 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 MessageResult PassMessage OmitMessage RemapMessage$fMonoidMessageResult$fSemigroupMessageResultmessageHookActionmessageHookNamemessageHookStatefulapplyMessageHooksbuffextrasHookImage' unpackImagetext'charstring splitImage imageWidth imageText resizeImage$fIsStringImage'$fSemigroupImage'$fMonoidImage' $fShowImage' parseIrcText parseIrcText' mircColor mircColors 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 ChngSummary AcctSummary 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 fromStrings toStrings$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_ssSts $fShowUseTls$fShowServerSettings ssAutoconnectssChanservChannels ssConnectCmdsssFloodPenaltyssFloodThreshold ssHostNamessLogDirssMessageHooksssNamessNickCompletionssNicks ssPasswordssPortssProtocolFamilyssRealssReconnectAttemptsssSaslEcdsaFilessSaslPasswordssSaslUsername ssSocksHost ssSocksPortssStsssTls ssTlsCiphersssTlsClientCertssTlsClientKeyssTlsServerCertssUser ssUserInfoloadDefaultServerSettings serverSpecidentifierSpecircPortwithConnectionTerminationReason PingTimeoutForcedDisconnect StsUpgrade NetworkEvent NetworkOpen NetworkLine NetworkError NetworkCloseNetworkConnection NetworkIdsendabortConnectioncreateConnection$fShowNetworkConnection$fExceptionTerminationReason$fShowTerminationReasonExtensionConfiguration_extensionPath_extensionRtldFlags_extensionArgsConfigurationFailureConfigurationReadFailedConfigurationParseFailedConfigurationMalformed 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$fExceptionConfigurationFailure$fShowPaddingMode$fShowLayoutMode$fShowConfigurationFailure$fShowExtensionConfiguration$fShowConfigurationconfigActivityBarconfigBellOnMentionconfigDefaultsconfigExtensionsconfigExtraHighlightsconfigHideMeta configIgnoresconfigJumpModifier configKeyMap configLayout configMacrosconfigNickPadding configPalette configServersconfigShowPingconfigUrlOpenerconfigWindowNamesFilePathContext extensionArgs extensionPathextensionRtldFlagsgetNewConfigPathloadConfigurationconfigurationSpecnewFilePathContextresolveFilePathIdentifierColorModePrivmsgIdentifierNormalIdentifier RenderMode NormalRenderDetailedRenderMessageRendererParams rendStatusMsgrendUserSigils rendNicks rendMyNicks rendPalettedefaultRenderParamsmsgImage cleanChar cleanText timeImagenickPadcoloredIdentifiercoloredUserInfoquietIdentifierparseIrcTextWithNicks metadataImg ignoreImagedrawWindowLineignoreListLinesLogLine logBaseDirlogDay logTargetlogLine writeLogLineignoreProblems renderLogLineActiveExtensionaeFgnaeDL aeSessionaeNameaeMajorVersionaeMinorVersionaeTimers aeNextTimerextensionSymbolpopTimer pushTimer cancelTimer openExtensionstartExtensiondeactivateExtension chatExtensionnotifyExtensioncommandExtension withRawIrcMsgwithChat evalNestedIO$fFunctorNestedIO$fApplicativeNestedIO$fMonadNestedIO$fMonadIONestedIOOptions_optConfigFile_optInitialNetworks _optNoConnect _optShowHelp_optShowVersion_optShowFullVersion_optShowConfigFormat optConfigFileoptInitialNetworks optNoConnect getOptions rtsStatsLines snoticeHook messageHooks Transaction NoTransactionNamesTransactionBanTransactionWhoTransactionCapTransactionCapLsTransaction TimedActionTimedDisconnect TimedSendPingTimedForgetLatency PingStatusPingSentPingNonePingConnecting UserAndHost_uhUser_uhHost _uhAccountAuthenticateStateAS_NoneAS_PlainStartedAS_EcdsaStartedAS_EcdsaWaitChallengeAS_ExternalStarted NetworkState _csNetworkId _csChannels _csSocket _csModeTypes _csUmodeTypes_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 uhAccountuhHostuhUser_PingConnectingcsNicksendMsgnewNetworkState applyMessage squelchIrcMsgiHaveOpinitialMessagesisChannelIdentifiercsUsernextTimedActionapplyTimedActionsendModeration useChanServ sendTopicExtensionStateMatcher matcherBefore matcherAfter matcherPred 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_clientRtsStats_clientStsPolicyclientActivityBarclientActivityReturn clientBell clientConfigclientConfigPathclientConnectionsclientDetailViewclientErrorMsg clientEventsclientExtensionsclientExtraFocus clientFocus clientHeightclientIgnoreMask clientIgnores clientLayoutclientLogQueueclientNetworkMapclientPrevFocus clientRegexclientRtsStats clientScrollclientShowPingclientStsPolicyclientSubfocus clientTextBoxclientTextBoxOffset clientWidth clientWindowsesActiveesMVar esStablePtrclientConnectionclientFirstLine clientLinewithClientState abortNetworkrecordChannelMessage identIgnoredrecordIrcMessagerecordNetworkMessage clientTick consumeInputcurrentCompletionListcurrentNickCompletionModechannelUserList clientMatcher buildMatcherclientActiveCommand urlPattern urlMatches removeNetwork addConnectionapplyMessageToClientState scrollClientclientExtraFocusesjumpToActivity jumpFocus changeFocus setExtraFocuschangeSubfocus returnFocus advanceFocus retreatFocusadvanceNetworkFocusclientHighlightsclientHighlightsNetworkclientWindowNames clientPaletteclientAutoconnectsclientToggleHideMeta windowsImagesuserListImagesuserInfoImagesurlSelectionViewchatMessageImagesmaskListImages keyMapLines digraphLineschannelInfoImagesclientStartExtensionsclientStopExtensionsclientChatExtensionclientNotifyExtensionsclientCommandExtensionclientExtTimerstatusLineImageminorStatusLineImagementionsViewLinesCommandSectioncmdSectionNamecmdSectionCmdsCommandcmdNamescmdArgumentSpeccmdDocumentationcmdImplementation CommandImpl ClientCommandNetworkCommand ChatCommandChannelCommand CommandResultCommandSuccessCommandFailure CommandQuitexecuteexecuteUserCommandcommandExpansion tabCompletioncommands commandsListhelpImageLines viewLines textboxImage drawLayout scrollAmount clientPicture eventLoopupdateTerminalSizeGlirc_cancel_timerGlirc_set_timerGlirc_resolve_pathGlirc_is_logged_onGlirc_is_channelGlirc_set_focusGlirc_current_focusGlirc_free_stringsGlirc_free_stringGlirc_clear_windowGlirc_mark_seenGlirc_channel_masksGlirc_channel_modesGlirc_user_channel_modesGlirc_user_account 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_user_accountglirc_user_channel_modesglirc_channel_modesglirc_channel_masksglirc_mark_seenglirc_clear_windowglirc_free_stringglirc_free_stringsglirc_current_focusglirc_set_focusglirc_is_channelglirc_is_logged_onglirc_resolve_pathglirc_set_timerglirc_cancel_timerdepsbaseForeign.Storablepoke emptyExecCmd powerWords Data.OldListwordsGHC.BaseString text-1.2.3.1Data.Text.Internal splitCommonsinglebothall childKeys!vty-5.25.1-CtFzdV69GLHKUsGgKnDqKvGraphics.Vty.AttributesdefAttrcolorNumberSpecrgbSpec actionInfosexceptionToLines'%irc-core-2.6.0-1ugfQPxbUB14zNuKN6CbQw Irc.MessageIrcMsg GHC.MaybeNothingJustremapGraphics.Vty.Image.InternalImage splitOptions dropSpaces lineWrap'defaultNickColorPalette Irc.UserInfoUserInfoparseMaskComponents translate isMetaChar filterContext digraphTableStReadyMatchFoundSkip2Skip1 lookupDigraphdigraphs currentLine forwardLine backwardLineupdateYankBuffer Data.String fromStringghc-prim GHC.Classes<= currentWord tabSearchprotocolFamilySpec#hookup-0.2.2-5uaUgLqn86CH0fMRwwdekCHookup ConnectiondefaultWindowNamesgetOldConfigPathdirectory-1.3.3.0System.DirectorygetAppUserDataDirectorygetXdgDirectory System.Directory.Internal.Common XdgConfigemptyConfigFilereadFileCatchNotFoundreadConfigurationFileexplainLoadError resolvePathsdefaultPaddingSidenickPaddingSpecfullNickPaddingSpec modifierSpec layoutSpeckeyBindingSpecactBindingSpeckeySpecdefaultRtldFlagssimpleExtensionSpecfullExtensionSpecbuildServerMapstatusMsgImage prefixImage bodyImage time-1.8.0.2&Data.Time.LocalTime.Internal.ZonedTime ZonedTime datetimeImage ircLinePrefix ircLineImagefullIrcLineImageseparatedParamsircWordsprettyUnixTime prettySecondshighlightNicks summaryLineNestedIO GHC.TypesTrue Irc.RawIrcMsg RawIrcMsgnest1nest2 withCommandversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNamedefaultOptionsoptions gitHashTxt gitDirtyTxtStatsgetStatsstatsToEntriesstr SemigroupMonoid$fMonoidStrictUnitmappend$fSemigroupStrictUnit<>stimes overStrictlens-4.17-aFUlRiupqdGKqVeQI6T4SControl.Lens.TypeSetterControl.Lens.Setterover setStrictsetzonedTimeLocalTimeLens&Data.Time.LocalTime.Internal.LocalTime LocalTimelocalTimeTimeOfDay localTimeDaynoReply pruneUsers doWelcome Irc.Codes RPL_WELCOME doBadNickERR_NICKNAMEINUSErecordListEntrysaveList squelchReplyupdateUserInfomassRegistrationnextForgetActionnextPingActiondoMode selectCapsisupport ParkState _esActive_esMVarGHC.MVarMVar _esStablePtr GHC.Stable StablePtr FocusSelector stepFocus TraversalsplitStatusMsgModes msgImportance ircIgnorablecomputeMsgLineSigilscomputeUserSigilsupdateTransientErrorrecordWindowLine toWindowLine' toWindowLinemarkSeennextAvailableKeyapplyWindowRenames recordLogLinenetworkChannelListdrawmetadataWindowLine MetadataStatewindowLinesToImages startMetadatatransitionMetadatagatherMetadataLines drawEntrystart1 clientParkchat1message1 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 TimerEvent ExtTimerEventgetEvent earliestEventbeep doNetworkOpendoNetworkClosedoNetworkError doNetworkLineclientResponsecomputeEffectiveTime parseZncTimelookups doVtyEventdoActiondoCommandResultclientShutdown executeInput doTimerEventreconnectLogic processStsprocessSaslEcdsaprocessConnectCmd recordError derefToken peekFgnMsgpeekFgnStringLen