Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cowchimp/grunt-jscodeshift
Grunt task to run codemods using jscodeshift
https://github.com/cowchimp/grunt-jscodeshift
Last synced: 5 days ago
JSON representation
Grunt task to run codemods using jscodeshift
- Host: GitHub
- URL: https://github.com/cowchimp/grunt-jscodeshift
- Owner: cowchimp
- Created: 2016-06-13T14:25:54.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-06-13T14:26:36.000Z (over 8 years ago)
- Last Synced: 2024-11-21T20:47:30.921Z (2 months ago)
- Language: JavaScript
- Size: 2.93 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-jscodeshift - grunt-jscodeshift
README
# grunt-jscodeshift
> Grunt task to run codemods using jscodeshift
## Common Usage
[jscodeshift](https://github.com/facebook/jscodeshift) is a tool for running codemods over multiple js files in parallel, which is great for refactoring large codebases. Read more about it [here](https://github.com/sejoker/awesome-jscodeshift).
`grunt-jscodeshift` is a simple [Grunt](http://gruntjs.com) task that wraps the jscodeshift runner and lets you execute transformations as part of your Grunt workflow.## Example (somewhat contrived)
Original source code file
`code.js````js
var myHeading = document.querySelector('h1');
myHeading.textContent = 'Hello world!';
```Transform file
`transform.js````js
module.exports = function transformer(file, api) {
var j = api.jscodeshift;return j(file.source)
.find(j.Identifier)
.replaceWith(function(p) {
return j.identifier(p.node.name.split('').reverse().join('')); })
.toSource();
};
```Transformed source code file
`code.js````js
var gnidaeHym = tnemucod.rotceleSyreuq('h1');
gnidaeHym.tnetnoCtxet = 'Hello world!';
```## Getting Started
This plugin requires Grunt `~0.4.5`If you haven't used [Grunt](http://gruntjs.com/) before, be sure to check out the [Getting Started](http://gruntjs.com/getting-started) guide, as it explains how to create a [Gruntfile](http://gruntjs.com/sample-gruntfile) as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:
```shell
npm install grunt-jscodeshift --save-dev
```Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:
```js
grunt.loadNpmTasks('grunt-jscodeshift');
```## The "jscodeshift" task
```js
grunt.initConfig({
"jscodeshift": {
"some-target": {
"options": {
"transform": "./transform.js"
},
"src": ["src/**/*.js"]
}
},
});
```Since jscodeshift is designed for code-modifications, it overwrites the source files it iterates over.
If this is not your desired behavior, clone the files beforehand with [grunt-contrib-copy](https://github.com/gruntjs/grunt-contrib-copy).### Options
The `options` object is passed to `jscodeshift`. See the [jscodeshift documentation](https://github.com/facebook/jscodeshift#usage-cli) for all options.
#### options.transform
Type: `String`
Default value: `'./transform.js'`Path to the transform file.
## Contributing
Feel free to open issues and send pull-requests.## Running tests
Run `npm test`