Involved Source Files
Package tabwriter implements a write filter (tabwriter.Writer) that
translates tabbed columns in input into properly aligned text.
The package is using the Elastic Tabstops algorithm described at
http://nickgravgaard.com/elastictabstops/index.html.
Package-Level Type Names (total 3, in which 1 are exported)
/* sort exporteds by: | */
A Writer is a filter that inserts padding around tab-delimited
columns in its input to align them in the output.
The Writer treats incoming bytes as UTF-8 encoded text consisting
of cells terminated by (horizontal or vertical) tabs or line
breaks (newline or formfeed characters). Cells in adjacent lines
constitute a column. The Writer inserts padding as needed to
make all cells in a column have the same width, effectively
aligning the columns. It assumes that all characters have the
same width except for tabs for which a tabwidth must be specified.
Note that cells are tab-terminated, not tab-separated: trailing
non-tab text at the end of a line does not form a column cell.
The Writer assumes that all Unicode code points have the same width;
this may not be true in some fonts.
If DiscardEmptyColumns is set, empty columns that are terminated
entirely by vertical (or "soft") tabs are discarded. Columns
terminated by horizontal (or "hard") tabs are not affected by
this flag.
If a Writer is configured to filter HTML, HTML tags and entities
are passed through. The widths of tags and entities are
assumed to be zero (tags) and one (entities) for formatting purposes.
A segment of text may be escaped by bracketing it with Escape
characters. The tabwriter passes escaped text segments through
unchanged. In particular, it does not interpret any tabs or line
breaks within the segment. If the StripEscape flag is set, the
Escape characters are stripped from the output; otherwise they
are passed through as well. For the purpose of formatting, the
width of the escaped text is always computed excluding the Escape
characters.
The formfeed character ('\f') acts like a newline but it also
terminates all columns in the current line (effectively calling
Flush). Cells in the next line start new columns. Unless found
inside an HTML tag or inside an escaped text segment, formfeed
characters appear as newlines in the output.
The Writer must buffer input internally, because proper spacing
of one line may depend on the cells in future lines. Clients must
call Flush when done calling Write.
// column alignment
current state
// collected text excluding tabs or line breaks
// current incomplete cell; cell.width is up to buf[pos] excluding ignored sections
// terminating char of escaped sequence (Escape for escapes, '>', ';' for HTML tags/entities, or 0)
flagsuint
// list of lines; each line is a list of cells
minwidthint
configuration
padbytes[8]bytepaddingint
// buffer position up to which cell.width of incomplete cell has been computed
tabwidthint
// list of column widths in runes - re-used during formatting
Flush should be called after the last call to Write to ensure
that any data buffered in the Writer is written to output. Any
incomplete escape sequence at the end is considered
complete for formatting purposes.
A Writer must be initialized with a call to Init. The first parameter (output)
specifies the filter output. The remaining parameters control the formatting:
minwidth minimal cell width including any padding
tabwidth width of tab characters (equivalent number of spaces)
padding padding added to a cell before computing its width
padchar ASCII char used for padding
if padchar == '\t', the Writer will assume that the
width of a '\t' in the formatted output is tabwidth,
and cells are left-aligned independent of align_left
(for correct-looking results, tabwidth must correspond
to the tab width in the viewer displaying the result)
flags formatting control
SetColumnAlignRight will mark a particular column as align right.
This is reset on the next flush.
Write writes buf to the writer b.
The only errors returned are ones encountered
while writing to the underlying output stream.
(*T) addLine()
Append text to current cell.
debugging support (keep code around)
Terminate escaped mode. If the escaped text was an HTML tag, its width
is assumed to be zero for formatting purposes; if it was an HTML entity,
its width is assumed to be one. In all other cases, the width is the
unicode width of the text.
Format the text between line0 and line1 (excluding line1); pos
is the buffer position corresponding to the beginning of line0.
Returns the buffer position corresponding to the beginning of
line1 and an error, if any.
Reset the current state.
Start escaped mode.
Terminate the current cell by adding it to the list of cells of the
current line. Returns the number of cells in that line.
Update the cell width.
(*T) write0(buf []byte)(*T) writeLines(pos0 int, line0, line1 int) (pos int)(*T) writeN(src []byte, n int)(*T) writePadding(textw, cellw int, useTabs bool)
*T : io.Writer
func NewWriter(output io.Writer, minwidth, tabwidth, padding int, padchar byte, flags uint) *Writer
func (*Writer).Init(output io.Writer, minwidth, tabwidth, padding int, padchar byte, flags uint) *Writer
A cell represents a segment of text terminated by tabs or line breaks.
The text itself is stored in a separate buffer; cell only describes the
segment's size in bytes, its width in runes, and whether it's an htab
('\t') terminated cell.
// true if the cell is terminated by an htab ('\t')
// cell size in bytes
// cell width in runes
local error wrapper so we can distinguish errors we want to return
as errors from genuine panics (which we don't want to return as errors)
errerror
Package-Level Functions (total 2, in which 1 are exported)
NewWriter allocates and initializes a new tabwriter.Writer.
The parameters are the same as for the Init function.
Package-Level Constants (total 7, all are exported)
Force right-alignment of cell content.
Default is left-alignment.
Print a vertical bar ('|') between columns (after formatting).
Discarded columns appear as zero-width columns ("||").
Handle empty columns as if they were not present in
the input in the first place.
To escape a text segment, bracket it with Escape characters.
For instance, the tab in this string "Ignore this tab: \xff\t\xff"
does not terminate a cell and constitutes a single character of
width one for formatting purposes.
The value 0xff was chosen because it cannot appear in a valid UTF-8 sequence.
Ignore html tags and treat entities (starting with '&'
and ending in ';') as single characters (width = 1).
Strip Escape characters bracketing escaped text segments
instead of passing them through unchanged with the text.
Always use tabs for indentation columns (i.e., padding of
leading empty cells on the left) independent of padchar.
The pages are generated with Goldsv0.3.2. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds.