local F = require "F"F provides some useful functions inspired by functional programming
languages, especially by these Haskell modules:
This module provides functions for Lua tables that can represent both
arrays (i.e. integral indices) and tables (i.e. any indice types). The
F constructor adds methods to tables which may interfere with table
fields that could have the same names. In this case, F also defines the
__call metamethod that takes a method name and returns a function that
actually calls the requested method. E.g.:
t = F{foo = 12, mapk = 42} -- note that mapk is also a method of F tables
t:mapk(func) -- fails because mapk is a field of t
t"mapk"(func) -- works and is equivalent to F.mapk(func, t)F.op.land(a, b) -- a and b
F.op.lor(a, b) -- a or b
F.op.lxor(a, b) -- (not a and b) or (not b and a)
F.op.lnot(a) -- not aLogical operators
F.op.band(a, b) -- a & b
F.op.bor(a, b) -- a | b
F.op.bxor(a, b) -- a ~ b
F.op.bnot(a) -- ~a
F.op.shl(a, b) -- a << b
F.op.shr(a, b) -- a >> bBitwise operators
F.op.eq(a, b) -- a == b
F.op.ne(a, b) -- a ~= b
F.op.lt(a, b) -- a < b
F.op.le(a, b) -- a <= b
F.op.gt(a, b) -- a > b
F.op.ge(a, b) -- a >= bComparison operators
F.op.ueq(a, b) -- a == b (†)
F.op.une(a, b) -- a ~= b (†)
F.op.ult(a, b) -- a < b (†)
F.op.ule(a, b) -- a <= b (†)
F.op.ugt(a, b) -- a > b (†)
F.op.uge(a, b) -- a >= b (†)Universal comparison operators ((†) recursive comparisons on elements of possibly different Lua types)
F.op.keq(a, b) -- a == b (†)
F.op.kne(a, b) -- a ~= b (†)
F.op.klt(a, b) -- a < b (†)
F.op.kle(a, b) -- a <= b (†)
F.op.kgt(a, b) -- a > b (†)
F.op.kge(a, b) -- a >= b (†)Universal comparison operators ((†) non recursive comparisons on elements of possibly different Lua types). The
kxxfunctions are faster but less generic thanuxx. They are more suitable for sorting keys (e.g. F.keys).
F.op.add(a, b) -- a + b
F.op.sub(a, b) -- a - b
F.op.mul(a, b) -- a * b
F.op.div(a, b) -- a / b
F.op.idiv(a, b) -- a // b
F.op.mod(a, b) -- a % b
F.op.neg(a) -- -a
F.op.pow(a, b) -- a ^ bArithmetic operators
F.op.concat(a, b) -- a .. b
F.op.len(a) -- #aString/list operators
F.maybe(b, f, a)Returns f(a) if f(a) is not nil, otherwise b
F.default(def, x)Returns x if x is not nil, otherwise def
F.case(x) {
t1 = v1,
...
tn = vn,
[F.Nil] = default_value,
}returns
visuch thatti == xordefault_valueif notiis equal tox.
F.fst(xs)
xs:fst()Extract the first component of a list.
F.snd(xs)
xs:snd()Extract the second component of a list.
F.thd(xs)
xs:thd()Extract the third component of a list.
F.nth(n, xs)
xs:nth(n)Extract the n-th component of a list.
F.comp(a, b)Comparison (-1, 0, 1)
F.ucomp(a, b)Comparison (-1, 0, 1) (using universal comparison operators)
F.max(a, b)max(a, b)
F.min(a, b)min(a, b)
F.succ(a)a + 1
F.pred(a)a - 1
F.negate(a)-a
F.abs(a)absolute value of a
F.signum(a)sign of a (-1, 0 or +1)
F.quot(a, b)integer division truncated toward zero
F.rem(a, b)integer remainder satisfying quot(a, b)*b + rem(a, b) == a, 0 <= rem(a, b) < abs(b)
F.quot_rem(a, b)simultaneous quot and rem
F.div(a, b)integer division truncated toward negative infinity
F.mod(a, b)integer modulus satisfying div(a, b)*b + mod(a, b) == a, 0 <= mod(a, b) < abs(b)
F.div_mod(a, b)simultaneous div and mod
F.recip(a)Reciprocal fraction.
F.pi
F.exp(x)
F.log(x), F.log(x, base)
F.log10(x), F.log2(x)
F.sqrt(x)
F.sin(x)
F.cos(x)
F.tan(x)
F.asin(x)
F.acos(x)
F.atan(x)
F.sinh(x)
F.cosh(x)
F.tanh(x)
F.asinh(x)
F.acosh(x)
F.atanh(x)standard math constants and functions
F.proper_fraction(x)returns a pair (n, f) such that x = n+f, and:
- n is an integral number with the same sign as x
- f is a fraction with the same type and sign as x, and with absolute value less than 1.
F.truncate(x)returns the integer nearest x between zero and x and the fractional part of x.
F.round(x)returns the nearest integer to x; the even integer if x is equidistant between two integers
F.ceiling(x)
F.ceil(x)returns the least integer not less than x.
F.floor(x)returns the greatest integer not greater than x.
F.is_nan(x)True if the argument is an IEEE “not-a-number” (NaN) value
F.is_infinite(x)True if the argument is an IEEE infinity or negative infinity
F.is_normalized(x)True if the argument is represented in normalized format
F.is_denormalized(x)True if the argument is too small to be represented in normalized format
F.is_negative_zero(x)True if the argument is an IEEE negative zero
F.atan2(y, x)computes the angle (from the positive x-axis) of the vector from the origin to the point (x, y).
F.even(n)
F.odd(n)parity check
F.gcd(a, b)
F.lcm(a, b)Greatest Common Divisor and Least Common Multiple of a and b.
F.id(x)Identity function.
F.const(...)Constant function. const(…)(y) always returns …
F.compose(fs)Function composition. compose{f, g, h}(…) returns f(g(h(…))).
F.flip(f)takes its (first) two arguments in the reverse order of f.
F.curry(f)curry(f)(x)(…) calls f(x, …)
F.uncurry(f)uncurry(f)(x, …) calls f(x)(…)
F.partial(f, ...)F.partial(f, xs)(ys) calls f(xs..ys)
F.call(f, ...)calls
f(...)
F.until_(p, f, x)yields the result of applying f until p holds.
F.error(message, level)
F.error_without_stack_trace(message, level)stops execution and displays an error message (with out without a stack trace).
F.prefix(pre)returns a function that adds the prefix pre to a string
F.suffix(suf)returns a function that adds the suffix suf to a string
F.memo1(f)returns a memoized function (one argument)
Note that the memoized function has a
resetmethod to forget all the previously computed values.
F.memo(f)returns a memoized function (any number of arguments)
Note that the memoized function has a
resetmethod to forget all the previously computed values.
F.show(x, [opt])Convert x to a string
optis an optional table that customizes the output string:
opt.int: integer formatopt.flt: floating point number formatopt.indent: number of spaces use to indent tables (nilfor a single line output)
F.read(s)Convert s to a Lua value
F(t)
F(t)sets the metatable oftand returnst. Most of the functions ofFwill be methods oft.Note that other
Ffunctions that return tables actually returnFtables.
F.clone(t)
t:clone()
F.clone(t)clones the first level oft.
F.deep_clone(t)
t:deep_clone()
F.deep_clone(t)recursively clonest.
F.rep(n, x)Returns a list of length n with x the value of every element.
F.range(a)
F.range(a, b)
F.range(a, b, step)Returns a range [1, a], [a, b] or [a, a+step, … b]
F.concat{xs1, xs2, ... xsn}
F{xs1, xs2, ... xsn}:concat()
xs1 .. xs2concatenates lists
F.flatten(xs, [leaf])
xs:flatten([leaf])Returns a flat list with all elements recursively taken from xs. The optional
leafparameter is a predicate that can stopflattenon some kind of nodes. By default,flattenonly recurses on tables with no metatable or onFtables.
F.str({s1, s2, ... sn}, [separator, [last_separator]])
ss:str([separator, [last_separator]])concatenates strings (separated with an optional separator) and returns a string.
F.from_set(f, ks)
ks:from_set(f)Build a map from a set of keys and a function which for each key computes its value.
F.from_list(kvs)
kvs:from_list()Build a map from a list of key/value pairs.
F.pairs(t, [comp_lt])
t:pairs([comp_lt])
F.ipairs(xs, [comp_lt])
xs:ipairs([comp_lt])behave like the Lua
pairsandipairsiterators.F.pairssorts keys using the functioncomp_ltor the default<=operator for keys (F.op.klt).
F.keys(t, [comp_lt])
t:keys([comp_lt])
F.values(t, [comp_lt])
t:values([comp_lt])
F.items(t, [comp_lt])
t:items([comp_lt])returns the list of keys, values or pairs of keys/values (same order than F.pairs).
F.head(xs)
xs:head()
F.last(xs)
xs:last()returns the first element (head) or the last element (last) of a list.
F.tail(xs)
xs:tail()
F.init(xs)
xs:init()returns the list after the head (tail) or before the last element (init).
F.uncons(xs)
xs:uncons()returns the head and the tail of a list.
F.unpack(xs, [ i, [j] ])
xs:unpack([ i, [j] ])returns the elements of xs between indices i and j
F.take(n, xs)
xs:take(n)Returns the prefix of xs of length n.
F.drop(n, xs)
xs:drop(n)Returns the suffix of xs after the first n elements.
F.split_at(n, xs)
xs:split_at(n)Returns a tuple where first element is xs prefix of length n and second element is the remainder of the list.
F.take_while(p, xs)
xs:take_while(p)Returns the longest prefix (possibly empty) of xs of elements that satisfy p.
F.drop_while(p, xs)
xs:drop_while(p)Returns the suffix remaining after
take_while(p, xs).
F.drop_while_end(p, xs)
xs:drop_while_end(p)Drops the largest suffix of a list in which the given predicate holds for all elements.
F.span(p, xs)
xs:span(p)Returns a tuple where first element is longest prefix (possibly empty) of xs of elements that satisfy p and second element is the remainder of the list.
F.break_(p, xs)
xs:break_(p)Returns a tuple where first element is longest prefix (possibly empty) of xs of elements that do not satisfy p and second element is the remainder of the list.
F.strip_prefix(prefix, xs)
xs:strip_prefix(prefix)Drops the given prefix from a list.
F.strip_suffix(suffix, xs)
xs:strip_suffix(suffix)Drops the given suffix from a list.
F.group(xs, [comp_eq])
xs:group([comp_eq])Returns a list of lists such that the concatenation of the result is equal to the argument. Moreover, each sublist in the result contains only equal elements.
F.inits(xs)
xs:inits()Returns all initial segments of the argument, shortest first.
F.tails(xs)
xs:tails()Returns all final segments of the argument, longest first.
F.is_prefix_of(prefix, xs)
prefix:is_prefix_of(xs)Returns
trueiffxsstarts withprefix
F.is_suffix_of(suffix, xs)
suffix:is_suffix_of(xs)Returns
trueiffxsends withsuffix
F.is_infix_of(infix, xs)
infix:is_infix_of(xs)Returns
trueiffxscontainsinfix
F.has_prefix(xs, prefix)
xs:has_prefix(prefix)Returns
trueiffxsstarts withprefix
F.has_suffix(xs, suffix)
xs:has_suffix(suffix)Returns
trueiffxsends withsuffix
F.has_infix(xs, infix)
xs:has_infix(infix)Returns
trueiffxscaontainsinfix
F.is_subsequence_of(seq, xs)
seq:is_subsequence_of(xs)Returns
trueif all the elements of the first list occur, in order, in the second. The elements do not have to occur consecutively.
F.is_submap_of(t1, t2)
t1:is_submap_of(t2)returns true if all keys in t1 are in t2.
F.map_contains(t1, t2)
t1:map_contains(t2)returns true if all keys in t2 are in t1.
F.is_proper_submap_of(t1, t2)
t1:is_proper_submap_of(t2)returns true if all keys in t1 are in t2 and t1 keys and t2 keys are different.
F.map_strictly_contains(t1, t2)
t1:map_strictly_contains(t2)returns true if all keys in t2 are in t1.
F.elem(x, xs, [comp_eq])
xs:elem(x, [comp_eq])Returns
trueif x occurs in xs (using the optional comp_eq function).
F.not_elem(x, xs, [comp_eq])
xs:not_elem(x, [comp_eq])Returns
trueif x does not occur in xs (using the optional comp_eq function).
F.lookup(x, xys, [comp_eq])
xys:lookup(x, [comp_eq])Looks up a key
xin an association list (using the optional comp_eq function).
F.find(p, xs)
xs:find(p)Returns the leftmost element of xs matching the predicate p.
F.filter(p, xs)
xs:filter(p)Returns the list of those elements that satisfy the predicate p(x).
F.filter_eq(y, xs)
xs:filter_eq(y)
F.filter_ne(y, xs)
xs:filter_ne(y)
F.filter_lt(y, xs)
xs:filter_lt(y)
F.filter_le(y, xs)
xs:filter_le(y)
F.filter_gt(y, xs)
xs:filter_gt(y)
F.filter_ge(y, xs)
xs:filter_ge(y)Returns the list of those elements that satisfy the predicate F.op.eq(x, y), f.op.ne(x, y), f.op.lt(x, y), f.op.le(x, y), f.op.gt(x, y), f.op.ge(x, y).
F.filter_ueq(y, xs)
xs:filter_ueq(y)
F.filter_une(y, xs)
xs:filter_une(y)
F.filter_ult(y, xs)
xs:filter_ult(y)
F.filter_ule(y, xs)
xs:filter_ule(y)
F.filter_ugt(y, xs)
xs:filter_ugt(y)
F.filter_uge(y, xs)
xs:filter_uge(y)Returns the list of those elements that satisfy the predicate F.op.ueq(x, y), f.op.une(x, y), f.op.ult(x, y), f.op.ule(x, y), f.op.ugt(x, y), f.op.uge(x, y).
F.filter_keq(y, xs)
xs:filter_keq(y)
F.filter_kne(y, xs)
xs:filter_kne(y)
F.filter_klt(y, xs)
xs:filter_klt(y)
F.filter_kle(y, xs)
xs:filter_kle(y)
F.filter_kgt(y, xs)
xs:filter_kgt(y)
F.filter_kge(y, xs)
xs:filter_kge(y)Returns the list of those elements that satisfy the predicate F.op.keq(x, y), f.op.kne(x, y), f.op.klt(x, y), f.op.kle(x, y), f.op.kgt(x, y), f.op.kge(x, y).
F.filteri(p, xs)
xs:filteri(p)Returns the list of those elements that satisfy the predicate p(i, x).
F.filter2t(p, xs)
xs:filter2t(p)filters the elements of
xswithpand returns the table{p(xs[1])=xs[1], p(xs[2])=xs[2], ...}wherep(x)is a predicate that returns the key forxin the returned table (nilto rejectx).
F.filteri2t(p, xs)
xs:filteri2t(p)filters the elements of
xswithpand returns the table{p(1, xs[1])=xs[1], p(2, xs[2])=xs[2], ...}wherep(i, x)is a predicate that returns the key forxin the returned table (nilto rejectx).
F.filtert(p, t)
t:filtert(p)Returns the table of those values that satisfy the predicate p(v).
F.filterk(p, t)
t:filterk(p)Returns the table of those values that satisfy the predicate p(k, v).
F.filtert2a(p, t)
t:filtert2a(p)filters
twithpand returns the array{t[k1], t[k2], ...}for allt[ki]that satisfyp(t[ki]).
F.filterk2a(f, t)
t:filterk2a(f)filters
twithpand returns the array{t[k1], t[k2], ...}for allt[ki]that satisfyp(ki, t[ki]).
F.restrict_keys(t, ks)
t:restrict_keys(ks)Restrict a map to only those keys found in a list.
F.without_keys(t, ks)
t:without_keys(ks)Remove all keys in a list from a map.
F.partition(p, xs)
xs:partition(p)Returns the pair of lists of elements which do and do not satisfy the predicate, respectively.
F.table_partition(p, t)
t:table_partition(p)Partition the map according to a predicate. The first map contains all elements that satisfy the predicate, the second all elements that fail the predicate.
F.table_partition_with_key(p, t)
t:table_partition_with_key(p)Partition the map according to a predicate. The first map contains all elements that satisfy the predicate, the second all elements that fail the predicate.
F.elem_index(x, xs)
xs:elem_index(x)Returns the index of the first element in the given list which is equal to the query element.
F.elem_indices(x, xs)
xs:elem_indices(x)Returns the indices of all elements equal to the query element, in ascending order.
F.find_index(p, xs)
xs:find_index(p)Returns the index of the first element in the list satisfying the predicate.
F.find_indices(p, xs)
xs:find_indices(p)Returns the indices of all elements satisfying the predicate, in ascending order.
F.null(xs)
xs:null()
F.null(t)
t:null("t")checks wether a list or a table is empty.
#xs
F.length(xs)
xs:length()Length of a list.
F.size(t)
t:size()Size of a table (number of (key, value) pairs).
F.map(f, xs)
xs:map(f)maps
fto the elements ofxsand returns{f(xs[1]), f(xs[2]), ...}(nilvalues are ignored)
F.mapi(f, xs)
xs:mapi(f)maps
fto the indices and elements ofxsand returns{f(1, xs[1]), f(2, xs[2]), ...}(nilvalues are ignored)
F.map2t(f, xs)
xs:map2t(f)maps
fto the elements ofxsand returns the table{fk(xs[1])=fv(xs[1]), fk(xs[2])=fv(xs[2]), ...}wheref(x)returns two valuesfk(x), fv(x)used as the keys and values of the returned table. (nilvalues are ignored)
F.mapi2t(f, xs)
xs:mapi2t(f)maps
fto the indices and elements ofxsand returns{fk(1, xs[1])=fv(1, xs[1]), fk(2, xs[2])=fv(2, xs[2]), ...}wheref(i, x)returns two valuesfk(i, x), fv(i, x)used as the keys and values of the returned table. (nilvalues are ignored)
F.mapt(f, t)
t:mapt(f)maps
fto the values oftand returns{k1=f(t[k1]), k2=f(t[k2]), ...}(nilvalues are ignored)
F.mapk(f, t)
t:mapk(f)maps
fto the keys and values oftand returns{k1=f(k1, t[k1]), k2=f(k2, t[k2]), ...}(nilvalues are ignored)
F.mapt2a(f, t)
t:mapt2a(f)maps
fto the values oftand returns the array{f(t[k1]), f(t[k2]), ...}(nilvalues are ignored)
F.mapk2a(f, t)
t:mapk2a(f)maps
fto the keys and the values oftand returns the array{f(k1, t[k1]), f(k2, t[k2]), ...}(nilvalues are ignored)
F.reverse(xs)
xs:reverse()reverses the order of a list
F.transpose(xss)
xss:transpose()Transposes the rows and columns of its argument.
F.update(f, k, t)
t:update(f, k)Updates the value
xatk. Iff(x)is nil, the element is deleted. Otherwise the keykis bound to the valuef(x).Warning: in-place modification.
F.updatek(f, k, t)
t:updatek(f, k)Updates the value
xatk. Iff(k, x)is nil, the element is deleted. Otherwise the keykis bound to the valuef(k, x).Warning: in-place modification.
F.foreach(xs, f)
xs:foreach(f)calls
fwith the elements ofxs(f(xi)forxiinxs)
F.foreachi(xs, f)
xs:foreachi(f)calls
fwith the indices and elements ofxs(f(i, xi)forxiinxs)
F.foreacht(t, f)
t:foreacht(f)calls
fwith the values oft(f(v)forvintsuch thatv = t[k])
F.foreachk(t, f)
t:foreachk(f)calls
fwith the keys and values oft(f(k, v)for (k,v) intsuch thatv = t[k])
F.fold(f, x, xs)
xs:fold(f, x)Left-associative fold of a list (
f(...f(f(x, xs[1]), xs[2]), ...)).
F.foldi(f, x, xs)
xs:foldi(f, x)Left-associative fold of a list (
f(...f(f(x, 1, xs[1]), 2, xs[2]), ...)).
F.fold1(f, xs)
xs:fold1(f)Left-associative fold of a list, the initial value is
xs[1].
F.foldt(f, x, t)
t:foldt(f, x)Left-associative fold of a table (in the order given by F.pairs).
F.foldk(f, x, t)
t:foldk(f, x)Left-associative fold of a table (in the order given by F.pairs).
F.land(bs)
bs:land()Returns the conjunction of a container of booleans.
F.lor(bs)
bs:lor()Returns the disjunction of a container of booleans.
F.any(p, xs)
xs:any(p)Determines whether any element of the structure satisfies the predicate.
F.all(p, xs)
xs:all(p)Determines whether all elements of the structure satisfy the predicate.
F.sum(xs)
xs:sum()Returns the sum of the numbers of a structure.
F.product(xs)
xs:product()Returns the product of the numbers of a structure.
F.maximum(xs, [comp_lt])
xs:maximum([comp_lt])The largest element of a non-empty structure, according to the optional comparison function.
F.minimum(xs, [comp_lt])
xs:minimum([comp_lt])The least element of a non-empty structure, according to the optional comparison function.
F.scan(f, x, xs)
xs:scan(f, x)Similar to
foldbut returns a list of successive reduced values from the left.
F.scan1(f, xs)
xs:scan1(f)Like
scanbut the initial value isxs[1].
F.concat_map(f, xs)
xs:concat_map(f)Map a function over all the elements of a container and concatenate the resulting lists.
F.zip(xss, [f])
xss:zip([f])
ziptakes a list of lists and returns a list of corresponding tuples.
F.unzip(xss)
xss:unzip()Transforms a list of n-tuples into n lists
F.zip_with(f, xss)
xss:zip_with(f)
zip_withgeneraliseszipby zipping with the function given as the first argument, instead of a tupling function.
F.nub(xs, [comp_eq])
xs:nub([comp_eq])Removes duplicate elements from a list. In particular, it keeps only the first occurrence of each element, according to the optional comp_eq function.
F.delete(x, xs, [comp_eq])
xs:delete(x, [comp_eq])Removes the first occurrence of x from its list argument, according to the optional comp_eq function.
F.difference(xs, ys, [comp_eq])
xs:difference(ys, [comp_eq])Returns the list difference. In
difference(xs, ys)the first occurrence of each element of ys in turn (if any) has been removed from xs, according to the optional comp_eq function.
F.union(xs, ys, [comp_eq])
xs:union(ys, [comp_eq])Returns the list union of the two lists. Duplicates, and elements of the first list, are removed from the the second list, but if the first list contains duplicates, so will the result, according to the optional comp_eq function.
F.intersection(xs, ys, [comp_eq])
xs:intersection(ys, [comp_eq])Returns the list intersection of two lists. If the first list contains duplicates, so will the result, according to the optional comp_eq function.
F.merge(ts)
ts:merge()
F.table_union(ts)
ts:table_union()Right-biased union of tables.
F.merge_with(f, ts)
ts:merge_with(f)
F.table_union_with(f, ts)
ts:table_union_with(f)Right-biased union of tables with a combining function.
F.merge_with_key(f, ts)
ts:merge_with_key(f)
F.table_union_with_key(f, ts)
ts:table_union_with_key(f)Right-biased union of tables with a combining function.
F.table_difference(t1, t2)
t1:table_difference(t2)Difference of two maps. Return elements of the first map not existing in the second map.
F.table_difference_with(f, t1, t2)
t1:table_difference_with(f, t2)Difference with a combining function. When two equal keys are encountered, the combining function is applied to the values of these keys.
F.table_difference_with_key(f, t1, t2)
t1:table_difference_with_key(f, t2)Union with a combining function.
F.table_intersection(t1, t2)
t1:table_intersection(t2)Intersection of two maps. Return data in the first map for the keys existing in both maps.
F.table_intersection_with(f, t1, t2)
t1:table_intersection_with(f, t2)Difference with a combining function. When two equal keys are encountered, the combining function is applied to the values of these keys.
F.table_intersection_with_key(f, t1, t2)
t1:table_intersection_with_key(f, t2)Union with a combining function.
F.disjoint(t1, t2)
t1:disjoint(t2)Check the intersection of two maps is empty.
F.table_compose(t1, t2)
t1:table_compose(t2)Relate the keys of one map to the values of the other, by using the values of the former as keys for lookups in the latter.
F.Nil
F.Nilis a singleton used to representnil(seeF.patch)
F.patch(t1, t2)
t1:patch(t2)returns a copy of
t1where some fields are replaced by values fromt2. Keys not found int2are not modified. Ift2containsF.Nilthen the corresponding key is removed fromt1. Unmodified subtrees are not cloned but returned as is (common subtrees are shared).
F.sort(xs, [comp_lt])
xs:sort([comp_lt])Sorts xs from lowest to highest, according to the optional comp_lt function.
F.sort_on(f, xs, [comp_lt])
xs:sort_on(f, [comp_lt])Sorts a list by comparing the results of a key function applied to each element, according to the optional comp_lt function.
F.insert(x, xs, [comp_lt])
xs:insert(x, [comp_lt])Inserts the element into the list at the first position where it is less than or equal to the next element, according to the optional comp_lt function.
F.subsequences(xs)
xs:subsequences()Returns the list of all subsequences of the argument.
F.permutations(xs)
xs:permutations()Returns the list of all permutations of the argument.
string.chars(s, i, j)
s:chars(i, j)Returns the list of characters of a string between indices i and j, or the whole string if i and j are not provided.
string.bytes(s, i, j)
s:bytes(i, j)Returns the list of byte codes of a string between indices i and j, or the whole string if i and j are not provided.
string.head(s)
s:head()Extract the first element of a string.
sting.last(s)
s:last()Extract the last element of a string.
string.tail(s)
s:tail()Extract the elements after the head of a string
string.init(s)
s:init()Return all the elements of a string except the last one.
string.uncons(s)
s:uncons()Decompose a string into its head and tail.
string.null(s)
s:null()Test whether the string is empty.
string.length(s)
s:length()Returns the length of a string.
string.intersperse(c, s)
c:intersperse(s)Intersperses a element c between the elements of s.
string.intercalate(s, ss)
s:intercalate(ss)Inserts the string s in between the strings in ss and concatenates the result.
string.subsequences(s)
s:subsequences()Returns the list of all subsequences of the argument.
string.permutations(s)
s:permutations()Returns the list of all permutations of the argument.
string.take(s, n)
s:take(n)Returns the prefix of s of length n.
string.drop(s, n)
s:drop(n)Returns the suffix of s after the first n elements.
string.split_at(s, n)
s:split_at(n)Returns a tuple where first element is s prefix of length n and second element is the remainder of the string.
string.take_while(s, p)
s:take_while(p)Returns the longest prefix (possibly empty) of s of elements that satisfy p.
string.drop_while(s, p)
s:drop_while(p)Returns the suffix remaining after
s:take_while(p).
string.drop_while_end(s, p)
s:drop_while_end(p)Drops the largest suffix of a string in which the given predicate holds for all elements.
string.strip_prefix(s, prefix)
s:strip_prefix(prefix)Drops the given prefix from a string.
string.strip_suffix(s, suffix)
s:strip_suffix(suffix)Drops the given suffix from a string.
string.inits(s)
s:inits()Returns all initial segments of the argument, shortest first.
string.tails(s)
s:tails()Returns all final segments of the argument, longest first.
string.is_prefix_of(prefix, s)
prefix:is_prefix_of(s)Returns
trueiff the first string is a prefix of the second.
string.has_prefix(s, prefix)
s:has_prefix(prefix)Returns
trueiff the second string is a prefix of the first.
string.is_suffix_of(suffix, s)
suffix:is_suffix_of(s)Returns
trueiff the first string is a suffix of the second.
string.has_suffix(s, suffix)
s:has_suffix(suffix)Returns
trueiff the second string is a suffix of the first.
string.is_infix_of(infix, s)
infix:is_infix_of(s)Returns
trueiff the first string is contained, wholly and intact, anywhere within the second.
string.has_infix(s, infix)
s:has_infix(infix)Returns
trueiff the second string is contained, wholly and intact, anywhere within the first.
string.matches(s, pattern, [init])
s:matches(pattern, [init])Returns the list of the captures from
patternby iterating onstring.gmatch. Ifpatterndefines two or more captures, the result is a list of list of captures.
string.split(s, sep, maxsplit, plain)
s:split(sep, maxsplit, plain)Splits a string
saround the separatorsep.maxsplitis the maximal number of separators. Ifplainis true then the separator is a plain string instead of a Lua string pattern.
string.lines(s)
s:lines()Splits the argument into a list of lines stripped of their terminating
\ncharacters.
string.words(s)
s:words()Breaks a string up into a list of words, which were delimited by white space.
F.unlines(xs)
xs:unlines()Appends a
\ncharacter to each input string, then concatenates the results.
string.unwords(xs)
xs:unwords()Joins words with separating spaces.
string.ltrim(s)
s:ltrim()Removes heading spaces
string.rtrim(s)
s:rtrim()Removes trailing spaces
string.trim(s)
s:trim()Removes heading and trailing spaces
string.ljust(s, w, [c])
s:ljust(w)Left-justify
sby appending spaces (or the characterc). The result is at leastwbyte long.sis not truncated.
string.rjust(s, w, [c])
s:rjust(w)Right-justify
sby prepending spaces (or the characterc). The result is at leastwbyte long.sis not truncated.
string.center(s, w)
s:center(w)Center
sby appending and prepending spaces (or the characterc). The result is at leastwbyte long.sis not truncated.
string.cap(s)
s:cap()Capitalizes a string. The first character is upper case, other are lower case.
string.lower_snake_case(s) -- e.g.: hello_world
string.upper_snake_case(s) -- e.g.: HELLO_WORLD
string.lower_camel_case(s) -- e.g.: helloWorld
string.upper_camel_case(s) -- e.g.: HelloWorld
string.dotted_lower_snake_case(s) -- e.g.: hello.world
string.dotted_upper_snake_case(s) -- e.g.: HELLO.WORLD
F.lower_snake_case(s) -- e.g.: hello_world
F.upper_snake_case(s) -- e.g.: HELLO_WORLD
F.lower_camel_case(s) -- e.g.: helloWorld
F.upper_camel_case(s) -- e.g.: HelloWorld
F.dotted_lower_snake_case(s) -- e.g.: hello.world
F.dotted_upper_snake_case(s) -- e.g.: HELLO.WORLD
s:lower_snake_case() -- e.g.: hello_world
s:upper_snake_case() -- e.g.: HELLO_WORLD
s:lower_camel_case() -- e.g.: helloWorld
s:upper_camel_case() -- e.g.: HelloWorld
s:dotted_lower_snake_case() -- e.g.: hello.world
s:dotted_upper_snake_case() -- e.g.: HELLO.WORLDConvert an identifier using some wellknown naming conventions.
scan be a string or a list of strings.
string.read(s)
s:read()Convert s to a Lua value (like
F.read)
F.I(t)returns a string interpolator that replaces
$(...)with the value of...in the environment defined by the tablet. An interpolator can be given another table to build a new interpolator with new values.The mod operator (
%) produces a new interpolator with a custom pattern. E.g.F.I % "@[]"is an interpolator that replaces@[...]with the value of....
F.choose(xs, prng)
F.choose(xs) -- using the global PRNG
xs:choose(prng)
xs:choose() -- using the global PRNGreturns a random item from xs
F.shuffle(xs, prng)
F.shuffle(xs) -- using the global PRNG
xs:shuffle(prng)
xs:shuffle() -- using the global PRNGreturns a shuffled copy of xs