Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/asterjs/aster-squery
Replace nodes with CSS-like selectors in aster.
https://github.com/asterjs/aster-squery
Last synced: 16 days ago
JSON representation
Replace nodes with CSS-like selectors in aster.
- Host: GitHub
- URL: https://github.com/asterjs/aster-squery
- Owner: asterjs
- License: mit
- Created: 2014-06-03T20:19:12.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2016-11-23T21:52:42.000Z (about 8 years ago)
- Last Synced: 2024-12-17T03:29:04.838Z (about 1 month ago)
- Language: JavaScript
- Homepage: https://npmjs.org/package/aster-squery
- Size: 184 KB
- Stars: 3
- Watchers: 2
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - asterjs/aster-squery - Replace nodes with CSS-like selectors in aster. (others)
README
# aster-squery
[![NPM version][npm-image]][npm-url]
[![Build Status][travis-image]][travis-url]> Replace nodes with CSS-like selectors in aster.
Allows to use CSS-style selectors for finding nodes and replacing them with results of corresponding handlers.
Uses [grasp-squery](https://npmjs.org/package/grasp-squery) behind the scenes, so check out [official documentation](http://graspjs.com/docs/squery/) for syntax details.
## Usage
First, install `aster-squery` as a development dependency:
```shell
npm install --save-dev aster-squery
```Then, add it to your build script:
```javascript
var aster = require('aster');
var squery = require('aster-squery');aster.src('src/**/*.js')
.map(squery({
'if[then=return][else=return]': function (node) {
return {
type: 'ReturnStatement',
argument: {
type: 'ConditionalExpression',
test: node.test,
consequent: node.consequent.argument,
alternate: node.alternate.argument
}
};
}
// , ...
}))
.map(aster.dest('dist'))
.subscribe(aster.runner);
```can be also written as:
```javascript
var aster = require('aster');
var equery = require('aster-equery');aster.src('src/**/*.js')
.map(equery({
'if[then=return][else=return]': 'return <%= test %> ? <%= consequent.argument %> : <%= alternate.argument %>'
// , ...
}))
.map(aster.dest('dist'))
.subscribe(aster.runner);
```## API
### squery(mappings)
#### mappings
Type: `{pattern: handler}`Replacement mappings.
##### pattern
Type: `String`[CSS-style node selector](http://graspjs.com/docs/squery/).
##### handler (option 1: callback)
Type: `Function(node, named)`Callback to be called on each found match. It will get two arguments - matched node object and hashmap of named subpatterns.
##### handler (option 2: template)
Type: `String`[estemplate](https://github.com/RReverser/estemplate) string to be used for generating AST.
## License
[MIT License](http://en.wikipedia.org/wiki/MIT_License)
[npm-url]: https://npmjs.org/package/aster-squery
[npm-image]: https://badge.fury.io/js/aster-squery.png[travis-url]: http://travis-ci.org/asterjs/aster-squery
[travis-image]: https://secure.travis-ci.org/asterjs/aster-squery.png?branch=master