Skip to main content

map

Note

This is a point-in-time snapshot of the API documentation from January 2026. Going forward, we will not be maintaining a public copy of these references, and recommend users to refer to the built-in signature helpers available in the Hack LSP instead for complete and up-to-date information.

Returns a new vec where each value is the result of calling the given function on the original value

namespace HH\Lib\Vec;

function map<Tv1, Tv2>(
Traversable<Tv1> $traversable,
(function(Tv1): Tv2) $value_func,
): vec<Tv2>;

For async functions, see Vec\map_async().

Time complexity: O(n) Space complexity: O(n)

Parameters

Returns

  • vec<Tv2>

Examples

$numbers = vec[1, 2, 3];
$new_numbers = Vec\map($numbers, $number ==> ($number + 1));
echo "new numbers are: \n";
\print_r($new_numbers);
//Output: new numbers are:
//vec[2, 3, 4]