@meteor-it/fs
Advanced tools
Comparing version 1.1.4 to 1.1.5
32
index.js
@@ -6,4 +6,2 @@ "use strict"; | ||
const utils_1 = require("@meteor-it/utils"); | ||
const { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fs_1.default; | ||
const { sep } = path_1.default; | ||
/** | ||
@@ -30,3 +28,3 @@ * Returns true if path is a valid data url | ||
async function readDir(dir) { | ||
return await fs.readdir(dir); | ||
return await fs_1.default.promises.readdir(dir); | ||
} | ||
@@ -41,15 +39,15 @@ exports.readDir = readDir; | ||
return parseDataUrl(file).data; | ||
return await fs.readFile(file); | ||
return await fs_1.default.promises.readFile(file); | ||
} | ||
exports.readFile = readFile; | ||
async function stat(file) { | ||
return await fs.stat(file); | ||
return await fs_1.default.promises.stat(file); | ||
} | ||
exports.stat = stat; | ||
async function open(file, mode, access) { | ||
return await fs.open(file, mode, access); | ||
return await fs_1.default.promises.open(file, mode, access); | ||
} | ||
exports.open = open; | ||
async function read(fd, buffer, offset, length, position) { | ||
return await fs.read(fd, buffer, offset, length, position); | ||
return await fs_1.default.promises.read(fd, buffer, offset, length, position); | ||
} | ||
@@ -61,3 +59,3 @@ exports.read = read; | ||
async function writeFile(filename, text) { | ||
return await fs.writeFile(filename, text); | ||
return await fs_1.default.promises.writeFile(filename, text); | ||
} | ||
@@ -80,3 +78,3 @@ exports.writeFile = writeFile; | ||
cb = (file, dir) => { | ||
returnValue.push(dir + sep + file); | ||
returnValue.push(dir + path_1.default.sep + file); | ||
}; | ||
@@ -86,7 +84,7 @@ } | ||
await utils_1.asyncEach(await readDir(dir), async (file) => { | ||
let path = dir + sep + file; | ||
if (await isFile(path)) { | ||
let pathStr = dir + path_1.default.sep + file; | ||
if (await isFile(pathStr)) { | ||
cb(file, dir); | ||
} | ||
else if (await isDirectory(path)) { | ||
else if (await isDirectory(pathStr)) { | ||
dirList.push(file); | ||
@@ -96,3 +94,3 @@ } | ||
await utils_1.asyncEach(dirList, async (dirLevelDown) => { | ||
await walkDir(dir + sep + dirLevelDown, cb); | ||
await walkDir(dir + path_1.default.sep + dirLevelDown, cb); | ||
}); | ||
@@ -110,3 +108,3 @@ if (shouldReturn) { | ||
try { | ||
let result = await fs.access(file, fsConstants.F_OK); | ||
let result = await fs_1.default.promises.access(file, fs_1.default.constants.F_OK); | ||
return result === undefined; | ||
@@ -139,3 +137,3 @@ } | ||
function getReadStream(path, options = {}) { | ||
return createReadStream(path, options); | ||
return fs_1.default.createReadStream(path, options); | ||
} | ||
@@ -147,6 +145,6 @@ exports.getReadStream = getReadStream; | ||
function getWriteStream(path, options = {}) { | ||
return createWriteStream(path, options); | ||
return fs_1.default.createWriteStream(path, options); | ||
} | ||
exports.getWriteStream = getWriteStream; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["xrest/node_modules/@meteor-it/fs/index.ts"],"names":[],"mappings":";;AAAA,2BAAqC;AACrC,+BAAwB;AACxB,4CAA6C;AAE7C,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,SAAS,EAAE,WAAW,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,GAAG,YAAQ,CAAC;AAC/F,MAAM,EAAE,GAAG,EAAE,GAAG,cAAI,CAAC;AAErB;;;GAGG;AACH,SAAS,SAAS,CAAC,IAAY;IAC9B,OAAO,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAA;AACxD,CAAC;AAMD;;;GAGG;AACH,SAAS,YAAY,CAAC,IAAY;IACjC,OAAO;QACN,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,QAAQ,CAAC;KAC9D,CAAA;AACF,CAAC;AAED;;GAEG;AACI,KAAK,UAAU,OAAO,CAAC,GAAW;IACxC,OAAO,MAAM,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;AAC9B,CAAC;AAFD,0BAEC;AACD;;;GAGG;AACI,KAAK,UAAU,QAAQ,CAAC,IAAY;IAC1C,IAAI,SAAS,CAAC,IAAI,CAAC;QAClB,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC;IAChC,OAAO,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAJD,4BAIC;AAEM,KAAK,UAAU,IAAI,CAAC,IAAY;IACtC,OAAO,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAFD,oBAEC;AAEM,KAAK,UAAU,IAAI,CAAC,IAAY,EAAE,IAAY,EAAE,MAAc;IACpE,OAAO,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;AAC1C,CAAC;AAFD,oBAEC;AAEM,KAAK,UAAU,IAAI,CAAC,EAAc,EAAE,MAAc,EAAE,MAAc,EAAE,MAAc,EAAE,QAAgB;IAC1G,OAAO,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;AAC5D,CAAC;AAFD,oBAEC;AAED;;GAEG;AACI,KAAK,UAAU,SAAS,CAAC,QAAgB,EAAE,IAAqB;IACtE,OAAO,MAAM,EAAE,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;AAC3C,CAAC;AAFD,8BAEC;AAED;;;;GAIG;AACI,KAAK,UAAU,OAAO,CAAC,GAAW,EAAE,EAAwC;IAClF,IAAI,CAAC,MAAM,MAAM,CAAC,GAAG,CAAC,EAAE;QAAE,MAAM,IAAI,KAAK,CAAC,6BAA6B,GAAG,GAAG,CAAC,CAAC;KAAE;IACjF,IAAI,WAAqB,CAAC;IAC1B,IAAI,YAAY,GAAG,KAAK,CAAC;IACzB,IAAI,CAAC,EAAE,EAAE;QACR,WAAW,GAAG,EAAE,CAAC;QACjB,YAAY,GAAG,IAAI,CAAC;QACpB,EAAE,GAAG,CAAC,IAAY,EAAE,GAAW,EAAE,EAAE;YAClC,WAAW,CAAC,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,CAAC;QACpC,CAAC,CAAC;KACF;IACD,IAAI,OAAO,GAAa,EAAE,CAAC;IAC3B,MAAM,iBAAS,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,IAAY,EAAE,EAAE;QAC1D,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC;QAC5B,IAAI,MAAM,MAAM,CAAC,IAAI,CAAC,EAAE;YACvB,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SACd;aAAM,IAAI,MAAM,WAAW,CAAC,IAAI,CAAC,EAAE;YACnC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACnB;IACF,CAAC,CAAC,CAAC;IACH,MAAM,iBAAS,CAAC,OAAO,EAAE,KAAK,EAAE,YAAoB,EAAE,EAAE;QACvD,MAAM,OAAO,CAAC,GAAG,GAAG,GAAG,GAAG,YAAY,EAAE,EAAE,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IACH,IAAI,YAAY,EAAE;QACjB,OAAO,WAAW,CAAC,IAAI,EAAE,CAAC;KAC1B;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AA3BD,0BA2BC;AAED;;GAEG;AACI,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,IAAI;QACH,IAAI,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;QACrD,OAAO,MAAM,KAAK,SAAS,CAAC;KAC5B;IAAC,OAAO,CAAC,EAAE;QACX,qDAAqD;QACrD,OAAO,KAAK,CAAC;KACb;AACF,CAAC;AARD,wBAQC;AAED;;;GAGG;AACI,KAAK,UAAU,MAAM,CAAC,IAAY;IACxC,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;AACpC,CAAC;AAFD,wBAEC;AACD;;GAEG;AACI,KAAK,UAAU,WAAW,CAAC,IAAY;IAC7C,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;AACzC,CAAC;AAFD,kCAEC;AAED;;GAEG;AACH,SAAgB,aAAa,CAAC,IAAY,EAAE,OAAO,GAAG,EAAE;IACvD,OAAO,gBAAgB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACxC,CAAC;AAFD,sCAEC;AAED;;GAEG;AACH,SAAgB,cAAc,CAAC,IAAY,EAAE,OAAO,GAAG,EAAE;IACxD,OAAO,iBAAiB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACzC,CAAC;AAFD,wCAEC","file":"xrest/node_modules/@meteor-it/fs/index.js","sourcesContent":["import fsNative, { Stats } from 'fs';\nimport path from 'path';\nimport { asyncEach } from '@meteor-it/utils';\n\nconst { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fsNative;\nconst { sep } = path;\ntype FileHandle = fsNative.promises.FileHandle;\n/**\n * Returns true if path is a valid data url\n * @param path path\n */\nfunction isDataUrl(path: string): boolean {\n\treturn /^data:.+\\/.+;base64,/.test(path.substr(0, 268))\n}\n\nexport interface IParsedDataUrl {\n\tmime: string,\n\tdata: Buffer\n}\n/**\n * Returns mime and data of dataurl\n * @param path Data url\n */\nfunction parseDataUrl(path: string): IParsedDataUrl {\n\treturn {\n\t\tmime: path.slice(5, path.indexOf(';')),\n\t\tdata: Buffer.from(path.slice(path.indexOf(',') + 1), 'base64')\n\t}\n}\n\n/**\n * Get all files in directory\n */\nexport async function readDir(dir: string) {\n\treturn await fs.readdir(dir);\n}\n/**\n * Read file or parse data url\n * @param file Path to file to read\n */\nexport async function readFile(file: string): Promise<Buffer> {\n\tif (isDataUrl(file))\n\t\treturn parseDataUrl(file).data;\n\treturn await fs.readFile(file);\n}\n\nexport async function stat(file: string): Promise<Stats> {\n\treturn await fs.stat(file);\n}\n\nexport async function open(file: string, mode: string, access: string): Promise<FileHandle> {\n\treturn await fs.open(file, mode, access);\n}\n\nexport async function read(fd: FileHandle, buffer: Buffer, offset: number, length: number, position: number) {\n\treturn await fs.read(fd, buffer, offset, length, position);\n}\n\n/**\n * Write text to file\n */\nexport async function writeFile(filename: string, text: string | Buffer) {\n\treturn await fs.writeFile(filename, text);\n}\n\n/**\n * Walk directory\n * @param dir Directory to walk\n * @param cb If provided, found files will returned realtime. If not - function will return all found files\n */\nexport async function walkDir(dir: string, cb?: (file: string, dir: string) => void): Promise<string[] | null> {\n\tif (!await exists(dir)) { throw new Error('No such file or directory: ' + dir); }\n\tlet returnValue: string[];\n\tlet shouldReturn = false;\n\tif (!cb) {\n\t\treturnValue = [];\n\t\tshouldReturn = true;\n\t\tcb = (file: string, dir: string) => {\n\t\t\treturnValue.push(dir + sep + file);\n\t\t};\n\t}\n\tlet dirList: string[] = [];\n\tawait asyncEach(await readDir(dir), async (file: string) => {\n\t\tlet path = dir + sep + file;\n\t\tif (await isFile(path)) {\n\t\t\tcb(file, dir);\n\t\t} else if (await isDirectory(path)) {\n\t\t\tdirList.push(file);\n\t\t}\n\t});\n\tawait asyncEach(dirList, async (dirLevelDown: string) => {\n\t\tawait walkDir(dir + sep + dirLevelDown, cb);\n\t});\n\tif (shouldReturn) {\n\t\treturn returnValue.sort();\n\t}\n\treturn null;\n}\n\n/**\n * Check if file exists\n */\nexport async function exists(file: string): Promise<boolean> {\n\ttry {\n\t\tlet result = await fs.access(file, fsConstants.F_OK);\n\t\treturn result === undefined;\n\t} catch (e) {\n\t\t// Because only \"err\" field is returned if not exists\n\t\treturn false;\n\t}\n}\n\n/**\n * Is path a file\n * @param path path to test\n */\nexport async function isFile(path: string): Promise<boolean> {\n\treturn (await stat(path)).isFile();\n}\n/**\n * Is path a directory\n */\nexport async function isDirectory(path: string): Promise<boolean> {\n\treturn (await stat(path)).isDirectory();\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getReadStream(path: string, options = {}) {\n\treturn createReadStream(path, options);\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getWriteStream(path: string, options = {}) {\n\treturn createWriteStream(path, options);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["xrest/node_modules/@meteor-it/fs/index.ts"],"names":[],"mappings":"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","file":"xrest/node_modules/@meteor-it/fs/index.js","sourcesContent":["import fsNative, { Stats } from 'fs';\nimport path from 'path';\nimport { asyncEach } from '@meteor-it/utils';\n\ntype FileHandle = fsNative.promises.FileHandle;\n/**\n * Returns true if path is a valid data url\n * @param path path\n */\nfunction isDataUrl(path: string): boolean {\n\treturn /^data:.+\\/.+;base64,/.test(path.substr(0, 268))\n}\n\nexport interface IParsedDataUrl {\n\tmime: string,\n\tdata: Buffer\n}\n/**\n * Returns mime and data of dataurl\n * @param path Data url\n */\nfunction parseDataUrl(path: string): IParsedDataUrl {\n\treturn {\n\t\tmime: path.slice(5, path.indexOf(';')),\n\t\tdata: Buffer.from(path.slice(path.indexOf(',') + 1), 'base64')\n\t}\n}\n\n/**\n * Get all files in directory\n */\nexport async function readDir(dir: string) {\n\treturn await fsNative.promises.readdir(dir);\n}\n/**\n * Read file or parse data url\n * @param file Path to file to read\n */\nexport async function readFile(file: string): Promise<Buffer> {\n\tif (isDataUrl(file))\n\t\treturn parseDataUrl(file).data;\n\treturn await fsNative.promises.readFile(file);\n}\n\nexport async function stat(file: string): Promise<Stats> {\n\treturn await fsNative.promises.stat(file);\n}\n\nexport async function open(file: string, mode: string, access: string): Promise<FileHandle> {\n\treturn await fsNative.promises.open(file, mode, access);\n}\n\nexport async function read(fd: FileHandle, buffer: Buffer, offset: number, length: number, position: number) {\n\treturn await fsNative.promises.read(fd, buffer, offset, length, position);\n}\n\n/**\n * Write text to file\n */\nexport async function writeFile(filename: string, text: string | Buffer) {\n\treturn await fsNative.promises.writeFile(filename, text);\n}\n\n/**\n * Walk directory\n * @param dir Directory to walk\n * @param cb If provided, found files will returned realtime. If not - function will return all found files\n */\nexport async function walkDir(dir: string, cb?: (file: string, dir: string) => void): Promise<string[] | null> {\n\tif (!await exists(dir)) { throw new Error('No such file or directory: ' + dir); }\n\tlet returnValue: string[];\n\tlet shouldReturn = false;\n\tif (!cb) {\n\t\treturnValue = [];\n\t\tshouldReturn = true;\n\t\tcb = (file: string, dir: string) => {\n\t\t\treturnValue.push(dir + path.sep + file);\n\t\t};\n\t}\n\tlet dirList: string[] = [];\n\tawait asyncEach(await readDir(dir), async (file: string) => {\n\t\tlet pathStr = dir + path.sep + file;\n\t\tif (await isFile(pathStr)) {\n\t\t\tcb(file, dir);\n\t\t} else if (await isDirectory(pathStr)) {\n\t\t\tdirList.push(file);\n\t\t}\n\t});\n\tawait asyncEach(dirList, async (dirLevelDown: string) => {\n\t\tawait walkDir(dir + path.sep + dirLevelDown, cb);\n\t});\n\tif (shouldReturn) {\n\t\treturn returnValue.sort();\n\t}\n\treturn null;\n}\n\n/**\n * Check if file exists\n */\nexport async function exists(file: string): Promise<boolean> {\n\ttry {\n\t\tlet result = await fsNative.promises.access(file, fsNative.constants.F_OK);\n\t\treturn result === undefined;\n\t} catch (e) {\n\t\t// Because only \"err\" field is returned if not exists\n\t\treturn false;\n\t}\n}\n\n/**\n * Is path a file\n * @param path path to test\n */\nexport async function isFile(path: string): Promise<boolean> {\n\treturn (await stat(path)).isFile();\n}\n/**\n * Is path a directory\n */\nexport async function isDirectory(path: string): Promise<boolean> {\n\treturn (await stat(path)).isDirectory();\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getReadStream(path: string, options = {}) {\n\treturn fsNative.createReadStream(path, options);\n}\n\n/**\n * Wrapper to fs function\n */\nexport function getWriteStream(path: string, options = {}) {\n\treturn fsNative.createWriteStream(path, options);\n}\n"]} |
30
index.ts
@@ -5,4 +5,2 @@ import fsNative, { Stats } from 'fs'; | ||
const { promises: fs, constants: fsConstants, createReadStream, createWriteStream } = fsNative; | ||
const { sep } = path; | ||
type FileHandle = fsNative.promises.FileHandle; | ||
@@ -36,3 +34,3 @@ /** | ||
export async function readDir(dir: string) { | ||
return await fs.readdir(dir); | ||
return await fsNative.promises.readdir(dir); | ||
} | ||
@@ -46,15 +44,15 @@ /** | ||
return parseDataUrl(file).data; | ||
return await fs.readFile(file); | ||
return await fsNative.promises.readFile(file); | ||
} | ||
export async function stat(file: string): Promise<Stats> { | ||
return await fs.stat(file); | ||
return await fsNative.promises.stat(file); | ||
} | ||
export async function open(file: string, mode: string, access: string): Promise<FileHandle> { | ||
return await fs.open(file, mode, access); | ||
return await fsNative.promises.open(file, mode, access); | ||
} | ||
export async function read(fd: FileHandle, buffer: Buffer, offset: number, length: number, position: number) { | ||
return await fs.read(fd, buffer, offset, length, position); | ||
return await fsNative.promises.read(fd, buffer, offset, length, position); | ||
} | ||
@@ -66,3 +64,3 @@ | ||
export async function writeFile(filename: string, text: string | Buffer) { | ||
return await fs.writeFile(filename, text); | ||
return await fsNative.promises.writeFile(filename, text); | ||
} | ||
@@ -83,3 +81,3 @@ | ||
cb = (file: string, dir: string) => { | ||
returnValue.push(dir + sep + file); | ||
returnValue.push(dir + path.sep + file); | ||
}; | ||
@@ -89,6 +87,6 @@ } | ||
await asyncEach(await readDir(dir), async (file: string) => { | ||
let path = dir + sep + file; | ||
if (await isFile(path)) { | ||
let pathStr = dir + path.sep + file; | ||
if (await isFile(pathStr)) { | ||
cb(file, dir); | ||
} else if (await isDirectory(path)) { | ||
} else if (await isDirectory(pathStr)) { | ||
dirList.push(file); | ||
@@ -98,3 +96,3 @@ } | ||
await asyncEach(dirList, async (dirLevelDown: string) => { | ||
await walkDir(dir + sep + dirLevelDown, cb); | ||
await walkDir(dir + path.sep + dirLevelDown, cb); | ||
}); | ||
@@ -112,3 +110,3 @@ if (shouldReturn) { | ||
try { | ||
let result = await fs.access(file, fsConstants.F_OK); | ||
let result = await fsNative.promises.access(file, fsNative.constants.F_OK); | ||
return result === undefined; | ||
@@ -139,3 +137,3 @@ } catch (e) { | ||
export function getReadStream(path: string, options = {}) { | ||
return createReadStream(path, options); | ||
return fsNative.createReadStream(path, options); | ||
} | ||
@@ -147,3 +145,3 @@ | ||
export function getWriteStream(path: string, options = {}) { | ||
return createWriteStream(path, options); | ||
return fsNative.createWriteStream(path, options); | ||
} |
MIT License | ||
Copyright (c) 2017 Yaroslaw Bolyukin <iam@f6cf.pw> | ||
Copyright (c) 2016-2019 CertainLach <iam@lach.pw> | ||
@@ -9,2 +9,2 @@ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: | ||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
{ | ||
"name": "@meteor-it/fs", | ||
"version": "1.1.4", | ||
"version": "1.1.5", | ||
"description": "Wrappers for native fs module", | ||
@@ -20,3 +20,3 @@ "module": "index.mjs", | ||
}, | ||
"gitHead": "6757ca3859d9bf61db6039a7be58afa5da07b66a" | ||
"gitHead": "4cf5ddb78afeda62243c0d3146d6f345075841cf" | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
33852
517