NAME

Term::Table2 - Provides formatted output of tables supplied as a combination of header and rows.

VERSION

Version 1.0.3 (The versioning is conform with https://semver.org/.)

SYNOPSIS

use Term::Table2;

my $table = Term::Table2->new(            # based on array of rows
  header      => [                        # defaults to output without header
    'id',
    'message type',
    'comment',
    'version',
  ],
  rows        => [                        # each element must contain array of scalars,
    ['SalcatKIAEST', 315, '', '001'],     # all arrays must have the same length
    ['SbakerKI2824', 997, '', 'SHP'],
    ...
  ],
  broad_column => [CUT, WRAP, CUT, CUT],  # defaults to wrap for all values in columns
  broad_header => [CUT, WRAP, CUT, CUT],  # defaults to wrap for all values in headers
  broad_row    => CUT,                    # defaults to row wrap; supports split to other page, too
  collapse     => [0, 1, 1, 1],           # defaults to no collapse for all columns
  column_width => [12, undef, 10, 3],     # defaults to maximum text length within header / values
  pad          => 2,                      # defaults to 1 for each side
  page_height  => 100,                    # defaults to 0 (no paging)
  table_width  => 120,                    # defaults to screen size
);

say while $table->fetch();

# or

my $table = Term::Table2->new(            # based on callback for rows
  rows          => &{$dbObject->fetch()}, # returns reference to array, all arrays must have the same length
  broad_column  => CUT,                   # considered as the same value for all columns
  broad_row     => CUT,                   # considered as the same value for all columns
  column_Width  => 20,                    # considered as the same value for all columns, does not have any default
  pad           => 2,                     # defaults to 1 for each side
  page_height   => 100,                   # defaults to 0 (no paging)
  separate_rows => 1,                     # defaults to 0 (no rows separation)
  table_width   => 120,                   # defaults to screen size
);

say while $table->fetch();

# or

say foreach @{Term::Table2->new(...)->fetch_all()};

This prints a table like this:

+----------------+-----------+-------+
|  id            |  message  |  ver  |
|                |  type     |       |
+----------------+-----------+-------+
|  SalcatKIAEST  |  315      |  001  |
|  SbakerKI2824  |  997      |  SHP  |
|  ...           |  ...      |  ...  |
+----------------+-----------+-------+

or like this:

+----------------+-----------+-------+
|  id            |  message  |  ver  |
|                |  type     |       |
+----------------+-----------+-------+
|  SalcatKIAEST  |  315      |  001  |
+----------------+-----------+-------+
|  SbakerKI2824  |  997      |  SHP  |
+----------------+-----------+-------+
|  ...           |  ...      |  ...  |
+----------------+-----------+-------+

DESCRIPTION

Provides a possibility for formatting of tables supplied in form of their row contents and headers. Trailing blanks - both in header and row contents - are ignored!

Among other things supports both horizontal and vertical splitting (paging), in other words can cope with tables wider and / or higher than the size of page you intend to use. Too long table rows and cell contents can be wrapped / truncated depending on options supplied.

Parameters supplied get validated, however the validation scope and its time point depend on the kind of row content transmission.

In case of rows supplied as an array reference all parameters are validated during the instantiating of Term::Table2 object.

In case of a reference to callback function only the types of parameters can be validated during the object instantiating, whereas their values can first be checked after the very first row will have been delivered by the callback function.

If table contains some wide unicode characters, the representation will only be correct if the module Unicode::GCString is installed and the Perl has been compiled without the debugging option (i.e. without -DDEBUGGING), otherwise this can be twisted but no exception will be raised. The reason, why the debugging option leads to troubles in form of the error perl: sv.c:2336: Perl_sv_2iv_flags: Assertion `SvTYPE(sv) != SVt_PVAV && SvTYPE(sv) != SVt_PVHV && SvTYPE(sv) != SVt_PVFM' failed using this module is still unclear.

COMMON METHODS

new

Description

Constructor preparing a table output on the base of options supplied.

use Term::Table2;
my $table = Term::Table2->new(%options);

%options

  • header => <array reference>

    Considers each element of this array as a header of column with the same index.

    If a header exists, if always starts and ends with a separating line consisting of hyphens (-) and plus characters (+).

    Undefined or non-scalar elements cause an exception.

    Defaults to output without any header at all.

  • rows => <reference to array of array references> or rows => <reference to callback function>

    In case of an array reference considers each element of this array as a single table tow, where each sub-element corresponds to a single column value.

    In case of a reference to callback function it is expected that this function returns an array reference corresponding to one table row.

    After the very last row is fetched (e.g. from a database) the callback function has to return undef.

    The table content (rows) always ends with the same separating line as described for the header.

    Undefined rows in case of an array reference as well as rows not represented by an array reference cause an exception.

    Undefined or non-scalar sub-elements (column values) cause an exception.

    Defaults to output without table content at all.

  • broad_column => <array reference> or broad_column => <scalar>

    Considers each element of this array as a flag defining the behaviour in case of too broad cell content. In case of scalar its value is applied to all columns.

    Whether a cell content (including padding required) is too broad, depends on the width of the corresponding column (please refer to column_width below) and on the table width (please refer to table_width below).

    If the table width is exceeded, the formatting depends on broad_row described below.

    If the table width is not exceeded but the column width is exceeded, the following possibilities are supported:

    CUT

    Only the allowed amount of left-most characters will be kept, the rest will be cut off.

    WRAP

    The cell content will be splitted into mutliple chunks in accordance with how many characters are allowed (except maybe of the very last chunk that can be shorter). As a result each cell in the corresponding table row will occupy multiple lines.

    Any value except of CUT and WRAP causes an exception.

    Defaults to WRAP.

  • broad_header => <array reference> or broad_header => <scalar>

    Considers each element of this array as a flag defining the behaviour in case of too broad header cells. In case of scalar its value is applied to all columns.

    Whether a header cell (including padding required) is too broad, depends on the width of the corresponding column (please refer to column_width below) and on the table width (please refer to table_width below).

    If the table width is exceeded, the formatting depends on broad_row described below.

    If the table width is not exceeded but the column width is exceeded, the following possibilities are supported:

    CUT

    Only the allowed amount of left-most characters will be kept, the rest will be cut off.

    WRAP

    The header cell will be splitted into mutliple chunks in accordance with how many characters are allowed (except maybe of the very last chunk that can be shorter). As a result the table header will occupy multiple lines.

    Any value except of CUT and WRAP causes an exception.

    Defaults to WRAP.

  • broad_row => <scalar>

    Defines the behaviour in case of too broad row (including padding required).

    Whether a row is too broad depends on the table width (please refer to table_width below).

    If the table width is exceeded, the following possibilities are supported:

    CUT

    Only the allowed amount of left-most characters in each line of each table row will be kept, the rest will be cut off.

    SPLIT

    Each line of each table row will be splitted into mutliple chunks in accordance with how many characters are allowed by table_width (except maybe of the very last chunk that can be shorter).

    Each next chunk will then be pushed into the result related to the next page so that the complete table row will be splitted "horizontally" and occupy multiple pages (this can be considered as a table cut through between some columns or even mid-column so that it should be afterwards stick together).

    This value applied in case of rows referring to a callback function causes an exception.

    WRAP

    Each line of each table row will be splitted into mutliple chunks in accordance with how many characters are allowed by table_width (except maybe of the very last chunk that can be shorter).

    All these chunks will then be pushed into the same result just after each other so that the complete table row will be wrapped and occupy multiple lines.

    Defaults to WRAP.

  • collapse => <array reference> or collapse => <scalar>

    Considers each element of this array as a flag defining the behaviour in case of column containing empty strings only. In case of scalar its value is applied to all columns.

    If an element is set to true (in terms of Perl) and the corresponding column contains empty strings only, this column will not be placed into the result.

    Defaults to false for all columns.

    This option has no effect in case of rows referring to a callback function.

  • column_width => <array reference> or column_width => <scalar>

    Considers each element of this array as maximum width of the same-indexed column excluding padding. In case of scalar its value is applied to all columns.

    The area of allowable values depends on the value of rows as mentioned below:

    - In case of rows => <reference to array of array references>

    If an element is set to 0 or exported constant ADJUST, the maximum length of values without trailing spaces in the column will be applied.

    Any value that is defined but not zero or a positive integer causes an exception.

    Defaults to ADJUST.

    - In case of rows => <reference to callback function>

    All column widths must be pre-defined explicitly, there is no default.

    Any value that is defined but not a positive integer causes an exception.

  • pad => <array reference> or pad => <scalar>

    Number of spaces to be added to each header / column value both on the left and on the right. In case of scalar its value is applied to all columns.

    If defined but not zero or a positive integer, causes an exception.

    Defaults to 1.

  • page_height => <scalar>

    Defines if the header must be repeated at the top of each page and how long must be each page.

    If set to 0 or exported constant ADJUST, the paging will be deactivated to that the header will appear in the result only once (if any).

    If defined but not zero or a positive integer, causes an exception.

    If lower than the height of the header + number of row chunks as described for broad_row, causes an exception.

    Defaults to the current screen height.

  • separate_rows => <scalar>

    Flag defining if a separating lines must be placed between table rows. Any value but false is considered true (in terms of Perl).

    The separating line itself consists of hyphens (-) placed under each cell and plus characters (+) placed between cells and at the table edges.

    Defaults to false (no separating line).

  • table_width => <scalar>

    Defines the table width including column separators.

    If set to 0 or exported constant ADJUST, there is no limitation so that the table width will depend on the column widths.

    If defined but not zero or a positive integer, causes an exception.

    If lower than the width of the narrowest possible column i.e. the column containing 1 character, its left-side separator and its left-side paddings, causes an exception.

    Defaults to the current screen width.

Returns

  • Object reference.

Exceptions

  • Header has less cells than a table row does.

  • Page height is too low.

  • Table width is too low.

fetch

Description

Returns next line from the formatting result delivering undef if all lines are exhausted.

The result depends on the screen size being current during the new execution.

say while $table->fetch();

Parameters

None.

Returns

Single result line as string.

Exceptions

  • Current row contains a non-scalar cell value (in case of rows => <reference to callback function> only).

  • Current row is not an array reference (in case of rows => <reference to callback function> only).

  • Wrong number of cells in the current row (in case of rows => <reference to callback function> only).

fetch_all

Description

Returns all remaining result lines as a reference to array of strings.

say foreach @{$table->fetch_all()};

Parameters

None.

Returns

Array of strings, each of them corresponds to a result line.

Exceptions

See exception description of fetch.

GETTERS

Description

Provides reference to array containing single column headers.

my $header = $table->header();

Parameters

None.

Returns

Reference to array of strings, each of them corresponds to a header of the same-index column.

rows

Description

Provides either reference to array containing all table rows or reference to callback function returning a single table row per call.

my $rows = $table->rows();

Parameters

None.

Returns

One of the following:

  • Reference to array of array references.

  • Reference to callback function.

broad_column

Description

Provides reference to array containing flags defining behaviour in case of too broad column values.

my $broad_column = $table->broad_column();

Parameters

None.

Returns

Reference to array of flags, each of them corresponds to the same-index column.

broad_header

Description

Provides reference to array containing flags defining behaviour in case of too broad header values.

my $broad_header = $table->broad_header();

Parameters

None.

Returns

Reference to array of flags, each of them corresponds to the same-index column.

broad_row

Description

Provides flag defining behaviour in case of too broad row (wider than the table width).

my $broad_row = $table->broad_row();

Parameters

None.

Returns

Scalar containing flag value.

collapse

Description

Provides reference to array containing flags defining behaviour in case of column containing empty strings only.

my $collapse = $table->collapse();

Parameters

None.

Returns

Reference to array of flags, each of them corresponds to the same-index column.

column_width

Description

Provides reference to array containing real width of columns really presented in the result (under consideration of collaps flags, table_width, and broad_row flag).

my $column_width = $table->column_width();

Parameters

None.

Returns

Reference to array of column widths.

current_row

Description

Provides order number of currently processed row (row counter starts with 1).

If the very last row has been delivered, contains number of rows + 1 and does not change anymore.

Returns 0 in case of empty table.

my $current_row = $table->current_row();

Parameters

None.

Returns

Scalar containing current row number.

end_of_table

Description

Provides boolean value showing if the end of the table has been reached.

while ($table->end_of_table()) {
  ...
}

Parameters

None.

Returns

Boolean flag.

pad

Description

Provides reference to array containing number of spaces to be added both on the left and on the right of each column value.

my @pad = @{$table->pad()};

Parameters

None.

Returns

Reference to array containing the size of padding space for each side of every column.

page_height

Description

Provides number of lines per page.

my $page_height = $table->page_height();

Parameters

None.

Returns

Scalar containing the page height.

separate_rows

Description

Provides boolean flag showing if a separating lines must be placed between table rows.

my $separate_rows = $table->separate_rows();

Parameters

None.

Returns

Scalar containing the flag.

table_width

Description

Provides maximum number of characters per line.

my $table_width = $table->table_width();

Parameters

None.

Returns

Scalar containing the table width.

CONSTANTS

The following constants are exported by request:

ADJUST

Equates the column width to the length of the longest cell content in this column. Contains 0.

CUT

Activates truncating of row / cell content. Contains 0.

SPLIT

Activates vertical splitting of table by page width. Contains 1.

WRAP

Wraps row / cell content. Contains 2.

AUTHOR

Jurij Fajnberg, <fajnbergj at gmail.com>

BUGS

Please report any bugs or feature requests to bug-term-ansitable at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Term-Table2. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

ACKNOWLEDGEMENTS

Copyright 2019 Jurij Fajnberg

This program is free software; you can redistribute it and/or modify it under the terms of the the Artistic License (2.0). You may obtain a copy of the full license at:

http://www.perlfoundation.org/artistic_license_2_0

Any use, modification, and distribution of the Standard or Modified Versions is governed by this Artistic License. By using, modifying or distributing the Package, you accept this license. Do not use, modify, or distribute the Package, if you do not accept this license.

If your Modified Version has been derived from a Modified Version made by someone other than you, you are nevertheless required to ensure that your Modified Version complies with the requirements of this license. This license does not grant you the right to use any trademark, service mark, tradename, or logo of the Copyright Holder. This license includes the non-exclusive, worldwide, free-of-charge patent license to make, have made, use, offer to sell, sell, import and otherwise transfer the Package with respect to any patent claims licensable by the Copyright Holder that are necessarily infringed by the Package. If you institute patent litigation (including a cross-claim or counterclaim) against any party alleging that the Package constitutes direct or contributory patent infringement, then this Artistic License to you shall terminate on the date that such litigation is filed.

Disclaimer of Warranty:

THE PACKAGE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS "AS IS' AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES. THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT ARE DISCLAIMED TO THE EXTENT PERMITTED BY YOUR LOCAL LAW. UNLESS REQUIRED BY LAW, NO COPYRIGHT HOLDER OR CONTRIBUTOR WILL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING IN ANY WAY OUT OF THE USE OF THE PACKAGE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.