NAME Perinci::Result::Format::Lite - Format enveloped result VERSION This document describes version 0.288 of Perinci::Result::Format::Lite (from Perl distribution Perinci-Result-Format-Lite), released on 2023-07-29. SYNOPSIS DESCRIPTION This module formats enveloped result structure to "pretty text" if it can do so, e.g. the structure can be represented as a 2-dimensional table. Otherwise, it falls back to JSON or Perl. The table formats supported include CSV, TSV, LTSV, or HTML. More table formats (e.g. Org, Markdown) are supported via Text::Table::Any when you set "FORMAT_PRETTY_TABLE_BACKEND". This module is a more lightweight version of Perinci::Result::Format but the long-term goal is to reunite the two formatting modules back to a modular/pluggable module. SUPPORTED RESULT METADATA PROPERTIES/ATTRIBUTES The enveloped result specification specifies various properties/attributes that can be used as formatting hints. Below are the list of properties/attributes supported by this module, including those that are not in the specification: * table.html_class Str. Used when formatting result as HTML table. * table.fields Array of str. Define fields in order. Used when formatting result as text table. Fields that are not defined in this array will be displayed after the defined fields (or hidden, if you set "table.hide_unknown_fields"). * table.hide_unknown_fields Bool. If set to true, then unknown fields (those not defined in "table.fields") will not be shown. Used when formatting result as text table. * table.field_orders Array of str. Like "table.fields", but with higher precedence. * table.field_labels Array of str. Define labels for each field (each element correspond to the field of the same element as defined in "table.fields"). Used when formatting result as text table. Will show this in header for fields instead the actual field name. * table.field_units Array of str. Define units for each field (each element correspond to the field of the same element as defined in "table.fields"). Used when formatting result as text table. Will show this along with field name/label. For example if a field's unit is defined as `cm` and field name is `length`, then the field header will show as `length (cm)`. * table.field_formats Array of str. Define format for each field (each element correspond to the field of the same element as defined in "table.fields"). Used when formatting result as text table. Known formats: `iso8601_datetime`, `iso8601_date`, `datetime`, `date`, `boolstr`, `filesize`, `sci2dec`, `percent`, `number`. * table.field_format_code Coderef. Will be called with argument of field name. Expected to return format name (see "table.field_formats"). Used when formatting result as text table. This option can be used when you want to dynamically determine a suitable format based on field name. * table.default_field_format Str. Instead of defining format for each field using `table.field_formats`, you can also specify default format for all fields. * table.field_aligns Array of str. Define alignment for each field (each element correspond to the field of the same element as defined in "table.fields"). Used when formatting result as text table. Known alignment value for each field: `number` (special rule to align on decimal point or `E`), `right`, `middle`|`center`, `right`. * table.field_align_code Coderef. Will be called with argument of field name. Expected to return alignment name (see "table.field_aligns"). Used when formatting result as text table. This option can be used when you want to dynamically determine a suitable alignment based on field name. * table.default_field_align Str. Instead of defining alignment for each field using `table.field_aligns`, you can also specify default alignment for all fields. FUNCTIONS format($res, $format[ , $is_naked=0, $cleanse=1 ]) => str ENVIRONMENT FORMAT_PRETTY_TABLE_BACKEND Str, optional. If this is set, will render text table using Text::Table::Any (with "backend" set to the value of this environment variable) instead of the default Text::Table::Sprintf. This is useful if you want to output text table in a different format, for example to generate Org tables (make sure Text::Table::Org backend is already installed): % FORMAT_PRETTY_TABLE_BACKEND=Text::Table::Org lcpan rdeps Getopt::Lucid For convenience, a default is chosen for you under certain condition. When inside Emacs (environment "INSIDE_EMACS" is set), "Text::Table::Org" is used as default. FORMAT_PRETTY_TABLE_BACKEND_OPTS Str, JSON-encoding expected. This setting is to accompany "FORMAT_PRETTY_TABLE_BACKEND", to be passed to Text::Table::Any::table()'s "backend_opts" argument. It should be a hash encoded in JSON, e.g.: # keep table aligned in the presence of wide Unicode characters % FORMAT_PRETTY_TABLE_BACKEND=Text::Table::More FORMAT_PRETTY_TABLE_BACKEND_OPTS='{"wide_char":1}' tabledata locale::JP::City::MIC --page FORMAT_PRETTY_TABLE_COLUMN_ORDERS => array (json) Set the default of "table_column_orders" in "format_options" in result metadata, similar to what's implemented in Perinci::Result::Format and Data::Format::Pretty::Console. COLOR => bool HOMEPAGE Please visit the project's homepage at <https://metacpan.org/release/Perinci-Result-Format-Lite>. SOURCE Source repository is at <https://github.com/perlancar/perl-Perinci-Result-Format-Lite>. SEE ALSO Perinci::Result::Format, a more heavyweight version of this module. Perinci::CmdLine::Lite uses this module to format enveloped result. AUTHOR perlancar <perlancar@cpan.org> CONTRIBUTING To contribute, you can send patches by email/via RT, or send pull requests on GitHub. Most of the time, you don't need to build the distribution yourself. You can simply modify the code, then test via: % prove -l If you want to build the distribution (e.g. to try to install it locally on your system), you can install Dist::Zilla, Dist::Zilla::PluginBundle::Author::PERLANCAR, Pod::Weaver::PluginBundle::Author::PERLANCAR, and sometimes one or two other Dist::Zilla- and/or Pod::Weaver plugins. Any additional steps required beyond that are considered a bug and can be reported to me. COPYRIGHT AND LICENSE This software is copyright (c) 2023, 2022, 2021, 2020, 2018, 2017, 2016, 2015 by perlancar <perlancar@cpan.org>. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. BUGS Please report any bugs or feature requests on the bugtracker website <https://rt.cpan.org/Public/Dist/Display.html?Name=Perinci-Result-Format -Lite> When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.