!      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~Safe None 456=>?x2rainbox)A single cell in a spreadsheet-like grid.rainbox6The cell can have multiple rows of text; there is one  for each row of text.rainbox How this  should align compared to other  in its row.rainbox How this  should align compared to other  in its column.rainboxCBackground color for this cell. The background in the individual  in the cellRows are not affected by cellBackground ; instead, cellBackgroundg determines the color of necessary padding that will be added so that the cells make a uniform table.rainbox2Things that are oriented around a horizontal axis.rainbox*Number of lines above the horizontal axis.rainbox*Number of lines below the horizontal axis. rainbox0Things that are oriented around a vertical axis. rainbox(Length to the left of the vertical axis. rainbox)Length to the right of the vertical axis. rainbox1This typeclass is responsible for transforming a  into Rainbow  so they can be printed to your screen. This requires adding appropriate whitespace with the right colors, as well as adding newlines in the right places.rainboxBuilds a one-dimensional box of the given size; its single dimension is parallel to the axis. When added to a box, it will insert blank space of the given length. For a  &), this produces a horizontal line; for a  #, a vertical line.rainboxBuilds a one-dimensional box of the given size; its single dimension is perpendicular to the axis. This can be used to make a  # wider or a  & taller.rainboxA  is the central building block. It consists of zero or more payloads; each payload has the same orientation, which is either & or #C. This orientation also determines the orientation of the entire .A  is a C so you can combine them using the usual monoid functions. For a  #", the leftmost values added with  are at the top of the ; for a  &!, the leftmost values added with  are on the left side of the .rainboxA  holds a D, which determines the number and content of the screen rows. The  also has an )E, which specifies how the payload aligns with the axis. Whether the ) is & or #$ determines the orientation of the . The 2 also contains a background color, which is type 7. The background color extends continuously from the 8 in both directions that are perpendicular to the axis.rainbox,A list of screen rows; each screen row is a  of .A ` with width but no height does nothing if rendered alone, but it can affect the width of other  if combined with them.rainbox Each outer ' represents a single screen row. Each  has a height of 1. The outer 6 must have a length of at least 1, even if the inner  is empty. If the outer : has a length of zero, undefined behavior occurs. For a # with no height and no width, use .rainboxA  that has no height. If the  is less than 1, the . has no width and no height. Otherwise, the ' has no height but has the given width.rainboxDAn intermediate type used in rendering; it consists either of text : or of a number of spaces coupled with a background color.rainboxA  is either a single : or, if the box is blank, is merely a height and a width.rainboxA count of columns.!rainboxA count of rows.#rainbox5Determines how a payload aligns with a vertical axis.&rainbox7Determines how a payload aligns with a horizontal axis.)rainbox%Alignment. Used in conjunction with & and #;, this determines how a payload aligns with the axis of a .,rainboxSPlace this payload so that it is centered on the vertical axis or horizontal axis.-rainboxCenter horizontally; like ,, but monomorphic..rainboxCenter vertically; like ,, but monomorphic./rainbox4Place this payload's left edge on the vertical axis.0rainbox5Place this payload's right edge on the vertical axis.1rainbox5Place this payload's top edge on the horizontal axis.2rainbox8Place this payload's bottom edge on the horizontal axis.3rainbox Convert a  to a  of  for rendering.4rainbox Converts a  to a nested  of M in preparation for rendering. Newlines are added to the end of each line.5rainboxIAdds padding to the top and bottom of each Payload. A Payload with a Core is converted to a RodRows and has padding added; a Payload with a RodRows has necessary padding added to the top and bottom. The number of elements in the resulting Seq is the same as the number of elements in the input Seq; no merging is performed.6rainboxMerges multiple horizontal RodRows into a single RodRows. All RodRows must already have been the same height; if they are not the same height, undefined behavior occurs.7rainboxaSplit a number into two parts, so that the sum of the two parts is equal to the original number.8rainboxIAdds padding to the left and right of each Payload. A Payload with a Core is converted to a RodRows and has padding added; a Payload with a RodRows has necessary padding added to the left and right. The number of elements in the resulting Seq is the same as the number of elements in the input Seq; no merging is performed.9rainboxgMerge multiple vertical RodRows into a single RodRows. Each RodRows should already be the same width.:rainboxConstruct a box from a single .;rainboxvConstruct a blank box. Useful for adding in background spacers. For functions that build one-dimensional boxes, see  and .<rainboxWrap a  in another . Useful for changing a &  to a # one, or simply for putting a 9 inside another one to control size and background color.=rainboxConvert a box to a  of $ in preparation for rendering. Use  to convert the  of < to a list so that you can print it using the functions in Rainbow.BrainboxCreates a blank Z with the given background color and width; useful for adding separators between columns.Crainbox Create a table where each inner  is a row of cells, from left to right. If necessary, blank cells are added to the end of a row to ensure that each row has the same number of cells as the longest row.Jrainbox Create a table where each inner  is a column of cells, from top to bottom. If necessary, blank cells are added to the end of a column to ensure that each column has the same number of cells as the longest column.QrainboxEnsures that each inner D is the same length by adding the given empty element where needed.Srainbox is ,.  takes the rightmost non-, value.nrainbox combines two = horizontally so they are side-by-side, left-to-right. The , , and , fields are combined using their respective  instances.  uses the respective  value for each field.:rainbox/Background color. The background color in the 1 is not changed; this background is used if the  must be padded later on.;rainboxColor for the blank area.<rainboxAlignment for new ). This also determines whether the new  is & or #.rainboxBackground color for new boxS  !"#%$&(')+*,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRS)+*&('#%$,-./012!" 3456789  :;<=>?@ABCDEFGHIJKLMNOPQRNonez #&),-./012:;<=>?@ABCJ)&#,/012-. :;<=B>?@ACJNone5rainbox Create a Boxe for the given text. The default foreground and background colors of the terminal are used for the O; the given background is used as the background color for any added padding.rainboxCenters the given Box within a larger BoxH that has the given height and width and background color. The larger Box has the given  Alignment.rainboxRPuts the given text in the center of a box. The resulting box is center aligned.rainbox Converts a  to a list of Cell.rainboxNumber of rowsrainboxNumber of columnsrainboxBackground colorrainboxNumber of rowsrainboxNumber of columnsrainbox Background color for smaller boxrainboxBackground color for larger box))       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~&rainbox-0.24.0.0-IPgLSNfLobGm5FylUBIc9Rainbox Rainbox.CoreRainbox.Tutorial Paths_rainboxCell_rows _horizontal _vertical _backgroundUpDownabovebelow LeftRightport starboard OrientationrodRowsspacerspreaderBoxPayloadRodRowsRodRowsWithHeightRodRowsNoHeightRodCoreHasWidthwidth HasHeightheightWidthHeightVerticalPort Starboard HorizontalTopBottom AlignmentCenter NonCentercentercenterHcenterVleftrighttopbottomrodRowsFromCorechunksFromRodRowsaddVerticalPaddinghorizontalMergesplitaddHorizontalPadding verticalMerge fromChunkblankwraprenderrows horizontalvertical background separator tableByRows rowToBoxV cellToBoxVtoBoxH addWidthMappadBoxV widestCellMaptableByColumns rowToBoxH cellToBoxH addHeightMaptallestCellMappadBoxHtoBoxVequalize mconcatSeq$fMonoidAlignment$fSemigroupAlignment$fHasHeightEither$fHasHeightChunk$fHasHeightHeight$fHasWidthEither$fHasWidthChunk$fHasWidthWidth$fHasHeightCore$fHasWidthCore $fHasWidthRod$fHasWidthRodRows$fHasHeightRodRows$fHasHeightPayload$fHasWidthPayload $fHasWidthBox$fHasHeightBox $fMonoidBox$fSemigroupBox$fOrientationHorizontal$fOrientationVertical$fHasWidthBox0$fLeftRightBox$fLeftRightPayload$fHasHeightBox0 $fUpDownBox$fUpDownPayload $fMonoidCell$fSemigroupCell $fEqAlignment$fOrdAlignment$fShowAlignment$fFunctorAlignment$fFoldableAlignment$fTraversableAlignment$fEqHorizontal$fOrdHorizontal$fShowHorizontal $fEqVertical $fOrdVertical$fShowVertical $fEqHeight $fOrdHeight $fShowHeight $fEqWidth $fOrdWidth $fShowWidth$fEqCore $fOrdCore $fShowCore$fEqRod$fOrdRod $fShowRod $fEqRodRows $fOrdRodRows $fShowRodRows $fEqPayload $fOrdPayload $fShowPayload$fEqBox$fOrdBox $fShowBox$fEqCell $fOrdCell $fShowCellStationname metroLinesaddress undergroundLineRedBlueOrangeGreenYellowSilvertextBoxwithin textWithinbox1 renderBox1box2 renderBox2box3 renderBox3box4 renderBox4box5 renderBox5nameCell linesCelllineRow addressCellundergroundCellstations coloredBack stationRowallStationRowsverticalStationTablerenderVerticalStationTable stationColumnallStationColumnshorizontalStationTablerenderHorizontalStationTable$fEqLine $fOrdLine $fShowLine $fEnumLineversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNamecontainers-0.6.0.1Data.Sequence.InternalSeq'rainbow-0.34.0.0-Lnf0BnAGnnoHNG5SpC8QhM Rainbow.TypesChunkbaseGHC.BaseMonoidmappendRadiantghc-prim GHC.TypesInt Data.FoldabletoListmempty text-1.2.3.1Data.Text.InternalText