StringExt

package
v0.2.31 Latest Latest
Warning

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

Go to latest
Published: Apr 25, 2024 License: MIT Imports: 10 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func ByteSplitter added in v0.2.28

func ByteSplitter(data []byte, sep byte) [][]byte

ByteSplitter splits a byte slice into multiple slices based on a separator byte. The separator byte is not included in the resulting slices.

If the input slice is empty, the function returns nil.

Parameters:

  • data: The byte slice to split.
  • sep: The separator byte.

Returns:

  • [][]byte: A slice of byte slices.

func CalculateNumberOfLines

func CalculateNumberOfLines(text []string, width int) (int, error)

CalculateNumberOfLines is a function that calculates the minimum number of lines needed to fit a given text within a specified width.

Panics with an error of type *ers.ErrInvalidParameter if the text is empty, or if the width is less than or equal to 0.

Parameters:

  • text: The slice of strings representing the text to calculate the number of lines for.
  • width: The width to fit the text within.

Returns:

  • int: The calculated number of lines needed to fit the text within the width.
  • bool: True if it is possible to fit the text within the width, and false otherwise.

The function calculates the total length of the text (Tl) and uses a mathematical formula to estimate the minimum number of lines needed to fit the text within the given width. The formula is explained in detail in the comments within the function.

func FindContentIndexes

func FindContentIndexes(openingToken, closingToken string, contentTokens []string) (int, int, error)

FindContentIndexes searches for the positions of opening and closing tokens in a slice of strings.

Panics with an error of type *ers.ErrInvalidParameter if the opening or closing tokens are empty, or with an error of type *ers.ErrCallFailed if the opening token is not found.

Parameters:

  • openingToken: The string that marks the beginning of the content.
  • closingToken: The string that marks the end of the content.
  • contentTokens: The slice of strings in which to search for the tokens.

Returns:

  • int: The start index of the content (inclusive).
  • int: The end index of the content (exclusive).
  • error: An error of type *ErrNeverOpened if the closing token is found without any corresponding opening token, or an error of type *ErrClosingTokenNotFound if the closing token is not found.

func GenerateID added in v0.2.14

func GenerateID(size int) (string, error)

GenerateID generates a random ID of the specified size (in bytes).

Parameters:

  • size: The size of the ID to generate (in bytes).

Returns:

  • string: The generated ID.
  • error: An error of type *ers.ErrInvalidParameter if the size is less than 1. Otherwise, any error returned by the rand.Read function.

The function uses the crypto/rand package to generate a random ID of the specified size.

func JoinBytes added in v0.2.28

func JoinBytes(slices [][]byte, sep byte) string

JoinBytes joins multiple byte slices into a single string using a separator byte.

If the input slice is empty, the function returns an empty string.

Parameters:

  • slices: A slice of byte slices to join.
  • sep: The separator byte.

Returns:

  • string: The joined string.

func ReplaceSuffix

func ReplaceSuffix(str, suffix string) (string, error)

ReplaceSuffix replaces the end of the given string with the provided suffix.

Panics with an error of type *ers.ErrCallFailed if the suffix is longer than the string.

Parameters:

  • str: The original string.
  • suffix: The suffix to replace the end of the string.

Returns:

  • string: The resulting string after replacing the end with the suffix.

func SplitSentenceIntoFields

func SplitSentenceIntoFields(sentence string, indentLevel int) ([][]string, error)

SplitSentenceIntoFields splits the string into fields, where each field is a substring separated by one or more whitespace characters. The function also handles special characters such as tabs, vertical tabs, carriage returns, line feeds, and form feeds.

Panics with an error of type *ers.ErrInvalidParameter if the indentLevel is negative.

Parameters:

  • sentence: The string to split into fields.
  • indentLevel: The number of spaces that a tab character is replaced with.

Returns:

  • [][]string: A two-dimensional slice of strings, where each inner slice represents the fields of a line from the input string.
  • error: An error if any of the runes in the string is invalid.

Types

type ErrClosingTokenNotFound

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

ErrClosingTokenNotFound is a struct that represents an error when a closing token is not found in the content.

func NewErrClosingTokenNotFound added in v0.2.25

func NewErrClosingTokenNotFound(token string) *ErrClosingTokenNotFound

NewErrClosingTokenNotFound is a constructor of ErrClosingTokenNotFound.

Parameters:

  • token: The closing token that was not found in the content.

Returns:

  • *ErrClosingTokenNotFound: A pointer to the newly created error.

func (*ErrClosingTokenNotFound) Error

func (e *ErrClosingTokenNotFound) Error() string

Error is a method of the ErrClosingTokenNotFound type that implements the error interface.

Returns:

  • string: The error message.

type ErrNeverOpened

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

ErrNeverOpened is a struct that represents an error when a closing token is found without a corresponding opening token.

func NewErrNeverOpened added in v0.2.25

func NewErrNeverOpened(openingToken, closingToken string) *ErrNeverOpened

