Strings

package
v0.4.9 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 2, 2024 License: MIT Imports: 8 Imported by: 1

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ArrayFormatter added in v0.3.8

func ArrayFormatter(values []string) string

ArrayFormatter formats a list of strings as an array.

Parameters:

  • values: The list of strings to format.

Returns:

  • string: The formatted array.

func DateStringer

func DateStringer(date time.Time) string

DateStringer prints the date in the format "1st January, 2006".

Parameters:

  • date: The date to print.

Returns:

  • string: The date in the format "1st January, 2006".

func FixTabStop added in v0.3.27

func FixTabStop(init, tabSize int, spacing, str string) (string, int)

FixTabStop fixes the tab stops in a string.

The initial level and the integer return are used for chaining multiple calls to this function.

Parameters:

  • init: The initial level of the tab stop.
  • tabSize: The size of the tab.
  • spacing: The spacing to use for the tab stop.
  • str: The string to fix the tab stops for.

Returns:

  • string: The string with the tab stops fixed.
  • int: The total number of characters in the string.

Behaviors:

  • If the tabSize is less than 1, it is set to 1.
  • If the initial tab stop is less than 0, it is set to 0.
  • If the string is empty, an empty string is returned.

func LongestLine added in v0.3.18

func LongestLine[T any](table [][]T) int

LongestLine finds the longest line in a table.

Parameters:

  • table: The table to find the longest line in.

Returns:

  • int: The length of the longest line. -1 if the table is empty.

func PrintTree added in v0.4.5

func PrintTree[T Noder](root T) (string, error)

PrintTree prints the tree.

Parameters:

  • root: The root node.

Returns:

  • string: The tree as a string.
  • error: An error if printing fails.

func StringsJoiner added in v0.2.36

func StringsJoiner[T fmt.Stringer](values []T, sep string) string

StringsJoiner joins a list of fmt.Stringer values using a separator.

Parameters:

  • values: The list of fmt.Stringer values to join.
  • sep: The separator to use when joining the strings.

Returns:

  • string: The string representation of the values.

func TabAlign added in v0.3.18

func TabAlign(table [][]string, column int, tabSize int) ([][]string, error)

TabAlign aligns the tabs of a table's column.

Parameters:

  • table: The table to align.
  • column: The column to align.
  • tabSize: The size of the tab.

Returns:

  • [][]string: The aligned table.
  • error: An error of type *errors.ErrInvalidParameter if the tabSize is less than 1 or the column is less than 0.

Behaviors:

  • If the column is not found in the table, the table is returned as is.

func TableEntriesAlign added in v0.3.18

func TableEntriesAlign(table [][]string, tabSize int) ([][]string, error)

TableEntriesAlign aligns the entries of a table.

Parameters:

  • table: The table to align.
  • tabSize: The size of the tab.

Returns:

  • [][]string: The aligned table.
  • error: An error if there was an issue aligning the table.

Errors:

  • *errors.ErrAt: If there was an issue aligning a specific column.
  • *errors.ErrInvalidParameter: If the tabSize is less than 1.

func TimeStringer

func TimeStringer(time time.Time) string

TimeStringer prints the time in the format "3:04 PM".

Parameters:

  • time: The time to print.

Returns:

  • string: The time in the format "3:04 PM".

Types

type Noder added in v0.4.5

type Noder interface {
	IsLeaf() bool

	uc.Iterable[Noder]
	fmt.Stringer
}

type Printer added in v0.4.5

type Printer[T Noder] struct {
	// contains filtered or unexported fields
}

Printer is a tree printer.

type StackElement added in v0.4.5

type StackElement[T Noder] struct {
	// contains filtered or unexported fields
}

StackElement is a stack element.

type TableAligner added in v0.3.32

type TableAligner struct {
	// contains filtered or unexported fields
}

TableAligner is a struct to help align tables.

func NewTableAligner added in v0.3.32

func NewTableAligner() *TableAligner

NewTableAligner creates a new table aligner.

func (*TableAligner) AddRow added in v0.3.32

func (ta *TableAligner) AddRow(elems ...string)

AddRow adds a row to the table.

Parameters:

  • elems: The elements of the row.

func (*TableAligner) AlignColumn added in v0.3.33

func (ta *TableAligner) AlignColumn(idx int)

AlignColumn specifies a row to align.

Parameters:

  • idx: The index of the row to align.

Behaviors:

  • If the index is less than 0, the function does nothing.

func (*TableAligner) Build added in v0.3.32

func (ta *TableAligner) Build(tabSize int, tableIndent bool) ([]string, error)

Accept accepts the table aligner.

Parameters:

  • tabSize: The size of the tab.
  • tableIndent: Whether to indent the table.

Returns:

  • error: An error of type *errors.ErrInvalidParameter if the tabSize is less than 1.

func (*TableAligner) Reset added in v0.3.32

func (ta *TableAligner) Reset()

Reset resets the table aligner for reuse.

func (*TableAligner) SetHead added in v0.3.32

func (ta *TableAligner) SetHead(head string)

SetHead sets the head of the table.

Parameters:

  • head: The head of the table.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL