The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

Name

SPVM::List - Dynamic Object Array

Usage

  use List;
  
  # Create a object list
  my $list = List->new;
  my $list = List->new([(object)Byte->new(1), Int->new(2), Long->new(3)]);

  # Create a Int list
  my $list = List->new([Int->new(1), Int->new(2), Int->new(3)]);
  
  # Create a object list with length
  my $list = List->new_len([], 3);

  # Create a Int list with length
  my $list = List->new_len(new Int[0], 3);

  # Get list length
  my $length = $list->length;
  
  # Push object value
  $list->push(Int->new(3));

  # Pop object value.
  my $element = $list->pop;

  # Unshift object value.
  $list->unshift(Int->new(3));
  
  # Shift object value.
  my $element = $list->shift;
  
  # Set object value.
  $list->set(2, Int->new(3));
  
  # Get object value.
  my $element = $list->get(2);

  # Insert object value
  $list->insert(1, Int->new(3));

  # Remove object value
  my $element = $list->remove(1);

  # Convert List to object array.
  my $int_array = $list->to_array;

  # Convert List to Int array.
  my $int_array = (Int[])$list->to_array;

Description

List is the dynamic object array that has a specified object array type.

Enumerations

  enum {
    DEFAULT_CAPACITY = 4,
  }

DEFAULT_CAPACITY

The default capacity. The value is 4.

Fields

capacity

  has capacity : ro int;

The capacity. This is the length of the internally reserved elements to extend the length of the list.

length

  has length : ro int;

The length of the list.

values

  has values : ro object[];

The values. This is the elements in the internally used array, but it can be manipulated directly.

Class Methods

new

  static method new : List ($array = undef : object[], $capacity = -1 : int);

Creates a new List object using "new_len".

The passed length to "new_len" is the length of the $array. If the array is undef, the length is 0.

The element's addresses of the object array are copied to the values of the the created array.

  # object[]
  my $list = List->new([(object)Byte->new(1), Int->new(2), Long->new(3)]);
  
  # Int[]
  my $list = List->new([Int->new(1), Int->new(2), Int->new(3)]);

new_len

  static method new_len : List ($proto_array : object[], $length : int, $capacity = -1 : int);

Creates a new StringList object with the $protot_array, the $length and the $capacity.

If the $protot_array is undefined, the $protot_array is set to an object[] object.

If the $capacity is less than 0, the $capacity is set to the value of "DEFAULT_CAPACITY".

If the $length is greater than the $capacity, the $capacity is set to the length.

Exceptions:

The $length must be greater than or equal to 0.

Examples:

  # Create a Int list with length
  my $list = List->new_len(new Int[0], 3);

Instance Methods

get

  method get : object ($index : int);

Gets the element of the position of the $index.

Exceptions:

The $index must be greater than or equal to 0.

The $index must be less than the length of the $list.

insert

  method insert : void ($index : int, $element : object);

Inserts an $element to the position of the $index.

Exceptions:

The $index must be greater than or equal to 0.

The $index must be less than or equal to the length of the $list.

pop

  method pop : object ();

Removes the last element and return it.

Exceptions:

The length of the $list must be greater than 0.

push

  method push : void ($element : object);

Adds an $element after the end of the list.

remove

  method remove : object ($index : int);

Removes the element at the position of the $index and return it.

Exceptions:

The $index must be greater than or equal to 0.

The $index must be less than the length of the $list.

replace

  method replace : void ($offset : int, $remove_length : int, $replace : string[]);

Replaces the elements of the range specified by the $offset and the $lenght with the $replace array.

Exceptions:

The $offset must be greater than or equal to 0.

The $remove_length must be greater than or equal to 0.

The $offset + the $removing lenght must be less than or equal to the length of the $list.

reserve

  method reserve : void ($new_capacity : int);

Reserves the elements with the $new_capacity.

If the $new_capacity is greater than the capacity of the list, the capacity of the list is extended to the $new_capacity.

Note that "values" is replaced with the new values and the values of the original list are copied to the new values in the above case.

Exceptions:

The $new_capacity must be greater than or equal to 0.

resize

  method resize : void ($new_length : int);

Resize the list with the $new_length.

Exceptions:

The $new_length must be greater than or equal to 0.

replace

  method replace : void ($offset : int, $remove_length : int, $replace : object[]);

Replaces the elements of the range specified by the $offset and the $remove_length with the replacement array.

Exceptions:

The $offset must be greater than or equal to 0.

The $remove_length must be greater than or equal to 0.

The $offset + the $removing lenght must be less than or equal to the length of the $list.

set

  method set : void ($index : int, $element : object);

Sets the $element at the position of the $index.

Exceptions:

The $index must be greater than or equal to 0.

The $index must be less than the length of the $list.

set_array

  method set_array : void ($array : object[]);

Sets an $array. Each element of the $array is copied to the element of the list.

Exceptions:

The $array must be defined.

The length of the $array must be the $same as the length of the $list.

shift

  method shift : object ();

Removes the first element and return it.

Exceptions:

The length of the $list must be greater than 0.

to_array

  method to_array : object[] ();

Converts the list to an array.

unshift

  method unshift : void ($element : object);

Inserts an $element at the beginning of the list.