This page presents selected functions of the standard that have been added or changed in a recent version of the language, that are mentioned somewhere else in this documentation, or for which we want to give you BaseX-specific information. For the complete picture, you can visit the following resources:
All functions and errors are assigned to the 
http://www.w3.org/2005/xpath-functions namespace, which is statically bound to the 
fn prefix.
Added: New 4.0 function, replacing string:tab, string:nl and string:cr.
| Signature | fn:char(
  $value  as (xs:string | xs:positiveInteger)
) as xs:string | 
|---|
| Summary | Returns a single-character string for the specified $value, which can be: | 
|---|
| Examples | Result:char(65), char(0x41), char(0b01000001)
 'A', 'A', 'A'
 Result:char('xcirc')
 '◯'
 Result:string-join(('auml', 'ouml', 'uuml', 'szlig') ! char(.))
 'äöüß'
 Result:string-to-codepoints(char('\t'))
 9 | 
|---|
| Signature | fn:characters(
  $value  as xs:string?
) as xs:string* | 
|---|
| Summary | Returns the single characters of $valueas a string sequence. Equivalent to:for $cp in string-to-codepoints($value)
return codepoints-to-string($cp)
 | 
|---|
| Examples | Result:characters('AB')
 'A', 'B' | 
|---|
| Signature | fn:contains-token(
  $value      as xs:string*,
  $token      as xs:string,
  $collation  as xs:string?  := fn:default-collation()
) as xs:boolean | 
|---|
| Summary | The supplied strings will be tokenized at whitespace boundaries. The function returns trueif one of the strings equals the supplied token, possibly under the rules of a supplied collation. | 
|---|
| Examples | Result:contains-token(('a', 'b c', 'd'), 'c')
 true() | 
