gridtables

Parser for reStructuredText-style grid tables.

https://github.com/tarleb/gridtables

Version on this page:0.0.3.0@rev:1
LTS Haskell 22.34:0.1.0.0@rev:1
Stackage Nightly 2024-09-10:0.1.0.0@rev:1
Latest on Hackage:0.1.0.0@rev:1

See all snapshots gridtables appears in

MIT licensed by Albert Krewinkel
Maintained by Albert Krewinkel
This version can be pinned in stack with:gridtables-0.0.3.0@sha256:0c34cec7ff7fde5629baa6b17ba4e54fe73bc534feb48816341ad9807e284654,3055

Module documentation for 0.0.3.0

Used by 1 package in lts-20.26(full list with versions):

gridtables

Parser for reStructuredText-style grid tables.

This package provides a parser for plain-text representations of tables, like the one given below.

+---------------------+-----------------------+
| Location            | Temperature 1961-1990 |
|                     | in degree Celsius     |
|                     +-------+-------+-------+
|                     | min   | mean  | max   |
+=====================+=======+=======+=======+
| Antarctica          | -89.2 | N/A   | 19.8  |
+---------------------+-------+-------+-------+
| Earth               | -89.2 | 14    | 56.7  |
+---------------------+-------+-------+-------+

Character widths

The tables are intended to look good when viewed in a monospace font. Therefore, wide and full-width characters, as those in East Asian scripts, are counted as two characters.

Column alignments

The parser re-implements a table extensions from John MacFarlane’s pandoc, namely support for column-wide cell alignments. The alignment of cells is determined by placing colons in the row that separates the table head from the body, like so:

+------+--------+-------+
| left | center | right |
+:=====+:======:+======:+
| 1    | 2      | 3     |
+------+--------+-------+

The first line must be used for headless tables:

+:-----+:------:+------:+
| left | center | right |
+------+--------+-------+
| a 1  | b 2    | c 3   |
+------+--------+-------+

Algorithm

The cell tracing algorithm used in this package has been translated from the original Python implementation for reStructuredText. The parser has been placed in the public domain.

Usage

The usual way to use this package will be to use it as part of a parsec parser:

main :: IO ()
main = do
  let gt = T.unlines
           [ "+------+--------+-------+"
           , "| left | center | right |"
           , "+:=====+:======:+======:+"
           , "| 1    | 2      | 3     |"
           , "+------+--------+-------+"
           ]
  in print (runParser GT.gridTable () "table" gt)

Use traceLines :: [Text] -> Maybe (GridTable [Text]), if the table’s raw lines have been retrieved in a different way.

Changes

Changelog

gridtables uses PVP Versioning.

gridtables-0.0.3.0

Released 2022-08-18.

  • Missing cells no longer cause an error, but are replaced with empty cells.

  • The borders of the last cell in a row are allowed to be shorter than the cell. Previously the last column was discarded in that case.

gridtables-0.0.2.0

Released 2022-07-30.

  • Treat “combining” Unicode characters, such as the zero-width space or the word joiner, as having no width.

gridtables-0.0.1.0

Released 2022-07-29.

  • Boldly going where no Haskell library has gone before.