diff options
author | Louis Pilfold <louis@lpil.uk> | 2023-01-19 11:36:25 +0000 |
---|---|---|
committer | Louis Pilfold <louis@lpil.uk> | 2023-01-19 11:36:25 +0000 |
commit | 32dea132cb56cf023634bc7e87550c7949cdf7f1 (patch) | |
tree | acfb0c664cb33b229f44f679152233f820efad6c /src | |
parent | 7a2d4cff2b4e881a749ab6de0a7cf0b6c989df08 (diff) | |
download | javascript-32dea132cb56cf023634bc7e87550c7949cdf7f1.tar.gz javascript-32dea132cb56cf023634bc7e87550c7949cdf7f1.zip |
length->size, documentation
Diffstat (limited to 'src')
-rw-r--r-- | src/gleam/javascript/array.gleam | 68 |
1 files changed, 62 insertions, 6 deletions
diff --git a/src/gleam/javascript/array.gleam b/src/gleam/javascript/array.gleam index 9718fc8..19b860d 100644 --- a/src/gleam/javascript/array.gleam +++ b/src/gleam/javascript/array.gleam @@ -1,24 +1,80 @@ -// TODO: docs -// TODO: labels +/// A JavaScript array, in Gleam! +/// +/// Unlike most data structures in Gleam this one is mutable. +/// pub external type Array(element) +/// Convert a JavaScript array to a Gleam list. +/// +/// Runs in linear time. +/// pub external fn to_list(Array(element)) -> List(element) = "../../gleam.mjs" "toList" +/// Convert a Gleam list to a JavaScript array. +/// +/// Runs in linear time. +/// pub external fn from_list(List(element)) -> Array(element) = "../../ffi.mjs" "toArray" -pub external fn length(Array(element)) -> Int = +/// Get the number of elements in the array. +/// +/// Runs in constant time. +/// +pub external fn size(Array(element)) -> Int = "../../ffi.mjs" "length" -pub external fn map(Array(a), fn(a) -> b) -> Array(b) = +/// Returns a new array containing only the elements of the first array after +/// the function has been applied to each one. +/// +/// Runs in linear time. +/// +/// # Examples +/// +/// ```gleam +/// > map(from_list([2, 4, 6]), fn(x) { x * 2 }) +/// from_list([4, 8, 12]) +/// ``` +/// +pub external fn map(Array(a), with: fn(a) -> b) -> Array(b) = "../../ffi.mjs" "map" -pub external fn fold(Array(e), a, fn(a, e) -> a) -> a = +/// Reduces a list of elements into a single value by calling a given function +/// on each element, going from left to right. +/// +/// `fold(from_list([1, 2, 3]), 0, add)` is the equivalent of +/// `add(add(add(0, 1), 2), 3)`. +/// +/// Runs in linear time. +/// +pub external fn fold(over: Array(e), from: a, with: fn(a, e) -> a) -> a = "../../ffi.mjs" "reduce" -pub external fn fold_right(Array(e), a, fn(a, e) -> a) -> a = +/// Reduces a list of elements into a single value by calling a given function +/// on each element, going from right to left. +/// +/// `fold_right(from_list([1, 2, 3]), 0, add)` is the equivalent of +/// `add(add(add(0, 3), 2), 1)`. +/// +/// Runs in linear time. +/// +pub external fn fold_right(over: Array(e), from: a, with: fn(a, e) -> a) -> a = "../../ffi.mjs" "reduceRight" +/// Get the element at the given index. +/// +/// # Examples +/// +/// ```gleam +/// > get(from_list([2, 4, 6]), 1) +/// Ok(4) +/// ``` +/// +/// ```gleam +/// > get(from_list([2, 4, 6]), 4) +/// Error(Nil) +/// ``` +/// pub external fn get(Array(e), Int) -> Result(e, Nil) = "../../ffi.mjs" "index" |