Provided by: libtickit-perl_0.73-1_amd64 bug

NAME

       "Tickit::Rect" - a lightweight data structure representing a rectangle

SYNOPSIS

        use Tickit::Rect;

        my $rect = Tickit::Rect->new(
           top => 0, left => 5, lines => 3, cols => 10
        );

DESCRIPTION

       Objects in this class represent a rectangle, by storing the top left corner coordinate and
       the size in lines and columns. This data structure is purely abstract and not tied to a
       particular window or coordinate system. It exists simply as a convenient data store
       containing some useful utility methods.

CONSTRUCTORS

   new
          $rect = Tickit::Rect->new( %args )

       Construct a new rectangle of the given geometry, given by "top", "left" and either "lines"
       and "cols", or "bottom" and "right".

          $rect = Tickit::Rect->new( $str )

       If given a single string, this will be parsed in the form

        (left,top)..(right,bottom)

   intersect
          $rect = $existing_rect->intersect( $other_rect )

       If there is an intersection between the given rectangles, return it. If not, return
       "undef".

   translate
          $rect = $existing_rect->translate( $downward, $rightward )

       Returns a new rectangle of the same size as the given one, moved down and to the right by
       the given argmuents (which may be negative)

ACCESSORS

   top
   left
   bottom
   right
          $top = $rect->top

          $left = $rect->left

          $bottom = $rect->bottom

          $right = $rect->right

       Return the edge boundaries of the rectangle.

   lines
   cols
          $lines = $rect->lines

          $cols = $rect->cols

       Return the size of the rectangle.

   linerange
          @lines = $rect->linerange( $min, $max )

       A convenient shortcut to generate the list of lines covered that are within the given
       bounds (either bound may be given as "undef"). Without bounds, equivalent to:

          $rect->top .. $rect->bottom - 1

METHODS

   equals
          $bool = $rect->equals( $other )

          $bool = ( $rect == $other )

       Returns true if $other represents the same area as $rect. This method overloads the
       numerical equality operator ("==").

   contains
          $bool = $rect->contains( $other )

       Returns true if $other is entirely contained within the bounds of $rect.

   intersects
          $bool = $rect->intersects( $other )

       Returns true if $other and $rect intersect at all, even if they overlap.

   add
          @r = $rect->add( $other )

       Returns a list of the non-overlapping regions covered by either $rect or $other.

       In the trivial case that the two given rectangles do not touch, the result will simply be
       a list of the two initial rectangles. Otherwise a list of newly-constructed rectangles
       will be returned that covers the same area as the original two. This list will contain
       anywhere between 1 and 3 rectangles.

   subtract
          @r = $rect->subtract( $other )

       Returns a list of the non-overlapping regions covered by $rect but not by $other.

       In the trivial case that $other completely covers $rect then the empty list is returned.
       In the trivial case that $other and $rect do not intersect then a list containing $rect is
       returned. Otherwise, a list of newly-constructed rectangles will be returned that covers
       the required area.  This list will contain anywhere between 1 and 4 rectangles.

AUTHOR

       Paul Evans <leonerd@leonerd.org.uk>