|---|
Updated: Action parameter added.
| Signature | fn:replace(
  $value        as xs:string?,
  $pattern      as xs:string,
  $replacement  as xs:string?                                             := (),
  $flags        as xs:string?                                             := '',
  $action       as (fn(xs:untypedAtomic, xs:untypedAtomic*) as item()?)?  := ()
) as xs:string | 
|---|
| Summary | Searches the regular expression $patternin$valueand performs a$replacement, using optional$flags. Instead of the replacement string, an$actioncan be specified for more sophisticated replacements. | 
|---|
| Examples | Result:replace('a1c', '\d', 'X')
 'aXc'
 Result:replace('1aBc2', '[a-z]', 'X', 'i')
 '1XXX2'
 Result:replace('1aBc2', '[a-z]', action := upper-case#1)
 '1ABC2'
 Result:replace("Chapter 9", "[0-9]+", action := fn($match) { $match + 1 })
 'Chapter 10'
 Result:replace(
  "12°34′57″",
  "([0-9]+)°([0-9]+)′([0-9]+)″",
  action := fn($full-match, $groups) {
    message($full-match),
    ($groups[1] + $groups[2] ÷ 60 + $groups[3] ÷ 3600) || '°'
  }
)
 '12.5825°'. Creates debugging output for the current match. | 
|---|
Updated: Action parameter added.
| Signature | fn:tokenize(
  $value    as xs:string?,
  $pattern  as xs:string?  := (),
  $flags    as xs:string?  := ''
) as xs:string* | 
|---|
| Summary | Splits $valueinto several substrings wherever the regular expression$patternis found, or (if no pattern is supplied) at whitespace boundaries. | 
|---|
| Examples | Result:tokenize('a b c')
 'a', 'b', 'c'
 Result:tokenize('a, b,  c', ',\s*')
 'a', 'b', 'c'
 Result:tokenize('a|b|c', '|', 'q')
 'a', 'b', 'c'. Literal pattern search. | 
|---|
Updated: Action parameter added.
| Signature | fn:string-join(
  $values     as xs:anyAtomicType*,
  $separator  as xs:string?         := ''
) as xs:string | 
|---|
| Summary | Creates a string by concatenating the supplied $values, optionally interspersed by a$separator. | 
|---|
| Examples | Result:string-join(1 to 3)
 '123'
 Result:string-join(('one', 'two', 'three'), ', ')
 'one, two, three' | 
|---|
Added: New function.
| Signature | fn:collation-key(
  $value      as xs:string,
  $collation  as xs:string?  := fn:default-collation()
) as xs:string | 
|---|
| Summary | Returns a binary item for $value, using the supplied$collation, which can be used for unambiguous and context-free comparisons. | 
|---|
| Examples | The result:for value $v in map:build(
  ('a', 'A', 'b'),
  collation-key(?, collation({ 'strength': 'primary' })),
  identity#1
)
return [ $v ]
 [ "b" ]
[ ("a", "A") ]
 
 Result:string-join(('one', 'two', 'three'), ', ')
 'one, two, three' | 
|---|
| Signature | fn:is-NaN(
  $value  as xs:anyAtomicType
) as xs:boolean* | 
|---|
| Summary | Returns trueif the argument is thexs:floatorxs:doublevalueNaN. | 
|---|
| Examples | Result:is-NaN(0e0 div 0)
 true()
 Result:is-NaN('NaN')
 false() | 
|---|
| Signature | fn:random-number-generator(
  $seed  as xs:anyAtomicType?  := ()
) as map(xs:string, item()) | 
|---|
| Summary | Creates a random number generator, using an optional seed. The returned map contains three entries: The returned random generator is deterministic: If the function is called twice with the same arguments and in the same execution scope, it will always return the same result.numberis a random double between 0 and 1nextis a function that returns another random number generatorpermuteis a function that returns a random permutation of its argument
 | 
|---|
| Examples | let $rng := random-number-generator()
let $number := $rng?number                (: random number :)
let $next-rng := $rng?next()              (: new generator :)
let $next-number := $next-rng?number      (: another random number :)
let $permutation := $rng?permute(1 to 5)  (: random permutation of (1 to 5) :)
return ($number, $next-number, $permutation)
 | 
|---|
Added: New 4.0 function.
| Signature | fn:transitive-closure(
  $node  as node()?,
  $step  as fn(node()) as node()*
) as node()* | 
|---|
| Summary | Computes the transitive closure of $nodeby applying$stepto each unchecked node and returns all the nodes except for the input node. | 
|---|
| Examples | The result:let $nodes := <xml>
  <node id='0'/>
  <node id='1' idref='0'/>
  <node id='2' idref='1'/>
  <node id='3' idref='1'/>
</xml>/node
return transitive-closure(
  head($nodes),
  fn($n) { $nodes[@idref = $n/@id] }
)
 <node id='1' idref='0'/>,
<node id='2' idref='1'/>,
<node id='3' idref='1'/>
 | 
|---|
| Signature | fn:distinct-ordered-nodes(
  $nodes  as node()*...
) as node()* | 
|---|
| Summary | Returns nodes in distinct document order: duplicate nodes (nodes with the same node identity) are removed, and the remaining nodes are returned in document order. This function makes explicit what the path expression does before returning the result of a node traversal. It is equivalent to expressions like: $nodes/self::node()
$nodes/.
$nodes union .
$nodes except ()
 | 
|---|
| Examples | Result:let $doc := <doc><b/><a/></doc>
return distinct-ordered-nodes($doc/a, $doc/a, $doc/b)
 <b/>, <a/> | 
|---|
Added: New 4.0 function.
| Signature | fn:in-scope-namespaces(
  $element  as element()
) as map((xs:NCName | enum('')), xs:anyURI) | 
|---|
| Summary | Returns the in-scope namespaces of $elementas a map. | 
|---|
| Examples | The result:in-scope-namespaces(<xsi:a/>)
 {
  "xsi": "http://www.w3.org/2001/XMLSchema-instance",
  "xml": "http://www.w3.org/XML/1998/namespace"
}
 | 
|---|
| Signature | fn:encode-for-uri(
  $value  as xs:string?
) as xs:string | 
|---|
| Summary | Escapes characters in $valuefor use in a URI. | 
|---|
| Examples | Result:encode-for-uri('São Paulo?')
 'S%C3%A3o%20Paulo%3F'
 Result:encode-for-uri('ABC123-~._ !"#<=>?')
 ABC123-~._%20%21%22%23%3C%3D%3E%3F | 
|---|
Added: New 4.0 function.
| Signature | fn:decode-from-uri(
  $value  as xs:string?
) as xs:string | 
|---|
| Summary | Decodes URI-escaped characters in $value. | 
|---|
| Examples | Result:decode-from-uri('S%C3%A3o%20Paulo%3F')
 'São Paulo?'
 Result:decode-from-uri('%00')
 �. Invalid characters are replaced with the Unicode replacement characterFFFD. | 
|---|
Added: New 4.0 function.
| Signature | fn:atomic-equal(
  $value1  as xs:anyAtomicType,
  $value2  as xs:anyAtomicType
) as xs:boolean | 
|---|
| Summary | Determines whether the atomic values $value1and$value2are equal. | 
|---|
| Examples | Result:atomic-equal(1, 1.0)
 true()
 Result:atomic-equal('a', xs:anyURI('a'))
 true()
 Result:atomic-equal(xs:double('NaN'), xs:double('NaN'))
 true()
 Result:atomic-equal(1, '1')
 false() | 
|---|
Updated: Options argument added.
| Signature | fn:deep-equal(
  $input1   as item()*,
  $input2   as item()*,
  $options  as (xs:string | map(*))?  := { 'collation': default-collation() }
) as xs:boolean | 
|---|
| Summary | Determines if $input1and$input2are deep-equal. The$optionscan be either a string, denoting a collation, or a options map:| option | default | description | 
|---|
 | base-uri | false() | Consider base-uriof nodes. |  | collation | default-collation() | Collation to be used. |  | comments | false() | Consider comments. |  | id-property | false() | Consider idproperty of elements and attributes. |  | idrefs-property | false() | Consider idrefsproperty of elements and attributes. |  | in-scope-namespaces | false() | Consider in-scope namespaces. |  | items-equal | void#0 | Custom function to compare items. If an empty sequence is returned, the standard comparison is applied. |  | namespace-prefixes | false() | Consider prefixes in QNames. |  | nilled-property | false() | Consider nilledproperty of elements and attributes. |  | normalization-form | () | Applies Unicode normalization to strings. Allowed values are NFC,NFD,NFKC,NFKDandFULLY-NORMALIZED. |  | ordered | true() | Considers the top-level order of the input sequences. |  | processing-instructions | false() | Consider processing instructions. |  | timezones | false() | Consider timezones in time/date values. |  | unordered-elements | () | A list of QNames of elements considered whose child elements may appear in any order. |  | whitespace | preserve | Handling of whitespace: preserve: Compare strings unchanged.strip: Ignore whitespace-only text nodes.normalize: Normalize whitespace; ignore whitespace-only text nodes.
 | 
 | 
|---|
| Examples | Result:deep-equal((), ())
 true()
 Result:deep-equal(1, 1.0)
 true()
 Result:deep-equal(
  <name sex='f' id='name1'>Sunita</name>,
  <name id="name1" sex="f">Sunita</name>
)
 true(). Attributes have no order, different quotes make no difference.
 Result:deep-equal((1, 2, 3), (3, 2, 1), { 'ordered': false() })
 true()
 Result:deep-equal('X', ' X ', { 'whitespace': 'normalize' })
 true()
 Result:deep-equal(sum#1, sum#2, {
  'items-equal': fn($a, $b) {
    if(($a, $b) instance of fn()) {
      function-name($a) = function-name($b)
    }
  }
})
 true(). When comparing functions, only the function name is considered, but not the arity. | 
|---|
Updated: Generalized to accept types other than strings.
| Signature | fn:compare(
  $value1     as xs:anyAtomicType?,
  $value2     as xs:anyAtomicType?,
  $collation  as xs:string?         := fn:default-collation()
) as xs:integer? | 
|---|
| Summary | Returns -1, 0, or 1, depending on whether $value1is less than, equal to, or greater than$value2, and using the specified$collationfor strings. | 
|---|
| Examples | Result:compare(1, 1.0)
 0
 Result:compare(xs:double('NaN'), 0)
 -1
 Result:compare('a', 'A')
 1
 Result:compare(
  'Strasse',
  'Straße',
  collation({ 'lang': 'de', 'strength': 'primary' })
)
 0
 Result:compare(xs:hexBinary('41'), xs:base64Binary('QQ=='))
 0 | 
