🐊Putout plugin helps to lint filesystem.
npm i @putout/plugin-filesystem -D
- ✅ bundle;
- ✅ convert-filesystem-to-simple-filesystem;
- ✅ convert-js-to-json;
- ✅ convert-json-to-js;
- ✅ convert-simple-filesystem-to-filesystem;
- ✅ move-referenced-file;
- ✅ read-all-files;
- ✅ rename-file;
- ✅ remove-files;
- ✅ rename-referenced-file;
- ✅ rename-spec-to-test;
- ✅ rename-test-to-spec;
- ✅ replace-cwd;
- ✅ write-all-files;
{
"rules": {
"filesystem/bundle": "off",
"filesystem/read-all-files": ["off", {
"mask": "*"
}],
"filesystem/write-all-files": "off",
"filesystem/rename-file": "off",
"filesystem/remove-files": "off",
"filesystem/rename-spec-to-test": "off",
"filesystem/rename-test-to-spec": "off",
"filesystem/rename-referenced-file": "off",
"filesystem/move-referenced-file": "off",
"filesystem/convert-simple-filesystem-to-filesystem": "off",
"filesystem/replace-cwd": ["off", {
"from": "/home/coderaiser/putout",
"to": "/"
}],
"filesystem/convert-json-to-js": ["off", {
"filename": "package.json"
}],
"filesystem/convert-js-to-json": ["off", {
"filename": "package.js"
}]
}
}Checkout in 🐊Putout Editor.
Update .putout.json to enable rule:
{
"rules": {
"filesystem/rename-file": ["on", {
"from": "README.md",
"to": "readme.md"
}]
}
}It will make next modifications to filesystem:
-README.md
+readme.mdFor more sophisticated example, use mask:
{
"rules": {
"filesystem/rename-file": ["on", {
"mask": "*.test.*",
"from": "test",
"to": "spec"
}]
}
}It will rename 'test' to 'spec' in *.test.* files:
-index.test.js
+index.spec.jsRemove next files:
*.swp;*.swo;*.lock;.DS_Store;.travis.yml;
Apply overrides:
{
"rules": {
"filesystem/remove-files": ["on", {
"names": ["coverage"],
"dismiss": [
".travis.yml"
]
}]
}
}It will make next modifications to filesystem:
/
|-- test/
| `-- hello.spec.js
-|-- coverage/
`-- lib/
`-- hello.jsCheckout in 🐊Putout Editor.
-index.spec.js
+index.test.jsCheckout in 🐊Putout Editor.
-index.test.js
+index.spec.jsUpdate .putout.json to enable rule:
{
"rules": {
"filesystem/rename-referenced-file": ["on", {
"from": "hello.js",
"to": "world.js"
}]
}
}Checkout in 🐊Putout Editor.
Before:
// hello.spec.js
import hello from './hello.js';// hello.js
export const hello = 'world';After:
-hello.js
+world.js// hello.spec.js
import hello from './world.js';// world.js
export const hello = 'world';Update .putout.json to enable rule:
{
"rules": {
"filesystem/move-referenced-file": ["on", {
"name": "hello.js",
"directory": "lib"
}]
}
}Checkout in 🐊Putout Editor.
Before:
/
|-- test/
| `-- hello.spec.js
|-- src/
| `-- hello.js
`-- lib/
// test/hello.spec.js
import hello from '../src/hello.js';// src/hello.js
export const hello = 'world';After:
/
|-- test/
| `-- hello.spec.js
|-- src/
`-- lib/
`-- hello.js
-src/hello.js
+lib/hello.js// test/hello.spec.js
import hello from '../lib/hello.js';// lib/hello.js
export const hello = 'world';Checkout in 🐊Putout Editor.
__putout_processor_filesystem([
'/',
'/hello.txt',
['/world.txt', 'hello world'],
'/abc/',
]);__putout_processor_filesystem({
type: 'directory',
filename: '/',
files: [{
type: 'file',
filename: '/hello.txt',
}, {
type: 'file',
filename: '/world.txt',
content: 'hello world',
}, {
type: 'directory',
filename: '/abc',
files: [],
}],
});Checkout in 🐊Putout Editor.
__putout_processor_filesystem({
type: 'directory',
filename: '/',
files: [{
type: 'file',
filename: '/hello.txt',
}, {
type: 'file',
filename: '/world.txt',
content: 'hello world',
}, {
type: 'directory',
filename: '/abc',
files: [],
}],
});__putout_processor_filesystem([
'/',
'/hello.txt',
['/world.txt', 'hello world'],
'/abc/',
]);Bundle and minify css files.
{
"rules": {
"filesystem/bundle": ["on", {
"groups": [
["__:columns/__", [
"name-size-date.css",
"name-size.css"
]],
[
"main.css",
["hello.css", "world.css"]
],
"1:1"
]
}]
}
}Checkout in 🐊Putout Editor.
Before:
/
|-- css/
| `-- hello.css
| `-- world.css
After:
/
|-- css/
| `-- hello.css
| `-- world.css
|-- dist/
| `-- main.css
Just minify styles:
{
"rules": {
"filesystem/bundle": ["on", {
"groups": ["1:1"]
}]
}
}Before:
/
|-- css/
| `-- hello.css
| `-- world.css
After:
/
|-- css/
| `-- hello.css
| `-- world.css
|-- dist/
| `-- hello.css
| `-- world.css
Create subdirectory:
{
"rules": {
"filesystem/bundle": ["on", {
"groups": [
["__:columns/__", [
"name-size-date.css",
"name-size.css"
]]
]
}]
}
}Before:
/
|-- css/
| `-- hello.css
| `-- world.css
After:
/
|-- css/
| `-- hello.css
| `-- world.css
|-- dist/
| `-- columns
| `-- hello.css
| `-- world.css
Filter css files by mask:
{
"rules": {
"filesystem/bundle": ["on", {
"mask": "*.good.css",
"groups": ["1:1"]
}]
}
}Before:
/
|-- css/
| `-- hello.css
| `-- world.good.css
After:
/
|-- css/
| `-- hello.css
| `-- world.css
|-- dist/
| `-- world.good.css
You can even override transform with your own config:
putout(filesystem, {
rules: {
'filesystem/bundle': ['on', {
transform: (source: string | string[], config) => string,
}],
},
});Concut files:
{
"rules": {
"filesystem/bundle": ["on", {
"groups": ["hello.css"]
}]
}
}Before:
/
|-- css/
| `-- hello.css
| `-- world.css
After:
/
|-- css/
| `-- hello.css
| `-- world.css
|-- dist/
| `-- hello.css
Checkout in 🐊Putout Editor.
When from=/home/coderaiser/putout and to=/:
{
"rules": {
"filesystem/replace-cwd": ["on", {
"from": "/home/coderaiser/putout",
"to": "/"
}]
}
}__putout_processor_filesystem([
'/home/coderaiser/putout/',
'/home/coderaiser/putout/README.md',
]);__putout_processor_filesystem(['/', '/README.md']);Checkout in 🐊Putout Editor.
["/", "/hello.xyz"][
"/",
["/hello.xyz", "hello world"]
]Write all files that was read before to Filesystem.
Checkout in 🐊Putout Editor.
[
"/",
["/hello.xyz", "hello world"]
]Checkout in 🐊Putout Editor.
Filesystem:
-["/", "/package.json"]
+["/", "/package.js"]{
"plugins": []
}export default {
plugins: [],
};Checkout in 🐊Putout Editor:
Filesystem:
-["/", "/package.js"]
+["/", "/package.json"]{
"plugins": []
}export default {
plugins: [],
};MIT