-
Notifications
You must be signed in to change notification settings - Fork 122
Collection manipulation
Wang Renxin edited this page Aug 5, 2016
·
32 revisions
MY-BASIC supplies a set of LIST
, DICT
manipulation function libraries which provide creation, accessing, iteration, etc. as below:
Name | Description |
---|---|
LIST | Creates a list |
DICT | Creates a dictionary |
PUSH | Pushes a value to the tail of a list, overridable for referenced usertype |
POP | Pops a value from the tail of a list, overridable for referenced usertype |
PEEK | Peeks the value of a tail of a list, overridable for referenced usertype |
INSERT | Inserts a value at a specific position of a list, overridable for referenced usertype |
SORT | Sorts a list increasingly, overridable for referenced usertype |
EXIST | Tells whether a list contains a specific value, or whether a dictionary contains a specific key, overridable for referenced usertype |
INDEX_OF | Gets the index of a value in a list, overridable for referenced usertype |
GET | Returns the value of a specific index in a list, or the value of a specific key in a dictionary, or a member of a class instance, overridable for referenced usertype |
SET | Sets the value of a specific index in a list, or the value of a specific key in a dictionary, or a member variable of a class instance, overridable for referenced usertype |
REMOVE | Removes the element of a specific index in a list, or the element of a specific key in a dictionary, overridable for referenced usertype |
CLEAR | Clears a list or a dictionary, overridable for referenced usertype |
CLONE | Clones a collection, each element will be duplicated |
TO_ARRAY | Copies all elements from a list to an array |
ITERATOR | Gets an iterator of a list or a dictionary |
MOVE_NEXT | Moves an iterator to next position for a list or a dictionary |
Besides, it's also able to apply some other generic function to collections:
Name | Description |
---|---|
VAL | Returns the number type value of a string, or the value of a dictionary iterator, overridable for referenced usertype |
LEN | Get element count of a collection, overridable for referenced usertype |
For example:
l = list(1, 2, 3, 4)
set(l, 1, “b”)
print exist(l, 2); pop(l); peek(l); len(l);
d = dict(1, “one”, 2, “two”)
set(d, 3, “three”)
print len(d)
it = iterator(d)
while move_next(it)
print get(it);
wend
It's able to implement other collection functions with these facilities, for example a REVERSED
function as follow:
def reversed(l)
if not l is type("list") then
return nil
endif
ret = list()
while len(l) <> 0
push(ret, pop(l))
wend
return ret
enddef
CAR
and CDR
as well:
def car(l)
if not (l is type("list")) then
return nil
endif
if len(l) = 0 then
return nil
endif
return l(0)
enddef
def cdr(l)
if not (l is type("list")) then
return nil
endif
if len(l) = 0 then
return nil
endif
ret = clone(l)
remove(ret, 0)
return ret
enddef
A JOIN
function:
def join(lst, sep)
ret = ""
l = len(lst)
for i = 0 to l - 1
ret = ret + lst(i)
if i <> l - 1 then
ret = ret + sep
endif
next
return ret
enddef
Sorted iterator for dictionary, with usage:
class iterator_node
var key = nil
var value = nil
endclass
def sorted_iterator(d)
l = list()
i = iterator(d)
while move_next(i)
push(l, get(i))
wend
sort(l)
i = iterator(l)
n = new(iterator_node)
return lambda()
(
if not move_next(i) then
return nil
endif
k = get(i)
n.key = k
n.value = d(k)
return n
)
enddef
d = dict()
d(1) = "uno"
d(2) = "dos"
d(3) = "thres"
i = sorted_iterator(d)
p = i()
while p
print p.key, ", ", p.value;
p = i()
wend
Read the Stack module page to get information about how to implement a stack collection.
- Principles
- Coding
- Data types
- Standalone shell
- Integration
- Customization
- More scripting API
- FAQ