|---|
Added: New 4.0 function.
| Signature | fn:starts-with-subsequence(
  $input        as item()*,
  $subsequence  as item()*,
  $compare      as (fn(item(), item()) as xs:boolean)?  := fn:deep-equal#2
) as xs:boolean | 
|---|
| Summary | Determines whether $inputstarts with$subsequence, using the$comparefunction to compare items. | 
|---|
| Examples | Result:starts-with-subsequence(1 to 10, 1 to 3)
 true()
 Result:starts-with-subsequence(1 to 10, ('a', 'bb', 'ccc'), fn($a, $b) { $a = string-length($b) })
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:ends-with-subsequence(
  $input        as item()*,
  $subsequence  as item()*,
  $compare      as (fn(item(), item()) as xs:boolean)?  := fn:deep-equal#2
) as xs:boolean | 
|---|
| Summary | Determines whether $inputends with$subsequence, using the$comparefunction to compare items. | 
|---|
| Examples | Result:ends-with-subsequence(1 to 10, 8 to 10)
 true()
 Result:ends-with-subsequence(
  ('one', 'two', 'three'),
  ('t', 't'),
  starts-with#2
)
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:contains-subsequence(
  $input        as item()*,
  $subsequence  as item()*,
  $compare      as (fn(item(), item()) as xs:boolean)?  := fn:deep-equal#2
) as xs:boolean | 
|---|
| Summary | Determines whether $inputcontains$subsequence, using the$comparefunction to compare items. | 
|---|
| Examples | Result:contains-subsequence(1 to 10, 4 to 6)
 true()
 Result:contains-subsequence(
  ('anna', 'berta', 'clara', 'dora'),
  ('CLARA', 'DORA'),
  fn($a, $b) { $a = lower-case($b) }
)
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:all-equal(
  $values     as xs:anyAtomicType*,
  $collation  as xs:string?         := fn:default-collation()
) as xs:boolean | 
|---|
| Summary | Returns trueif all items in$valuesare equal, using the specified$collationfor string comparisons. | 
|---|
| Examples | Result:all-equal((1, 1.0, 1e0))
 true()
 Result:all-equal((1, '1'))
 false()
 Result:all-equal(())
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:all-different(
  $values     as xs:anyAtomicType*,
  $collation  as xs:string?         := fn:default-collation()
) as xs:boolean | 
|---|
| Summary | Returns trueif all items in$valuesare distinct, using the specified$collationfor string comparisons. | 
|---|
| Examples | Result:all-different(1 to 5)
 true()
 Result:all-different(())
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:every(
  $input      as item()*,
  $predicate  as (fn(item(), xs:integer) as xs:boolean)?  := fn:boolean#1
) as xs:boolean | 
|---|
| Summary | Returns trueif every item in$inputmatches$predicate. If no predicate is specified, the boolean value of the item will be checked. | 
|---|
| Examples | Result:every(1 to 5)
 true()
 Result:every(1 to 5, fn { . > 3 })
 false()
 Result:every(())
 true() | 
|---|
Added: New 4.0 function.
| Signature | fn:some(
  $input      as item()*,
  $predicate  as (fn(item(), xs:integer) as xs:boolean)?  := fn:boolean#1
) as xs:boolean | 
|---|
| Summary | Returns trueif some items in$inputmatch$predicate. If no predicate is specified, the boolean value of the item will be checked. | 
|---|
| Examples | Result:some(-3 to 3)
 true()
 Result:every(1 to 5, fn { . > 3 })
 false()
 Result:some(())
 false() | 
|---|
Added: New 4.0 function.
| Signature | fn:index-where(
  $input      as item()*,
  $predicate  as fn(item(), xs:integer) as xs:boolean
) as xs:integer* | 
|---|
| Summary | Returns the positions of all items of $inputthat match the$predicatefunction. | 
|---|
| Examples | Result:index-where(
  (10, 11, 12, 14, 17, 21, 26),
  fn { . mod 2 = 0 }
)
 1, 3, 4, 7
 Result:index-where(
  (1, 8, 2, 7, 3),
  fn($item, $pos) { $item < 5 and $pos > 2 }
)
 3, 5 | 
