!;       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQR 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 { | } ~                       !!!!!!!!!!!!!!!!!!!!!!!!!!"#########$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%&'''''''''''''''''''''''''''''''''''''''''''''''' ' ' ' ' ''''''''''''''''''' '!'"'#'$'%'&'''(')'*'+','-'.'/'0'1'2'3(4(5(6(7(8(9(:(;(<(=(>(?(@(A(B(C(D(E(F(G(H(I(J(K(L(M(N(O(P(Q(R(S(T(U(V(W(X(Y(Z([(\(](^(_(`(a(b(c(d(e(f(g(h(i(j(k(l(m(n(o(p(q(r(s(t(u(v(w(x(y(z({(|(}(~(((((((((((((((((((((((((((()**+,-./0112333333333333333333333333345677899::::::::::::::::::::::::::::::::::::A;*Dynamically generated configuration moduleSafe5glircCTransitive dependencies for this package computed at configure-timeglircpackage name, version numberBinding to ecdsatool(c) Eric Mertens, 2016ISCemertens@gmail.comSafe>glircRIdentifier 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"#j*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 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 2 and 3. enum message_code;-glircDynamic import for $..glircDynamic import for %./glircDynamic import for &.0glircDynamic import for '.1glircDynamic import for (.2glirc]Normal client message. Unread counter increments, but no client bell or error status update.3glirc[Important client message. Unread counter increments, bell rings, and error status updates.4glirc6Allow the message to proceed through the client logic.5glirc)Drop the message from further processing.6glircLike  except it doesn't write to NULL7glirc7Marshal a text as a malloced null-terminated CStringLen8glirc8Marshal a text as a temporary null-terminated CStringLen9glirc struct glirc_string:glirc struct glirc_command;glirc struct glirc_message=glirc struct glirc_extension$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 6  !"#$%&'()*+,-./0123456786 !"('&%$  #10/.-+,23)*458763Argument specifications used within client commands(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'Fn_Mglircrequired names glircoptional names @CABDEFGHIJKLMGKHIMLJDEF@CAB-Interpret argument specifications as a parser(c) Eric Mertens, 2017ISCemertens@gmail.comSafe&'pNN Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNone3 Sglirc 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.Uglircoutput networkVglircoutput channelWglirccommand filenameXglirc stdin sourceYglirccommand argumentsglircDefault values for /exec to be overridden by flags.cglircParse the arguments to /exec> looking for various flags and the command and its arguments.dglircCExecute 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.cglircexec arguments glircerror or parsed command dglircexec configuration glircerror lines or output lines OPQRSTUVWXYabcdSTUVWXYOPQRbacd9Parser and evaluator for string interpolation in commands(c) Eric Mertens, 2016ISCemertens@gmail.comSafe&'QVkglirc%Parsed chunk of an expandable commandlglirc regular textmglircinline variable $x or ${x y}nglircinline variable $1 or ${1}oglirc bracketed variable with default ${x|lit}pglirc2Specification used when unspecified, no arguments.rglircParse a / searching for the expansions as specified in k. $$ is used to escape a single $.sglircAttempt 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.sglircvariable resolution glircargument index resolution glircchunks glircconcatenated, expanded chunks efghijklmnopqrsklmnorsghijefqpTrie for recognizing commands(c) Dan Doel, 2016ISCemertens@gmail.comSafe3Lwglirc%Possible results of recognizing text.xglirc.text matched exactly, yielding the given valueyglirc8text would be recognized if joined to the given suffixeszglirc%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 w 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 . wyxz{|}~ {|wyxz}~*Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone/glircAParse a text attribute. This value should be a sections with the fg and/or bg attributes. Otherwise it should be a color entry that will be used for the foreground color. An empty sections value will result in glirc#Parse a color. Support formats are:Number between 0-255 Name of colorRGB values of color as a listglirc4Match integers between 0 and 255 as Terminal colors.glirckConfiguration section that matches 3 integers in the range 0-255 representing red, green, and blue values. Configuration schema for macros(c) Eric Mertens, 2017ISCemertens@gmail.comNone/ Programmable keyboard actions(c) Eric Mertens, 2016ISCemertens@gmail.comNoneQVglircCLookup table for keyboard events to actions. Use with keyToAction.glirc/Actions that can be invoked using the keyboard.glirc/Names and default key bindings for each action.bNote that Jump, Insert and Ignored are excluded. These will be computed on demand by keyToAction.glirc%Render action as human-readable text.glircCLookup the action to perform in response to a particular key event.glirc&Bind a keypress event to a new action.glirc(Unbind the action associated with a key.glircDefault key bindingsglircactions glircjump modifier glircwindow names glircactual modifier glirckey glircaction glirc modifiers glirc key glirc action glirc actions glirc modifiers glirc key glirc actions 22 -Human-readable versions of connection failure(c) Eric Mertens, 2016ISCemertens@gmail.comNonemglircBCompute the message message text to be used for a connection errorglircnetwork error glircclient lines glircnetwork error glircclient lines  'Hooks into the operation of the client.(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglircIdentifying name for the hookglirc0Whether the remapping should affect client stateglirc"(Partial) message remapping actionglircThe possible results of a 2 action. A hook can decline to handle a message (), filter out a message (9), or change a message into an arbitrary other message ().glirccontinue processingglirc stop processing and drop messageglirc&stop processing and return new messageglirc$Apply the given message hooks to an A. The hooks are tried in order until one handles the message. A 9 result means the message was filtered out by a hook. A  result contains the actual  to be processed. %Hook to remap znc buffextras messages(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglircMap ZNC's buffextras messages to native client messages. Set debugging to pass through buffextras messages that the hook doesn't understand.glircenable debugging glircenable debugging Available hooks(c) Dan Doel, 2016ISCdan.doel@gmail.comNoneglirc All the available message hooks.Packed vty Image type(c) Eric Mertens, 2016ISCemertens@gmail.comNone7glircPacked, strict version of & used for long-term storage of images.glirc"Width in terms of terminal columnsglirc image width *Parser for mIRC's text formatting encoding(c) Eric Mertens, 2016ISCemertens@gmail.comNoneCglircEParse mIRC encoded format characters and hide the control characters.glircParse mIRC encoded format characters and render the control characters explicitly. This view is useful when inputting control characters to make it clear where they are in the text.glirc"Safely render a control character.glirc Render a  with default attributes and replacing all of the control characters with reverse-video letters corresponding to caret notation.Chat message view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneglircTrailing space with default attributes deals with bug in VTY where the formatting will continue past the end of chat messages. This adds an extra space if a line doesn't end on the terminal edge.glircCThis version of line wrap wraps without regard for word boundaries.glircXList of image widths suitable for breaking the image on that correspond to word breaks.glirc%Drop the leading spaces from an imageglircterminal width glircunwrapped image glircwrapped image glircterminal width glircunwrapped image glircwrapped image glircterminal width glircprefix image glircunwrapped image glircwrapped image glircfirst line length glircimage glircsplits glircfirst line length glircimage glircsplits 'Palette of colors used to render the UI(c) Eric Mertens, 2016ISCemertens@gmail.comNone Zglirc.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 commandglirccommand argument placeholderglircDivider between split windowsglirc$Divider between new and old messagesglircBDefault UI colors that look nice in my dark solarized color schemeglircSDefault nick highlighting colors that look nice in my dark solarized color scheme.glircTList of palette entry names and lenses for accessing that component of the palette.,     ,     6Interpretation of argument specification as a renderer(c) Eric Mertens, 2017ISCemertens@gmail.comNone&'glircpalette glircenvironment glircrender placeholders glircspecification glircuser input None/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.comNone3glirc7Compute a searchable text representation of the message !"#$%&'()*+,-./01234 !"#102$%&'()*+,-./43IRC channel session state(c) Eric Mertens, 2016ISCemertens@gmail.comNone?glirc5Dynamic information about the state of an IRC channelAglirc topic textBglircauthor and timestamp for topicCglirc channel URLDglircuser list and sigilsEglircchannel settings and parametersFglircmode, mask, setter, set timeGglirccreation time of channelHglircdelayed op messagesXglircConstruct an empty ?YglircAdd a user to the user listZglirc Remove a user from the user list[glircRename a user in the user list\glircSet the channel topic#789:;<=>?@ABCDEFGHLMNOPQRSTUVWXYZ[\#?@ABCDEFGHPQRSNMLO789:VW;<=>TUX\YZ[9Types for representing the current window being displayed(c) Eric Mertens, 2016ISCemertens@gmail.comNone.9]glircCurrently focused window^glirc No network_glircNetwork`glircNetwork Channel/NickcglircFilter argument for mdglirc no filtereglirconly network windowsfglirconly channel windowsgglirconly user windowshglirc Subfocus viewiglirc Show messagesjglircShow channel metadatakglircShow channel user listlglirc%Show channel mask list for given modemglircShow client windowsnglircShow current paletteoglircShow all mentionspglircShow all digraphsqglircShow key bindingsrglirc&Show help window with optional commandsglircShow GHC RTS statisticstglircShow ignored masksxglirc4Return the network associated with the current focusyglircUnfocused first, followed by focuses sorted by network. Within the same network the network focus comes first and then the channels are ordered by channel identifierxglircnetwork ]^_`cdefghijklmnopqrstuvwx]^_`hijklmnopqrstcdefgxwvu2Types and operations for managing message buffers.(c) Eric Mertens, 2016ISCemertens@gmail.comNone>?F~glirc;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.comNoneLlglircGenerate lines used for /palettet. These lines show all the colors used in the current palette as well as the colors available for use in palettes.>/Template Haskell quasi-quoter for digraph table(c) Eric Mertens, 2017ISCemertens@gmail.comSafeN ?Character mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comSafeT glirc+States for the digraph lookup state machine glirc!ready to match two-character name glirc)first character matched, ready for second glirc(both characters matched, return the nextglircskip the next two charactersglircskip the next characterglirc[Find the entry in the digraph table give a two-character key and return the matched value.$Multiline text container with cursor(c) Eric Mertens, 2016ISCemertens@gmail.comNonei^glirc0Zipper-ish view of the multi-line content of an EditBox . Lines  the  are stored in reverse order.glircDefault  valueglirc Single line .glirc!Shifts the first line off of the =, yielding the text of the line and the rest of the content.glirclWhen at beginning of line, jump to beginning of previous line. Otherwise jump to beginning of current line.glircVWhen at end of line, jump to end of next line. Otherwise jump to end of current line.glirc0Move the cursor left, across lines if necessary.glirc1Move the cursor right, across lines if necessary.glirc3Move the cursor left to the previous word boundary.glirc0Move the cursor right to the next word boundary.glirc'Delete the character before the cursor.glirc,Delete the character after/under the cursor.glirc/Insert character at cursor, cursor is advanced.glircSmarter version of  that removes spurious newlines.glircOInsert string at cursor, cursor is advanced to the end of the inserted string.glirc)Advance to the beginning of the next lineglirc'Retreat to the end of the previous lineglircmUse the two characters preceeding the cursor as a digraph and replace them with the corresponding character.Console-mode text box(c) Eric Mertens, 2016ISCemertens@gmail.comNone|4 glircDefault  valueglircDSets the given string to the yank buffer unless the string is empty.glircIndicate that the contents of the text box were successfully used by the program. This clears the first line of the contents and updates the history.glircAUpdate the editbox to reflect the earlier element in the history.glirc?Update the editbox to reflect the later element in the history.glirc.Jump the cursor to the beginning of the input.glirc(Jump the cursor to the end of the input.glircLDelete all text from the cursor to the end and store it in the yank buffer.glircRDelete all text from the cursor to the beginning and store it in the yank buffer.glirc%Insert the yank buffer at the cursor.glircKKill the content from the cursor back to the previous word boundary. When yank( is set the yank buffer will be updated.glircJKill the content from the curser forward to the next word boundary. When yank' is set the yank buffer will be updatedglirc8Insert a character at the cursor and advance the cursor.glircyank glircyank ))Tab-completion logic(c) Eric Mertens, 2016ISCemertens@gmail.comNone glirc'Class for types that are isomorphic to > and which can support a total order and a prefix predicate. @A ( x) == x  (@A x) == x @B x y ==> x  y glircDCheck if the first argument is a lexicographic prefix of the second.glirc Convert to a .glirc!Word completion prefix and suffixglirc3Word completion without adding any prefix or suffixglirc>Word completion adding a ": " suffix at the beginning of linesglirc+Word completion using a "@" prefix intendedglirc&Perform word completion on a text box.The leading update operation is applied to the result of tab-completion when tab completing from the beginning of the text box. This is useful when auto-completing a nick and including a trailing colon.The reversed parameter indicates that tab-completion should return the previous entry. When starting a fresh tab completion the priority completions will be considered in order before resorting to the set of possible completions.glircFind the word preceeding the cursor skipping over any characters that can be found in the prefix and suffix for the current completion mode.glircRFind the next entry in a list of possible choices using an alphabetical ordering.glircleading update operation glirc reversed glircpriority completions glircpossible completions glircreversed glircsearch prefix glircprevious result glircposibilities  )Settings for an individual IRC connection(c) Eric Mertens, 2016ISCemertens@gmail.comNone/#glirc'Security setting for network connectionglircTLS connectionglirc+TLS connection without certificate checkingglircPlain connectionglircStatic server-level settingsglircconnection nicknamesglircconnection usernameglircconnection realname / GECOSglirc CTCP userinfoglircserver password glirc SASL username glircSASL plain password glircSASL ecdsa private key glircserver hostname glirc server portglircuse TLS to connectglircpath to client TLS certificateglircpath to client TLS keyglirc0additional CA certificates for validating serverglircOpenSSL cipher suiteglirc.commands to execute upon successful connectionglirchostname of SOCKS proxyglircport of SOCKS proxyglirc"Channels with chanserv permissionsglircFlood limiter penalty (seconds)glirc!Flood limited threshold (seconds)glircInitial message hooksglirc+The name referencing the server in commandsglirc1The number of reconnect attempts to make on errorglirc)Connect to this network on server startupglirc$Nick completion mode for this serverglircDirectory to save logs of chatglircProtocol family to connect with>glircJLoad the defaults for server settings based on the environment variables.Environment variables USER,  IRCPASSSWORD, and  SASLPASSWORD are used.glirc%Specification for IP protocol family.A     "#$%&'()*+,-./0123456789:;<=>?@A     ?@,<0=-432'.79:;8$56#%&)*1"+(/>#Interface to the connection package(c) Eric Mertens, 2016ISCemertens@gmail.comNoneAglirc Create a new 6 which will be closed when the continuation finishes.AAEvent-based network IO(c) Eric Mertens, 2016ISCemertens@gmail.comNoneĤ Bglirc-Exceptions used to kill connections manually.Cglircsent when ping timer expiresDglirc*sent when client commands force disconnectEglircThe 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.Fglirc'Event for successful connection to hostGglirc/Event for a new recieved line (newline removed)Hglirc6Final message indicating the network connection failedIglirc8Final message indicating the network connection finishedJglircHandle for a network connectionKglirc:Identifier used to match connection events to connections.LglircSchedule a message to be transmitted on the network connection. These messages are sent unmodified. The message should contain a newline terminator.Mglirc(Force the given connection to terminate.Nglirc9Initiate a new network connection according to the given R. All events on this connection will be added to the given queue. The resulting J^ value can be used for sending outgoing messages and for early termination of the connection.Nglircdelay in seconds glirc)Identifier to be used on incoming events BCDEFGHIJKLMN JKEFGHINLMBCD *Client configuration format and operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#/65RglircJConfiguration information for run-time loaded dynamic library extensions.Tglircpath to shared objectUglircdynamic linker flagsVglirc%arguments to the extension on startupWglirc0Failure cases when loading a configuration file.Xglirc-Error message from reading configuration fileYglirc"Error message from parser or lexerZglirc/Error message from loading parsed configuration\glirc/Vertically stack all windows in a single column]glirc1Vertically stack extra windows in a second column^glirc*Setting for how to pad the message prefix._glirc.Whitespace add to the left side of chat prefix`glirc/Whitespace add to the right side of chat prefixaglircNo whitespace addedbglirc\Top-level client configuration information. When connecting to a server configuration from e$ is used where possible, otherwise d is used.dglircDefault connection settingseglircHost-specific settingsfglircUser-customized color palettegglirc(Names of windows, used when alt-jumping)hglircExtra highlight nicks/termsiglircPadding of nicks in messagesjglirccommand macroskglircextensions to loadlglircpaths to url opening executablemglircinitial ignore mask listnglirc(initially visibility of the activity baroglircnotify terminal on mentionpglirc+default setting for hidemeta on new windowsqglirckeyboard bindingsrglircDefault layout on startupsglircvisibility of ping timetglirc!Modifier used for jumping windowsuglircdefault instanceglircThe default client behavior for naming windows is to use the first two rows of a QWERTY keyboard followed by the first two rows combined with SHIFT.glircUses  to find ~.glircconfigglircUses    to find ~.config glirc/config!glirc_Empty configuration file used when no path is specified and the configuration file is missing."glircYAttempt to read a file using the given handler when a file does not exist. On failure a X 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: 15)glirc@Parse either a single modifier key or a list of modifier keys: meta, alt, ctrl*glirc Parse either  one-column or  two-column and return the corresponding [ value.+glirckParse a single key binding. This can be an action binding, command binding, or an unbinding specification.,glircYParse a single action key binding. Action bindings are a map specifying a binding using - and an action: $bind: "M-a" action: jump-to-activity-glircCCustom configuration specification for emacs-style key descriptions.glircDefault dynamic linker flags:  RTLD_LOCAL and RTLD_NOW/glirc[Given only a filepath build an extension configuration that loads the extension using the . and no arguments.0glircFull 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."glirc file to read glirc!error handler for not found case #glirc&just file or use default search paths glircpath to configuration file 1glirc defaults glircconfiguration file path =RSTUVWXYZ[\]^a_`bcdefghijklmnopqrst{|}~=bcdefghijklmnopqrstWXYZ[\]^a_`RSTUV}~{|!Renderer for message lines(c) Eric Mertens, 2016ISCemertens@gmail.comNone;"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.2glirc+Render the sigils for a restricted message.3glirc Render a ; given the sender's sigils and the nicknames to highlight.4glirc Render a ; given the sender's sigils and the nicknames to highlight.glirc Render a 5 as time using quiet attributes 23:15 6glirc Render a 5A 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.7glircQRender the sender of a message in normal mode. This is typically something like  @nickname:8glircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.9glircRender a chat message given a rendering mode, the sigils of the user who sent the message, and a list of nicknames to highlight.:glircProcess list of } as individual IRC formatted words separated by a special separator to distinguish parameters from words within parameters.;glircProcess list of " as individual IRC formatted words<glircETransform string representing seconds in POSIX time to pretty format.=glircJRender string representing seconds into days, hours, minutes, and seconds.glirc*Render a nickname in its hash-based color.glircRender an a full user. In normal mode only the nickname will be rendered. If detailed mode the full user info including the username and hostname parts will be rendered. The nickname will be colored.glircGRender an identifier without using colors. This is useful for metadata.glircParse message text to construct an image. If the text has formatting control characters in it then the text will be rendered according to the formatting codes. Otherwise the nicknames in the message are highlighted.>glircGiven a list of nicknames and a chat message, this will generate an image where all of the occurrences of those nicknames are colored.glircKReturns image and identifier to be used when collapsing metadata messages.glirc:Image used when treating ignored chat messages as metadataglircARender the normal view of a chat message line padded and wrapped.glirctime of message glircmessage body glircprefix, image, full 2glircsigils glirc padding mode glirc input image glirc padded image glirccolor palette glircdraw mode glircmy nicknames glircidentifier to draw glirccolor palette glircmode glircmy nicks glircuserinfo to drawglirc palette glirc my nicks glirc other nicks glircexplicit controls rendering glirc input text glirc colored text >glirc my nicks glirc other nicks glircpalette glircdraw columns glircnick padding glircwindow line glircwrapped lines "(Line renderers for ignore mask list view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneAEglirc-Render the lines used in a channel mask list.?glirc7Render a summary describing the number of ignore masks.glirc ignore masks glirc palette ?glirc ignore masks glirc palette #Support for logging IRC traffic(c) Eric Mertens, 2016ISCemertens@gmail.comNoneIglirc: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"#KQVn@glirc.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; glircLoad 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 message callbacks in the list of extensions. This operation marshals the IRC message once and shares that across all of the callbacks.Returns A< to pass message to client. Returns 'False to drop message.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 A< to pass message to client. Returns 'False to drop message.glircBNotify an extension of a client command with the given parameters.Bglirc Marshal a C into a  ; which will be valid for the remainder of the computation.DglircReturn the bracket IO action.EglircIWrap up a bracketing IO operation where the continuation takes 1 argumentFglircIWrap up a bracketing IO operation where the continuation takes 2 argumentglircextension configuration glircclientstate stable pointer glircnetwork glirccurrent message glircall active extensions glircshould pass message glircclientstate stable pointer glircnetwork glirctarget (channel or user) glircmessage body glircall active extensions glircshould pass message glircclient state stableptr glirccommand glircextension to command Bglirc network glirc message Gglircnetwork glirctarget glircmessage Hglirccommand CSafeoHIJKLMNOP%"Processing of command-line options(c) Eric Mertens, 2016ISCemertens@gmail.comNone^y glircCommand-line optionsglircconfiguration file pathglircinitial networksglircdisable autoconnectglircshow help messageglircshow version messageglirc+show version of ALL transitive dependenciesglircshow configuration file formatQglircDefault values for RglircOption descriptionsglircuLoad command line options. This action will terminate early in the case of the version flag, help flag, or an error.SglircReturns  "-SOMEHASH" when in a git repository, "" otherwise.TglircReturns "-dirty"! when in a dirty git repository, "" otherwise.  D.Human readable interface to GHC RTS statistics(c) Eric Mertens, 2017ISCemertens@gmail.comSafe{UVW&View current GHC RTS statistics(c) Eric Mertens, 2017ISCemertens@gmail.comNone~glircGenerate lines used for  /rtsstats.EStrict unit type(c) Eric Mertens, 2016ISCemertens@gmail.comSafeXglircUnit data type with a strict Y and Z instances.[glirc\ is strict]glirc^ is strict, _ is O(1)X`FLens utility functions(c) Eric Mertens, 2016ISCemertens@gmail.comSafeiaglircModify the target of a bd with a function. The result is strict in the results of applying the function. Strict version of cdglirc9Set a value strictly in the set value. Strict version of e.fglircg to the h component of a 5iglircg" to the 'TimeOfDay component of a h.jglircg" to the 'TimeOfDay component of a h.adfij'IRC network session state(c) Eric Mertens, 2016ISCemertens@gmail.comNoneȏ5glircTimer-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.glircusernameglirchostnameglircservices accountglirc'State of the authentication transactionglircno active transactionglircPLAIN mode initiatedglircECDSA-NIST mode initiatedglirc*ECDSA-NIST user sent waiting for challengeglirc%State tracked for each IRC connectionglircnetwork connection identifierglircjoined channelsglircnetwork socketglircchannel mode meaningsglircchannel identifier prefixesglirc!state for multi-message sequencesglircmodes for the connected userglirc)modes that prefix statusmsg channel namesglirc!settings used for this connectionglirc/usermask used by the server for this connectionglirc!user and hostname for other nicksglirc%maximum mode changes per MODE commandglircname of network connectionglirc2names of message hooks to apply to this connectionglirctime for next ping eventglirc%latency calculated from previous pongglircstate of ping timerglirctime of last message received&glirc Transmit a C; on the connection associated with the given network. For PRIVMSG and NOTICEF overlong commands are detected and transmitted as multiple messages.'glircqConstruct a new network state using the given settings and default values as specified by the IRC specification.kglircUsed for updates to a  that require no reply. noReply x = ([], x)lglirc Restrict  A to only users are in a channel that the client is connected to.mglirc001 n 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.oglircHandle p errors when connecting.qglirc'Add an entry to a mode list transactionrglircKSave a completed ban, quiet, invex, or exempt list into the channel state.sglirc[These replies are interpreted by the client and should only be shown in the detailed view.)glircReturn A for messages that should be hidden outside of full detail view. These messages are interpreted by the client so the user shouldn't need to see them directly to get the relevant information.*glirc>Predicate to test if the connection has op in a given channel.tglircProcess a list of WHO replies.glirc:Compute the earliest timed action for a connection, if anyuglircCompute 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.vglirc9Compute the next action needed for the client ping logic./glircApply the given  to a connection state.0glircUsed to send commands that require ops to perform. If this channel is one that the user has chanserv access and ops are needed then ops are requested and the commands are queued, otherwise send them directly. 'glircunique network ID glircnetwork name glircserver settings glircactive network connection glircinitial ping status glircnew network state mglircmessage received glircmy nickname oglirc bad nickname glircreplies, updated state qglircmask glircset by glirc set time rglircmode glircchannel wglirctime of message glircsender glircchannel glircmode flags glircmode parameters xglircnetwork state glircserver caps glirccaps to enable yglirc  "key=value"0glircchannel glirccommands glircnetwork state 1glircchannel glircnetwork state glircchanserv available 2glircchannel glirctopic glircnetwork state R !"#$%&'()*+,-./012R'% -#"!,*&+()$./102(/Primary client state type and update operations(c) Eric Mertens, 2016ISCemertens@gmail.comNone?X3glircState of the extension API including loaded extensions and the mechanism used to support reentry into the Haskell runtime from the C API.zglircactive extensions{glirc| used to with o}glirc~ used with o4glirc(All state information for the IRC client6glircclient message buffers7glircpreviously focused buffer8glirc"focus prior to jumping to activity9glirccurrently focused buffer:glirccurrent view mode;glircextra messages windows to view<glircstate of active connections=glircincoming network event queue>glircnetwork name to connection ID?glircclient configuration@glircclient configuration file pathAglircprimary text boxBglirc"size to crop from left of text boxCglirccurrent terminal widthDglirccurrent terminal heightEglircbuffer scroll linesFglircuse detailed rendering modeGglircvisible activity barHglircvisible ping timeIglircoptional persistent filterJglirclayout mode for split screenKglircsound a bell next drawLglirc ignored masksMglirc,precomputed ignore regular expression (lazy)Nglircstate of loaded extensionsOglirclog lines ready to writePglirctransient error box textQglircmost recent GHC RTS statsglircSelection function used in oglirc=Prepare the client to support reentry from the extension API.pglirc for finding the I associated with a given network if that connection is currently active.qglirc-The full top-most line that would be executedrglirc*The line under the cursor in the edit box.sglircConstruct an initial 4 using default values.tglircTForcefully terminate the connection currently associated with a given network name.uglirc;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 listvglircCPredicate for nicknames to determine if messages should be ignored.wglircARecord 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.xglirc$Record a message on a network windowglircFRecord window line at the given focus creating the window if necessaryglirc& but with mostly defaulted parameters.yglirc2Function applied to the client state every redraw.glircAMark the messages on the current window (and any splits) as seen.zglirc@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.glircStrict version of ~glircFConstruct a text matching predicate used to filter the message window.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.glirc*Actions to be run when exiting the client.glircUnload all active extensions.glirc9Start extensions after ensuring existing ones are stoppedglirc0Scroll 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 A.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 oglirc4client state glirc4continuation using the stable pointer to the client pglircnetwork rglircline number, line content tglircnetwork uglircnetwork glircchannel glirc message glirc target glirc client state glircpossible modes glirctarget glircactual modes, actual target vglirc target user glirc client state glirc is ignored wglircnetwork glircnetwork glircchannel glircsigils glircnetwork glircchannel glircuser glircsigils glircnetwork glirc channels }glircnetwork glircchannel glircnicks ~glircclient state glircoptional predicate glircclient state glircoptional predicate glirc!client state glirc!command name and argument string glircattempts glircoptional disconnect time 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 g3456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~g456789:;<=>?@ABCDEFGHIJKLMNOPQmjkWl^Z]d\UgXRhic`_pT[ebSYafVso~}z{vqrty|uxw3n) View of the list of open windows(c) Eric Mertens, 2016ISCemertens@gmail.comNoneE\glirc)Draw the image lines associated with the /windows command.*)Line renderers for channel user list view(c) Eric Mertens, 2016ISCemertens@gmail.comNoneM'glircRender the lines used by the /users command in normal mode. These lines show the count of users having each channel mode in addition to the nicknames of the users.glircRender lines for the /usersu command in detailed view. Each user will be rendered on a separate line with username and host visible when known.glircnetwork glircchannel glircnetwork glircchannel +URL selection module(c) Eric Mertens, 2016ISCemertens@gmail.comNoneVglirc1Generate 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.comNone_Eglirc-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.comNonebglirc,Render the lines used in a channel mask listglirc Mask mode glirc network glirc channel glirc draw width .List of the current key map(c) Eric Mertens, 2017ISCemertens@gmail.comNonef=glircHRender the lines of a table showing all of the available digraph entriesglirc client state glirc output lines /Character mnemonics(c) Eric Mertens, 2016ISCemertens@gmail.comNonej4glircHRender the lines of a table showing all of the available digraph entriesglirc draw width glirc client state glirc output lines glirc3-character entry 0Channel information renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNonelglirc,Render the lines used in a channel mask listglircnetwork glircchannel 1Renderer 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 2 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 glircpalette glircdraw columns glircnick padding glircdetailed view glircwindow name glircwindow focus glircwindow 3 Implementation of slash commands(c) Eric Mertens, 2016ISCemertens@gmail.comNoneCVLglircuA command section is a logical grouping of commands. This allows for showing more structure in the help menu system.glircA command is a list of aliases, an argument specification, implementation, and documentation. The arguments and implementation must match so that the parsed arguments will match what the implementation expects.glirc>Names of this command, first in the list is the "primary" nameglirc-Specification of the arguments of the commandglirc5Multi-line IRC-formatted documentation text used for /helpglircCImplementation of the command for both execution and tab completionglircPair of implementations for executing a command and tab completing one. The tab-completion logic is extended with a bool indicating that tab completion should be reversedglircno requirementsglircrequires an active networkglircrequires an active chat windowglirc!requires an active channel windowglirc=Type of commands that require an active channel to be focusedglirc=Type of commands that require an active network to be focusedglirc!Type of commands that always workglirc%Possible results of running a commandglircDContinue running the client, consume input if command was from inputglirc,Continue running the client, report an errorglircClient should closeglirc8Consider the text entry successful and resume the clientglirc7Consider the text entry a failure and resume the clientglirc>Command failure with an error message printed to client windowglirc5Interpret the given chat message or command. Leading /d indicates a command. Otherwise if a channel or user query is focused a chat message will be sent.glirc?Execute command provided by user, resolve aliases if necessary.The last disconnection time is stored in text form and is available for substitutions in macros. It is only provided when running startup commands during a reconnect event.glirc?Compute the replacement value for the given expansion variable.glircRespond to the TAB key being pressed. This can dispatch to a command specific completion mode when relevant. Otherwise this will complete input based on the users of the channel related to the current buffer.glirc;Treat the current text input as a chat message and send it.glircParse and execute the given command. When the first argument is Nothing the command is executed, otherwise the first argument is the cursor position for tab-completionglirc@Expands each alias to have its own copy of the command callbacksglirciMap of built-in client commands to their implementations, tab completion logic, and argument structures.glirc+Raw list of commands in the order used for /helpglirc.Provides no tab completion for client commandsglirc/Provides no tab completion for network commandsglirc/Provides no tab completion for channel commandsglirc:Provides nickname based tab completion for client commandsglirc;Provides nickname based tab completion for network commandsglirc;Provides nickname based tab completion for channel commandsglircImplementation of /exit command.glircWhen used on a channel that the user is currently joined to this command will clear the messages but preserve the window. When used on a window that the user is not joined to this command will delete the window.glircImplementation of /quoteJ. Parses arguments as a raw IRC command and sends to the current network.glircImplementation of /meglircImplementation of /ctcpglircImplementation of /noticeglircImplementation of /msgglircCommon logic for /msg and /noticeglircCommon logic for /msg and /notice returning the client stateglircImplementation of /windows" command. Set subfocus to Windows.glircImplementation of  /mentions# command. Set subfocus to Mentions.glircImplementation of /palette" command. Set subfocus to Palette.glircImplementation of  /digraphs# command. Set subfocus to Digraphs.glircImplementation of /keymap! command. Set subfocus to Keymap.glircImplementation of  /rtsstatsM command. Set subfocus to RtsStats. Update cached rts stats in client state.glircImplementation of /help command. Set subfocus to Help.glircTab completion for  /splits[+]. When given no arguments this populates the current list of splits, otherwise it tab completes all of the currently available windows.glircTab completion for /splits-J. This completes only from the list of active entries in the splits list.glirc3Parses a single focus name given a default network./The default is parameterized over an arbitrary 7 instance so that if you know the network you can use $ and if you might not, you can use glirc6Render a entry from splits back to the textual format.glircImplementation of /splitsglircImplementation of /splits+B. When no focuses are provided the current focus is used instead.glircImplementation of /splits-B. When no focuses are provided the current focus is used instead.glirc/connect! tab completes known server namesglirc\When tab completing the first parameter of the focus command the current networks are used.glircyThis command is equivalent to chatting without a command. The primary use at the moment is to be able to send a leading / to chat easily.glirc/query` command. Takes a channel or nickname and switches focus to that target on the current network.glirc/channel` command. Takes a channel or nickname and switches focus to that target on the current network.glircTab completion for /channel,. Tab completion uses pre-existing windows.glircSReturn the list of identifiers for open channel windows on the given network name.glircReconnect to the currently focused network. It's possible that we're not currently connected to a network, so this is implemented as a client command.glircsComplete the nickname at the current cursor position using the userlist for the currently focused channel (if any)glircImplementation of /reload(Attempt to reload the configuration fileglircSSupport file name tab completion when providing an alternative configuration file.NOT IMPLEMENTEDglircwThis function computes the list of required and optional parameters corresponding to the flags that have been entered.glircIUse the *!*@host masks of users for channel lists when setting list modes.Use the channel's mask list for removing modesUse the nick list otherwiseglirc=Predicate for mode commands that can be performed without opsglircsComplete the nickname at the current cursor position using the userlist for the currently focused channel (if any)glircImplementation of /exec command.glircImplementation of /grep and /grepiglircfocused channel glirccurrent network glirc arguments glircchat or command glircclient state glirccommand result glircdisconnection time glirccommand glircclient state glirccommand result glircdisconnect time glircclient state glircexpansion variable glircexpansion value glircreversed glircclient state glirccommand result glircchat message glircclient state glirccommand result glirctab-completion direction glirccommand glircclient state glirccommand result glirctarget glirctarget glircdefault network glirc [network:]targetglircword completion mode glirchints glircall completions glircreversed order glircclient state glirc reversed glircreversed order glircnetwork glircclient state glircopen channel windows glirc reversed glirc reversed glirc&network's mode behaviors glirc&polarity mode-letter unused-parameter glirc&required-names optional-names glirc&required-names optional-names glircmode polarity glircmode glircchannel glirc(hint, complete) glirc reversed glirccase sensitive 4Renderer for help lines(c) Eric Mertens, 2016ISCemertens@gmail.comNone&zglircGenerate either the list of all commands and their arguments, or when given a command name generate the detailed help text for that command.glircAGenerate detailed help lines for the command with the given name.glirc]Generate an explanation of the context where the given command implementation will be valid.glirc<Generate the lines for the help window showing all commands.glircdGenerate the help line for the given command and its specification for use in the list of commands.glircclient state glircoptional command name glircpalette glirchelp lines glirc client state glirc command name glirc palette glirc lines glirccommand implementation glirchelp line glircclient state glircpalette glirchelp lines glircclient state glircpalette glirccommand section glirchelp lines glircclient state glircpalette glirccommand name and aliases glircargument specification glircsummary help line 5View selection module(c) Eric Mertens, 2016ISCemertens@gmail.comNone'6Textbox renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNone:hglircCompute the UI image for the text input box. This computes the logical cursor position on the screen to compensate for VTY's cursor placement behavior.glirc5Renders the whole, uncropped text box as well as the  corresponding to the rendered image which can be used for computing the logical cursor position of the cropped version of the text box.glirc Version of wcwidth7 that accounts for how control characters are renderedglirc Version of wcswidth7 that accounts for how control characters are renderedglirc}Render the active text box line using command highlighting and placeholders, and WYSIWYG mIRC formatting control characters.glirc cursor column, new offset, imageglirc&client state glirc&my nicknames glirc&other nicknames glirc&macro completions glirc&palette glirc&content glirc&plain text rendering, image rendering glirc commands glirc focused glirc input text glirc output image 7'Layout code for the multi-window splits(c) Eric Mertens, 2016ISCemertens@gmail.comNoneVglirc?Compute the combined image for all the visible message windows.glirc4Layout algorithm for all windows in a single column.glirc4Layout algorithm for all windows in a single column.glirc#Draw one of the extra windows from /splitsglircGenerate an image corresponding to the image lines of the given focus and subfocus. Returns the number of lines overscrolled to assist in clamping scroll to the lines available in the window.glircConstructs a list of numbers with the length of the divisor and that sums to the dividend. Each element will be within one of the quotient.glirc@Compute the number of lines in a page at the current window size glirc1client state glirc1overscroll, cursor pos, next offset, final image glircclient state glircextra window names glircoverscroll and final image glirc,client state glirc,extra window names glirc,overscroll, cursor pos, offset, final image glircdraw width glircdraw height glircscroll amount glircclient state glircclient state glircdraw width glircdraw height glircfocus glircimage lines glircrendered window glircclient width glircavailable rows glirccurrent scroll glircfocused window glircoverscroll, rendered messages glirc"screen rows to fill glirc"number of extra windows glirc"list of heights for each division glirc dividend glirc divisor glircclient state glircscroll amount 8 UI renderer(c) Eric Mertens, 2016ISCemertens@gmail.comNone[glirc Generate a u for the current client state. The resulting client state is updated for render specific information like scrolling.glircPrimary UI render logicglirc client state glirc/text box cursor position, image, updated state 9Event loop for IRC client(c) Eric Mertens, 2016ISCemertens@gmail.comNoneZcglirc<Sum of the three possible event types the event loop handlesglircKey presses and resizingglircIncoming network eventsglirc'Timed action and the applicable networkglircBlock waiting for the next V. This function will compute an appropriate timeout based on the current connections.glirc:Compute the earliest scheduled timed action for the clientglirc"Apply this function to an initial 4 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.NetworkStateglirc!Find the ZNC provided server timeglirc6Parses the time format used by ZNC for buffer playbackglircgReturns 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 stateglircRespond to a VTY event.glirc,Map keyboard inputs to actions in the client glircProcess  and update the 40 textbox and error state. When quitting return . glirc9Execute the the command on the first line of the text box glircRespond to a timer event.glirc 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  glircthread failure reason glircfailed network glircclient state glirc!Network ID of message glirc!current time glirc!Raw IRC message without newlines glirc!client state  glircmessage time glircchallenge glircnetwork state glircclient state glircnow glirccurrent network glircclient state glirccommand glircnow glirccurrent network glircerror message glircclient state glircvty handle glircvty event glircclient state glircnothing when finished glircvty handle glircaction glircclient state  glircclear on success glirccommand result  glirc client state  glircNetwork related to event glircAction to perform glircclient state :9Foreign exports which expose functionality for extensions(c) Eric Mertens, 2016ISCemertens@gmail.comNone"#'glircType 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-pointglircType of  extension entry-pointglirc<Dereference the stable pointer passed to extension callbacksglirc Import a   into an CglircPeek 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.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.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.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 glircnewly allocated network string glircnetwork length glircnewly allocated target string glirctarget 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 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 $$GHIJJKKLMMNOPQQRSTUVWXYZ[\\]^_`abcdefghijkkllmnopqrstuvwxyz{|}~@                                                            !"#$%%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYYZ[\]^_`abcdefghijklmnoppqrsstuvvwxyz{|}~      @BA!!"#$%&'()*+,--./00123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                                                   !!!!!!!!!!!!!!!!!!!!!!!!!!"#########$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%&'''''''''' ' ' ' ' ''''''''''''''''''''' '!'"'#'$'%'&'''(')'*'+','-'.'/'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(Y(Z([(\(](^(_(`(a(b(c(d(e(f(g(h(i(j(k(l(m(n(o(p(q(r(s(t(u(v(w(x(y(z({(|(}(~((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((()**+,-./0112333333333333333333333333345677899::::::::::::::::::::::::::::::::: : : : ; = !" # $%&'() *+,-./0%12345>6?7?8?9?:?;?<?=?>?@ABCDEFGHIJKLM N OPQRPQSPQT U V W X Y Z [ \ ] ^ _ ` a b c d e!f!g!hijk!l!m!n!o!p!q!r!s!t"u$vEwx$y%z{$|$}$~$$CCCCCCCC%%%%DDDEEEEEEFFFiFF'''%'%'''''''''((((((((((((((((((((+,,,,,,/111111111122222223333333333333333333333333333333333 3 3 3 3 3333333333333333333 4!4"4#4$4%6&6'6(6)7*7+7,7-7.7/70128394959r969798999:9;9<9=9>9?9@9A9B9C9D9E9F9G9H9I9J:K:L:MN!glirc-2.28-9l5NmbutNp63v9JuYz0O3xClient.Authentication.EcdsaClient.CApi.TypesClient.Commands.Arguments.Spec Client.Commands.Arguments.ParserClient.Commands.ExecClient.Commands.InterpolationClient.Commands.RecognizerClient.Configuration.ColorsClient.Configuration.MacrosClient.EventLoop.ActionsClient.EventLoop.Errors Client.HookClient.Hook.Znc.Buffextras Client.HooksClient.Image.PackedImageClient.Image.MircFormattingClient.Image.LineWrapClient.Image.Palette"Client.Commands.Arguments.Renderer Client.MaskClient.MessageClient.State.ChannelClient.State.FocusClient.State.WindowClient.View.PaletteClient.State.EditBox.ContentClient.State.EditBoxClient.Commands.WordCompletion#Client.Configuration.ServerSettingsClient.Network.ConnectClient.Network.AsyncClient.ConfigurationClient.Image.MessageClient.View.IgnoreList Client.Log Client.CApiClient.OptionsClient.View.RtsStatsClient.State.Network Client.StateClient.View.WindowsClient.View.UserListClient.View.UrlSelectionClient.View.MessagesClient.View.MaskListClient.View.KeyMapClient.View.DigraphsClient.View.ChannelInfoClient.Image.StatusLineClient.View.MentionsClient.CommandsClient.View.Help Client.ViewClient.Image.TextboxClient.Image.Layout Client.ImageClient.EventLoopClient.CApi.Exports Build_glircDataText DigraphQuoteDigraphsPrefixtoStringisPrefix Paths_glircRtsStats StrictUnit LensUtilsauthenticationModeencodeUsernamecomputeResponse FgnStringLenFgnCmd fcCommandFgnChat fhNetworkfhTarget fhMessageFgnMsg fmNetwork fmPrefixNick fmPrefixUser fmPrefixHost fmCommandfmParamsfmParamN fmTagKeys fmTagValsfmTagN FgnExtensionfgnStartfgnStop fgnMessagefgnChat fgnCommandfgnNamefgnMajorVersionfgnMinorVersionDynamic ProcessChatProcessCommandProcessMessage StopExtensionStartExtension ProcessResult MessageCoderunProcessChatrunProcessCommandrunProcessMessagerunStopExtensionrunStartExtension 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 macroMapSpecmacroCommandSpecKeyMapAction ActBackspace ActDeleteActLeftActRightActHomeActEnd ActOlderLine ActNewerLine ActScrollUp ActScrollDown ActBackWordActForwardWordActYank ActKillHome ActKillEndActKillWordBackActKillWordForward ActToggleActBoldActColor ActItalic ActUnderlineActReverseVideoActClearFormatActInsertEnter ActDigraphActRetreatFocusActAdvanceFocusActAdvanceNetworkActJumpToActivityActJumpPreviousActJumpActTabCompleteActTabCompleteBackActEnterActReset ActRefresh ActCommand ActInsert ActIgnored keyMapEntries actionName keyToAction addKeyBindingremoveKeyBinding initialKeyMapparseKeyprettyModifierKey $fSpecAction $fEqAction $fOrdAction $fReadAction $fShowAction $fShowKeyMapexceptionToLines MessageHook_messageHookName_messageHookStateful_messageHookAction MessageResult PassMessage OmitMessage RemapMessage$fMonoidMessageResult$fSemigroupMessageResultmessageHookActionmessageHookNamemessageHookStatefulapplyMessageHooksbuffextrasHook messageHooksImage' unpackImagetext'charstring splitImage imageWidth imageText resizeImage$fIsStringImage'$fSemigroupImage'$fMonoidImage' $fShowImage' parseIrcText parseIrcText' mircColor controlImage plainText terminate fullLineWraplineWrapPrefixlineWrapPalette _palNicks_palSelf_palSelfHighlight_palTime_palMeta _palSigil _palLabel _palLatency_palWindowName _palError _palTextBox _palActivity _palMention _palCommand_palCommandReady_palCommandPrefix_palCommandError_palCommandPlaceholder_palWindowDivider_palLineMarker $fShowPalette palActivity palCommandpalCommandErrorpalCommandPlaceholderpalCommandPrefixpalCommandReadypalErrorpalLabel palLatency palLineMarker palMentionpalMetapalNickspalSelfpalSelfHighlightpalSigil palTextBoxpalTimepalWindowDivider palWindowNamedefaultPalette paletteMaprenderMask buildMask matchMask MessageBodyIrcBody ErrorBody NormalBody ClientMessage _msgNetwork_msgBody_msgTime_IrcBody _ErrorBody _NormalBody IrcSummary JoinSummary QuitSummary PartSummary NickSummary ReplySummary ChatSummary CtcpSummary NoSummarymsgBody msgNetworkmsgTimemsgText msgSummary$fEqIrcSummary$fShowIrcSummary MaskListEntry_maskListSetter _maskListTimeTopicProvenance _topicAuthor _topicTime ChannelState _chanTopic_chanTopicProvenance_chanUrl _chanUsers _chanModes _chanLists _chanCreation_chanQueuedModeration$fShowTopicProvenance$fShowMaskListEntry$fShowChannelState chanCreation chanLists chanModeschanQueuedModeration chanTopicchanTopicProvenancechanUrl chanUsers topicAuthor topicTimemaskListSetter maskListTime newChannel joinChannel partChannel nickChangesetTopicFocus Unfocused NetworkFocus ChannelFocus $fEqFocus $fShowFocus WindowsFilter AllWindowsNetworkWindowsChannelWindows UserWindowsSubfocus FocusMessages FocusInfo FocusUsers FocusMasks FocusWindows FocusPalette FocusMentions FocusDigraphs FocusKeyMap FocusHelp FocusRtsStatsFocusIgnoreList _Unfocused _NetworkFocus _ChannelFocus focusNetwork $fOrdFocus$fEqWindowsFilter$fShowWindowsFilter $fEqSubfocus$fShowSubfocusWindowLineImportanceWLBoringWLNormal WLImportantWindow _winMessages _winMarker _winUnread _winTotal _winMention _winHideMeta PackedTime WindowLine _wlSummary _wlPrefix_wlImage _wlFullImage _wlImportance _wlTimestamp$fEqActivityLevel$fOrdActivityLevel$fReadActivityLevel$fShowActivityLevel$fEqWindowLineImportance$fOrdWindowLineImportance$fShowWindowLineImportance$fReadWindowLineImportance winHideMeta winMarker winMention winMessageswinTotal winUnread wlFullImagewlImage wlImportancewlPrefix wlSummary wlTimestampwlText emptyWindow addToWindow windowSeenwindowActivatewindowDeactivate packZonedTimeunpackTimeOfDay unpackUTCTime0$fEachWindowLinesWindowLinesWindowLineWindowLinepaletteViewLinesLine_pos_text $fReadLine $fShowLineContentHasLinelinepostextendLine $fHasLineLine $fReadContent $fShowContentabovebelow noContent singleLineshiftjumpLeft jumpRightleftrightleftWord rightWord backspacedelete insertCharinsertPastedString insertStringtoggledigraph$fHasLineContent LastOperation TabOperation KillOperationOtherOperationEditBox$fReadLastOperation$fShowLastOperation $fReadEditBox $fShowEditBoxcontent lastOperationdefaultEditBoxsuccessearlierlaterhomeendkillEndkillHomeyankkillWordBackwardkillWordForwardinsert insertPaste insertDigraph$fHasLineEditBoxWordCompletionModewcmStartPrefixwcmStartSuffixwcmMiddlePrefixwcmMiddleSuffixplainWordCompleteModedefaultNickWordCompleteModeslackNickWordCompleteMode wordComplete $fPrefixText$fPrefixIdentifier$fShowWordCompletionModeUseTlsUseInsecureTls UseInsecureServerSettings_ssNicks_ssUser_ssReal _ssUserInfo _ssPassword_ssSaslUsername_ssSaslPassword_ssSaslEcdsaFile _ssHostName_ssPort_ssTls_ssTlsClientCert_ssTlsClientKey_ssTlsServerCert _ssTlsCiphers_ssConnectCmds _ssSocksHost _ssSocksPort_ssChanservChannels_ssFloodPenalty_ssFloodThreshold_ssMessageHooks_ssName_ssReconnectAttempts_ssAutoconnect_ssNickCompletion _ssLogDir_ssProtocolFamily $fShowUseTls$fShowServerSettings ssAutoconnectssChanservChannels ssConnectCmdsssFloodPenaltyssFloodThreshold ssHostNamessLogDirssMessageHooksssNamessNickCompletionssNicks ssPasswordssPortssProtocolFamilyssRealssReconnectAttemptsssSaslEcdsaFilessSaslPasswordssSaslUsername ssSocksHost ssSocksPortssTls ssTlsCiphersssTlsClientCertssTlsClientKeyssTlsServerCertssUser ssUserInfoloadDefaultServerSettings serverSpecidentifierSpecwithConnectionTerminationReason PingTimeoutForcedDisconnect NetworkEvent NetworkOpen NetworkLine NetworkError NetworkCloseNetworkConnection NetworkIdsendabortConnectioncreateConnection$fShowNetworkConnection$fExceptionTerminationReason$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 aeSessionaeNameaeMajorVersionaeMinorVersionextensionSymbolactivateExtensiondeactivateExtensionnotifyExtensions chatExtensioncommandExtension$fFunctorNestedIO$fApplicativeNestedIO$fMonadNestedIO$fMonadIONestedIOOptions_optConfigFile_optInitialNetworks _optNoConnect _optShowHelp_optShowVersion_optShowFullVersion_optShowConfigFormat optConfigFileoptInitialNetworks optNoConnect getOptions rtsStatsLines Transaction NoTransactionNamesTransactionBanTransactionWhoTransactionCapTransaction TimedActionTimedDisconnect TimedSendPingTimedForgetLatency PingStatusPingSentPingNonePingConnecting UserAndHost_uhUser_uhHost _uhAccountAuthenticateStateAS_NoneAS_PlainStartedAS_EcdsaStartedAS_EcdsaWaitChallenge NetworkState _csNetworkId _csChannels _csSocket _csModeTypes_csChannelTypes_csTransaction_csModes _csStatusMsg _csSettings _csUserInfo_csUsers _csModeCount _csNetwork_csMessageHooks_csAuthenticationState_csNextPingTime _csLatency _csPingStatus_csLastReceived$fShowAuthenticateState$fShowUserAndHost$fShowPingStatus$fEqTimedAction$fOrdTimedAction$fShowTimedAction$fShowTransaction$fShowNetworkStatecsAuthenticationStatecsChannelTypes csChannelscsLastReceived csLatencycsMessageHooks csModeCount csModeTypescsModes csNetwork csNetworkIdcsNextPingTime csPingStatus csSettingscsSocket csStatusMsg csTransaction csUserInfocsUsers uhAccountuhHostuhUser_PingConnectingcsNicksendMsgnewNetworkState applyMessage squelchIrcMsgiHaveOpinitialMessagesisChannelIdentifiercsUsernextTimedActionapplyTimedActionsendModeration useChanServ sendTopicExtensionState ClientState_clientWindows_clientPrevFocus_clientActivityReturn _clientFocus_clientSubfocus_clientExtraFocus_clientConnections _clientEvents_clientNetworkMap _clientConfig_clientConfigPath_clientTextBox_clientTextBoxOffset _clientWidth _clientHeight _clientScroll_clientDetailView_clientActivityBar_clientShowPing _clientRegex _clientLayout _clientBell_clientIgnores_clientIgnoreMask_clientExtensions_clientLogQueue_clientErrorMsg_clientRtsStatsclientActivityBarclientActivityReturn clientBell clientConfigclientConfigPathclientConnectionsclientDetailViewclientErrorMsg clientEventsclientExtensionsclientExtraFocus clientFocus clientHeightclientIgnoreMask clientIgnores clientLayoutclientLogQueueclientNetworkMapclientPrevFocus clientRegexclientRtsStats clientScrollclientShowPingclientSubfocus clientTextBoxclientTextBoxOffset clientWidth clientWindowsesActive clientParkclientConnectionclientFirstLine clientLinewithClientState abortNetworkrecordChannelMessage identIgnoredrecordIrcMessagerecordNetworkMessage clientTick consumeInputcurrentCompletionListcurrentNickCompletionModechannelUserList clientMatcherclientMatcher'clientActiveRegexclientActiveCommand urlPattern urlMatches removeNetwork addConnectionapplyMessageToClientStateclientShutdownclientStartExtensions scrollClientclientExtraFocusesjumpToActivity jumpFocus changeFocus setExtraFocuschangeSubfocus returnFocus advanceFocus retreatFocusadvanceNetworkFocusclientHighlightsclientHighlightsNetworkclientWindowNames clientPaletteclientAutoconnectsclientToggleHideMeta windowsImagesuserListImagesuserInfoImagesurlSelectionViewchatMessageImagesmaskListImages keyMapLines digraphLineschannelInfoImagesstatusLineImageminorStatusLineImagementionsViewLinesCommandSectioncmdSectionNamecmdSectionCmdsCommandcmdNamescmdArgumentSpeccmdDocumentationcmdImplementation CommandImpl ClientCommandNetworkCommand ChatCommandChannelCommand CommandResultCommandSuccessCommandFailure CommandQuitexecuteexecuteUserCommandcommandExpansion tabCompletioncommands commandsListhelpImageLines viewLines textboxImage drawLayout scrollAmount clientPicture eventLoopupdateTerminalSizeGlirc_resolve_pathGlirc_is_logged_onGlirc_is_channelGlirc_current_focusGlirc_free_stringsGlirc_free_stringGlirc_clear_windowGlirc_mark_seenGlirc_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_mark_seenglirc_clear_windowglirc_free_stringglirc_free_stringsglirc_current_focusglirc_is_channelglirc_is_logged_onglirc_resolve_pathdepsbaseForeign.Storablepoke emptyExecCmd powerWords Data.OldListwordsGHC.BaseString text-1.2.3.0Data.Text.Internal splitCommonsinglebothall childKeys!vty-5.23.1-Lcg3W72ezal6l0neelICIxGraphics.Vty.AttributesdefAttrcolorNumberSpecrgbSpec actionInfosexceptionToLines'%irc-core-2.5.0-AR5c5rM06bc7yo2HcoPl82 Irc.MessageIrcMsgNothingJustremapGraphics.Vty.Image.InternalImage splitOptions dropSpaces lineWrap'defaultNickColorPalette Irc.UserInfoUserInfoparseMaskComponents translate isMetaChar digraphTableStReadyMatchFoundSkip2Skip1 lookupDigraphdigraphs currentLine forwardLine backwardLineupdateYankBuffer Data.String fromStringghc-prim GHC.Classes<= currentWord tabSearchprotocolFamilySpec#hookup-0.2.2-4iEXlexrSf6Aux5jwXvhxPHookup ConnectiondefaultWindowNamesgetOldConfigPathdirectory-1.3.1.5System.DirectorygetAppUserDataDirectorygetXdgDirectory XdgConfigemptyConfigFilereadFileCatchNotFoundreadConfigurationFileexplainLoadError resolvePathsdefaultPaddingSidenickPaddingSpecfullNickPaddingSpec modifierSpec layoutSpeckeyBindingSpecactBindingSpeckeySpecdefaultRtldFlagssimpleExtensionSpecfullExtensionSpecbuildServerMapstatusMsgImage prefixImage bodyImage time-1.8.0.2&Data.Time.LocalTime.Internal.ZonedTime ZonedTime datetimeImage ircLinePrefix ircLineImagefullIrcLineImageseparatedParamsircWordsprettyUnixTime prettySecondshighlightNicks summaryLineNestedIO GHC.TypesTrue withRawIrcMsg Irc.RawIrcMsg RawIrcMsg evalNestedIOnest1nest2withChat withCommandversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNamedefaultOptionsoptions gitHashTxt gitDirtyTxtStatsgetStatsstatsToEntries SemigroupMonoid$fMonoidStrictUnitmappend$fSemigroupStrictUnit<>stimes overStrict lens-4.17-4hErJ42O7uV8vzBxecIjOxControl.Lens.TypeSetterControl.Lens.Setterover setStrictsetzonedTimeLocalTimeLens&Data.Time.LocalTime.Internal.LocalTime LocalTimelocalTimeTimeOfDay localTimeDaynoReply pruneUsers doWelcome Irc.Codes RPL_WELCOME doBadNickERR_NICKNAMEINUSErecordListEntrysaveList squelchReplymassRegistrationnextForgetActionnextPingActiondoMode selectCapsisupport _esActive_esMVarGHC.MVarMVar _esStablePtr GHC.Stable StablePtr FocusSelector stepFocus TraversalsplitStatusMsgModes msgImportance ircIgnorablecomputeMsgLineSigilscomputeUserSigilsupdateTransientErrorrecordWindowLine toWindowLine' toWindowLinemarkSeennextAvailableKeyapplyWindowRenamesclientStopExtensions recordLogLinenetworkChannelListdrawmetadataWindowLine MetadataStatewindowLinesToImages startMetadatatransitionMetadatagatherMetadataLines drawEntry scrollImage filterImage latencyImage infoBubble detailImage nometaImageactivitySummaryactivityBarImages makeLinestransientErrorImage mlTimestamp mlWindowNamemlFocusmlImage addMarkersmerge windowEntriescommandSuccesscommandFailurecommandFailureMsg executeChatexecuteCommand expandAliases noClientTab noNetworkTab noChannelTabsimpleClientTabsimpleNetworkTabsimpleChannelTabcmdExitcmdClearcmdQuotecmdMecmdCtcp cmdNoticecmdMsg chatCommand chatCommand' cmdWindows cmdMentions cmdPalette cmdDigraphs cmdKeyMap cmdRtsStatscmdHelp tabSplitstabActiveSplits parseFocus ApplicativeData.Functor.IdentityIdentityMayberenderSplitFocus cmdSplits cmdSplitsAdd cmdSplitsDel tabConnecttabFocuscmdSaycmdQuery cmdChannel tabChannelchannelWindowsOnNetwork cmdReconnect tabIgnore cmdReload tabReload countFlagscomputeModeCompletionisPublicChannelModenickTabCompletioncmdExeccmdGrepsimpleTabCompletiontabTopiccommandHelpLinesexplainContextlistAllCommandscommandSummarylistCommandSection renderContent myWcwidth myWcswidth renderLine drawLayoutOne drawLayoutTwo drawExtra messagePane divisionsdrawMain splitHeightsGraphics.Vty.PicturePicture clientImage ClientEventVtyEvent TimerEventgetEvent earliestEventbeep doNetworkOpendoNetworkClosedoNetworkError doNetworkLineclientResponsecomputeEffectiveTime parseZncTimelookups doVtyEventdoActiondoCommandResult executeInput doTimerEventreconnectLogicprocessSaslEcdsaprocessConnectCmd recordError derefToken peekFgnMsgpeekFgnStringLen