de.vandermeer.asciitable.v2.package-info Maven / Gradle / Ivy
/* Copyright 2014 Sven van der Meer
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* Second generation of an ASCII table.
*
*
Features
* This table implementation provides the following features:
*
* - flexible columns - the number of columns in the first content row determine the columns the table supports
* - various methods to define column width - overall table width with evenly distributed columns, fixed column width, others can be added if required
* - text alignment in columns - left, right, center and two version of justified, configurable per column
* - automated text wrapping in columns with automated adjustment of adjacent columns
* - padding of columns - number of padding characters before and after text in columns
* - spanning columns - a column spanning multiple columns
* - renders to render - a table is rendered by a separate object, called the renderer, with a standard renderer provided
* - table row themes - allow to define a theme for a table for for content rows and several rule types, large set of standard themes are defined
* - table themes - allow to define a theme for a complete table, some standard themes are provided
* - one content row - a standard row for content with alignment and padding
* - rule rows with 2 different types - rules are horizontal delimiters, e.g. lines. Rules can be top (first in the table), mid (anywhere in the middle) or bottom (last in the table). Rules can be normal or strong (e.g. extra thick line).
*
*
*
*
*
Concepts and Realization
*
* The main concepts are: table, row, renderer, theme, and rendered table.
*
*
*
*
* Table
*
* A table is a collection of rows.
* The package provides a single implementation of the table {@link de.vandermeer.asciitable.v2.V2_AsciiTable}.
* The implementation allows to add rows and set some general configuration, such as default padding (per constructor).
*
*
*
*
* Row
*
* A row is either a rule (horizontal delimiter) or a content row (then with columns of content).
* The terminology used here is rule for a rule row and row for a content row.
*
*
* The row package defines an interface for a row {@link de.vandermeer.asciitable.v2.row.V2_Row}.
* It also provides two implementations: {@link de.vandermeer.asciitable.v2.row.ContentRow} for content rows
* and {@link de.vandermeer.asciitable.v2.row.RuleRow} for rules.
* Both of those row classes are supported by the provided renderer.
* Other row classes can be added if required, but then special renderers need to provided as well.
*
*
*
*
* Renderer
*
* A renderer is taking a finalized (filled) table producing a rendered version of it.
* The render package defines a general interface {@link de.vandermeer.asciitable.v2.render.V2_TableRenderer}
* and a default implementation {@link de.vandermeer.asciitable.v2.render.V2_AsciiTableRenderer}.
* Other renderers can be created by implementing the interface.
*
*
* A renderer is taking a {@link de.vandermeer.asciitable.v2.render.V2_Width} object for calculating the width of columns.
* This object is defined as an interface with several implementations provided for different ways of defining column width.
* More of those width object can be defined as required.
*
*
* A table can be rendered multiple times by any render object, i.e. the underlying original table will not be changed by the renderer.
* The renderer is building a list of so called processed rows {@link de.vandermeer.asciitable.v2.render.ProcessedRow}, which hold all render-specific settings.
*
*
* This feature, render a table any time with any renderer and re-render a table with the same renderer, allows to change settings such as width, themes, padding character.
* It also allows to render a table for different output, such as HTML or LaTeX, of such renderers where provided.
*
*
*
*
* Theme
*
* A theme is either a table theme or a row theme used by the renderer to generate the output.
* The theme package defines both as interfaces: {@link de.vandermeer.asciitable.v2.themes.V2_TableTheme} and {@link de.vandermeer.asciitable.v2.themes.V2_RowTheme}.
* It also provides builders to generate theme objects: {@link de.vandermeer.asciitable.v2.themes.V2_TableThemeBuilder} and {@link de.vandermeer.asciitable.v2.themes.V2_RowThemeBuilder}.
* The builders allow for an easy creation of new themes as required.
*
*
* The themes are supported by underlying abstract implementation of their respective interfaces: {@link de.vandermeer.asciitable.v2.themes.AbstractTableTheme} and {@link de.vandermeer.asciitable.v2.themes.AbstractRowTheme}.
*
*
* A large number of row themes are defined in {@link de.vandermeer.asciitable.v2.themes.V2_E_RowThemes}, ready to be used.
* A number of table themes are defined in {@link de.vandermeer.asciitable.v2.themes.V2_E_TableThemes}, ready to be used.
* These two enumerates also demonstrate how to define a theme.
*
*
*
*
* Rendered Table
*
* A rendered table is the output of a renderer. This final table can then be printed or written to a file.
* The package implements the rendered table in {@link de.vandermeer.asciitable.v2.RenderedTable}.
* It is essentially a list of {@link org.apache.commons.lang3.text.StrBuilder} objects with an overwritten toString method.
*
*
*
*
*
Standard usage - create and render a simple table
* The standard usage is:
*
* - create a table
* - add rules and rows
* - create a renderer and configure it
* - render the table
* - use the finally rendered table, e.g. print it to a console or write it to a file
*
*
*
*
* Create a table
* {@code
V2_AsciiTable at = new V2_AsciiTable();
* }
*
* Add content and rule rows
* We add a combination of rows and rules and a final rule.
* {@code
at.addRule();
at.addRow("first row (col1)", "with some information (col2)");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)");
at.addRule();
* }
*
*
*
* Create a renderer and configure it
* We create the standard renderer and configure it to use the provided table theme {@link de.vandermeer.asciitable.v2.themes.V2_E_TableThemes#UTF_LIGHT}.
* The we add a width to the renderer using {@link de.vandermeer.asciitable.v2.render.WidthAbsoluteEven} for a table width of 76 characters.
* {@code
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
* }
*
*
*
* Render the table
* {@code
RenderedTable rt = rend.render(at);
* }
*
*
*
* Use the finally rendered table
* Simply print it to standard out.
* {@code
System.out.println(rt);
* }
*
* The will result in the following table being printed to the console:
*
┌─────────────────────────────────────┬────────────────────────────────────┐
│ first row (col1) │ with some information (col2) │
├─────────────────────────────────────┼────────────────────────────────────┤
│ second row (col1) │ with some information (col2) │
└─────────────────────────────────────┴────────────────────────────────────┘
*
*
*
*
*
Examples for tables with 1 to 5 columns
* The following examples show how to create tables with 1 to 5 columns.
* Each of the tables uses the feature of spanning: if columns for a row are set to {@code null} (not simply empty),
* they will be treated as columns the next non-null column should span.
*
*
*
* A table with 1 column
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(null,"Table Heading");
at.addRule();
at.addRow("first row (col1)", "with some information (col2)");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* Will print the following table to the standard output:
*
┌──────────────────────────────────────────────────────────────────────────┐
│ Table Heading │
├──────────────────────────────────────────────────────────────────────────┤
│ first row (col1) │
├──────────────────────────────────────────────────────────────────────────┤
│ second row (col1) │
└──────────────────────────────────────────────────────────────────────────┘
*
*
*
*
* A table with 2 columns
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(null,"Table Heading");
at.addRule();
at.addRow("first row (col1)", "with some information");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* Will print the following table to the standard output:
*
┌──────────────────────────────────────────────────────────────────────────┐
│ Table Heading │
├─────────────────────────────────────┬────────────────────────────────────┤
│ first row (col1) │ with some information (col2) │
├─────────────────────────────────────┼────────────────────────────────────┤
│ second row (col1) │ with some information (col2) │
└─────────────────────────────────────┴────────────────────────────────────┘
*
*
*
*
* A table with 3 columns
* The following example creates a table with 3 columns:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(null, null, "Table Heading");
at.addRule();
at.addRow("first row (col1)", "with some information", "and more information");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)", "and more information (col3)");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* Will print the following table to the standard output:
*
┌──────────────────────────────────────────────────────────────────────────┐
│ Table Heading │
├────────────────────────┬────────────────────────┬────────────────────────┤
│ first row (col1) │ with some information │ and more information │
├────────────────────────┼────────────────────────┼────────────────────────┤
│ second row (col1) │ with some information │ and more information │
│ │ (col2) │ (col3) │
└────────────────────────┴────────────────────────┴────────────────────────┘
*
*
*
*
* A table with 4 columns
* The following example creates a table with 4 columns:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(null, null, null, "Table Heading");
at.addRule();
at.addRow("first row (col1)", "with some information", "and more information", "even more");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)", "and more information (col3)", "even more");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* Will print the following table to the standard output:
*
┌──────────────────────────────────────────────────────────────────────────┐
│ Table Heading │
├──────────────────┬──────────────────┬──────────────────┬─────────────────┤
│ first row (col1) │ with some │ and more │ even more │
│ │ information │ information │ │
├──────────────────┼──────────────────┼──────────────────┼─────────────────┤
│ second row │ with some │ and more │ even more │
│ (col1) │ information │ information │ │
│ │ (col2) │ (col3) │ │
└──────────────────┴──────────────────┴──────────────────┴─────────────────┘
*
*
*
*
* A table with 5 columns
* The following example creates a table with 5 columns:
* {@code
new V2_AsciiTable();
at.addRule();
at.addRow(null, null, null, null, "Table Heading");
at.addRule();
at.addRow("first row (col1)", "with some information", "and more information", "even more", "more");
at.addRule();
at.addRow("second row (col1)", "with some information (col2)", "and more information (col3)", "even more", "more");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* Will print the following table to the standard output:
*
┌──────────────────────────────────────────────────────────────────────────┐
│ Table Heading │
├──────────────┬──────────────┬──────────────┬──────────────┬──────────────┤
│ first row │ with some │ and more │ even more │ more │
│ (col1) │ information │ information │ │ │
├──────────────┼──────────────┼──────────────┼──────────────┼──────────────┤
│ second row │ with some │ and more │ even more │ more │
│ (col1) │ information │ information │ │ │
│ │ (col2) │ (col3) │ │ │
└──────────────┴──────────────┴──────────────┴──────────────┴──────────────┘
*
*
*
*
*
Text alignment in columns
* Text in columns can be aligned left, right, centered, justified with last line left bound, or justified with last line right bound.
* The first example shows left, right, and centered.
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("left", "right", "center").setAlignment(new char[]{'l', 'r', 'c'});
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌────────────────────────┬────────────────────────┬────────────────────────┐
│ left │ right │ center │
└────────────────────────┴────────────────────────┴────────────────────────┘
*
*
* The second example shows justified text.
* The first row justifies the text and has the last line left bound.
* The second row justifies the text and has the last line right bound.
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(new LoremIpsum().getWords()).setAlignment(new char[]{'j'});
at.addRule();
at.addRow(new LoremIpsum().getWords()).setAlignment(new char[]{'t'});
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(60));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌──────────────────────────────────────────────────────────┐
│ Lorem ipsum dolor sit amet, consetetur sadipscing elitr, │
│ sed diam nonumy eirmod tempor invidunt ut labore et │
│ dolore magna aliquyam erat, sed diam voluptua. At vero │
│ eos et accusam et justo duo dolores et ea rebum. Stet │
│ clita kasd gubergren, no sea takimata sanctus est Lorem │
│ ipsum dolor sit amet. │
├──────────────────────────────────────────────────────────┤
│ Lorem ipsum dolor sit amet, consetetur sadipscing elitr, │
│ sed diam nonumy eirmod tempor invidunt ut labore et │
│ dolore magna aliquyam erat, sed diam voluptua. At vero │
│ eos et accusam et justo duo dolores et ea rebum. Stet │
│ clita kasd gubergren, no sea takimata sanctus est Lorem │
│ ipsum dolor sit amet. │
└──────────────────────────────────────────────────────────┘
*
*
*
* The example above is using the loremipsum package to generate the text.
*
*
*
*
*
Conditional line breaks
*
* Text in column content can contain conditional line breaks.
* When text is processed, CRLF, CR, and LF line breaks are used to calculate columns.
* In addition, the HTML entities <br> and <br/> can be used for conditional line breaks.
*
*
* The following example creates a table with one column.
* The text in the column is broken into paragraps using conditional line breaks.
* Three of them are used: the first will seperate the two text bloks into paragraphs while the other two will create empty lines between them:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(new LoremIpsum().getParagraphs(1) + "\r\n\n
" + new LoremIpsum().getParagraphs(1));
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthFixedColumns().add(60));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌────────────────────────────────────────────────────────────┐
│ Lorem ipsum dolor sit amet, consetetur sadipscing elitr, │
│ sed diam nonumy eirmod tempor invidunt ut labore et dolore │
│ magna aliquyam erat, sed diam voluptua. At vero eos et │
│ accusam et justo duo dolores et ea rebum. Stet clita kasd │
│ gubergren, no sea takimata sanctus est Lorem ipsum dolor │
│ sit amet. │
│ │
│ │
│ Lorem ipsum dolor sit amet, consetetur sadipscing elitr, │
│ sed diam nonumy eirmod tempor invidunt ut labore et dolore │
│ magna aliquyam erat, sed diam voluptua. At vero eos et │
│ accusam et justo duo dolores et ea rebum. Stet clita kasd │
│ gubergren, no sea takimata sanctus est Lorem ipsum dolor │
│ sit amet. │
└────────────────────────────────────────────────────────────┘
*
*
*
*
*
Creating lists using conditional line breaks
* Conditional line breaks can also be used to create simple lists.
* The text formatting is not fexible (and all formatting must be done in the actual text) but the result (given that the column width is sufficient) will be a list in a column.
* The following example shows a table with 2 columns, the second column creating a treee-item list using conditional line break and extra formatting for lable, spacing and indentation:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("column with a list using line breaks", " * list item one\n * list item two \r\n * list item three");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthFixedColumns().add(25).add(40));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌─────────────────────────┬────────────────────────────────────────┐
│ column with a list │ * list item one │
│ using line breaks │ * list item two │
│ │ * list item three │
└─────────────────────────┴────────────────────────────────────────┘
*
*
*
*
*
Column padding
*
* Text in rows can be padded.
* Padding means to add padding character before and after the text in the row (the same for both, so it is symetrical).
* The {@link de.vandermeer.asciitable.v2.V2_AsciiTable} uses a default padding of 1.
*
*
* The default padding of the table can be changed creating a table with a different default padding.
* The padding of individual rows can be set (overwriting default padding) using {@link de.vandermeer.asciitable.v2.row.ContentRow#setPadding(int[])}.
* Increased padding will impact the wrapping of text in columns since it reduces the available space for text in a column.
*
*
* This example shows 5 rows with different padding and how it impacts line wrapping:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("padding 0", "padding 1", "padding 2", "padding 3", "padding 4").setPadding(new int[]{0, 1, 2, 3, 4});
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌──────────────┬──────────────┬──────────────┬──────────────┬──────────────┐
│padding 0 │ padding 1 │ padding 2 │ padding │ paddin │
│ │ │ │ 3 │ g 4 │
└──────────────┴──────────────┴──────────────┴──────────────┴──────────────┘
*
*
*
*
*
Column spanning
* Rows can span columns.
* This is done by adding columns of {@code null} content to a row followed by a column with content.
* The column with content will span all previous rows with content {@code null}.
* The following example creates a table with 5 columns and different column spanning (all to none columns):
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow(null, null, null, null, "span all 5 columns");
at.addRule();
at.addRow(null, null, null, "span 4 columns", "just 1 column");
at.addRule();
at.addRow(null, null, "span 3 columns", null, "span 2 columns");
at.addRule();
at.addRow(null, "span 2 columns", null, null, "span 3 columns");
at.addRule();
at.addRow("just 1 column", null, null, null, "span 4 columns");
at.addRule();
at.addRow("just 1 column", "just 1 column", "just 1 column", "just 1 column", "just 1 column");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌───────────────────────────────────────────────────────────────────────────────┐
│ span all 5 columns │
├───────────────────────────────────────────────────────────────┬───────────────┤
│ span 4 columns │ just 1 column │
├───────────────────────────────────────────────┬───────────────┴───────────────┤
│ span 3 columns │ span 2 columns │
├───────────────────────────────┬───────────────┴───────────────────────────────┤
│ span 2 columns │ span 3 columns │
├───────────────┬───────────────┴───────────────────────────────────────────────┤
│ just 1 column │ span 4 columns │
├───────────────┼───────────────┬───────────────┬───────────────┬───────────────┤
│ just 1 column │ just 1 column │ just 1 column │ just 1 column │ just 1 column │
└───────────────┴───────────────┴───────────────┴───────────────┴───────────────┘
*
*
*
*
*
Padding character
* The table renderer can be set to use different padding characters.
* A padding character is the character used to fill content rows (all their columns) up to the next border.
* Using UTF-8 characters might not be result in the anticipated result.
* The following example creates a table with 1 table rendered with the same renderer set for different padding characters:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("some text with padding");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
rend.setPaddingChar('*');
System.out.println(rend.render(at));
rend.setPaddingChar('-');
System.out.println(rend.render(at));
rend.setPaddingChar('␣');
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
+--------------------------------------------------------------------------+
| some text with padding |
+--------------------------------------------------------------------------+
+--------------------------------------------------------------------------+
| some text with padding***************************************************|
+--------------------------------------------------------------------------+
+--------------------------------------------------------------------------+
| some text with padding---------------------------------------------------|
+--------------------------------------------------------------------------+
+--------------------------------------------------------------------------+
| some text with padding␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣␣|
+--------------------------------------------------------------------------+
*
*
*
*
*
Table theme
* The table renderer can be set to use different table themes.
* A table theme defines all border characters for rules, strong rules and content rows.
* The following example creates a table with 1 table rendered with the same renderer set for different table themes (using pre-defined themes):
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("some column text");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setWidth(new WidthAbsoluteEven(76));
System.out.println(rend.render(at));
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
System.out.println(rend.render(at));
rend.setTheme(V2_E_TableThemes.UTF_DOUBLE_LIGHT.get());
System.out.println(rend.render(at));
rend.setTheme(V2_E_TableThemes.UTF_DOUBLE.get());
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
+--------------------------------------------------------------------------+
| some column text |
+--------------------------------------------------------------------------+
┌──────────────────────────────────────────────────────────────────────────┐
│ some column text │
└──────────────────────────────────────────────────────────────────────────┘
╓──────────────────────────────────────────────────────────────────────────╖
║ some column text ║
╙──────────────────────────────────────────────────────────────────────────╜
╔══════════════════════════════════════════════════════════════════════════╗
║ some column text ║
╚══════════════════════════════════════════════════════════════════════════╝
*
*
*
*
*
Rule styles
*
* Rules can come in two style: normal or strong.
* To add a normal rule the the table use {@link de.vandermeer.asciitable.v2.V2_AsciiTable#addRule()}.
* To add a normal rule the the table use {@link de.vandermeer.asciitable.v2.V2_AsciiTable#addStrongRule()}.
*
*
* Any table theme will suport normal rules.
* Strong rules will only be rendered differently if the table theme support them.
* The rendering for strong rules can differ for top, mid, and bottom rules dependin on the theme.
* That means they can all look the same or very different depending on what the table theme defines.
* For instance, the them {@link de.vandermeer.asciitable.v2.themes.V2_E_TableThemes#ASC7_LATEX_STYLE_STRONG}
* defines the same strong top and bottom but different mid rules.
* However, the theme {@link de.vandermeer.asciitable.v2.themes.V2_E_TableThemes#ASC7_LATEX_STYLE_STRONG2}
* defines very different strong rules for top, mid, bottom.
*
*
* The following example creates a table with several strong rules and renders them using the two different themes used above.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addStrongRule();
at.addRow("col1", "col2", "col3");
at.addStrongRule();
at.addRow("col1", "col2", "col3");
at.addRule();
at.addRow("col1", "col2", "col3");
at.addStrongRule();
at.addRow("col1", "col2", "col3");
at.addRule();
at.addRow("col1", "col2", "col3");
at.addStrongRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setWidth(new WidthAbsoluteEven(76));
rend.setTheme(V2_E_TableThemes.ASC7_LATEX_STYLE_STRONG.get());
System.out.println(rend.render(at));
rend.setTheme(V2_E_TableThemes.ASC7_LATEX_STYLE_STRONG2.get());
System.out.println(rend.render(at));
* }
*
* The output of the first table is:
*
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
col1 col2 col3
════════════════════════════════════════════════════════════════════════════
col1 col2 col3
────────────────────────────────────────────────────────────────────────────
col1 col2 col3
════════════════════════════════════════════════════════════════════════════
col1 col2 col3
────────────────────────────────────────────────────────────────────────────
col1 col2 col3
≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡≡
*
*
* The output of the second table is:
*
▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀
col1 col2 col3
════════════════════════════════════════════════════════════════════════════
col1 col2 col3
────────────────────────────────────────────────────────────────────────────
col1 col2 col3
════════════════════════════════════════════════════════════════════════════
col1 col2 col3
────────────────────────────────────────────────────────────────────────────
col1 col2 col3
▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓
*
*
*
*
Table and column widths
*
* The renderer can be configured with {@link de.vandermeer.asciitable.v2.render.V2_Width} objects for calculating the width of columns and the overall table.
* Depending on the object, the rendering of the table will differ.
* Several implementations are provided, others can be added by implementing the interface.
*
*
*
*
* Width with table width and evenly distributed column witdh
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthAbsoluteEven} calculates the width using an absolute table width and then using the same width for each column.
* Same here means as evenly distributed as possible.
* The following examples show the same 3-row table rendered with different widths.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("col1", "col2", "col3");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthAbsoluteEven(50));
System.out.println(rend.render(at));
rend.setWidth(new WidthAbsoluteEven(30));
System.out.println(rend.render(at));
rend.setWidth(new WidthAbsoluteEven(20));
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
┌────────────────┬───────────────┬───────────────┐
│ col1 │ col2 │ col3 │
└────────────────┴───────────────┴───────────────┘
┌─────────┬─────────┬────────┐
│ col1 │ col2 │ col3 │
└─────────┴─────────┴────────┘
┌──────┬─────┬─────┐
│ col1 │ col │ col │
│ │ 2 │ 3 │
└──────┴─────┴─────┘
*
*
*
*
* Width with fixed width per column
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthFixedColumns} calculates the width using a fixed width per column.
* The following examples show the same 3-row table rendered with different widths.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("col1", "col2", "col3");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthFixedColumns().add(10).add(20).add(30));
System.out.println(rend.render(at));
rend.setWidth(new WidthFixedColumns().add(5).add(10).add(15));
System.out.println(rend.render(at));
rend.setWidth(new WidthFixedColumns().add(3).add(5).add(7));
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
┌──────────┬────────────────────┬──────────────────────────────┐
│ col1 │ col2 │ col3 │
└──────────┴────────────────────┴──────────────────────────────┘
┌─────┬──────────┬───────────────┐
│ col │ col2 │ col3 │
│ 1 │ │ │
└─────┴──────────┴───────────────┘
┌───┬─────┬───────┐
│ c │ col │ col3 │
│ o │ 2 │ │
│ l │ │ │
│ 1 │ │ │
└───┴─────┴───────┘
*
*
*
* Width using the longest word per column for column width, no further restrictions
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthLongestWord} calculates column width using the longest word per column (plus column padding).
* The following examples show the same 2-row table rendered with different widths.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable(0);
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWord());
System.out.println(rend.render(at));
at = new V2_AsciiTable(1);
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWord());
System.out.println(rend.render(at));
at = new V2_AsciiTable(0);
at.addRule();
at.addRow("first", "information".setPadding(new int[]{2, 3});
at.addRule();
at.addRow("second", "info").setPadding(new int[]{3, 4});
at.addRule();
rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWord());
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
┌──────┬───────────┐
│first │information│
├──────┼───────────┤
│second│info │
└──────┴───────────┘
┌────────┬─────────────┐
│ first │ information │
├────────┼─────────────┤
│ second │ info │
└────────┴─────────────┘
┌────────────┬─────────────────┐
│ first │ information │
├────────────┼─────────────────┤
│ second │ info │
└────────────┴─────────────────┘
*
*
*
*
* Width using the longest word per column for column width with minimum column width
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthLongestWordMinCol} calculates column width using the longest word per column (plus column padding) with a minimum column width.
* The following examples show the same 2-row table rendered with different widths.
* Example one uses an overall minimum (so column 1 is longer).
* Example two uses individual minimum with column 2 being longer.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWordMinCol(11));
System.out.println(rend.render(at));
at = new V2_AsciiTable();
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWordMinCol(new int[]{-1,50}));
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
┌───────────┬─────────────┐
│ first │ information │
├───────────┼─────────────┤
│ second │ info │
└───────────┴─────────────┘
┌────────┬──────────────────────────────────────────────────┐
│ first │ information │
├────────┼──────────────────────────────────────────────────┤
│ second │ info │
└────────┴──────────────────────────────────────────────────┘
*
*
*
*
* Width using the longest word per column for column width with maximum column width
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthLongestWordMaxCol} calculates column width using the longest word per column (plus column padding) with a maximum column width.
* The following examples show the same 2-row table rendered with different widths.
* Example one uses an overall maximum (so column 2 is shorter).
* Example two uses individual maximum with column 1 being shorter.
*
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWordMaxCol(10));
System.out.println(rend.render(at));
at = new V2_AsciiTable();
at.addRule();
at.addRow("first", "information");
at.addRule();
at.addRow("second", "info");
at.addRule();
rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthLongestWordMaxCol(new int[]{5,-1}));
System.out.println(rend.render(at));
* }
*
* The output of the examples is:
*
┌────────┬──────────┐
│ first │ informat │
│ │ ion │
├────────┼──────────┤
│ second │ info │
└────────┴──────────┘
┌─────┬─────────────┐
│ fir │ information │
│ st │ │
├─────┼─────────────┤
│ sec │ info │
│ ond │ │
└─────┴─────────────┘
*
*
*
*
* Width using the longest line per column for column width with added minimum and maximum column width
*
* The class {@link de.vandermeer.asciitable.v2.render.WidthLongestLine} calculates column width using the longest possible line per column with.
* Additionally, the class allows to set minimum and maximum column width per column.
* The following examples show a 5-column table rendered with different settings for longest line.
*
*
* The first example creates the table and uses default width, i.e. every column should be only as long as the longest line in it:
* {@code
V2_AsciiTable at = new V2_AsciiTable();
at.addRule();
at.addRow("", "1", "22", "333", "4444");
at.addRule();
WidthLongestLine width = new WidthLongestLine();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
System.out.println(rend.setWidth(width).render(at));
* }
*
* The output of the example is:
*
┌──┬───┬────┬─────┬──────┐
│ │ 1 │ 22 │ 333 │ 4444 │
└──┴───┴────┴─────┴──────┘
*
*
* Now we change the minimum width of the first column to twice the table padding without setting a maximum:
* {@code
int padd = 2 * at.getDefaultPadding();
width.add(padd + 2, 0);
System.out.println(rend.setWidth(width).render(at));
* }
*
* The output of the example is:
*
┌────┬───┬────┬─────┬──────┐
│ │ 1 │ 22 │ 333 │ 4444 │
└────┴───┴────┴─────┴──────┘
*
*
* Now add a maximum value for the last column set to the table padding plus 4.
* This means the maximum column size is now smaller than the longes line and line wrapping will happen:
* {@code
width.add(padd + 2, 0).add(0, 0).add(0, 0).add(0, padd + 2);
System.out.println(rend.setWidth(width).render(at));
* }
*
* The output of the example is:
*
┌────┬────┬────┬─────┬────┐
│ │ 1 │ 22 │ 333 │ 44 │
│ │ │ │ │ 44 │
└────┴────┴────┴─────┴────┘
*
*
* Now we add another row in which column 4 has a longer line ("4444") then the one in the first row ("333").
* The example is also using conditional line break in the added row:
* {@code
at.addRow("", "1", "22", "333\n4444", "4444");
at.addRule();
System.out.println(rend.setWidth(width).render(at));
* }
*
* The output of the example is:
*
┌────┬────┬────┬──────┬────┐
│ │ 1 │ 22 │ 333 │ 44 │
│ │ │ │ │ 44 │
├────┼────┼────┼──────┼────┤
│ │ 1 │ 22 │ 333 │ 44 │
│ │ │ │ 4444 │ 44 │
└────┴────┴────┴──────┴────┘
*
*
*
*
*
Table without border to format text paragraphs
*
* The table can be used to format paragraphs simply using the table theme {@link de.vandermeer.asciitable.v2.themes.V2_E_TableThemes#NO_BORDERS}.
* This theme will print no borders, so the only formatting visible is the padding and the paragraph alignement.
*
*
* The follwing example creates a table with two rows, using the no-border-theme.
* The first row creates a simple justified paragraph.
* The second row creates a paragraph with the same content plus a padding of 5.
* {@code
ContentRow row;
V2_AsciiTable at = new V2_AsciiTable(0);
at.addRule();
row = at.addRow(new LoremIpsum().getParagraphs(1));
row.setAlignment(new char[]{'j'});
at.addRule();
row = at.addRow(new LoremIpsum().getParagraphs(1));
row.setPadding(new int[]{5});
row.setAlignment(new char[]{'j'});
at.addRule();
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.NO_BORDERS.get());
rend.setWidth(new WidthFixedColumns().add(60));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed
diam nonumy eirmod tempor invidunt ut labore et dolore magna
aliquyam erat, sed diam voluptua. At vero eos et accusam et
justo duo dolores et ea rebum. Stet clita kasd gubergren, no
sea takimata sanctus est Lorem ipsum dolor sit amet.
Lorem ipsum dolor sit amet, consetetur sadipscing
elitr, sed diam nonumy eirmod tempor invidunt ut
labore et dolore magna aliquyam erat, sed diam
voluptua. At vero eos et accusam et justo duo
dolores et ea rebum. Stet clita kasd gubergren, no
sea takimata sanctus est Lorem ipsum dolor sit
amet.
*
*
*
*
Using AsciiLists in tables
* AsciiLists from the asciilist project can be used in tables.
* The lists provide rendering for a given width already, so the table renderer can simply set the width for such a list and use the list's renderer.
* All AsciiLists are supported, but some settings can produce unwanted results:
*
* -
* Using UTF characters for list labels might not work inside a table.
* Reason for that is that some monospace fonts do not print all UTF characters with equal length.
* Most special label characters in the lists fall into that category.
*
* -
* When using lists in columns of the same row some UTF characters are not printed out correctly.
* The reason for that is not yet known.
*
*
*
* For the example we first create a set of AsciiList lists, one per itemize, enumerate and check list.
* The itemize list example has two nested lists with two items each.
* The padding is set to 0.:
* {@code
ItemizeList il = new ItemizeList();
il.addItem("il 1 item 1 some text");
il.addItem("il 1 item 2 some text");
ItemizeList il2 = new ItemizeList();
il2.addItem("il 2 item 1 text");
il2.addItem("il 2 item 2 text");
il.addItem(il2);
il.setPreLabelIndent(0);
il.setListStyle(NestedItemizeStyles.ALL_STAR_INCREMENTAL);
* }
*
* The enumerate list example has two nested lists with two items each.
* The padding is set to 0.:
* {@code
EnumerateList el = new EnumerateList();
el.addItem("el 1 item 1 some text");
el.addItem("el 1 item 2 some text");
EnumerateList el2 = new EnumerateList();
el2.addItem("el 2 item 1 text");
el2.addItem("el 2 item 2 text");
el.addItem(el2);
el.setPreLabelIndent(0);
el.setListStyle(NestedEnumerateStyles.aLL_alpha_ascii);
* }
*
* The checklist example has two one list with two items (one checked and one not checked).
* The padding is set to 0:
* {@code
CheckList cl = new CheckList();
cl.addItem ("cl 1 item 1 some text");
cl.addItemChecked("cl 1 item 2 some text");
cl.setPreLabelIndent(0);
cl.setListStyle(NestedCheckStyles.ALL_SQUARE_BRACKET_BLANK_X);
* }
*
* Now we create a table and add the three lists into a row using the default padding of 1.
* Then we add all lists to a second row with specific padding of 3 for each column.
* This second row will show the wrapping of overlength list items:
* {@code
V2_AsciiTable at = new V2_AsciiTable(1);
at.addRule();
at.addRow(il, el, cl);
at.addRule();
at.addRow(il, el, cl).setPadding(new int[]{3, 3, 3});
at.addRule();
* }
*
* For the renderer, we use a fixed column length set to 25 for the columns with itemize and enumerate lists.
* The width for the columns with the check lists is set to 27 to show one column with and one without line wrapping:
* {@code
V2_AsciiTableRenderer rend = new V2_AsciiTableRenderer();
rend.setTheme(V2_E_TableThemes.UTF_LIGHT.get());
rend.setWidth(new WidthFixedColumns().add(25).add(25).add(27));
System.out.println(rend.render(at));
* }
*
* The output of the example is:
*
┌─────────────────────────┬─────────────────────────┬───────────────────────────┐
│ * il 1 item 1 some text │ a el 1 item 1 some text │ [ ] cl 1 item 1 some text │
│ * il 1 item 2 some text │ b el 1 item 2 some text │ [X] cl 1 item 2 some text │
│ ** il 2 item 1 text │ b.a el 2 item 1 text │ │
│ ** il 2 item 2 text │ b.b el 2 item 2 text │ │
├─────────────────────────┼─────────────────────────┼───────────────────────────┤
│ * il 1 item 1 some │ a el 1 item 1 some │ [ ] cl 1 item 1 some │
│ text │ text │ text │
│ * il 1 item 2 some │ b el 1 item 2 some │ [X] cl 1 item 2 some │
│ text │ text │ text │
│ ** il 2 item 1 │ b.a el 2 item 1 │ │
│ text │ text │ │
│ ** il 2 item 2 │ b.b el 2 item 2 │ │
│ text │ text │ │
└─────────────────────────┴─────────────────────────┴───────────────────────────┘
*
*
* @author Sven van der Meer <[email protected]>
* @version v1.0.0 build 160319 (19-Mar-16) for Java 1.7
*/
package de.vandermeer.asciitable.v2;