
Research
/Security News
60 Malicious Ruby Gems Used in Targeted Credential Theft Campaign
A RubyGems malware campaign used 60 malicious packages posing as automation tools to steal credentials from social media and marketing tool users.
unist-util-remove
Advanced tools
The unist-util-remove package is a utility for removing nodes from a Unist syntax tree. It allows you to filter out nodes based on specific criteria, making it useful for manipulating abstract syntax trees (ASTs) in various text processing tasks.
Remove nodes by type
This feature allows you to remove all nodes of a specific type from the tree. In this example, all 'paragraph' nodes are removed from the tree.
const remove = require('unist-util-remove');
const tree = { type: 'root', children: [ { type: 'paragraph', children: [ { type: 'text', value: 'Hello' } ] }, { type: 'paragraph', children: [ { type: 'text', value: 'World' } ] } ] };
remove(tree, 'paragraph');
console.log(tree);
Remove nodes by test function
This feature allows you to remove nodes based on a test function. In this example, only the 'paragraph' node containing the text 'World' is removed.
const remove = require('unist-util-remove');
const tree = { type: 'root', children: [ { type: 'paragraph', children: [ { type: 'text', value: 'Hello' } ] }, { type: 'paragraph', children: [ { type: 'text', value: 'World' } ] } ] };
remove(tree, node => node.type === 'paragraph' && node.children[0].value === 'World');
console.log(tree);
Remove nodes by index
This feature allows you to remove nodes by their index in the parent node's children array. In this example, the second 'paragraph' node (index 1) is removed.
const remove = require('unist-util-remove');
const tree = { type: 'root', children: [ { type: 'paragraph', children: [ { type: 'text', value: 'Hello' } ] }, { type: 'paragraph', children: [ { type: 'text', value: 'World' } ] } ] };
remove(tree, { type: 'paragraph' }, 1);
console.log(tree);
The unist-util-filter package allows you to filter nodes in a Unist tree based on a test function. It is similar to unist-util-remove but instead of removing nodes, it creates a new tree with only the nodes that pass the test.
The unist-util-visit package is used to recursively walk through a Unist tree and perform actions on nodes that match a specific type or test function. While it doesn't remove nodes, it can be used in conjunction with other utilities to manipulate the tree.
The unist-util-map package allows you to transform nodes in a Unist tree by applying a function to each node. It is useful for modifying the tree structure or node values, but it does not directly remove nodes.
unist utility to remove all nodes that pass a test from the tree.
This is a small utility that helps you clean a tree by removing some stuff.
You can use this utility to remove things from a tree.
This utility is very similar to unist-util-filter
, which
creates a new tree.
Modifying a tree like this utility unist-util-remove
does is much faster on
larger documents though.
You can also walk the tree with unist-util-visit
to remove
nodes.
To create trees, use unist-builder
.
This package is ESM only. In Node.js (version 16+), install with npm:
npm install unist-util-remove
In Deno with esm.sh
:
import {remove} from 'https://esm.sh/unist-util-remove@4'
In browsers with esm.sh
:
<script type="module">
import {remove} from 'https://esm.sh/unist-util-remove@4?bundle'
</script>
import {u} from 'unist-builder'
import {remove} from 'unist-util-remove'
const tree = u('root', [
u('leaf', '1'),
u('parent', [
u('leaf', '2'),
u('parent', [u('leaf', '3'), u('other', '4')]),
u('parent', [u('leaf', '5')])
]),
u('leaf', '6')
])
// Remove all nodes of type `leaf`.
remove(tree, 'leaf')
console.dir(tree, {depth: undefined})
Yields:
{
type: 'root',
children: [
{
type: 'parent',
children: [{type: 'parent', children: [{type: 'other', value: '4'}]}]
}
]
}
π Note: the parent of leaf
5
is also removed,options.cascade
can change that.
This package exports the identifier remove
.
There is no default export.
remove(tree[, options], test)
Change the given tree
by removing all nodes that pass test
.
tree
itself is never tested.
The tree is walked in preorder (NLR), visiting the node itself, then its
head, etc.
tree
(Node
)
β tree to changeoptions
(Options
, optional)
β configurationtest
(Test
, optional)
β unist-util-is
compatible testNothing (undefined
).
Options
Configuration (TypeScript type).
cascade
(boolean
, default: true
)
β whether to drop parent nodes if they had children, but all their children
were filtered outThis package is fully typed with TypeScript.
It exports the additional type Options
.
Projects maintained by the unified collective are compatible with maintained versions of Node.js.
When we cut a new major release, we drop support for unmaintained versions of
Node.
This means we try to keep the current release line, unist-util-remove@^4
,
compatible with Node.js 16.
unist-util-filter
β create a new tree with all nodes that pass the given functionunist-util-flatmap
β create a new tree by expanding a node into manyunist-util-map
β create a new tree by mapping nodesunist-util-select
β select nodes with CSS-like selectorsunist-util-visit
β walk the treeunist-builder
β create treesSee 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, organisation, or community you agree to abide by its terms.
MIT Β© Eugene Sharygin
FAQs
unist utility to remove nodes from a tree
The npm package unist-util-remove receives a total of 1,401,847 weekly downloads. As such, unist-util-remove popularity was classified as popular.
We found that unist-util-remove demonstrated a not healthy version release cadence and project activity because the last version was released a year ago.Β It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
/Security News
A RubyGems malware campaign used 60 malicious packages posing as automation tools to steal credentials from social media and marketing tool users.
Security News
The CNA Scorecard ranks CVE issuers by data completeness, revealing major gaps in patch info and software identifiers across thousands of vulnerabilities.
Research
/Security News
Two npm packages masquerading as WhatsApp developer libraries include a kill switch that deletes all files if the phone number isnβt whitelisted.