Documentation ¶
Index ¶
- func FixBoundaries[T any](maxWidth, maxHeight int, elems [][]T, x, y *int) [][]T
- type Table
- func (dt *Table[T]) ClearTable()
- func (dt *Table[T]) GetAt(x, y int) T
- func (dt *Table[T]) GetFullTable() [][]T
- func (dt *Table[T]) GetHeight() int
- func (dt *Table[T]) GetWidth() int
- func (dt *Table[T]) IsXInBounds(x int) error
- func (dt *Table[T]) IsYInBounds(y int) error
- func (t *Table[T]) Iterator() uc.Iterater[T]
- func (dt *Table[T]) WriteAt(x, y int, cell T)
- func (dt *Table[T]) WriteHorizontalSequence(x, y *int, sequence []T)
- func (dt *Table[T]) WriteTableAt(table *Table[T], x, y *int)
- func (dt *Table[T]) WriteVerticalSequence(x, y *int, sequence []T)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func FixBoundaries ¶
FixBoundaries is a function that fixes the boundaries of a table of elements based on the maximum width and height of the table.
Parameters:
- maxWidth: The maximum width of the table.
- maxHeight: The maximum height of the table.
- elems: The elements of the table.
- x: The x-coordinate to fix the boundaries at.
- y: The y-coordinate to fix the boundaries at.
Returns:
- [][]T: The elements of the table with the boundaries fixed.
Behaviors:
- If maxWidth is less than 0, it is set to 0.
- If maxHeight is less than 0, it is set to 0.
- If elems is empty, nil is returned.
Types ¶
type Table ¶
type Table[T any] struct { // contains filtered or unexported fields }
Table[T] represents a table of cells that can be drawn to the screen.
func NewTable ¶
NewDrawTable creates a new Table[T] with the given width and height.
Parameters:
- width: The width of the table.
- height: The height of the table.
Returns:
- *Table[T]: The new table.
Behaviors:
- If the width or height is negative, the absolute value is used.
func (*Table[T]) ClearTable ¶
func (dt *Table[T]) ClearTable()
ClearTable clears the table by setting all cells to their zero value.
func (*Table[T]) GetAt ¶
GetAt returns the cell at the given coordinates in the table.
Parameters:
- x: The x-coordinate of the cell.
- y: The y-coordinate of the cell.
Returns:
- T: The cell at the given coordinates.
Behaviors:
- If the x or y coordinates are out of bounds, the function returns the zero value of type T.
func (*Table[T]) GetFullTable ¶
func (dt *Table[T]) GetFullTable() [][]T
GetFullTable returns the full table as a 2D slice of elements of type T.
Returns:
- [][]T: The full table.
func (*Table[T]) GetHeight ¶
GetHeight returns the height of the table.
Returns:
- int: The height of the table.
func (*Table[T]) GetWidth ¶
GetWidth returns the width of the table.
Returns:
- int: The width of the table.
func (*Table[T]) IsXInBounds ¶
IsXInBounds checks if the given x-coordinate is within the bounds of the table.
Parameters:
- x: The x-coordinate to check.
Returns:
- error: An error of type *uc.ErrOutOfBounds if the x-coordinate is out of bounds.
func (*Table[T]) IsYInBounds ¶
IsYInBounds checks if the given y-coordinate is within the bounds of the table.
Parameters:
- y: The y-coordinate to check.
Returns:
- error: An error of type *uc.ErrOutOfBounds if the y-coordinate is out of bounds.
func (*Table[T]) Iterator ¶
Iterator returns an iterator for the table. It iterates over the rows and columns as if it were an array of elements of type T.
Returns:
- uc.Iterater[T]: An iterator for the table.
Behaviors:
- For efficiency, the iterator is procedural. It is not a generator.
func (*Table[T]) WriteAt ¶
WriteAt writes a cell to the table at the given coordinates.
Parameters:
- x: The x-coordinate of the cell.
- y: The y-coordinate of the cell.
- cell: The cell to write to the table.
Behaviors:
- If the x or y coordinates are out of bounds, the function does nothing.
func (*Table[T]) WriteHorizontalSequence ¶
WriteHorizontalSequence writes a sequence of cells to the table starting at the given coordinates. The sequence is written horizontally from the starting coordinates.
Parameters:
- x: The x-coordinate of the starting cell.
- y: The y-coordinate of the starting cell.
- sequence: The sequence of cells to write to the table.
Behaviors:
- Any value that would cause the sequence to be written outside the bounds of the table is ignored.
- The x-coordinate is updated to the next available cell after the sequence is written.
func (*Table[T]) WriteTableAt ¶
WriteTableAt writes the given table to the table at the given coordinates.
Parameters:
- x: The x-coordinate to write the table at.
- y: The y-coordinate to write the table at.
- table: The table to write to the table.
Behaviors:
- If the table is nil, the function does nothing.
- Any value that would cause the table to be written outside the bounds of the table is ignored.
- The x and y coordinates are updated to the next available cell after the table is written.
func (*Table[T]) WriteVerticalSequence ¶
WriteVerticalSequence writes a sequence of cells to the table starting at the given coordinates. The sequence is written vertically from the starting coordinates.
Parameters:
- x: The x-coordinate of the starting cell.
- y: The y-coordinate of the starting cell.
- sequence: The sequence of cells to write to the table.
Behaviors:
- Any value that would cause the sequence to be written outside the bounds of the table is ignored.
- The y-coordinate is updated to the next available cell after the sequence is written.