unified

Project: syntax-tree/unist-util-map

Package: unist-util-map@2.0.1

  1. Dependencies: 2·Dependents: 62
  2. unist utility to create a new tree by mapping all nodes
  1. util 118
  2. utility 114
  3. unist 110
  4. tree 42
  5. unist-util 24
  6. node 21
  7. walk 7
  8. visit 5
  9. map 2

unist-util-map

Build Coverage Downloads Size Sponsors Backers Chat

unist utility to create a new tree by mapping all nodes with the given function.

Install

npm:

npm install unist-util-map

Use

var u = require('unist-builder')
var map = require('unist-util-map')

var tree = u('tree', [
  u('leaf', 'leaf 1'),
  u('node', [u('leaf', 'leaf 2')]),
  u('void'),
  u('leaf', 'leaf 3')
])

var next = map(tree, function(node) {
  return node.type === 'leaf'
    ? Object.assign({}, node, {value: 'CHANGED'})
    : node
})

console.dir(next, {depth: null})

Yields:

{
  type: 'tree',
  children: [
    {type: 'leaf', value: 'CHANGED'},
    {type: 'node', children: [{type: 'leaf', value: 'CHANGED'}]},
    {type: 'void'},
    {type: 'leaf', value: 'CHANGED'}
  ]
}

…note that tree is not mutated.

API

map(tree, mapFn)

Create a new tree by mapping all nodes with the given function.

Parameters
Returns

Node — New mapped tree.

function mapFn(node[, index, parent])

Function called with a node to produce a new node.

Parameters
Returns

Node — Node to be used in the new tree. Its children are not used: if the original node has children, those are mapped.

Contribute

See contributing.md in syntax-tree/.github for ways to get started. See support.md for ways to get help.

This project has a code of conduct. By interacting with this repository, organization, or community you agree to abide by its terms.

License

MIT © azu