NewErrNeverOpened is a constructor of ErrNeverOpened.

Parameters:

  • openingToken: The opening token that was never closed.
  • closingToken: The closing token that was found without a corresponding opening token.

Returns:

  • *ErrNeverOpened: A pointer to the newly created error.

func (*ErrNeverOpened) Error

func (e *ErrNeverOpened) Error() string

Error is a method of the ErrNeverOpened type that implements the error interface.

Returns:

  • string: The error message.

type ErrOpeningTokenNotFound

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

ErrOpeningTokenNotFound is a struct that represents an error when an opening token is not found in the content.

func NewErrOpeningTokenNotFound added in v0.2.25

func NewErrOpeningTokenNotFound(token string) *ErrOpeningTokenNotFound

NewErrOpeningTokenNotFound is a constructor of ErrOpeningTokenNotFound.

Parameters:

  • token: The opening token that was not found in the content.

Returns:

  • *ErrOpeningTokenNotFound: A pointer to the newly created error.

func (*ErrOpeningTokenNotFound) Error

func (e *ErrOpeningTokenNotFound) Error() string

Error is a method of the ErrOpeningTokenNotFound type that implements the error interface.

Returns:

  • string: The error message.

type SpltLine

type SpltLine struct {
	// The Line field is a slice of strings, each representing a word in the line.
	Line []string

	// The Len field is an integer representing the total length of the line,
	// including spaces between words.
	Len int
}

SpltLine is a helper struct used in the SplitTextInEqualSizedLines function. It represents a line of text.

func NewSpltLine

func NewSpltLine(word string) SpltLine

NewSpltLine creates a new SpltLine instance.

Parameters:

  • word: The initial word to add to the line.

Returns:

  • *SpltLine: A pointer to the created SpltLine instance.

func (*SpltLine) InsertWord

func (sl *SpltLine) InsertWord(word string)

InsertWord is a method of SpltLine that adds a given word to the end of the line.

Parameters:

  • word: The word to add to the line.

func (*SpltLine) String

func (sl *SpltLine) String() string

String is a method of SpltLine that converts the SpltLine to a string.

Returns:

  • string: The resulting string.

type TextSplitter

type TextSplitter struct {
	// The Width represents the maximum length of a line.
	Width int

	// The Lines field is a slice of pointers to SpltLine structs, each representing
	// a line of text.
	Lines []SpltLine
}

TextSplitter is a helper struct used in the SplitTextInEqualSizedLines function. It holds the width of the lines and a slice of pointers to SpltLine structs.

func SplitTextInEqualSizedLines

func SplitTextInEqualSizedLines(text []string, width int, maxHeight optional.Int) (TextSplitter, error)

SplitTextInEqualSizedLines is a function that splits a given text into lines of equal width.

Parameters:

  • text: The slice of strings representing the text to split.
  • width: The width of the lines.
  • maxHeight: The maximum height of the text.

Returns:

  • *TextSplitter: A pointer to the created TextSplitter instance.
  • error: An error of type *ErrEmptyText if the input text is empty, or an error of type *ErrWidthTooSmall if the width is less than or equal to 0.

The function calculates the minimum number of lines needed to fit the text within the width using the CalculateNumberOfLines function. Furthermore, it uses the Sum of Squared Mean (SQM) to find the optimal solution for splitting the text into lines of equal width.

If maxHeight is not provided, the function calculates the number of lines needed to fit the text within the width using the CalculateNumberOfLines function.

func (*TextSplitter) CanInsertWord

func (ts *TextSplitter) CanInsertWord(word string, lineIndex int) bool

CanInsertWord is a method of TextSplitter that checks if a given word can be inserted into a specific line without exceeding the width of the TextSplitter.

Parameters:

  • word: The word to check.
  • lineIndex: The index of the line to check.

Returns:

  • bool: True if the word can be inserted into the line at lineIndex without exceeding the width, and false otherwise.

func (*TextSplitter) GetFurthestRightEdge

func (ts *TextSplitter) GetFurthestRightEdge() int

GetFurthestRightEdge is a method of TextSplitter that returns the length of the longest line in the TextSplitter.

Returns:

  • int: The length of the longest line.

func (*TextSplitter) InsertWord

func (ts *TextSplitter) InsertWord(word string) bool

InsertWord is a method of TextSplitter that attempts to insert a given word into the TextSplitter.

Parameters:

  • word: The word to insert.

Returns:

  • bool: True if the word was successfully inserted, and false if the word is too long to fit within the width of the TextSplitter.

func (*TextSplitter) InsertWordAt

func (ts *TextSplitter) InsertWordAt(word string, lineIndex int) error

InsertWordAt is a method of TextSplitter that attempts to insert a given word into a specific line of the TextSplitter.

Panics with an error of type *ers.ErrInvalidParameter if the lineIndex is out of bounds.

Parameters:

  • word: The word to insert.
  • lineIndex: The index of the line to insert the word into.

Jump to

Keyboard shortcuts

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