roList
This object functions as a general-purpose, doubly linked list. It can be used as a container for arbitrary-length lists of BrightSign objects. The array operator [ ] can be used to access any element in an ordered list.
ifList
Count() As Integer
Returns the number of elements in the list.
ResetIndex() As Boolean
Resets the current index or position in the list to the head element.
AddTail(obj As Object) As Void
Adds a typed value to the tail of the list.
AddHead(obj As Object) As Void
Adds a typed value to the head of the list.
RemoveIndex() As Object
Removes an entry from the list at the current index or position and increments the index or position in the list. It returns Invalid when the end of the list is reached.
GetIndex() As Object
Retrieves an entry from the list at the current index or position and increments the index or position in the list. It returns Invalid when the end of the list is reached.
RemoveTail() As Object
Removes the entry at the tail of the list.
RemoveHead() As Object
Removes the entry at the head of the list.
GetTail() As Object
Retrieves the entry at the tail of the list and keeps the entry in the list.
GetHead() As Object
Retrieves the entry at the head of the list and keeps the entry in the list.
Clear()
Removes all elements from the list.
ifEnum
Reset()
Resets the position to the first element of enumeration.
Next() As Dynamic
Returns a typed value at the current position and increment position.
IsNext() As Boolean
Returns True if there is a next element.
IsEmpty() As Boolean
Returns True if there is not an exact statement.
ifArray
Peek() As Dynamic
Returns the last (highest index) list entry without removing it.
Pop() As Dynamic
Returns the last (highest index) entry and removes it from the list.
Push(entry As Dynamic)
Adds a new highest-index entry to the end of the list.
Shift() As Dynamic
Removes index zero from the list and shifts all other entries down by one unit.
Unshift(entry As Dynamic)
Adds a new index zero to the list and shifts all other entries up by one unit.
Delete(index As Integer) As Boolean
Deletes the indicated list entry and shifts all above entries down by one unit.
Count() As Integer
Returns the length of the list (i.e. the index of the highest entry in the list plus one).
Clear()
Deletes every entry in the list.
Append(list As roList)
Appends one roList to another. If the passed roList contains entries that were never set to a value, they are not appended.
The two appended objects must be of the same type.
ifArrayGet
GetEntry(a As Integer) As Dynamic
Returns a list entry of a given index. Entries start at zero. If an entry that has not been set is fetched, Invalid is returned.
ifArraySet
SetEntry(a As Integer, b As Dynamic)
Sets an entry of a given index to the passed type value.
Example
list = CreateObject("roList")
list.AddTail("a")
list.AddTail("b")
list.AddTail("c")
list.AddTail("d")
list.ResetIndex()
x= list.GetIndex()
while x <> invalid
print x
x = list.GetIndex()
end while
print list[2]