at:tutorial:appendix
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revisionNext revisionBoth sides next revision | ||
at:tutorial:appendix [2008/07/10 14:28] – Added tvcutsem | at:tutorial:appendix [2008/07/10 15:42] – added tvcutsem | ||
---|---|---|---|
Line 102: | Line 102: | ||
==== Vector ==== | ==== Vector ==== | ||
- | A vector is a dynamically resizable AmbientTalk table (aka array). Vectors may be created as follows: | + | A vector is a dynamically resizable AmbientTalk table (aka array). Indexed reading from and writing to a vector is fast (O(1)). Adding elements to a vector is mostly fast, but sometimes requires a resize of the vector. Vectors support the traditional stack operations '' |
+ | |||
+ | Vectors may be created as follows: | ||
< | < | ||
Line 112: | Line 114: | ||
< | < | ||
- | // returns the number of elements in the vector (not the capacity | + | // returns the number of elements in the vector (not its capacity!) |
length() | length() | ||
+ | |||
// returns whether the vector contains elements or not | // returns whether the vector contains elements or not | ||
isEmpty() | isEmpty() | ||
+ | |||
// is the vector at max. capacity? | // is the vector at max. capacity? | ||
atMaxCapacity() | atMaxCapacity() | ||
+ | |||
// return idx'th element or raise an IndexOutOfBounds exception | // return idx'th element or raise an IndexOutOfBounds exception | ||
at(idx) | at(idx) | ||
+ | |||
// write idx'th element or raise IndexOutOfBounds exception | // write idx'th element or raise IndexOutOfBounds exception | ||
- | //atPut(idx, val) | + | atPut(idx, val) |
// iterate over the vector | // iterate over the vector | ||
each: iterator, returns nil | each: iterator, returns nil | ||
+ | |||
// map a unary function over the vector, returns a new vector | // map a unary function over the vector, returns a new vector | ||
map: fun | map: fun | ||
+ | |||
// accumulate a function with a given starting value | // accumulate a function with a given starting value | ||
inject: init into: accum; | inject: init into: accum; | ||
+ | |||
// returns a new vector whose elements satisfy " | // returns a new vector whose elements satisfy " | ||
filter: cond; | filter: cond; | ||
+ | |||
// implode a vector of character strings into one text string | // implode a vector of character strings into one text string | ||
implode() | implode() | ||
+ | |||
// join a vector of character strings together with the given string | // join a vector of character strings together with the given string | ||
join(txt) | join(txt) | ||
+ | |||
// returns a range [start, | // returns a range [start, | ||
select(start, | select(start, | ||
- | // appends an element to the back of the vector | + | |
- | // returns | + | // appends an element to the back of the vector. Returns |
add(element) | add(element) | ||
// alias for add(element) | // alias for add(element) | ||
- | def << | + | << |
// insert an element at a given position, causing subsequent elements to shift one pos to the right. Returns this vector | // insert an element at a given position, causing subsequent elements to shift one pos to the right. Returns this vector | ||
insert(atPos, | insert(atPos, | ||
+ | |||
// delete the element at the given position, shifts all following elements one pos to the left. Returns the value of the element at the deleted position. | // delete the element at the given position, shifts all following elements one pos to the left. Returns the value of the element at the deleted position. | ||
delete(atPos) | delete(atPos) | ||
+ | |||
// adds elements to the back of the vector | // adds elements to the back of the vector | ||
push(element) | push(element) | ||
+ | |||
// deletes elements from the back of the vector | // deletes elements from the back of the vector | ||
pop() | pop() | ||
- | // return the index of the first element matching the given filter (a unary predicate), or nil if none is found | + | |
+ | // return the index of the first element matching the unary predicate or nil if none is found | ||
find: filter | find: filter | ||
+ | |||
// remove the given element from the vector, return true if the element was actually found and deleted, false otherwise | // remove the given element from the vector, return true if the element was actually found and deleted, false otherwise | ||
remove(elt, cmp := defaultComparator) | remove(elt, cmp := defaultComparator) | ||
+ | |||
// remove all objects for which filter(elt) returns true | // remove all objects for which filter(elt) returns true | ||
removeAll: filter | removeAll: filter | ||
+ | |||
// destructively appends otherVector to self. Returns this vector | // destructively appends otherVector to self. Returns this vector | ||
addAll(otherVector) | addAll(otherVector) | ||
+ | |||
// empties the vector | // empties the vector | ||
clear() | clear() | ||
+ | |||
// Return a new vector whose elements form the set-union of all elements in self U otherVector | // Return a new vector whose elements form the set-union of all elements in self U otherVector | ||
union(otherVector, | union(otherVector, | ||
+ | |||
// Return a new vector whose elements form the set-intersection of all elements in self ^ otherVector | // Return a new vector whose elements form the set-intersection of all elements in self ^ otherVector | ||
intersection(otherVector, | intersection(otherVector, | ||
+ | |||
// Return a new vector whose elements form the set-difference of self \ otherVector | // Return a new vector whose elements form the set-difference of self \ otherVector | ||
difference(otherVector, | difference(otherVector, | ||
+ | |||
// Quicksort the vector in-place. The comparator defines the ordering among elements. | // Quicksort the vector in-place. The comparator defines the ordering among elements. | ||
sort(cmp := { |e1,e2| e1 < e2 }) | sort(cmp := { |e1,e2| e1 < e2 }) | ||
+ | |||
// Turn the vector into a set without duplicates in O(nlogn + n) | // Turn the vector into a set without duplicates in O(nlogn + n) | ||
// The vector' | // The vector' | ||
uniq(cmp := defaultComparator, | uniq(cmp := defaultComparator, | ||
+ | |||
// return an element drawn randomly using a uniform distribution from the array or raise an EmptyVector exception. | // return an element drawn randomly using a uniform distribution from the array or raise an EmptyVector exception. | ||
random() | random() | ||
+ | |||
// return a table containing all elements of the vector | // return a table containing all elements of the vector | ||
asTable() | asTable() | ||
</ | </ | ||
+ | |||
+ | The file '' | ||
==== List ==== | ==== List ==== | ||
+ | |||
+ | The module ''/ | ||
+ | |||
+ | The list module defines two styles to manipulate cons-cells: an object-oriented and a functional style. The object-oriented style represents cons-cells as '' | ||
+ | |||
+ | The functional style allows one to manipulate lists by means of the following functions: | ||
+ | |||
+ | < | ||
+ | cons(car, | ||
+ | car(conscell) -> the car | ||
+ | cdr(conscell) -> the cdr | ||
+ | list(@items) -> a cons-cell representing the head of a list | ||
+ | </ | ||
+ | |||
+ | Lists (cons-cells or the empty list) support the following operations: | ||
+ | |||
+ | < | ||
+ | // accessors for car and cdr | ||
+ | car() | ||
+ | cdr() | ||
+ | |||
+ | // the length of the list | ||
+ | length() | ||
+ | |||
+ | // whether the list is empty or not | ||
+ | isEmpty() | ||
+ | |||
+ | // returns the nth element of the list | ||
+ | nth(n) | ||
+ | |||
+ | // apply a unary function to each element of the list | ||
+ | each: fun | ||
+ | |||
+ | // apply a function to each element and its index in the list | ||
+ | // i.e. list.eachWithIndex: | ||
+ | eachWithIndex: | ||
+ | |||
+ | // map a unary function over the list, returning a new list | ||
+ | map: fun | ||
+ | |||
+ | // accumulate a value over a list | ||
+ | inject: init into: accum | ||
+ | |||
+ | // return a new list whose elements satisfy the unary predicate | ||
+ | filter: cond | ||
+ | |||
+ | // does the list contain the element? | ||
+ | contains(elt, | ||
+ | |||
+ | // implode or join a list of text strings | ||
+ | implode() | ||
+ | join(txt) | ||
+ | |||
+ | // drop the first n elements from the list | ||
+ | tail(n) | ||
+ | |||
+ | // prepend an element to the list | ||
+ | add(elt) | ||
+ | |||
+ | // insert an element in the list (functionally) | ||
+ | insert(atPos, | ||
+ | |||
+ | // return a new list where the element atPos is deleted | ||
+ | delete(atPos) | ||
+ | |||
+ | // functional append | ||
+ | append(aList) | ||
+ | |||
+ | // return the index of the first matching element, or nil if none is found | ||
+ | find: filter | ||
+ | |||
+ | // return the index in the list of the element or nil of not found | ||
+ | indexOf(elt, | ||
+ | |||
+ | // return a list where the given element is removed | ||
+ | remove(elt, cmp := DEFAULTCOMPARATOR) | ||
+ | |||
+ | // return a new list where all objects for which filter(elt) is true are removed | ||
+ | removeAll: filter | ||
+ | |||
+ | // convert the list into a table | ||
+ | asTable() | ||
+ | </ | ||
+ | |||
+ | The file '' | ||
+ | |||
+ | |||
+ | ===== Top-level functions ===== | ||
+ | |||
+ | The file '' | ||
+ | |||
+ | ==== Asynchronous control structures ==== | ||
+ | |||
+ | The '' | ||
+ | |||
+ | '' | ||
+ | < | ||
+ | loop: { | ||
+ | ... | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | An '' | ||
+ | < | ||
+ | whenTrue: booleanFuture then: { ... } else: { ... } | ||
+ | </ | ||
+ | |||
+ | Asynchronous while loop over future-type conditional: | ||
+ | < | ||
+ | asLongAs: { /* asynchronous computation returning a future */ } do: { ... } | ||
+ | </ | ||
+ | |||
+ | ==== Mobile code ==== | ||
+ | |||
+ | The function '' | ||
+ | |||
+ | < | ||
+ | def mobileAdder(x) { | ||
+ | script: { |n| x + n } carrying: [`x] | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | A call to '' | ||
+ | |||
+ | The constructor function '' | ||
+ | |||
+ | < | ||
+ | def foo := 42; | ||
+ | def i := isolate: { | ||
+ | ... | ||
+ | } passAs: { |foo| | ||
+ | / | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | The above code defines an isolate object '' | ||
+ | |||
+ | ===== Custom Exceptions ===== | ||
+ | |||
+ | The module ''/ | ||
+ | |||
+ | < | ||
+ | deftype FooException; | ||
+ | </ | ||
+ | |||
+ | Next, define a prototype exception object using the '' | ||
+ | |||
+ | < | ||
+ | def XFooException := createException(FooException); | ||
+ | </ | ||
+ | |||
+ | '' | ||
+ | |||
+ | < | ||
+ | raise: XFooException.new(" | ||
+ | </ | ||
+ | |||
+ | If your custom exception requires additional state, you can define it as an extension of the prototype exception. If you define a custom constructor, | ||
+ | |||
+ | < | ||
+ | deftype IndexOutOfBounds; | ||
+ | def XIndexOutOfBounds := createException(IndexOutOfBounds) with: { | ||
+ | def min; | ||
+ | def max; | ||
+ | def idx; | ||
+ | def init(min, max, idx) { | ||
+ | super^init(" | ||
+ | self.min := min; | ||
+ | self.max := max; | ||
+ | self.idx := idx; | ||
+ | }; | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | The exception module also exports an auxiliary function '' | ||
+ | |||
+ | ===== Language Extensions ===== | ||
+ | |||
+ | The files in the '' | ||
+ | |||
+ | ==== Futures and Multifutures ==== | ||
+ | |||
+ | ==== Dynamic Variables ==== | ||
+ | |||
+ | ==== Ambient References ==== | ||
+ | |||
+ | ==== Structural Types ==== | ||
+ | |||
+ | ==== Traits ==== | ||
+ | |||
+ |
at/tutorial/appendix.txt · Last modified: 2021/09/24 10:28 by elisag