63 lines
		
	
	
		
			85 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			85 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| title: "map"
 | |
| excerpt: "Apply a function to every element of a list."
 | |
| layout: manual
 | |
| ---
 | |
| 
 | |
| Apply a function to every element of a list.
 | |
| 
 | |
| Given a list like `[a, b, c]`, and a function like `f`, returns `[f(a), f(b), f(c)]`
 | |
| 
 | |
| ```kcl
 | |
| map(
 | |
|   array: [any],
 | |
|   f: FunctionSource,
 | |
| ): [any]
 | |
| ```
 | |
| 
 | |
| 
 | |
| ### Arguments
 | |
| 
 | |
| | Name | Type | Description | Required |
 | |
| |----------|------|-------------|----------|
 | |
| | `array` | [`[any]`](/docs/kcl/types/std-types-any) | Input array. The output array is this input array, but every element has had the function `f` run on it. | Yes |
 | |
| | `f` | `FunctionSource` | A function. The output array is just the input array, but `f` has been run on every item. | Yes |
 | |
| 
 | |
| ### Returns
 | |
| 
 | |
| [`[any]`](/docs/kcl/types/std-types-any)
 | |
| 
 | |
| 
 | |
| ### Examples
 | |
| 
 | |
| ```kcl
 | |
| r = 10 // radius
 | |
| fn drawCircle(@id) {
 | |
|   return startSketchOn(XY)
 | |
|     |> circle(center = [id * 2 * r, 0], radius = r)
 | |
| }
 | |
| 
 | |
| // Call `drawCircle`, passing in each element of the array.
 | |
| // The outputs from each `drawCircle` form a new array,
 | |
| // which is the return value from `map`.
 | |
| circles = map([1..3], f = drawCircle)
 | |
| ```
 | |
| 
 | |
| 
 | |
| 
 | |
| ```kcl
 | |
| r = 10 // radius
 | |
| // Call `map`, using an anonymous function instead of a named one.
 | |
| circles = map(
 | |
|   [1..3],
 | |
|   f = fn(id) {
 | |
|     return startSketchOn(XY)
 | |
|       |> circle(center = [id * 2 * r, 0], radius = r)
 | |
|   },
 | |
| )
 | |
| ```
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 |