|---|
Updated: Support for multiple sort key definitions.
| Signature | fn:sort(
  $input       as item()*,
  $collations  as xs:string*                          := fn:default-collation(),
  $keys        as (fn(item()) as xs:anyAtomicType*)*  := fn:data#1,
  $orders      as enum('ascending', 'descending')*    := 'ascending'
) as item()* | 
|---|
| Summary | Returns a new sequence with sorted $inputitems. Multiple$collations,$keysand$orderscan be supplied, which will be applied on each sort items. The items resulting from the sort keys will be sorted using the semantics of theltoperator. | 
|---|
| Examples | Result:sort(reverse(1 to 3))
 1, 2, 3
 Result:sort(1 to 3, orders := 'descending')
 3, 2, 1
 Result:sort((-2, 1, 3), keys := abs#1)
 1, -2, 3
 Sorts employees by their name and city.sort($employees, (), (fn { @name }, fn { number(@age) }))
 
 Raises an error because strings and integers cannot be compared.sort((1, 'a'))
 | 
|---|
Added: New 4.0 function.
| Signature | fn:sort-with(
  $input        as item()*,
  $comparators  as (fn(item(), item()) as xs:integer)*
) as item()* | 
|---|
| Summary | Returns a new sequence of $inputwith the order induced by the supplied$comparators. | 
|---|
| Examples | Result:sort-with((1, 4, 6, 5, 3), compare#2)
 1, 3, 4, 5, 6
 Result:sort-with(
  (1, -2, 5, 10, -12, 8),
  fn($a, $b) { abs($a) - abs($b) }
)
 1, -2, 5, 8, 10, -12
 The result:let $persons := <persons>
  <person name='Josipa' age='8'/>
  <person name='Jade' age='6'/>
  <person name='Jie' age='8'/>
</persons>
return sort-with($persons/person, (
  fn($a, $b) { compare($a/@age, $b/@age) },
  fn($a, $b) { compare($a/@name, $b/@name) }
))
 <person name="Jade" age="6"/>,
<person name="Jie" age="8"/>,
<person name="Josipa" age="8"/>
 | 
|---|
Added: New 4.0 function, replacing util:last.
| Signature | fn:foot(
  $input  as item()*
) as item()? | 
|---|
| Summary | Returns the last item of $input. Equivalent to$value[last()]. | 
|---|
| Examples | Result:foot(reverse(1 to 100))
 1 | 
|---|
Added: New 4.0 function, replacing util:init.
| Signature | fn:trunk(
  $input  as item()*
) as item()* | 
|---|
| Summary | Returns all item of $inputexcept for the last one. Equivalent to$value[position() < last()]. | 
|---|
| Examples | Result:trunk(reverse(1 to 4))
 4, 3, 2 | 
|---|
Added: New 4.0 function, replacing util:item.
| Signature | fn:items-at(
  $input  as item()*,
  $at     as xs:integer*
) as item()* | 
|---|
| Summary | Returns the items from $inputat the positions specified with$atin the given order. Equivalent to:for $pos in $at
return $input[$pos]
 | 
|---|
| Examples | Result:items-at(reverse(1 to 5), 1)
 5
 Result:items-at(('one', 'two'), (2, 1))
 'two', 'one'
 Result:items-at(('a', 'b'), 0)
 () | 
|---|
Added: New 4.0 function.
| Signature | fn:slice(
  $input  as item()*,
  $start  as xs:integer?  := (),
  $end    as xs:integer?  := (),
  $step   as xs:integer?  := ()
) as item()* | 
|---|
| Summary | Returns a new version of $inputstarting from$startand ending at$end, using the specified$step:If no start is specified, the sequence will start with the first item.If no end is specified, all remaining items are returned.If end is smaller than start, the items are returned in reverse order.If a negative start or end is specified, the counter start from the end of the sequence.
 | 
|---|
| Examples | Result:slice(1 to 5, 3)
 3, 4, 5
 Result:slice(1 to 5, 3, 4)
 3, 4
 Result:slice(1 to 10, -3)
 8, 9, 10
 Result:slice(1 to 5, 4, 2)
 4, 3, 2
 Result:slice(1 to 5, step := 2)
 1, 3, 5 | 
|---|
Updated: More than one position can now be specified.
| Signature | fn:remove(
  $input      as item()*,
  $positions  as xs:integer*
) as item()* | 
|---|
| Summary | Returns a new version of $inputthat excludes the items at the specified$positions. | 
|---|
| Examples | Result:remove(1 to 3, 2)
 1, 3
 Result:remove(1 to 5, (5, 3, 1))
 2, 4 | 
|---|
Added: New 4.0 function, replacing hof:drop-while.
| Signature | fn:subsequence-where(
  $input  as item()*,
  $from   as (fn(item(), xs:integer) as xs:boolean)?  := true#0,
  $to     as (fn(item(), xs:integer) as xs:boolean)?  := false#0
) as item()* | 
|---|
| Summary | Returns a subsequence of $inputstarting with the first item that matches$from, and ending with the first subsequent item that matches$to.The function is equivalent to: let $start := index-where($input, $from)[1]             otherwise (count($input) + 1)
let $end   := index-where($input, $to)[. ge $start][1]  otherwise (count($input) + 1)
return slice($input, $start, $end)
 | 
|---|
| Examples | Result:subsequence-where(1 to 5, fn { . >= 3 })
 3, 4, 5
 Result:subsequence-where(1 to 5, fn { . >= 2 }, fn { . >= 4 })
 2, 3, 4
 Result:let $drop-while := fn($input, $predicate) {
  subsequence-where($input, fn { not($predicate(.)) })
}
return $drop-while(1 to 5, fn { . <= 2 })
 3, 4, 5. The function can be used to emulate the nonexistingdrop-whilefunction. | 
|---|
Added: New 4.0 function, replacing hof:take-while.
| Signature | fn:take-while(
  $input      as item()*,
  $predicate  as fn(item(), xs:integer) as xs:boolean?
) as item()* | 
|---|
| Summary | Returns items of $inputas long as$predicateis satisfied. The predicate is called with the current item and position.The function is equivalent to: declare function take-while($input, $predicate, $pos := 1) {
  if(exists($input) and $predicate(head($input), $pos)) {
    head($input),
    take-while(tail($input), $predicate, $pos + 1)
  }
};
 | 
|---|
| Examples | Returns all integers until a value is larger thantake-while((1, 5, 10, 20, 50, 100), fn { . <= 30 })
 30.
 Computes at mosttake-while(
  (1 to 100) ! random:integer(50),
  fn($item, $pos) { . >= 10 }
)
 100random integers, but stops if an integer is smaller than10. | 
|---|
Added: New 4.0 function, replacing util:intersperse.
| Signature | fn:intersperse(
  $input      as item()*,
  $separator  as item()*
) as item()* | 
|---|
| Summary | Inserts a $separatorbetween each item of$input. Equivalent to:head($input), tail($input) ! ($separator, .)
 | 
|---|
| Examples | Result:(1 to 3)
=> intersperse('|')
=> string-join()
 '1|2|3'
 Inserts semicolon strings between the three input items.intersperse((<_>1</_>, <_>2</_>, <_>3</_>), '; ')
 | 
|---|
Added: New 4.0 function, replacing util:replicate.
| Signature | fn:replicate(
  $input  as item()*,
  $count  as xs:nonNegativeInteger
) as item()* | 
|---|
| Summary | Evaluates $inputand returns the result$counttimes. | 
|---|
| Examples | Result:replicate('A', 3)
 'A', 'A', 'A'
 let $nodes := replicate(<node/>, 2)
return $nodes[1] is $nodes[2]
 trueis returned, as two instances of the same node are returned. | 
|---|
Added: New 4.0 function, replacing prof:void.
| Signature | fn:void(
  $input  as item()*
) as empty-sequence() | 
|---|
| Summary | Absorbs $inputand returns an empty sequence. This function is helpful if some (often nondeterministic or side-effecting) code needs to be evaluated and if the resulting value is not required | 
|---|
| Examples | Performs an HTTP request and ignores the result.void(fetch:binary('http://my.rest.service'))
 | 
|---|
Added: New 4.0 function.
| Signature | fn:highest(
  $input      as item()*,
  $collation  as xs:string?                       := fn:default-collation(),
  $key        as fn(item()) as xs:anyAtomicType*  := fn:data#1
) as item()* | 
|---|
| Summary | Returns those items from $inputfor which$keyproduces the highest value, using the specified$collationfor strings. | 
|---|
| Examples | Result:highest(8 to 12)
 12
 Result:highest(98 to 102, key := string#1)
 99
 Result:highest(1 to 7, (), fn { . idiv 3 })
 6, 7 | 
|---|
Added: New 4.0 function.
| Signature | fn:lowest(
  $input      as item()*,
  $collation  as xs:string?                       := fn:default-collation(),
  $key        as fn(item()) as xs:anyAtomicType*  := fn:data#1
) as item()* | 
|---|
| Summary | Returns those items from $inputfor which$keyproduces the lowest value, using the specified$collationfor strings. | 
|---|
| Examples | Result:lowest(8 to 12)
 8
 Result:lowest(98 to 102, key := string#1)
 100
 Result:lowest(1 to 7, (), fn { . idiv 3 })
 1, 2 | 
|---|
Added: New 4.0 function, replacing util:duplicates.
| Signature | fn:duplicate-values(
  $values     as xs:anyAtomicType*,
  $collation  as xs:string?         := fn:default-collation()
) as xs:anyAtomicType* | 
|---|
| Summary | Returns all values that appear in $valuesmore than once. If no$collationis specified, the function is equivalent to:for $group in $values
group by $value := $group
where count($group) > 1
return $value
 | 
|---|
| Examples | Result:duplicate-values((1, 2, 3, 1.0, 1e0))
 1
 Result:duplicate-values(1 to 100)
 ()
 Raises an error for duplicates in a sequence.let $ids := duplicate-values(//@id)
where exists($ids)
return error((), 'Duplicate IDs found: ' || string-join($ids, ', '))
 | 
|---|
Added: New 4.0 function.
| Signature | fn:partition(
  $input       as item()*,
  $split-when  as fn(item()*, item(), xs:integer) as xs:boolean
) as array(item())* | 
|---|
| Summary | Partitions the $inputinto a sequence of non-empty arrays, starting a new partition when$split-whenis true for a tested item. | 
|---|
| Examples | Result:partition((1 to 5), fn($seq) { count($seq) = 2 })
 [ 1, 2 ], [ 3, 4 ], [ 5 ]
 The result:partition(
  ('Anita', 'Anne', 'Barbara', 'Catherine', 'Christine'), 
  fn($partition, $next) {
    substring(head($partition), 1, 1) ne substring($next, 1, 1)
  }
)
 [ 'Anita', 'Anne' ],
[ 'Barbara' ],
[ 'Catherine', 'Christine' ]
 | 
|---|
Added: New 4.0 function.
| Signature | fn:parse-integer(
  $value  as xs:string,
  $radix  as xs:integer?  := 10
) as xs:integer | 
|---|
| Summary | Converts $valueto an integer, using the supplied$radixin the range 2 to 36. The input may be positive or negative and can contain whitespace and underscore separators. | 
|---|
| Examples | Result:parse-integer('7B', 16)
 123
 Result:parse-integer('11111111', 2)
 255
 Result:parse-integer(' -1_000_000 ')
 -1000000 | 
|---|
Added: New 4.0 function.
| Signature | fn:parse-QName(
  $value  as xs:string
) as xs:QName | 
|---|
| Summary | Converts $valueto a QName. The supplied string can be a local name, have a namespace prefix, or use the braced URI syntax. | 
|---|
| Examples | Result:parse-QName('xml:node') => namespace-uri-from-QName()
 'http://www.w3.org/XML/1998/namespace'
 Result:let $qname := parse-QName('Q{http://gotcha.org/works}fine')
return string-join((
  namespace-uri-from-QName($qname),
  local-name-from-QName($qname)
), ': ')
 'http://gotcha.org/works: fine' | 
|---|
| Signature | fn:parse-ietf-date(
  $value  as xs:string?
) as xs:dateTime? | 
|---|
| Summary | Parses a string in the IETF format (which is widely used on the Internet) and returns a xs:dateTimeitem: | 
|---|
| Examples | Result:parse-ietf-date('28-Feb-1984 07:07:07')
 xs:dateTime('1984-02-28T07:07:07Z')
 Result:parse-ietf-date('Wed, 01 Jun 2001 23:45:54 +02:00')
 xs:dateTime('2001-06-01T23:45:54+02:00') | 
|---|
Added: New 4.0 function.
A separate page is available on 
Invisible XML and how to use it in XQuery.
| Signature | fn:serialize(
  $input    as item()*,
  $options  as (element(output:serialization-parameters) | map(*))?  := ()
) as xs:string | 
|---|
| Summary | Returns a string representation of $input. The$optionsargument contains serialization parameters, which can be supplied…
  as a map…
{ "method": "xml", "cdata-section-elements": "div" }
or (for backward compliance) as an element:
<output:serialization-parameters>
  <output:method value='xml'/>
  <output:cdata-section-elements value='div'/>
</output:serialization-parameters>
 | 
|---|
| Examples | Result:serialize(1 to 3)
 '1 2 3'
 Result:serialize(<xml id='1'></xml>)
 '<xml id="1"/>'
 Result:serialize(<html/>, { 'method': 'html', 'html-version': '5.0' })
 '<!DOCTYPE html><html></html>'
 Result:serialize({ 1: "one" }, { 'method': 'json' })
 '{"1":"one"}' | 
|---|
Updated: Support for formatting integers in a different radix.
| Signature | fn:format-integer(
  $value     as xs:integer?,
  $picture   as xs:string,
  $language  as xs:string?   := ()
) as xs:string | 
|---|
| Summary | Converts $valueto a string, using the supplied$pictureand (optionally)$language. | 
|---|
| Examples | Result:format-integer(123, '0')
 '123'
 Result:format-integer(12, 'w')
 'twelve'
 Result:format-integer(21, 'Ww;o', 'de')
 'Einundzwanzigste'
 Result:format-integer(65535, '16^xxxx')
 'ffff'
 Result:format-integer(15, '2^xxxx')
 '1111' | 
|---|
Updated: Easier definition of languages and decimal formats.
| Signature | fn:format-number(
  $value    as xs:numeric?,
  $picture  as xs:string,
  $options  as (xs:string | map(*))?  := ()
) as xs:string | 
|---|
| Summary | Converts $valueto a string, using the supplied$pictureand$options. The options argument can be the name of a statically available decimal-format or a set of options. | 
|---|
| Examples | Result:format-number(123, '0')
 '123'
 Result:format-number(1.23, '0,0##', 'de')
 '1,23'
 Result:format-number(1234, "0.000,0", { 'format-name': 'de' })
 '1.234,0'
 Result:format-number(1010, '0^0', { 'exponent-separator': '^' })
 '1^3'
 Result:format-number(1984.42, '00.0e0')
 '19.8e2' | 
|---|
Added: New 4.0 function.
| Signature | fn:expanded-QName(
  $value  as xs:QName?
) as xs:string? | 
|---|
| Summary | Returns a string representation of the QName $valuein the formatQ{uri}local. | 
|---|
| Examples | Result:expanded-QName(xs:QName('country'))
 'Q{}country'
 Result:expanded-QName(QName('http://eat.org/lunch', 'cake'))
 'Q{http://eat.org/lunch}cake' | 
|---|
Strings and resources can be parsed to XDM items and serialized back to their original form.
| Signature | fn:parse-json(
  $value    as xs:string?,
  $options  as map(*)?     := {}
) as item()? | 
|---|
| Summary | Parses the supplied $valueas a JSON string and returns an item representation, using the supplied$options. The result may be a map, an array, a string, a double, a boolean, or an empty sequence. | 
|---|
| Examples | { "name": "json" }.parse-json('{ "name": "john" }')
 
 [ 1, 2, 4, 8, 16 ].parse-json('[ 1, 2, 4, 8, 16 ]')
 | 
|---|
| Signature | fn:json-doc(
  $href     as xs:string?,
  $options  as map(*)?     := {}
) as item()? | 
|---|
| Summary | Parses the JSON string retrieved from the $hreflocation and returns an item representation, using the supplied$options. | 
|---|
| Examples | Returns your IP address.json-doc("http://ip.jsontest.com/")?id
 | 
|---|
| Signature | fn:json-to-xml(
  $value    as xs:string?,
  $options  as map(*)?     := {}
) as document-node()? | 
|---|
| Summary | Parses the supplied $valueas a JSON string and returns an XML representation, using the supplied$options. | 
|---|
| Examples | The result:json-to-xml('{ "message": "world" }')
 document {
  <map xmlns="http://www.w3.org/2005/xpath-functions">
    <string key="message">world</string>
  </map>
}
 | 
|---|
| Signature | fn:xml-to-json(
  $node     as node()?,
  $options  as map(*)?  := {}
) as xs:string? | 
|---|
| Summary | Converts a $node, whose format conforms to the results created byfn:json-to-xml, to a JSON string, using the supplied$options. | 
|---|
| Examples | Result:<map xmlns="http://www.w3.org/2005/xpath-functions">
  <string key="message">world</string>
</map>
=> xml-to-json()
 '{"message":"world"}' | 
|---|
| Signature | fn:function-name(
  $function  as fn(*)
) as xs:QName? | 
|---|
| Summary | Returns the name of a $functionitem. | 
|---|
| Examples | Result:function-name(true#0)
 xs:QName('fn:true')
 Result:function-name(fn { . + 1 })
 () | 
|---|
| Signature | fn:function-arity(
  $function  as fn(*)
) as xs:integer | 
|---|
| Summary | Returns the arity (number of parameters) of a $functionitem. | 
|---|
| Examples | Result:function-arity(true#0)
 0
 Result:function-arity(fn { . + 1 })
 1 | 
|---|
Added: New 4.0 function.
| Signature | fn:function-annotations(
  $function  as fn(*)
) as map(xs:QName, xs:anyAtomicType*) | 
|---|
| Summary | Returns the annotations of a $functionitem in a map. | 
|---|
| Examples | The result:declare
  %public
  %rest:GET
  %rest:path('/')
  %perm:allow('all')
function local:index($n) {
  <html>Welcome!</html>
};
function-annotations(local:index#1)
 {
  QName('http://www.w3.org/2012/xquery', 'public'): (),
  QName('http://exquery.org/ns/restxq', 'GET'): (),
  QName('http://exquery.org/ns/restxq', 'path'): '/',
  QName('http://basex.org/modules/perm', 'allow'): 'all'
}
 
 Result:let $add := fn($a, $b) { $a * $b }
let $double := %local:deprecated fn($a) { $a + $a }
for $f in ($add, $double)
where map:keys(function-annotations($f)) = xs:QName('local:deprecated')
return 'Deprecated function found.'
 'Deprecated function found.' | 
|---|
Updated: Positional argument added to the function parameter.
| Signature | fn:filter(
  $input      as item()*,
  $predicate  as fn(item(), xs:integer) as xs:boolean?
) as item()* | 
|---|
| Summary | Applies the boolean $predicateto all elements of the sequence$input, returning those for which it returnstrue(). The function can easily be implemented withfn:for-each:declare function filter($input, $pred) {
  for-each(
    $input,
    fn($item) { if ($pred($item)) { $item } }
  )
};
 An equivalent XQuery function is: declare function filter(
  $input      as item()*,
  $predicate  as fn(item()) as xs:boolean?
) as item()* {
  $input[$predicate(.)]
};
 | 
|---|
| Examples | Result:filter(1 to 10, fn { . mod 2 eq 0 })
 2, 4, 6, 8, 10. Returns all even integers until 10.
 Result:let $first-upper := fn($str) {
  let $first := substring($str, 1, 1)
  return $first eq upper-case($first)
}
return filter(('FooBar', 'foo', 'BAR'), $first-upper)
 'FooBar', 'BAR'. Returns strings that start with an upper-case letter.
 Result:let $is-prime := fn($x) {
  $x gt 1 and (every $y in 2 to ($x - 1) satisfies $x mod $y != 0)
}
return filter(1 to 20, $is-prime)
 2, 3, 5, 7, 11, 13, 17, 19. An inefficient prime number generator. | 
|---|
Updated: Positional argument added to the function parameter.
| Signature | fn:for-each(
  $input   as item()*,
  $action  as fn(item(), xs:integer) as item()*
) as item()* | 
|---|
| Summary | Applies the specified $actionto every item of$inputand returns all results as a single sequence.An equivalent XQuery function is: declare function for-each(
  $input   as item()*,
  $action  as fn(item()) as item()*
) as item()* {
  for $item in $input
  return $action($item)
}
 | 
|---|
| Examples | Result:for-each(1 to 10, math:pow(?, 2))
 1, 4, 9, 16, 25, 36, 49, 64, 81, 100. Computes the square of all numbers from 1 to 10.
 Result:let $fs := (
  upper-case#1,
  substring(?, 4),
  string-length#1
)
return for-each($fs, fn($f) { $f('foobar') })
 'FOOBAR', 'bar', 6. Applies a list of functions to a string.
 Result:("one", "two", "three") => for-each(upper-case(?))
 'ONE', 'TWO', 'THREE'. Processes each item of a sequence with the arrow operator. | 
|---|
Updated: Positional argument added to the function parameter.
| Signature | fn:for-each-pair(
  $input1  as item()*,
  $input2  as item()*,
  $action  as fn(item(), item(), xs:integer) as item()*
) as item()* | 
|---|
| Summary | Applies the specified $actionto the successive pairs of items of$input1and$input2. Evaluation is stopped if one sequence yields no more items.An equivalent function is: declare function for-each-pair(
  $input1  as item()*,
  $input2  as item()*,
  $action  as fn(item(), item()) as item()*
) as item()* {
  for $pos in 1 to min((count($input1), count($input2)))
  return $action($input1[$pos], $input2[$pos])
};
 | 
|---|
| Examples | Result:for-each-pair(
  for-each(1 to 10, fn { . mod 2 }),
  replicate(1, 5),
  fn($a, $b) { $a + $b }
)
 2, 1, 2, 1, 2. Adds one to the numbers at odd positions.
 Result:let $number-words := fn($str) {
  string-join(
    for-each-pair(
      1 to 1000000000,
      tokenize($str, ' +'),
      concat(?, ': ', ?)
    ),
    ', '
  )
}
return $number-words('how are you?')
 '1: how, 2: are, 3: you?'
 Result:let $is-sorted := fn($input) {
  every $b in
    for-each-pair(
      $input,
      tail($input),
      fn($a, $b) { $a <= $b }
    )
  satisfies $b
}
return (
  $is-sorted(1 to 10),
  $is-sorted((1, 2, 42, 4, 5))
)
 true(), false(). Checks if a sequence is sorted. | 
|---|
Added: New 4.0 function, replacing hof:until.
| Signature | fn:while-do(
  $input      as item()*,
  $predicate  as fn(item()*, xs:integer) as xs:boolean,
  $action     as fn(item()*, xs:integer) as item()*
) as item()* | 
|---|
| Summary | This function provides a way to write functionally clean and interruptible iterations, commonly known as while loops: $predicateis called with$input.If the result is true,$actionis called with$input, the result is adopted as new$input, and step 2 is repeated.Otherwise, $inputis returned.
 | 
|---|
| Examples | Result:while-do(2, fn { . <= 100 }, fn { . * . })
 256. The loop is interrupted as soon as the computed product is greater than 100.
 Result:while-do(
  1,
  fn($num, $pos) { $pos <= 10 },
  fn($num, $pos) { $num * $pos }
)
 3628800. Returns the factorial of 10, i.e., the product of all integers from 1 to 10.
 Result:let $input := (0 to 4, 6 to 10)
return while-do(
  0,
  fn($n) { $n = $input },
  fn($n) { $n + 1 }
)
 5. Returns the first positive number missing in a sequence.
 Result:let $input := 3936256
return while-do(
  $input,
  fn($result) { abs($result * $result - $input) >= 0.0000000001 },
  fn($guess) { ($guess + $input div $guess) div 2 }
) => round(5)
 1984. Computes the square root of a number. | 
|---|
Added: New 4.0 function, replacing hof:until.
| Signature | fn:do-until(
  $input      as item()*,
  $action     as fn(item()*, xs:integer) as item()*,
  $predicate  as fn(item()*, xs:integer) as xs:boolean
) as item()* | 
|---|
| Summary | This function provides a way to write functionally clean and interruptible iterations, commonly known as do while/until loops: $actionis called with$inputand the result is adopted as new$input.$predicateis called with$input. If the result isfalse, step 1 is repeated.Otherwise, $inputis returned.
 | 
|---|
| Examples | Result:do-until(
  (),
  fn($value, $pos) { $value, $pos * $pos },
  fn($value) { foot($value) > 50  }
)
 1, 4, 9, 16, 25, 36, 49, 64. The loop is interrupted once the last value of the generated sequence is greater than 50.
 Result:do-until(
  (1, 0),
  fn($value) { $value[1] + $value[2], $value },
  fn($value) { avg($value) > 10 }
)
 55, 34, 21, 13, 8, 5, 3, 2, 1, 1, 0. The computation is continued as long as the average of the first Fibonacci numbers is smaller than 10. | 
|---|
Added: New 4.0 function, replacing hof:id.
| Signature | fn:identity(
  $input  as item()*
) as item()* | 
|---|
| Summary | Returns $inputunchanged. This function isn’t useful on its own, but can be used as an argument to other higher-order functions. | 
|---|
| Examples | Result:let $sort := sort(?, (), identity#1)
let $reverse-sort := sort(?, (), fn($x) { -$x })
return string-join((
  $sort((1, 5, 3, 2, 4)),
  '|',
  $reverse-sort((1, 5, 3, 2, 4))
))
 '12345|54321'
 Result:map:for-each({ 1: 'one', 2: 'two' }, identity#1)
 1, 2.map:for-eachinvokes the supplied function with the key and value of every entry of the supplied map.  Asidentity#1takes only the first argument (the second argument is ignored, see calling higher-order functions) the result is the sequence of keys of the map. | 
|---|
| Signature | fn:apply(
  $function   as fn(*),
  $arguments  as array(*)
) as item()* | 
|---|
| Summary | The supplied $functionis invoked with the specified$arguments. The arity of the function must be the same as the size of the array. | 
|---|
| Examples | Result:apply(concat#5, array { 1 to 5 })
 '12345'
 Result:apply(fn($a) { sum($a) }, [ 1 to 5 ])
 15
 Raises an error as the array has two members.apply(count#1, [ 1, 2 ])
 | 
|---|
Added: New 4.0 function.
| Signature | fn:op(
  $operator  as xs:string
) as fn(item()*, item()*) as item()* | 
|---|
| Summary | Returns a new function that applies the specified $operatorto two arguments. The supported operators are:+*-|||<<==>=>!=<<>>ismoddividivandorltleeqgegtnetounionintersectexceptotherwise
 | 
|---|
| Examples | Result:for-each-pair(1 to 3, 4  to 6, op('+'))
 5, 7, 9
 Result:map:keys-where(
  { 2: 1234, 3: 3, 4: 5678, 5: 5 },
  op('=')
)
 3, 5 | 
|---|
A fold, also called reduce or accumulate in other languages, is a very basic higher-order function on sequences. It starts from a seed value and incrementally builds up a result, consuming one element from the sequence at a time and combining it with the aggregate of a user-defined function.
Folds are one solution to the problem of not having state in functional programs. Solving a problem in imperative programming languages often means repeatedly updating the value of variables, which isn’t allowed in functional languages.
Calculating the product of a sequence of integers for example is easy in Java:
public int product(int[] seq) {
  int result = 1;
  for(int i : seq) {
    result = result * i;
  }
  return result;
}
Nice and efficient implementations using folds will be given below.
The linear folds on sequences come in two flavors. They differ in the direction in which they traverse the sequence:
Updated: Positional argument added to the function parameter. Calculations are skipped once a condition in the supplied function is met.
| Signature | fn:fold-left(
  $input   as item()*,
  $zero    as item()*,
  $action  as fn(item()*, item(), xs:integer) as item()*
) as item()* | 
|---|
| Summary | The left fold traverses the $inputfrom the left. The queryfold-left(1 to 5, 0, $f), for example, would be evaluated as:$f($f($f($f($f(0, 1), 2), 3), 4), 5)
 An equivalent XQuery function is: declare function fold-left(
  $input   as item()*,
  $zero    as item()*,
  $action  as fn(item()*, item()) as item()*
) as item()* {
  if (empty($input)) then $zero
  else fold-left(
    tail($input),
    $action($zero, head($input)),
    $action
  )
};
 | 
|---|
| Examples | Result:fold-left(1 to 5, 1, fn($result, $curr) { $result * $curr })
 120. Computes the product of a sequence of integers.
 Illustrates the evaluation order and returnsfold-left(1 to 5, '$seed',
  concat('$f(', ?, ', ', ?, ')')
)
 $f($f($f($f($f($seed, 1), 2), 3), 4), 5).
 Result:let $from-digits := fold-left(?, 0,
  fn($n, $d) { 10 * $n + $d }
)
return (
  $from-digits(1 to 5),
  $from-digits((4, 2))
)
 12345, 42. Builds a decimal number from digits.
 Result:fold-left(
  1 to 10000000000,
  1,
  fn($n, $curr) { if($n > 100000) then $n else $n * $curr }
)
 362880. Once the condition is met, further calculations are skipped. | 
|---|
Updated: Positional argument added to the function parameter. Calculations are skipped once a condition in the supplied function is met.
| Signature | fn:fold-right(
  $input   as item()*,
  $zero    as item()*,
  $action  as fn(item(), item()*, xs:integer) as item()*
) as item()* | 
|---|
| Summary | The right fold traverses the $inputfrom the right. The queryfold-right(1 to 5, 0, $f), for example, would be evaluated as:$f(1, $f(2, $f(3, $f(4, $f(5, 0)))))
 Note that the order of the arguments of $funare inverted compared to that infn:fold-left: declare function fold-right(
  $input   as item()*,
  $zero    as item()*,
  $action  as fn(item(), item()*) as item()*
) as item()* {
  if (empty($input)) then $zero
  else $action(
    head($input),
    fold-right(tail($input), $zero, $action)
  )
};
 | 
|---|
| Examples | Result:fold-right(1 to 5, 1,
  fn($curr, $result) { $result * $curr }
)
 120. Computes the product of a sequence of integers.
 Illustrates the evaluation order andfold-right(1 to 5, '$seed',
  concat('$f(', ?, ', ', ?, ')')
)
 $f(1, $f(2, $f(3, $f(4, $f(5, $seed))))).
 Result:let $reverse := fold-right(?, (), fn($item, $rev) { $rev, $item })
return $reverse(1 to 5)
 5, 4, 3, 2, 1. Reverses a sequence of items. | 
|---|
Added: New 4.0 function, replacing prof:dump.
| Signature | fn:message(
  $input  as item()*,
  $label  as xs:string?  := ()
) as empty-sequence() | 
|---|
| Summary | Generates a serialized representation of $input, optionally prefixed with$label, and sends it toSTDERR, the Info View of the Graphical User Interface or to the log files in the server context. The function itself returns an empty sequence. In contrast tofn:trace, the evaluated result will be swallowed. | 
|---|
| Examples | Results can also be output and swallowed with'Hello' => trace() => void()
 fn:traceandfn:void. | 
|---|
| Signature | fn:trace(
  $input  as item()*,
  $label  as xs:string?  := ()
) as item()* | 
|---|
| Summary | Generates a serialized representation of $input, optionally prefixed with$label, and sends it toSTDERR, the Info View of the Graphical User Interface or to the log files in the server context. In contrast tofn:message, the evaluated result is returned unchanged. | 
|---|
Added: New 4.0 function, replacing the custom hashing functions.
| Signature | fn:hash(
  $value    as (xs:string|xs:hexBinary|xs:base64Binary)?  := (),
  $options  as map(*)?                                    := {}
) as xs:hexBinary? | 
|---|
| Summary | Computes a hash for the given $value. The following$optionsare available:| option | default | description | 
|---|
 | algorithm | MD5 | The hash algorithm. Supported values are MD5,SHA-1,SHA-256, and the cyclic redundancy checkCRC-32. | 
 | 
|---|
| Examples | Result:string(hash(''))
 'D41D8CD98F00B204E9800998ECF8427E'
 Result:string(hash('', { 'algorithm': 'SHA-1' }))
 'DA39A3EE5E6B4B0D3255BFEF95601890AFD80709'
 Result:hash('', { 'algorithm': 'CRC-32' }) => string()
 '00000000'
 Result:hash('BaseX', { 'algorithm': 'CRC-32' }) => string()
 '4C06FC7F' | 
|---|
Added: New 4.0 function.
| Signature | fn:seconds(
  $value  as xs:decimal?  := ()
) as xs:dayTimeDuration? | 
|---|
| Summary | Returns a duration for $value, which specified the number of seconds. | 
|---|
| Examples | Result:seconds(0)
 xs:dayTimeDuration('PT0S')
 Result:seconds(86_400.1)
 xs:dayTimeDuration('P1DT0.1S')
 Adds 100 seconds to the current time.current-time() + seconds(100)
 | 
|---|
Returns the default language used for formatting numbers and dates. BaseX always returns en.
Version 11.0- Added: fn:all-different,fn:all-equal,fn:atomic-equal,fn:char,fn:collation-key,fn:contains-subsequence,fn:decode-from-uri,fn:distinct-ordered-nodes,fn:do-until,fn:duplicate-values,fn:ends-with-subsequence,fn:every,fn:expanded-QName,fn:foot,fn:function-annotations,fn:hash,fn:highest,fn:identity,fn:in-scope-namespaces,fn:index-where,fn:intersperse,fn:items-at,fn:lowest,fn:message,fn:op,fn:parse-QName,fn:parse-integer,fn:partition,fn:replicate,fn:seconds,fn:slice,fn:some,fn:sort-with,fn:starts-with-subsequence,fn:subsequence-where,fn:take-while,fn:transitive-closure,fn:trunk,fn:void,fn:while-do
- Updated: fn:compare,fn:deep-equal,fn:filter,fn:fold-left,fn:fold-right,fn:for-each,fn:for-each-pair,fn:format-integer,fn:format-number,fn:remove,fn:replace,fn:sort,fn:string-join,fn:tokenize
- Updated: Positional argument added to the function parameters.