2019-04-13 21:30:56 +02:00
|
|
|
# fs
|
|
|
|
|
|
|
|
fs module is made to provide helpers to manipulate the filesystem.
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
2020-08-25 06:33:38 -04:00
|
|
|
Most the following modules are exposed in `mod.ts` This feature is currently
|
|
|
|
<b>unstable</b>. To enable it use `deno run --unstable`
|
2019-04-13 21:30:56 +02:00
|
|
|
|
|
|
|
### emptyDir
|
|
|
|
|
2019-10-09 17:22:22 -04:00
|
|
|
Ensures that a directory is empty. Deletes directory contents if the directory
|
|
|
|
is not empty. If the directory does not exist, it is created. The directory
|
|
|
|
itself is not deleted.
|
2019-04-13 21:30:56 +02:00
|
|
|
|
|
|
|
```ts
|
|
|
|
import { emptyDir, emptyDirSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
emptyDir("./foo"); // returns a promise
|
|
|
|
emptyDirSync("./foo"); // void
|
|
|
|
```
|
|
|
|
|
|
|
|
### ensureDir
|
|
|
|
|
2019-10-09 17:22:22 -04:00
|
|
|
Ensures that the directory exists. If the directory structure does not exist, it
|
|
|
|
is created. Like mkdir -p.
|
2019-04-13 21:30:56 +02:00
|
|
|
|
|
|
|
```ts
|
|
|
|
import { ensureDir, ensureDirSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
ensureDir("./bar"); // returns a promise
|
|
|
|
ensureDirSync("./ensureDirSync"); // void
|
|
|
|
```
|
|
|
|
|
2019-04-14 16:53:19 +02:00
|
|
|
### ensureFile
|
2019-04-13 21:30:56 +02:00
|
|
|
|
2019-10-09 17:22:22 -04:00
|
|
|
Ensures that the file exists. If the file that is requested to be created is in
|
|
|
|
directories that do not exist, these directories are created. If the file
|
|
|
|
already exists, it is **NOT MODIFIED**.
|
2019-04-13 21:30:56 +02:00
|
|
|
|
|
|
|
```ts
|
|
|
|
import { ensureFile, ensureFileSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
ensureFile("./folder/targetFile.dat"); // returns promise
|
|
|
|
ensureFileSync("./folder/targetFile.dat"); // void
|
|
|
|
```
|
|
|
|
|
2019-04-22 03:23:44 +08:00
|
|
|
### ensureSymlink
|
|
|
|
|
2019-10-09 17:22:22 -04:00
|
|
|
Ensures that the link exists. If the directory structure does not exist, it is
|
|
|
|
created.
|
2019-04-22 03:23:44 +08:00
|
|
|
|
|
|
|
```ts
|
|
|
|
import {
|
|
|
|
ensureSymlink,
|
2020-03-29 04:03:49 +11:00
|
|
|
ensureSymlinkSync,
|
2019-04-22 03:23:44 +08:00
|
|
|
} from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
2020-04-27 19:03:13 +08:00
|
|
|
ensureSymlink("./folder/targetFile.dat", "./folder/targetFile.link.dat"); // returns promise
|
|
|
|
ensureSymlinkSync("./folder/targetFile.dat", "./folder/targetFile.link.dat"); // void
|
2019-04-22 03:23:44 +08:00
|
|
|
```
|
|
|
|
|
2020-05-17 19:24:39 +02:00
|
|
|
### EOL
|
2019-04-13 21:30:56 +02:00
|
|
|
|
|
|
|
Detects and format the passed string for the targeted End Of Line character.
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { format, detect, EOL } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
const CRLFinput = "deno\r\nis not\r\nnode";
|
|
|
|
const Mixedinput = "deno\nis not\r\nnode";
|
|
|
|
const LFinput = "deno\nis not\nnode";
|
|
|
|
const NoNLinput = "deno is not node";
|
|
|
|
|
|
|
|
detect(LFinput); // output EOL.LF
|
|
|
|
detect(CRLFinput); // output EOL.CRLF
|
|
|
|
detect(Mixedinput); // output EOL.CRLF
|
|
|
|
detect(NoNLinput); // output null
|
|
|
|
|
|
|
|
format(CRLFinput, EOL.LF); // output "deno\nis not\nnode"
|
|
|
|
...
|
|
|
|
```
|
|
|
|
|
|
|
|
### exists
|
|
|
|
|
|
|
|
Test whether or not the given path exists by checking with the file system
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { exists, existsSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
exists("./foo"); // returns a Promise<boolean>
|
|
|
|
existsSync("./foo"); // returns boolean
|
|
|
|
```
|
|
|
|
|
|
|
|
### move
|
|
|
|
|
|
|
|
Moves a file or directory. Overwrites it if option provided
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { move, moveSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
move("./foo", "./bar"); // returns a promise
|
|
|
|
moveSync("./foo", "./bar"); // void
|
|
|
|
moveSync("./foo", "./existingFolder", { overwrite: true });
|
|
|
|
// Will overwrite existingFolder
|
|
|
|
```
|
|
|
|
|
2019-05-17 00:19:17 +08:00
|
|
|
### copy
|
|
|
|
|
|
|
|
copy a file or directory. Overwrites it if option provided
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { copy, copySync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
copy("./foo", "./bar"); // returns a promise
|
|
|
|
copySync("./foo", "./bar"); // void
|
|
|
|
copySync("./foo", "./existingFolder", { overwrite: true });
|
|
|
|
// Will overwrite existingFolder
|
|
|
|
```
|
|
|
|
|
2019-04-13 21:30:56 +02:00
|
|
|
### readJson
|
|
|
|
|
|
|
|
Reads a JSON file and then parses it into an object
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { readJson, readJsonSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
const f = await readJson("./foo.json");
|
|
|
|
const foo = readJsonSync("./foo.json");
|
|
|
|
```
|
|
|
|
|
2020-05-01 02:32:44 +08:00
|
|
|
### writeJson
|
|
|
|
|
|
|
|
Writes an object to a JSON file.
|
|
|
|
|
2020-07-26 21:51:33 +02:00
|
|
|
#### WriteJsonOptions
|
2020-05-01 02:32:44 +08:00
|
|
|
|
|
|
|
- replacer : An array of strings and numbers that acts as a approved list for
|
|
|
|
selecting the object properties that will be stringified.
|
|
|
|
- space : Adds indentation, white space, and line break characters to the
|
|
|
|
return-value JSON text to make it easier to read.
|
|
|
|
|
2020-07-26 21:51:33 +02:00
|
|
|
You can also specify options from `Deno.WriteFileOptions` to configure how the
|
|
|
|
file is written.
|
|
|
|
|
2020-05-01 02:32:44 +08:00
|
|
|
```ts
|
|
|
|
import { writeJson, writeJsonSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
writeJson("./target.dat", { foo: "bar" }, { spaces: 2 }); // returns a promise
|
|
|
|
writeJsonSync("./target.dat", { foo: "bar" }, { replacer: ["foo"] }); // void
|
2020-07-26 21:51:33 +02:00
|
|
|
|
|
|
|
// appends to the file instead of rewriting
|
|
|
|
writeJsonSync("./target.dat", { foo: "bar" }, { append: true });
|
2020-05-01 02:32:44 +08:00
|
|
|
```
|
|
|
|
|
2019-04-13 21:30:56 +02:00
|
|
|
### walk
|
|
|
|
|
|
|
|
Iterate all files in a directory recursively.
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { walk, walkSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
2020-06-08 23:09:38 +02:00
|
|
|
for (const entry of walkSync(".")) {
|
|
|
|
console.log(entry.path);
|
2019-04-13 21:30:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Async
|
2019-06-14 16:57:30 +02:00
|
|
|
async function printFilesNames() {
|
2020-05-20 18:24:02 +02:00
|
|
|
for await (const entry of walk(".")) {
|
2020-04-29 22:00:31 +02:00
|
|
|
console.log(entry.path);
|
2019-05-01 22:45:30 +01:00
|
|
|
}
|
2019-04-13 21:30:56 +02:00
|
|
|
}
|
2019-05-01 22:45:30 +01:00
|
|
|
|
2019-06-14 16:57:30 +02:00
|
|
|
printFilesNames().then(() => console.log("Done!"));
|
2019-04-13 21:30:56 +02:00
|
|
|
```
|
|
|
|
|
2020-06-21 03:34:28 +09:00
|
|
|
### expandGlob
|
|
|
|
|
|
|
|
Expand the glob string from the specified `root` directory and yield each result
|
|
|
|
as a `WalkEntry` object.
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { expandGlob } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
for await (const file of expandGlob("**/*.ts")) {
|
|
|
|
console.log(file);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### expandGlobSync
|
|
|
|
|
|
|
|
Synchronous version of `expandGlob()`.
|
|
|
|
|
|
|
|
```ts
|
|
|
|
import { expandGlobSync } from "https://deno.land/std/fs/mod.ts";
|
|
|
|
|
|
|
|
for (const file of expandGlobSync("**/*.ts")) {
|
|
|
|
console.log(file);
|
|
|
|
}
|
|
|
|
```
|