new project

master 1.0.0
宇天 2017-02-26 17:46:04 +08:00
commit b31001bd93
4 changed files with 363 additions and 0 deletions

7
History.md Normal file
View File

@ -0,0 +1,7 @@
1.0.0 / 2017-02-26
==================
* new project

118
Readme.md Normal file
View File

@ -0,0 +1,118 @@
![module info](https://nodei.co/npm/iofs.png?downloads=true&downloadRank=true&stars=true)
# iofs
> `iofs` is a bash-like module for reading and writing files on Node.js. It base on Node.js's native `fs` module.
## property
### self
> It return the native `fs` module for more requests.
## API
### cat(file)
- file `<String>`
> Just like bash's cat, it will read a file and return a Buffer.
### ls(path)
- path `<String>`
> List all files and folders of the path given exclude '.' and '..'. I t return an array.
### echo(data, file[, append][, encode])
- data `<String>` | `<Buffer>` | `<Number>`
- file `<String>`
- append `<Boolean>` optional
- encode `<String>` optional
> Write/Append data to a file. creating the file if it does not yet exist.
> If `append` is set true, it will append data to the file.
> Default `encode` is utf8.
```javascript
let fs = require('iofs')
fs.echo('hello ', 'test.txt') // replacing test.txt if it exists.
fs.echo('world', 'test.txt', true) // append the data to test.txt
```
### chmod(file, mode)
- file `<String>` | `<Buffer>`
- mode `<Integer>`
> Changes the mode of the file specified whose pathname is given.
```javascript
fs.chmod('test.txt', 777) // replacing test.txt if it exists.
```
### mv(from, to)
- from `<String>`
- to `<String>`
> Move a fil to the target location. It can also use to renaming a file.
### cp(from, to)
- from `<String>`
- to `<String>`
> Copy a fil to the target location.
### rm(path, recursion)
- path `<String>`
- recursion `<Boolean>`
> Delete a file or a folder. If path is a folder, `recursion` must be set to true.
```javascript
fs.rm('./foo/test.txt')
fs.rm('./foo', true)
```
### stat(path)
- path `<String>`
> Returns an instance of fs.Stats.
### isdir(path)
- path `<String>`
> Return true if the path is a folder, and false when it is a file or not yet exists.
### mkdir(path)
- path `<String>`
> Build a folder in where you want.
### exists(path)
- path `<String>`
> Return true if the path exists, and false not.

219
index.js Normal file
View File

@ -0,0 +1,219 @@
/**
*
* @authors yutent (yutent@doui.cc)
* @date 2015-12-28 14:28:38
*
*/
"use strict";
const fs = require('fs'),
path = require('path');
class Iofs {
constructor(){
this.self = fs
}
/**
* [cat 文件读取]
* @param {String} file [文件路径]
* @param {Function} cb [回调] 可选
*/
cat(file){
try{
return fs.readFileSync(file)
}catch(err){
console.error(err)
return null
}
}
/**
* [ls 读取整个目录(不遍历子目录)]
* @param {string} file [目标路径]
* @return {array} [返回目标目录所有文件名和子目录名, 不包括'.''..']
*/
ls(file){
try{
return fs.readdirSync(file)
}catch(err){
console.error(err)
return null
}
}
/**
* [echo 写文件]
* @param {String|Buffer|Number} data [要写入的数据]
* @param {String} file [要写的文件]
* @param {Boolean} append [是否在后面追加默认否]
* @param {String} encode [编码, 默认utf8]
*/
echo(data, file, append, encode){
if(!file){
return data;
}
let updir = path.parse(file).dir,
opt = {};
if(!this.isdir(updir)){
this.mkdir(updir)
}
if(append && typeof append === 'string'){
encode = append;
append = false;
opt.encoding = encode;
}else{
if(typeof encode === 'string'){
opt.encoding = encode
}
}
try{
if(!!append){
fs.appendFileSync(file, data, opt)
}else{
fs.writeFileSync(file, data, opt)
}
}catch(err){
console.error(err)
}
}
//修改权限
chmod(path, mode){
try{
fs.chmodSync(path, mode)
}catch(err){
console.error(err)
}
}
/**
* [mv 移动文件,兼具重命名功能]
* @param {String} from [原路径/原名]
* @param {String} to [目标路径/新名]
*/
mv(from, to){
let updir = path.parse(to).dir
if(!this.isdir(updir))
this.mkdir(updir)
try{
fs.renameSync(from, to)
}catch(e){
let rs = fs.createReadStream(from),
ws = fs.createWriteStream(to);
rs.pipe(ws)
rs.on('end', err => {
this.rm(from)
})
}
}
cp(from, to){
let updir = path.parse(to).dir
if(!this.isdir(updir)){
this.mkdir(updir)
}
let rs = fs.createReadStream(from),
ws = fs.createWriteStream(to);
rs.pipe(ws)
rs.on('end', err => console.error(err))
}
/**
* [rm 删除文件/目录]
* @param {[type]} from [源文件/目录路径]
* @param {[type]} recursion [是否递归删除若删除目录此值须为true]
*/
rm(from, recursion){
try{
if(!!recursion){
fs.rmdirSync(from)
}else{
fs.unlinkSync(from)
}
}catch(err){
console.error(err)
}
}
/**
* [stat 返回文件/目录的状态信息]
* @param {[type]} path [目标路径]
*/
stat(path){
try{
return fs.statSync(path)
}catch(err){
return null
}
}
/**
* [isdir 判断目标是否为目录]
* @param {String} path [目标路径]
*/
isdir(path){
try{
return this.stat(path).isDirectory()
}catch(err){
return false
}
}
/**
* [mkdir 新建目录]
* @param {String} dir [目标路径]
*/
mkdir(dir){
let updir = path.parse(dir).dir
if(!updir)
return
if(!this.isdir(updir)){
this.mkdir(updir)
}
try{
fs.mkdirSync(dir)
}catch(err){
console.error(err)
}
}
/**
* [exists 判断目标(文件/目录)是否存在]
* @param {String} file [目标路径]
*/
exists(file){
return fs.existsSync(file)
}
}
module.exports = new Iofs

19
package.json Normal file
View File

@ -0,0 +1,19 @@
{
"name": "iofs",
"version": "1.0.0",
"description": "Base on native fs module, for easy using.",
"main": "index.js",
"repository": {
"type": "git",
"url": "https://github.com/yutent/iofs.git"
},
"keywords": [
"dojs",
"fs",
"iofs",
"fs.io",
"file"
],
"author": "yutent",
"license": "MIT"
}