Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/popomore/rename
Rename files using some transformers.
https://github.com/popomore/rename
Last synced: 2 months ago
JSON representation
Rename files using some transformers.
- Host: GitHub
- URL: https://github.com/popomore/rename
- Owner: popomore
- Created: 2014-04-09T05:49:59.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2016-12-27T11:15:50.000Z (about 8 years ago)
- Last Synced: 2024-11-01T09:33:57.333Z (2 months ago)
- Language: JavaScript
- Homepage:
- Size: 18.6 KB
- Stars: 17
- Watchers: 3
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.md
Awesome Lists containing this project
README
# rename
Rename files using some transformers.
---
[![NPM version](https://img.shields.io/npm/v/rename.svg?style=flat)](https://npmjs.org/package/rename)
[![Build Status](https://img.shields.io/travis/popomore/rename.svg?style=flat)](https://travis-ci.org/popomore/rename)
[![Build Status](https://img.shields.io/coveralls/popomore/rename.svg?style=flat)](https://coveralls.io/r/popomore/rename)
[![NPM downloads](http://img.shields.io/npm/dm/rename.svg?style=flat)](https://npmjs.org/package/rename)**NOTE: Rename < 0.2.0 is not the same lib, you can see [renamer](https://www.npmjs.org/package/renamer). 1.0.0 have a big change.**
## Install
```
$ npm install rename -g
```## Usage
Rename file using another filepath.
```js
rename('a.js', 'b.js');
// => b.js
```Rename file using a _transform object_ that contain some property.
```
{
dirname: "replace dirname",
prefix: "add prefix before basename",
basename: "replace dirname",
suffix: "add prefix after basename",
extname: "replace extname"
}
```Add `-debug` suffix
```js
rename('a.js', {suffix: '-debug'});
// => a-debug.js
```Also can use a _transform function_ that could return a _transform object_.
```js
rename('a.js', function() {
return {suffix: '-debug'};
});
// => a-debug.js
```## API
### rename(filepath, transformer)
#### filepath
Filepath can be a string or object. Parse the filepath to _file object_ if it's a string.
_File object_ should contain property dirname, basename and extname.
```js
rename({
basename: 'a',
extname: '.js'
}, 'b.js');
// => b.js
```#### transformer
Transformer can be a function, string or object.
Simple example about _transform function_ using custom property.
```js
function transformer(fileObj) {
return {
suffix: fileObj.hash || '-debug'
};
}rename({
basename: 'a',
extname: '.js'
}, transformer);
// => a-debug.jsrename({
basename: 'a',
extname: '.js',
hash: '-123'
}, transformer);
// => a-123.js
```The value of _transform object_ can be template that parsed from _file object_.
```
rename({
basename: 'c',
extname: '.js',
hash: '111'
}, {
suffix: '-${hash}',
}).should.eql('c-111.js');
```### rename.parse
Generate a _file object_ from a string or object.
### rename.stringify
Generate a filepath from _file object_.
## LISENCE
Copyright (c) 2017 popomore. Licensed under the MIT license.