diff --git a/.gitignore b/.gitignore
index 9d4ae5d..91c0db0 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,7 +1,22 @@
-node_modules/
+.nogit/
+
+# artifacts
coverage/
-pages/
public/
+pages/
-test/temp/
+# installs
+node_modules/
+# caches
+.yarn/
+.cache/
+.rpt2_cache
+
+# builds
+dist/
+dist_web/
+dist_serve/
+dist_ts_web/
+
+# custom
\ No newline at end of file
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index 8321aed..8d4acf4 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -1,5 +1,5 @@
-# gitzone standard
-image: hosttoday/ht-docker-node:npmci
+# gitzone ci_default
+image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
cache:
paths:
@@ -49,23 +49,11 @@ testLTS:
tags:
- docker
- notpriv
-
-testSTABLE:
- stage: test
- script:
- - npmci npm prepare
- - npmci node install stable
- - npmci npm install
- - npmci npm test
- coverage: /\d+.?\d+?\%\s*coverage/
- tags:
- - docker
- - notpriv
release:
stage: release
script:
- - npmci node install stable
+ - npmci node install lts
- npmci npm publish
only:
- tags
@@ -78,19 +66,11 @@ release:
# ====================
codequality:
stage: metadata
- image: docker:stable
allow_failure: true
- services:
- - docker:stable-dind
script:
- - export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
- - docker run
- --env SOURCE_CODE="$PWD"
- --volume "$PWD":/code
- --volume /var/run/docker.sock:/var/run/docker.sock
- "registry.gitlab.com/gitlab-org/security-products/codequality:$SP_VERSION" /code
- artifacts:
- paths: [codeclimate.json]
+ - npmci command npm install -g tslint typescript
+ - npmci npm install
+ - npmci command "tslint -c tslint.json ./ts/**/*.ts"
tags:
- docker
- priv
@@ -109,10 +89,10 @@ pages:
image: hosttoday/ht-docker-node:npmci
stage: metadata
script:
- - npmci command npm install -g typedoc typescript
+ - npmci command npm install -g @gitzone/tsdoc
- npmci npm prepare
- npmci npm install
- - npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/
+ - npmci command tsdoc
tags:
- docker
- notpriv
diff --git a/dist/index.d.ts b/dist/index.d.ts
deleted file mode 100644
index d5c1940..0000000
--- a/dist/index.d.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-import * as SmartfileFs from './smartfile.fs';
-import * as SmartfileInterpreter from './smartfile.interpreter';
-import * as SmartfileMemory from './smartfile.memory';
-import * as SmartfileRemote from './smartfile.remote';
-export { Smartfile } from './smartfile.classes.smartfile';
-export declare let fs: typeof SmartfileFs;
-export declare let interpreter: typeof SmartfileInterpreter;
-export declare let memory: typeof SmartfileMemory;
-export declare let remote: typeof SmartfileRemote;
-export declare let requireReload: (path: string) => any;
diff --git a/dist/index.js b/dist/index.js
deleted file mode 100644
index ff6138b..0000000
--- a/dist/index.js
+++ /dev/null
@@ -1,14 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-const SmartfileFs = require("./smartfile.fs");
-const SmartfileInterpreter = require("./smartfile.interpreter");
-const SmartfileMemory = require("./smartfile.memory");
-const SmartfileRemote = require("./smartfile.remote");
-var smartfile_classes_smartfile_1 = require("./smartfile.classes.smartfile");
-exports.Smartfile = smartfile_classes_smartfile_1.Smartfile;
-exports.fs = SmartfileFs;
-exports.interpreter = SmartfileInterpreter;
-exports.memory = SmartfileMemory;
-exports.remote = SmartfileRemote;
-exports.requireReload = SmartfileFs.requireReload;
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLDhDQUE4QztBQUM5QyxnRUFBZ0U7QUFDaEUsc0RBQXNEO0FBQ3RELHNEQUFzRDtBQUV0RCw2RUFBMEQ7QUFBakQsa0RBQUEsU0FBUyxDQUFBO0FBRVAsUUFBQSxFQUFFLEdBQUcsV0FBVyxDQUFDO0FBQ2pCLFFBQUEsV0FBVyxHQUFHLG9CQUFvQixDQUFDO0FBQ25DLFFBQUEsTUFBTSxHQUFHLGVBQWUsQ0FBQztBQUN6QixRQUFBLE1BQU0sR0FBRyxlQUFlLENBQUM7QUFDekIsUUFBQSxhQUFhLEdBQUcsV0FBVyxDQUFDLGFBQWEsQ0FBQyJ9
\ No newline at end of file
diff --git a/dist/smartfile.classes.smartfile.d.ts b/dist/smartfile.classes.smartfile.d.ts
deleted file mode 100644
index ed30ae7..0000000
--- a/dist/smartfile.classes.smartfile.d.ts
+++ /dev/null
@@ -1,79 +0,0 @@
-///
-import * as plugins from './smartfile.plugins';
-export interface ISmartfileConstructorOptions {
- path?: string;
- contentString?: string;
- contentBuffer?: Buffer;
- base?: string;
-}
-/**
- * class Smartfile
- * -> is vinyl file compatible
- */
-export declare class Smartfile {
- /**
- * the full path of the file on disk
- */
- path: string;
- /**
- *
- */
- parsedPath: plugins.path.ParsedPath;
- /**
- * the content of the file as Buffer
- */
- contentBuffer: Buffer;
- /**
- * The current working directory of the file
- * Note:this is similar to gulp and different from native node path base
- */
- base: string;
- /**
- * sync the file with disk
- */
- sync: boolean;
- /**
- * the constructor of Smartfile
- * @param optionsArg
- */
- constructor(optionsArg: ISmartfileConstructorOptions);
- /**
- * set contents from string
- * @param contentString
- */
- setContentsFromString(contentString: string): void;
- /**
- * write file to disk
- * Behaviours:
- * - no argument write to exactly where the file was picked up
- */
- write(pathArg?: string): Promise;
- /**
- * read file from disk
- */
- read(): Promise;
- /**
- * vinyl-compatibility: alias of this.contentBuffer
- */
- contents: Buffer;
- /**
- * vinyl-compatibility
- */
- readonly cwd: string;
- /**
- * return relative path of file
- */
- readonly relative: string;
- /**
- * return truw when the file has content
- */
- isNull(): boolean;
- /**
- * return true if contents are Buffer
- */
- isBuffer(): boolean;
- isDirectory(): boolean;
- isStream(): boolean;
- isSymbolic(): boolean;
- updateFileName(fileNameArg: string): void;
-}
diff --git a/dist/smartfile.classes.smartfile.js b/dist/smartfile.classes.smartfile.js
deleted file mode 100644
index b178581..0000000
--- a/dist/smartfile.classes.smartfile.js
+++ /dev/null
@@ -1,118 +0,0 @@
-"use strict";
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
-};
-Object.defineProperty(exports, "__esModule", { value: true });
-const plugins = require("./smartfile.plugins");
-const memory = require("./smartfile.memory");
-/**
- * class Smartfile
- * -> is vinyl file compatible
- */
-class Smartfile {
- /**
- * the constructor of Smartfile
- * @param optionsArg
- */
- constructor(optionsArg) {
- if (optionsArg.contentBuffer) {
- this.contentBuffer = optionsArg.contentBuffer;
- }
- else if (optionsArg.contentString) {
- this.setContentsFromString(optionsArg.contentString);
- }
- else {
- console.log('created empty Smartfile?');
- }
- this.path = optionsArg.path;
- this.parsedPath = plugins.path.parse(this.path);
- this.base = optionsArg.base;
- }
- /**
- * set contents from string
- * @param contentString
- */
- setContentsFromString(contentString) {
- this.contents = new Buffer(contentString);
- }
- /**
- * write file to disk
- * Behaviours:
- * - no argument write to exactly where the file was picked up
- */
- write(pathArg) {
- return __awaiter(this, void 0, void 0, function* () {
- const stringToWrite = this.contentBuffer.toString();
- yield memory.toFs(stringToWrite, this.path);
- });
- }
- /**
- * read file from disk
- */
- read() {
- return __awaiter(this, void 0, void 0, function* () { });
- }
- // -----------------------------------------------
- // vinyl compatibility
- // -----------------------------------------------
- /**
- * vinyl-compatibility: alias of this.contentBuffer
- */
- get contents() {
- return this.contentBuffer;
- }
- set contents(contentsArg) {
- this.contentBuffer = contentsArg;
- }
- /**
- * vinyl-compatibility
- */
- get cwd() {
- return process.cwd();
- }
- /**
- * return relative path of file
- */
- get relative() {
- return plugins.path.relative(this.base, this.path);
- }
- /**
- * return truw when the file has content
- */
- isNull() {
- if (!this.contentBuffer) {
- return true;
- }
- return false;
- }
- /**
- * return true if contents are Buffer
- */
- isBuffer() {
- if (this.contents instanceof Buffer) {
- return true;
- }
- return false;
- }
- isDirectory() {
- return false;
- }
- isStream() {
- return false;
- }
- isSymbolic() {
- return false;
- }
- // update things
- updateFileName(fileNameArg) {
- let oldFileName = this.parsedPath.base;
- this.path = this.path.replace(new RegExp(oldFileName + '$'), fileNameArg);
- }
-}
-exports.Smartfile = Smartfile;
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxlLmNsYXNzZXMuc21hcnRmaWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRmaWxlLmNsYXNzZXMuc21hcnRmaWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQSwrQ0FBK0M7QUFFL0MsNkNBQTZDO0FBUzdDOzs7R0FHRztBQUNIO0lBMkJFOzs7T0FHRztJQUVILFlBQVksVUFBd0M7UUFDbEQsSUFBSSxVQUFVLENBQUMsYUFBYSxFQUFFO1lBQzVCLElBQUksQ0FBQyxhQUFhLEdBQUcsVUFBVSxDQUFDLGFBQWEsQ0FBQztTQUMvQzthQUFNLElBQUksVUFBVSxDQUFDLGFBQWEsRUFBRTtZQUNuQyxJQUFJLENBQUMscUJBQXFCLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQ3REO2FBQU07WUFDTCxPQUFPLENBQUMsR0FBRyxDQUFDLDBCQUEwQixDQUFDLENBQUM7U0FDekM7UUFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxJQUFJLENBQUM7UUFDNUIsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDaEQsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO0lBQzlCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxxQkFBcUIsQ0FBQyxhQUFxQjtRQUN6QyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRDs7OztPQUlHO0lBQ0csS0FBSyxDQUFDLE9BQWdCOztZQUMxQixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3BELE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzlDLENBQUM7S0FBQTtJQUVEOztPQUVHO0lBQ0csSUFBSTs4REFBSSxDQUFDO0tBQUE7SUFFZixrREFBa0Q7SUFDbEQsc0JBQXNCO0lBQ3RCLGtEQUFrRDtJQUNsRDs7T0FFRztJQUNILElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxRQUFRLENBQUMsV0FBVztRQUN0QixJQUFJLENBQUMsYUFBYSxHQUFHLFdBQVcsQ0FBQztJQUNuQyxDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFJLEdBQUc7UUFDTCxPQUFPLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFJLFFBQVE7UUFDVixPQUFPLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFRDs7T0FFRztJQUNILE1BQU07UUFDSixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN2QixPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQ7O09BRUc7SUFDSCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsUUFBUSxZQUFZLE1BQU0sRUFBRTtZQUNuQyxPQUFPLElBQUksQ0FBQztTQUNiO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsV0FBVztRQUNULE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxVQUFVO1FBQ1IsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO0lBRUQsZ0JBQWdCO0lBQ2hCLGNBQWMsQ0FBQyxXQUFtQjtRQUNoQyxJQUFJLFdBQVcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztRQUN2QyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksTUFBTSxDQUFDLFdBQVcsR0FBRyxHQUFHLENBQUMsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUM1RSxDQUFDO0NBQ0Y7QUFwSUQsOEJBb0lDIn0=
\ No newline at end of file
diff --git a/dist/smartfile.fs.d.ts b/dist/smartfile.fs.d.ts
deleted file mode 100644
index e3d8f6a..0000000
--- a/dist/smartfile.fs.d.ts
+++ /dev/null
@@ -1,143 +0,0 @@
-import { Smartfile } from './smartfile.classes.smartfile';
-/**
- *
- * @param filePath
- * @returns {boolean}
- */
-export declare let fileExistsSync: (filePath: any) => boolean;
-/**
- *
- * @param filePath
- * @returns {any}
- */
-export declare let fileExists: (filePath: any) => Promise<{}>;
-/**
- * Checks if given path points to an existing directory
- */
-export declare let isDirectory: (pathArg: any) => boolean;
-/**
- * Checks if a given path points to an existing file
- */
-export declare let isFile: (pathArg: any) => boolean;
-/**
- * copies a file from A to B on the local disk
- */
-export declare let copy: (fromArg: string, toArg: string) => Promise<{}>;
-/**
- * copies a file SYNCHRONOUSLY from A to B on the local disk
- */
-export declare let copySync: (fromArg: string, toArg: string) => boolean;
-/**
- * ensures that a directory is in place
- */
-export declare let ensureDir: (dirPathArg: string) => Promise<{}>;
-/**
- * ensures that a directory is in place
- */
-export declare let ensureDirSync: (dirPathArg: string) => void;
-/**
- * ensure an empty directory
- * @executes ASYNC
- */
-export declare let ensureEmptyDir: (dirPathArg: string) => Promise<{}>;
-/**
- * ensure an empty directory
- * @executes SYNC
- */
-export declare let ensureEmptyDirSync: (dirPathArg: string) => void;
-/**
- * ensures that a file is on disk
- * @param filePath the filePath to ensureDir
- * @param the fileContent to place into a new file in case it doesn't exist yet
- * @returns Promise
- * @exec ASYNC
- */
-export declare let ensureFile: (filePathArg: any, initFileStringArg: any) => Promise;
-/**
- * ensures that a file is on disk
- * @param filePath the filePath to ensureDir
- * @param the fileContent to place into a new file in case it doesn't exist yet
- * @returns Promise
- * @exec SYNC
- */
-export declare let ensureFileSync: (filePathArg: string, initFileStringArg: string) => void;
-/**
- * removes a file or folder from local disk
- */
-export declare let remove: (pathArg: string) => Promise;
-/**
- * removes a file SYNCHRONOUSLY from local disk
- */
-export declare let removeSync: (pathArg: string) => boolean;
-/**
- * removes an array of filePaths from disk
- */
-export declare let removeMany: (filePathArrayArg: string[]) => Promise;
-/**
- * like removeFilePathArray but SYNCHRONOUSLY
- */
-export declare let removeManySync: (filePathArrayArg: string[]) => void;
-/**
- *
- * @param filePathArg
- * @param fileTypeArg
- * @returns {any}
- */
-export declare let toObjectSync: (filePathArg: any, fileTypeArg?: any) => any;
-/**
- * reads a file content to a String
- * @param filePath
- * @returns {string|Buffer|any}
- */
-export declare let toStringSync: (filePath: string) => string;
-export declare let fileTreeToObject: (dirPathArg: string, miniMatchFilter: string) => Promise;
-/**
- *
- * @param filePathArg
- * @param options
- * @returns {number}
- */
-export declare let toVinylSync: (filePathArg: any, options?: {}) => any;
-/**
- * lets you reload files hot.
- * @param path
- * @returns {any}
- */
-export declare let requireReload: (path: string) => any;
-/**
- * lists Folders in a directory on local disk
- * @returns Promise
- */
-export declare let listFolders: (pathArg: string, regexFilter?: RegExp) => Promise<{}>;
-/**
- * lists Folders SYNCHRONOUSLY in a directory on local disk
- * @returns an array with the folder names as strings
- */
-export declare let listFoldersSync: (pathArg: string, regexFilter?: RegExp) => string[];
-/**
- * lists Files in a directory on local disk
- * @returns Promise
- */
-export declare let listFiles: (pathArg: string, regexFilter?: RegExp) => Promise<{}>;
-/**
- * lists Files SYNCHRONOUSLY in a directory on local disk
- * @returns an array with the folder names as strings
- */
-export declare let listFilesSync: (pathArg: string, regexFilter?: RegExp) => string[];
-/**
- * lists all items (folders AND files) in a directory on local disk
- * @returns Promise
- */
-export declare let listAllItems: (pathArg: string, regexFilter?: RegExp) => Promise;
-/**
- * lists all items (folders AND files) in a directory on local disk
- * @returns an array with the folder names as strings
- * @executes SYNC
- */
-export declare let listAllItemsSync: (pathArg: string, regexFilter?: RegExp) => string[];
-/**
- * lists a file tree using a miniMatch filter
- * note: if the miniMatch Filter is an absolute path, the cwdArg will be omitted
- * @returns Promise string array with the absolute paths of all matching files
- */
-export declare let listFileTree: (dirPathArg: string, miniMatchFilter: string) => Promise;
diff --git a/dist/smartfile.fs.js b/dist/smartfile.fs.js
deleted file mode 100644
index 78d5f7e..0000000
--- a/dist/smartfile.fs.js
+++ /dev/null
@@ -1,374 +0,0 @@
-"use strict";
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
-};
-Object.defineProperty(exports, "__esModule", { value: true });
-const plugins = require("./smartfile.plugins");
-const SmartfileInterpreter = require("./smartfile.interpreter");
-const smartfile_classes_smartfile_1 = require("./smartfile.classes.smartfile");
-const memory = require("./smartfile.memory");
-/*===============================================================
-============================ Checks =============================
-===============================================================*/
-/**
- *
- * @param filePath
- * @returns {boolean}
- */
-exports.fileExistsSync = function (filePath) {
- let fileExistsBool = false;
- try {
- plugins.fsExtra.readFileSync(filePath);
- fileExistsBool = true;
- }
- catch (err) {
- fileExistsBool = false;
- }
- return fileExistsBool;
-};
-/**
- *
- * @param filePath
- * @returns {any}
- */
-exports.fileExists = function (filePath) {
- let done = plugins.smartpromise.defer();
- plugins.fs.access(filePath, 4, function (err) {
- err ? done.reject(err) : done.resolve();
- });
- return done.promise;
-};
-/**
- * Checks if given path points to an existing directory
- */
-exports.isDirectory = function (pathArg) {
- try {
- return plugins.fsExtra.statSync(pathArg).isDirectory();
- }
- catch (err) {
- return false;
- }
-};
-/**
- * Checks if a given path points to an existing file
- */
-exports.isFile = function (pathArg) {
- return plugins.fsExtra.statSync(pathArg).isFile();
-};
-/*===============================================================
-============================ FS ACTIONS =========================
-===============================================================*/
-/**
- * copies a file from A to B on the local disk
- */
-exports.copy = function (fromArg, toArg) {
- let done = plugins.smartpromise.defer();
- plugins.fsExtra.copy(fromArg, toArg, {}, function () {
- done.resolve();
- });
- return done.promise;
-};
-/**
- * copies a file SYNCHRONOUSLY from A to B on the local disk
- */
-exports.copySync = function (fromArg, toArg) {
- plugins.fsExtra.copySync(fromArg, toArg);
- return true;
-};
-/**
- * ensures that a directory is in place
- */
-exports.ensureDir = (dirPathArg) => {
- let done = plugins.smartpromise.defer();
- plugins.fsExtra.ensureDir(dirPathArg, done.resolve);
- return done.promise;
-};
-/**
- * ensures that a directory is in place
- */
-exports.ensureDirSync = (dirPathArg) => {
- plugins.fsExtra.ensureDirSync(dirPathArg);
-};
-/**
- * ensure an empty directory
- * @executes ASYNC
- */
-exports.ensureEmptyDir = (dirPathArg) => {
- let done = plugins.smartpromise.defer();
- plugins.fsExtra.ensureDir(dirPathArg, () => {
- plugins.fsExtra.emptyDir(dirPathArg, done.resolve);
- });
- return done.promise;
-};
-/**
- * ensure an empty directory
- * @executes SYNC
- */
-exports.ensureEmptyDirSync = (dirPathArg) => {
- plugins.fsExtra.ensureDirSync(dirPathArg);
- plugins.fsExtra.emptyDirSync(dirPathArg);
-};
-/**
- * ensures that a file is on disk
- * @param filePath the filePath to ensureDir
- * @param the fileContent to place into a new file in case it doesn't exist yet
- * @returns Promise
- * @exec ASYNC
- */
-exports.ensureFile = (filePathArg, initFileStringArg) => {
- let done = plugins.smartpromise.defer();
- exports.ensureFileSync(filePathArg, initFileStringArg);
- done.resolve();
- return done.promise;
-};
-/**
- * ensures that a file is on disk
- * @param filePath the filePath to ensureDir
- * @param the fileContent to place into a new file in case it doesn't exist yet
- * @returns Promise
- * @exec SYNC
- */
-exports.ensureFileSync = (filePathArg, initFileStringArg) => {
- if (exports.fileExistsSync(filePathArg)) {
- return null;
- }
- else {
- memory.toFsSync(initFileStringArg, filePathArg);
- }
-};
-/**
- * removes a file or folder from local disk
- */
-exports.remove = function (pathArg) {
- let done = plugins.smartpromise.defer();
- plugins.fsExtra.remove(pathArg, function () {
- done.resolve();
- });
- return done.promise;
-};
-/**
- * removes a file SYNCHRONOUSLY from local disk
- */
-exports.removeSync = function (pathArg) {
- plugins.fsExtra.removeSync(pathArg);
- return true;
-};
-/**
- * removes an array of filePaths from disk
- */
-exports.removeMany = function (filePathArrayArg) {
- let promiseArray = [];
- for (let filePath of filePathArrayArg) {
- promiseArray.push(exports.remove(filePath));
- }
- return Promise.all(promiseArray);
-};
-/**
- * like removeFilePathArray but SYNCHRONOUSLY
- */
-exports.removeManySync = function (filePathArrayArg) {
- for (let filePath of filePathArrayArg) {
- exports.removeSync(filePath);
- }
-};
-/*===============================================================
-============================ Write/Read =========================
-===============================================================*/
-/**
- *
- * @param filePathArg
- * @param fileTypeArg
- * @returns {any}
- */
-exports.toObjectSync = function (filePathArg, fileTypeArg) {
- let fileString = plugins.fsExtra.readFileSync(filePathArg, 'utf8');
- let fileType;
- fileTypeArg ? (fileType = fileTypeArg) : (fileType = SmartfileInterpreter.filetype(filePathArg));
- return SmartfileInterpreter.objectFile(fileString, fileType);
-};
-/**
- * reads a file content to a String
- * @param filePath
- * @returns {string|Buffer|any}
- */
-exports.toStringSync = function (filePath) {
- let fileString = plugins.fsExtra.readFileSync(filePath, 'utf8');
- return fileString;
-};
-exports.fileTreeToObject = (dirPathArg, miniMatchFilter) => __awaiter(this, void 0, void 0, function* () {
- // handle absolute miniMatchFilter
- let dirPath;
- if (plugins.path.isAbsolute(miniMatchFilter)) {
- dirPath = '/';
- }
- else {
- dirPath = dirPathArg;
- }
- let fileTree = yield exports.listFileTree(dirPath, miniMatchFilter);
- let smartfileArray = [];
- for (let filePath of fileTree) {
- let readPath = (() => {
- if (!plugins.path.isAbsolute(filePath)) {
- return plugins.path.join(dirPath, filePath);
- }
- else {
- return filePath;
- }
- })();
- let fileContentString = exports.toStringSync(readPath);
- // push a read file as Smartfile
- smartfileArray.push(new smartfile_classes_smartfile_1.Smartfile({
- contentBuffer: new Buffer(fileContentString),
- base: dirPath,
- path: filePath
- }));
- }
- return smartfileArray;
-});
-/**
- *
- * @param filePathArg
- * @param options
- * @returns {number}
- */
-exports.toVinylSync = function (filePathArg, options = {}) {
- return plugins.vinylFile.readSync(filePathArg, options);
-};
-/**
- * lets you reload files hot.
- * @param path
- * @returns {any}
- */
-exports.requireReload = function (path) {
- return plugins.requireReload(path);
-};
-/**
- * lists Folders in a directory on local disk
- * @returns Promise
- */
-exports.listFolders = function (pathArg, regexFilter) {
- let done = plugins.smartpromise.defer();
- let folderArray = plugins.fsExtra.readdirSync(pathArg).filter(function (file) {
- return plugins.fsExtra.statSync(plugins.path.join(pathArg, file)).isDirectory();
- });
- if (regexFilter) {
- folderArray = folderArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- done.resolve(folderArray);
- return done.promise;
-};
-/**
- * lists Folders SYNCHRONOUSLY in a directory on local disk
- * @returns an array with the folder names as strings
- */
-exports.listFoldersSync = function (pathArg, regexFilter) {
- let folderArray = plugins.fsExtra.readdirSync(pathArg).filter(function (file) {
- return plugins.fsExtra.statSync(plugins.path.join(pathArg, file)).isDirectory();
- });
- if (regexFilter) {
- folderArray = folderArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- return folderArray;
-};
-/**
- * lists Files in a directory on local disk
- * @returns Promise
- */
-exports.listFiles = function (pathArg, regexFilter) {
- let done = plugins.smartpromise.defer();
- let fileArray = plugins.fsExtra.readdirSync(pathArg).filter(function (file) {
- return plugins.fsExtra.statSync(plugins.path.join(pathArg, file)).isFile();
- });
- if (regexFilter) {
- fileArray = fileArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- done.resolve(fileArray);
- return done.promise;
-};
-/**
- * lists Files SYNCHRONOUSLY in a directory on local disk
- * @returns an array with the folder names as strings
- */
-exports.listFilesSync = function (pathArg, regexFilter) {
- let fileArray = plugins.fsExtra.readdirSync(pathArg).filter(function (file) {
- return plugins.fsExtra.statSync(plugins.path.join(pathArg, file)).isFile();
- });
- if (regexFilter) {
- fileArray = fileArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- return fileArray;
-};
-/**
- * lists all items (folders AND files) in a directory on local disk
- * @returns Promise
- */
-exports.listAllItems = function (pathArg, regexFilter) {
- let done = plugins.smartpromise.defer();
- let allItmesArray = plugins.fsExtra.readdirSync(pathArg);
- if (regexFilter) {
- allItmesArray = allItmesArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- done.resolve(allItmesArray);
- return done.promise;
-};
-/**
- * lists all items (folders AND files) in a directory on local disk
- * @returns an array with the folder names as strings
- * @executes SYNC
- */
-exports.listAllItemsSync = function (pathArg, regexFilter) {
- let allItmesArray = plugins.fsExtra.readdirSync(pathArg).filter(function (file) {
- return plugins.fsExtra.statSync(plugins.path.join(pathArg, file)).isFile();
- });
- if (regexFilter) {
- allItmesArray = allItmesArray.filter(fileItem => {
- return regexFilter.test(fileItem);
- });
- }
- return allItmesArray;
-};
-/**
- * lists a file tree using a miniMatch filter
- * note: if the miniMatch Filter is an absolute path, the cwdArg will be omitted
- * @returns Promise string array with the absolute paths of all matching files
- */
-exports.listFileTree = (dirPathArg, miniMatchFilter) => {
- let done = plugins.smartpromise.defer();
- // handle absolute miniMatchFilter
- let dirPath;
- if (plugins.path.isAbsolute(miniMatchFilter)) {
- dirPath = '/';
- }
- else {
- dirPath = dirPathArg;
- }
- let options = {
- cwd: dirPath,
- nodir: true,
- dot: true
- };
- plugins.glob(miniMatchFilter, options, (err, files) => {
- if (err) {
- console.log(err);
- done.reject(err);
- }
- done.resolve(files);
- });
- return done.promise;
-};
-//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartfile.fs.js","sourceRoot":"","sources":["../ts/smartfile.fs.ts"],"names":[],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/smartfile.interpreter.d.ts b/dist/smartfile.interpreter.d.ts
deleted file mode 100644
index de74b2a..0000000
--- a/dist/smartfile.interpreter.d.ts
+++ /dev/null
@@ -1,2 +0,0 @@
-export declare let filetype: (pathArg: string) => string;
-export declare let objectFile: (fileStringArg: string, fileTypeArg: any) => any;
diff --git a/dist/smartfile.interpreter.js b/dist/smartfile.interpreter.js
deleted file mode 100644
index 9836ed9..0000000
--- a/dist/smartfile.interpreter.js
+++ /dev/null
@@ -1,21 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-const plugins = require("./smartfile.plugins");
-exports.filetype = (pathArg) => {
- let extName = plugins.path.extname(pathArg);
- let fileType = extName.replace(/\.([a-z]*)/, '$1'); // remove . form fileType
- return fileType;
-};
-exports.objectFile = (fileStringArg, fileTypeArg) => {
- switch (fileTypeArg) {
- case 'yml':
- case 'yaml':
- return plugins.yaml.safeLoad(fileStringArg);
- case 'json':
- return JSON.parse(fileStringArg);
- default:
- console.error('file type ' + fileTypeArg.blue + ' not supported');
- break;
- }
-};
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxlLmludGVycHJldGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRmaWxlLmludGVycHJldGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsK0NBQWdEO0FBRXJDLFFBQUEsUUFBUSxHQUFHLENBQUMsT0FBZSxFQUFVLEVBQUU7SUFDaEQsSUFBSSxPQUFPLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUMsSUFBSSxRQUFRLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyx5QkFBeUI7SUFDN0UsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyxDQUFDO0FBRVMsUUFBQSxVQUFVLEdBQUcsQ0FBQyxhQUFxQixFQUFFLFdBQVcsRUFBRSxFQUFFO0lBQzdELFFBQVEsV0FBVyxFQUFFO1FBQ25CLEtBQUssS0FBSyxDQUFDO1FBQ1gsS0FBSyxNQUFNO1lBQ1QsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM5QyxLQUFLLE1BQU07WUFDVCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDbkM7WUFDRSxPQUFPLENBQUMsS0FBSyxDQUFDLFlBQVksR0FBRyxXQUFXLENBQUMsSUFBSSxHQUFHLGdCQUFnQixDQUFDLENBQUM7WUFDbEUsTUFBTTtLQUNUO0FBQ0gsQ0FBQyxDQUFDIn0=
\ No newline at end of file
diff --git a/dist/smartfile.memory.d.ts b/dist/smartfile.memory.d.ts
deleted file mode 100644
index d02b87d..0000000
--- a/dist/smartfile.memory.d.ts
+++ /dev/null
@@ -1,25 +0,0 @@
-import { Smartfile } from './smartfile.classes.smartfile';
-/**
- * converts file to Object
- * @param fileStringArg
- * @param fileTypeArg
- * @returns {any|any}
- */
-export declare let toObject: (fileStringArg: string, fileTypeArg: string) => any;
-export interface IToFsOptions {
- respectRelative?: boolean;
-}
-/**
- * writes string or Smartfile to disk.
- * @param fileArg
- * @param fileNameArg
- * @param fileBaseArg
- */
-export declare let toFs: (fileContentArg: string | Smartfile, filePathArg: any, optionsArg?: IToFsOptions) => Promise<{}>;
-/**
- * writes a string or a Smartfile to disk synchronously, only supports string
- * @param fileArg
- * @param filePathArg
- */
-export declare let toFsSync: (fileArg: string, filePathArg: string) => void;
-export declare let smartfileArrayToFs: (smartfileArrayArg: Smartfile[], dirArg: string) => Promise;
diff --git a/dist/smartfile.memory.js b/dist/smartfile.memory.js
deleted file mode 100644
index 171de91..0000000
--- a/dist/smartfile.memory.js
+++ /dev/null
@@ -1,87 +0,0 @@
-"use strict";
-var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
- return new (P || (P = Promise))(function (resolve, reject) {
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
- function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
- step((generator = generator.apply(thisArg, _arguments || [])).next());
- });
-};
-Object.defineProperty(exports, "__esModule", { value: true });
-const plugins = require("./smartfile.plugins");
-const smartfile_classes_smartfile_1 = require("./smartfile.classes.smartfile");
-const smartfileFs = require("./smartfile.fs");
-const SmartfileInterpreter = require("./smartfile.interpreter");
-/**
- * converts file to Object
- * @param fileStringArg
- * @param fileTypeArg
- * @returns {any|any}
- */
-exports.toObject = function (fileStringArg, fileTypeArg) {
- return SmartfileInterpreter.objectFile(fileStringArg, fileTypeArg);
-};
-/**
- * writes string or Smartfile to disk.
- * @param fileArg
- * @param fileNameArg
- * @param fileBaseArg
- */
-exports.toFs = (fileContentArg, filePathArg, optionsArg = {}) => __awaiter(this, void 0, void 0, function* () {
- let done = plugins.smartpromise.defer();
- // check args
- if (!fileContentArg || !filePathArg) {
- throw new Error('expected valid arguments');
- }
- // prepare actual write action
- let fileString;
- let filePath = filePathArg;
- // handle Smartfile
- if (fileContentArg instanceof smartfile_classes_smartfile_1.Smartfile) {
- let fileContentArg2 = fileContentArg;
- fileString = fileContentArg.contentBuffer.toString();
- // handle options
- if (optionsArg.respectRelative) {
- filePath = plugins.path.join(filePath, fileContentArg.path);
- }
- }
- else if (typeof fileContentArg === 'string') {
- fileString = fileContentArg;
- }
- else {
- throw new Error('fileContent is neither string nor Smartfile');
- }
- yield smartfileFs.ensureDir(plugins.path.parse(filePath).dir);
- plugins.fsExtra.writeFile(filePath, fileString, { encoding: 'utf8' }, done.resolve);
- return yield done.promise;
-});
-/**
- * writes a string or a Smartfile to disk synchronously, only supports string
- * @param fileArg
- * @param filePathArg
- */
-exports.toFsSync = function (fileArg, filePathArg) {
- // function checks to abort if needed
- if (!fileArg || !filePathArg) {
- throw new Error('expected a valid arguments');
- }
- // prepare actual write action
- let fileString;
- let filePath = filePathArg;
- if (typeof fileArg !== 'string') {
- throw new Error('fileArg is not of type String.');
- }
- else if (typeof fileArg === 'string') {
- fileString = fileArg;
- }
- plugins.fsExtra.writeFileSync(filePath, fileString, { encoding: 'utf8' });
-};
-exports.smartfileArrayToFs = (smartfileArrayArg, dirArg) => __awaiter(this, void 0, void 0, function* () {
- yield smartfileFs.ensureDir(dirArg);
- for (let smartfile of smartfileArrayArg) {
- yield exports.toFs(smartfile, dirArg, {
- respectRelative: true
- });
- }
-});
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxlLm1lbW9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0ZmlsZS5tZW1vcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBLCtDQUFnRDtBQUNoRCwrRUFBMEQ7QUFDMUQsOENBQThDO0FBRTlDLGdFQUFpRTtBQUVqRTs7Ozs7R0FLRztBQUNRLFFBQUEsUUFBUSxHQUFHLFVBQVMsYUFBcUIsRUFBRSxXQUFtQjtJQUN2RSxPQUFPLG9CQUFvQixDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsV0FBVyxDQUFDLENBQUM7QUFDckUsQ0FBQyxDQUFDO0FBTUY7Ozs7O0dBS0c7QUFDUSxRQUFBLElBQUksR0FBRyxDQUNoQixjQUFrQyxFQUNsQyxXQUFXLEVBQ1gsYUFBMkIsRUFBRSxFQUM3QixFQUFFO0lBQ0YsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUV4QyxhQUFhO0lBQ2IsSUFBSSxDQUFDLGNBQWMsSUFBSSxDQUFDLFdBQVcsRUFBRTtRQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7S0FDN0M7SUFFRCw4QkFBOEI7SUFDOUIsSUFBSSxVQUFrQixDQUFDO0lBQ3ZCLElBQUksUUFBUSxHQUFXLFdBQVcsQ0FBQztJQUVuQyxtQkFBbUI7SUFDbkIsSUFBSSxjQUFjLFlBQVksdUNBQVMsRUFBRTtRQUN2QyxJQUFJLGVBQWUsR0FBUSxjQUFjLENBQUM7UUFDMUMsVUFBVSxHQUFHLGNBQWMsQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDckQsaUJBQWlCO1FBQ2pCLElBQUksVUFBVSxDQUFDLGVBQWUsRUFBRTtZQUM5QixRQUFRLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUM3RDtLQUNGO1NBQU0sSUFBSSxPQUFPLGNBQWMsS0FBSyxRQUFRLEVBQUU7UUFDN0MsVUFBVSxHQUFHLGNBQWMsQ0FBQztLQUM3QjtTQUFNO1FBQ0wsTUFBTSxJQUFJLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDO0tBQ2hFO0lBQ0QsTUFBTSxXQUFXLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlELE9BQU8sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BGLE9BQU8sTUFBTSxJQUFJLENBQUMsT0FBTyxDQUFDO0FBQzVCLENBQUMsQ0FBQSxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLFFBQUEsUUFBUSxHQUFHLFVBQVMsT0FBZSxFQUFFLFdBQW1CO0lBQ2pFLHFDQUFxQztJQUNyQyxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsV0FBVyxFQUFFO1FBQzVCLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztLQUMvQztJQUVELDhCQUE4QjtJQUM5QixJQUFJLFVBQWtCLENBQUM7SUFDdkIsSUFBSSxRQUFRLEdBQVcsV0FBVyxDQUFDO0lBRW5DLElBQUksT0FBTyxPQUFPLEtBQUssUUFBUSxFQUFFO1FBQy9CLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztLQUNuRDtTQUFNLElBQUksT0FBTyxPQUFPLEtBQUssUUFBUSxFQUFFO1FBQ3RDLFVBQVUsR0FBRyxPQUFPLENBQUM7S0FDdEI7SUFDRCxPQUFPLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsVUFBVSxFQUFFLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7QUFDNUUsQ0FBQyxDQUFDO0FBRVMsUUFBQSxrQkFBa0IsR0FBRyxDQUFPLGlCQUE4QixFQUFFLE1BQWMsRUFBRSxFQUFFO0lBQ3ZGLE1BQU0sV0FBVyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNwQyxLQUFLLElBQUksU0FBUyxJQUFJLGlCQUFpQixFQUFFO1FBQ3ZDLE1BQU0sWUFBSSxDQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUU7WUFDNUIsZUFBZSxFQUFFLElBQUk7U0FDdEIsQ0FBQyxDQUFDO0tBQ0o7QUFDSCxDQUFDLENBQUEsQ0FBQyJ9
\ No newline at end of file
diff --git a/dist/smartfile.plugins.d.ts b/dist/smartfile.plugins.d.ts
deleted file mode 100644
index 655662a..0000000
--- a/dist/smartfile.plugins.d.ts
+++ /dev/null
@@ -1,10 +0,0 @@
-export import fs = require('fs');
-export import fsExtra = require('fs-extra');
-export declare let glob: any;
-export import path = require('path');
-export import smartpromise = require('@pushrocks/smartpromise');
-export import smartrequest = require('@pushrocks/smartrequest');
-export declare let requireReload: any;
-export import smartpath = require('smartpath');
-export declare let vinylFile: any;
-export declare let yaml: any;
diff --git a/dist/smartfile.plugins.js b/dist/smartfile.plugins.js
deleted file mode 100644
index 7d50327..0000000
--- a/dist/smartfile.plugins.js
+++ /dev/null
@@ -1,13 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-exports.fs = require("fs");
-exports.fsExtra = require("fs-extra");
-exports.glob = require('glob');
-exports.path = require("path");
-exports.smartpromise = require("@pushrocks/smartpromise");
-exports.smartrequest = require("@pushrocks/smartrequest");
-exports.requireReload = require('require-reload');
-exports.smartpath = require("smartpath");
-exports.vinylFile = require('vinyl-file');
-exports.yaml = require('js-yaml');
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxlLnBsdWdpbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9zbWFydGZpbGUucGx1Z2lucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDJCQUFpQztBQUNqQyxzQ0FBNEM7QUFDakMsUUFBQSxJQUFJLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ2xDLCtCQUFxQztBQUNyQywwREFBZ0U7QUFDaEUsMERBQWdFO0FBQ3JELFFBQUEsYUFBYSxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQ3JELHlDQUErQztBQUNwQyxRQUFBLFNBQVMsR0FBRyxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUM7QUFDbEMsUUFBQSxJQUFJLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDIn0=
\ No newline at end of file
diff --git a/dist/smartfile.remote.d.ts b/dist/smartfile.remote.d.ts
deleted file mode 100644
index 9124081..0000000
--- a/dist/smartfile.remote.d.ts
+++ /dev/null
@@ -1,12 +0,0 @@
-/**
- *
- * @param fromArg
- * @returns {any}
- */
-export declare let toObject: (fromArg: string) => Promise<{}>;
-/**
- *
- * @param fromArg
- * @returns {any}
- */
-export declare let toString: (fromArg: string) => Promise<{}>;
diff --git a/dist/smartfile.remote.js b/dist/smartfile.remote.js
deleted file mode 100644
index f03c297..0000000
--- a/dist/smartfile.remote.js
+++ /dev/null
@@ -1,51 +0,0 @@
-"use strict";
-Object.defineProperty(exports, "__esModule", { value: true });
-const plugins = require("./smartfile.plugins");
-/* export let toFs = function (from: string, toPath: string) {
- let done = plugins.q.defer()
- let stream = plugins.smartrequest(from).pipe(plugins.fsExtra.createWriteStream(toPath))
- stream.on('finish', function () {
- done.resolve(toPath)
- })
- return done.promise
-} */
-/**
- *
- * @param fromArg
- * @returns {any}
- */
-exports.toObject = function (fromArg) {
- let done = plugins.smartpromise.defer();
- plugins.smartrequest
- .request(fromArg, {
- method: 'get'
- })
- .then((res) => {
- if (res.statusCode === 200) {
- done.resolve(res.body);
- }
- else {
- console.log('could not get remote file from ' + fromArg);
- done.reject(new Error('could not get remote file from ' + fromArg));
- }
- });
- return done.promise;
-};
-/**
- *
- * @param fromArg
- * @returns {any}
- */
-exports.toString = (fromArg) => {
- let done = plugins.smartpromise.defer();
- plugins.smartrequest.get(fromArg).then((res) => {
- if (res.statusCode === 200) {
- done.resolve(res.body);
- }
- else {
- done.reject(new Error('could not get remote file from ' + fromArg));
- }
- });
- return done.promise;
-};
-//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRmaWxlLnJlbW90ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0ZmlsZS5yZW1vdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSwrQ0FBZ0Q7QUFHaEQ7Ozs7Ozs7SUFPSTtBQUVKOzs7O0dBSUc7QUFDUSxRQUFBLFFBQVEsR0FBRyxVQUFTLE9BQWU7SUFDNUMsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN4QyxPQUFPLENBQUMsWUFBWTtTQUNqQixPQUFPLENBQUMsT0FBTyxFQUFFO1FBQ2hCLE1BQU0sRUFBRSxLQUFLO0tBQ2QsQ0FBQztTQUNELElBQUksQ0FBQyxDQUFDLEdBQVEsRUFBRSxFQUFFO1FBQ2pCLElBQUksR0FBRyxDQUFDLFVBQVUsS0FBSyxHQUFHLEVBQUU7WUFDMUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDeEI7YUFBTTtZQUNMLE9BQU8sQ0FBQyxHQUFHLENBQUMsaUNBQWlDLEdBQUcsT0FBTyxDQUFDLENBQUM7WUFDekQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxpQ0FBaUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQ3JFO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7QUFDdEIsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNRLFFBQUEsUUFBUSxHQUFHLENBQUMsT0FBZSxFQUFFLEVBQUU7SUFDeEMsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN4QyxPQUFPLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFRLEVBQUUsRUFBRTtRQUNsRCxJQUFJLEdBQUcsQ0FBQyxVQUFVLEtBQUssR0FBRyxFQUFFO1lBQzFCLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3hCO2FBQU07WUFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxDQUFDLGlDQUFpQyxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUM7U0FDckU7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUNILE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN0QixDQUFDLENBQUMifQ==
\ No newline at end of file
diff --git a/docs/index.md b/docs/index.md
deleted file mode 100644
index 24eb151..0000000
--- a/docs/index.md
+++ /dev/null
@@ -1,43 +0,0 @@
-# smartfile
-
-make files easily accessible for processing in javascript.
-
-## Availabililty
-
-[![npm](https://pushrocks.gitlab.io/assets/repo-button-npm.svg)](https://www.npmjs.com/package/smartfile)
-[![git](https://pushrocks.gitlab.io/assets/repo-button-git.svg)](https://gitlab.com/pushrocks/smartfile)
-[![git](https://pushrocks.gitlab.io/assets/repo-button-mirror.svg)](https://github.com/pushrocks/smartfile)
-[![docs](https://pushrocks.gitlab.io/assets/repo-button-docs.svg)](https://pushrocks.gitlab.io/smartfile/)
-
-## Status for master
-
-[![build status](https://gitlab.com/pushrocks/smartfile/badges/master/build.svg)](https://gitlab.com/pushrocks/smartfile/commits/master)
-[![coverage report](https://gitlab.com/pushrocks/smartfile/badges/master/coverage.svg)](https://gitlab.com/pushrocks/smartfile/commits/master)
-[![Dependency Status](https://david-dm.org/pushrocks/smartfile.svg)](https://david-dm.org/pushrocks/smartfile)
-[![bitHound Dependencies](https://www.bithound.io/github/pushrocks/smartfile/badges/dependencies.svg)](https://www.bithound.io/github/pushrocks/smartfile/master/dependencies/npm)
-[![bitHound Code](https://www.bithound.io/github/pushrocks/smartfile/badges/code.svg)](https://www.bithound.io/github/pushrocks/smartfile)
-[![TypeScript](https://img.shields.io/badge/TypeScript-2.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
-[![node](https://img.shields.io/badge/node->=%206.x.x-blue.svg)](https://nodejs.org/dist/latest-v6.x/docs/api/)
-[![JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-brightgreen.svg)](http://standardjs.com/)
-
-## Usage
-
-smartfile is an approach of being one tool to handle files in diverse environments.
-
-### Smartfile Sections
-
-smartfile thinks in sections:
-
-| section | description |
-| ----------- | ---------------------------------------------------------------------------- |
-| fs | (object) gets data from fs to somewhere |
-| memory | gets data from memory to somewhere |
-| remote | gets data from remote locations to somewhere |
-| interpreter | (object) handles yaml and json |
-| smartfile | (class) a virtual representation of a file, alternative to vinyl file format |
-
-For further information read the linked docs at the top of this README.
-
-> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
-
-[![npm](https://pushrocks.gitlab.io/assets/repo-footer.svg)](https://push.rocks)
diff --git a/package.json b/package.json
index 257c741..029abb4 100644
--- a/package.json
+++ b/package.json
@@ -47,5 +47,15 @@
"gulp-function": "^2.2.14",
"tslint": "^5.15.0",
"tslint-config-prettier": "^1.18.0"
- }
-}
+ },
+ "files": [
+ "ts/*",
+ "ts_web/*",
+ "dist/*",
+ "dist_web/*",
+ "assets/*",
+ "cli.js",
+ "npmextra.json",
+ "readme.md"
+ ]
+}
\ No newline at end of file
diff --git a/test/test.ts b/test/test.ts
index 1db6364..c10b948 100644
--- a/test/test.ts
+++ b/test/test.ts
@@ -8,112 +8,112 @@ import { expect, tap } from '@pushrocks/tapbundle';
// ---------------------------
tap.test('.fs.fileExistsSync -> should return an accurate boolean', async () => {
- expect(smartfile.fs.fileExistsSync('./test/mytest.json')).to.be.true;
- expect(smartfile.fs.fileExistsSync('./test/notthere.json')).be.false;
+ expect(smartfile.fs.fileExistsSync('./test/testassets/mytest.json')).to.be.true;
+ expect(smartfile.fs.fileExistsSync('./test/testassets/notthere.json')).be.false;
});
tap.test('.fs.fileExists -> should resolve or reject a promise', async () => {
- expect(smartfile.fs.fileExists('./test/mytest.json')).to.be.instanceof(Promise);
- await smartfile.fs.fileExists('./test/mytest.json');
- await smartfile.fs.fileExists('./test/notthere.json').catch(err => {
+ expect(smartfile.fs.fileExists('./test/testassets/mytest.json')).to.be.instanceof(Promise);
+ await smartfile.fs.fileExists('./test/testassets/mytest.json');
+ await smartfile.fs.fileExists('./test/testassets/notthere.json').catch(err => {
return expect(err.message).to.equal(
- "ENOENT: no such file or directory, access './test/notthere.json'"
+ "ENOENT: no such file or directory, access './test/testassets/notthere.json'"
);
});
});
tap.test('.fs.listFoldersSync() -> should get the file type from a string', async () => {
- expect(smartfile.fs.listFoldersSync('./test/')).to.include('testfolder');
- expect(smartfile.fs.listFoldersSync('./test/')).to.not.include('notExistentFolder');
+ expect(smartfile.fs.listFoldersSync('./test/testassets/')).to.include('testfolder');
+ expect(smartfile.fs.listFoldersSync('./test/testassets/')).to.not.include('notExistentFolder');
});
tap.test('.fs.listFolders() -> should get the file type from a string', async () => {
- let folderArrayArg = await smartfile.fs.listFolders('./test/');
+ let folderArrayArg = await smartfile.fs.listFolders('./test/testassets/');
expect(folderArrayArg).to.include('testfolder');
expect(folderArrayArg).to.not.include('notExistentFolder');
});
tap.test('.fs.listFilesSync() -> should get the file type from a string', async () => {
- expect(smartfile.fs.listFilesSync('./test/')).to.include('mytest.json');
- expect(smartfile.fs.listFilesSync('./test/')).to.not.include('notExistentFile');
- expect(smartfile.fs.listFilesSync('./test/', /mytest\.json/)).to.include('mytest.json');
- expect(smartfile.fs.listFilesSync('./test/', /mytests.json/)).to.not.include('mytest.json');
+ expect(smartfile.fs.listFilesSync('./test/testassets/')).to.include('mytest.json');
+ expect(smartfile.fs.listFilesSync('./test/testassets/')).to.not.include('notExistentFile');
+ expect(smartfile.fs.listFilesSync('./test/testassets/', /mytest\.json/)).to.include('mytest.json');
+ expect(smartfile.fs.listFilesSync('./test/testassets/', /mytests.json/)).to.not.include('mytest.json');
});
tap.test('.fs.listFiles() -> should get the file type from a string', async () => {
- let folderArrayArg = await smartfile.fs.listFiles('./test/');
+ let folderArrayArg = await smartfile.fs.listFiles('./test/testassets/');
expect(folderArrayArg).to.include('mytest.json');
expect(folderArrayArg).to.not.include('notExistentFile');
});
tap.test('.fs.listFileTree() -> should get a file tree', async () => {
- let folderArrayArg = await smartfile.fs.listFileTree(path.resolve('./test/'), '**/*.txt');
+ let folderArrayArg = await smartfile.fs.listFileTree(path.resolve('./test/testassets/'), '**/*.txt');
expect(folderArrayArg).to.include('testfolder/testfile1.txt');
expect(folderArrayArg).to.not.include('mytest.json');
});
tap.test('.fs.fileTreeToObject -> should read a file tree into an Object', async () => {
- let fileArrayArg = await smartfile.fs.fileTreeToObject(path.resolve('./test/'), '**/*.txt');
+ let fileArrayArg = await smartfile.fs.fileTreeToObject(path.resolve('./test/testassets/'), '**/*.txt');
expect(fileArrayArg[0]).to.be.instanceof(smartfile.Smartfile);
expect(fileArrayArg[0].contents.toString()).to.equal(fileArrayArg[0].contentBuffer.toString());
});
tap.test('.fs.copy() -> should copy a directory', async () => {
- smartfile.fs.copy('./test/testfolder/', './test/temp/');
+ smartfile.fs.copy('./test/testassets/testfolder/', './test/testassets/temp/');
});
tap.test('.fs.copy() -> should copy a file', async () => {
- smartfile.fs.copy('./test/mytest.yaml', './test/temp/');
+ smartfile.fs.copy('./test/testassets/mytest.yaml', './test/testassets/temp/');
});
tap.test('.fs.copy() -> should copy a file and rename it', async () => {
- smartfile.fs.copy('./test/mytest.yaml', './test/temp/mytestRenamed.yaml');
+ smartfile.fs.copy('./test/testassets/mytest.yaml', './test/testassets/temp/mytestRenamed.yaml');
});
tap.test('.fs.remove() -> should remove an entire directory', async () => {});
tap.test('.fs.remove -> should remove single files', async () => {
- await smartfile.fs.remove('./test/temp/mytestRenamed.yaml');
+ await smartfile.fs.remove('./test/testassets/temp/mytestRenamed.yaml');
});
tap.test('.fs.removeSync -> should remove single files synchronouly', async () => {
- smartfile.fs.removeSync('./test/temp/testfile1.txt');
- expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false;
+ smartfile.fs.removeSync('./test/testassets/temp/testfile1.txt');
+ expect(smartfile.fs.fileExistsSync('./test/testassets/temp/testfile1.txt')).to.be.false;
});
tap.test('.fs.removeMany -> should remove and array of files', async () => {
- smartfile.fs.removeMany(['./test/temp/testfile1.txt', './test/temp/testfile2.txt']).then(() => {
- expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false;
- expect(smartfile.fs.fileExistsSync('./test/temp/testfile2.txt')).to.be.false;
+ smartfile.fs.removeMany(['./test/testassets/temp/testfile1.txt', './test/testassets/temp/testfile2.txt']).then(() => {
+ expect(smartfile.fs.fileExistsSync('./test/testassets/temp/testfile1.txt')).to.be.false;
+ expect(smartfile.fs.fileExistsSync('./test/testassets/temp/testfile2.txt')).to.be.false;
});
});
tap.test('.fs.removeManySync -> should remove and array of single files synchronouly', async () => {
- smartfile.fs.removeManySync(['./test/temp/testfile1.txt', './test/temp/testfile2.txt']);
- expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false;
- expect(smartfile.fs.fileExistsSync('./test/temp/testfile2.txt')).to.be.false;
+ smartfile.fs.removeManySync(['./test/testassets/temp/testfile1.txt', './test/testassets/temp/testfile2.txt']);
+ expect(smartfile.fs.fileExistsSync('./test/testassets/temp/testfile1.txt')).to.be.false;
+ expect(smartfile.fs.fileExistsSync('./test/testassets/temp/testfile2.txt')).to.be.false;
});
tap.test('.fs.toObjectSync() -> should read an ' + '.yaml' + ' file to an object', async () => {
- let testData = smartfile.fs.toObjectSync('./test/mytest.yaml');
+ let testData = smartfile.fs.toObjectSync('./test/testassets/mytest.yaml');
expect(testData).to.include({ key1: 'this works' });
expect(testData).to.include({ key2: 'this works too' });
});
tap.test(
'.fs.toObjectSync() -> should state unknown file type for unknown file types',
async () => {
- let testData = smartfile.fs.toObjectSync('./test/mytest.txt');
+ let testData = smartfile.fs.toObjectSync('./test/testassets/mytest.txt');
}
);
tap.test('.fs.toObjectSync() -> should read an ' + '.json' + ' file to an object', async () => {
- let testData = smartfile.fs.toObjectSync('./test/mytest.json');
+ let testData = smartfile.fs.toObjectSync('./test/testassets/mytest.json');
expect(testData).to.include({ key1: 'this works' });
expect(testData).to.include({ key2: 'this works too' });
});
tap.test('.fs.toStringSync() -> should read a file to a string', async () => {
- expect(smartfile.fs.toStringSync('./test/mytest.txt')).to.equal('Some TestString &&%$');
+ expect(smartfile.fs.toStringSync('./test/testassets/mytest.txt')).to.equal('Some TestString &&%$');
});
// ---------------------------
@@ -130,7 +130,7 @@ tap.test('.interpreter.filetype() -> should get the file type from a string', as
tap.test('.memory.toFs() -> should write a file to disk and return a promise', async () => {
let localString = 'myString';
- await smartfile.memory.toFs(localString, path.join(process.cwd(), './test/temp/testMemToFs.txt'));
+ await smartfile.memory.toFs(localString, path.join(process.cwd(), './test/testassets/temp/testMemToFs.txt'));
});
tap.test(
@@ -139,7 +139,7 @@ tap.test(
let localString = 'myString';
smartfile.memory.toFsSync(
localString,
- path.join(process.cwd(), './test/temp/testMemToFsSync.txt')
+ path.join(process.cwd(), './test/testassets/temp/testMemToFsSync.txt')
);
}
);
@@ -165,7 +165,7 @@ tap.test('.remote.toString() -> should reject a Promise when the link is false',
// ---------------------------
tap.test('.Smartfile -> should produce vinyl compatible files', async () => {
- let smartfileArray = await smartfile.fs.fileTreeToObject(process.cwd(), './test/testfolder/**/*');
+ let smartfileArray = await smartfile.fs.fileTreeToObject(process.cwd(), './test/testassets/testfolder/**/*');
let localSmartfile = smartfileArray[0];
expect(localSmartfile).to.be.instanceof(smartfile.Smartfile);
expect(localSmartfile.contents).to.be.instanceof(Buffer);
@@ -178,7 +178,7 @@ tap.test('.Smartfile -> should produce vinyl compatible files', async () => {
});
tap.test('should output a smartfile array to disk', async () => {
- let smartfileArray = await smartfile.fs.fileTreeToObject('./test/testfolder/', '*');
+ let smartfileArray = await smartfile.fs.fileTreeToObject('./test/testassets/testfolder/', '*');
for (let smartfile of smartfileArray) {
console.log(smartfile.relative);
console.log(smartfile.path);
@@ -187,7 +187,7 @@ tap.test('should output a smartfile array to disk', async () => {
}
await smartfile.memory.smartfileArrayToFs(
smartfileArray,
- path.resolve('./test/temp/testoutput/')
+ path.resolve('./test/testassets/temp/testoutput/')
);
});
diff --git a/test/mytest.json b/test/testassets/mytest.json
similarity index 100%
rename from test/mytest.json
rename to test/testassets/mytest.json
diff --git a/test/mytest.txt b/test/testassets/mytest.txt
similarity index 100%
rename from test/mytest.txt
rename to test/testassets/mytest.txt
diff --git a/test/mytest.yaml b/test/testassets/mytest.yaml
similarity index 100%
rename from test/mytest.yaml
rename to test/testassets/mytest.yaml
diff --git a/test/testfolder/subfolder/deepsubfolder/deepsubtestfile.txt b/test/testassets/temp/subfolder/deepsubfolder/deepsubtestfile.txt
similarity index 100%
rename from test/testfolder/subfolder/deepsubfolder/deepsubtestfile.txt
rename to test/testassets/temp/subfolder/deepsubfolder/deepsubtestfile.txt
diff --git a/test/testfolder/subfolder/subtestfile.txt b/test/testassets/temp/subfolder/subtestfile.txt
similarity index 100%
rename from test/testfolder/subfolder/subtestfile.txt
rename to test/testassets/temp/subfolder/subtestfile.txt
diff --git a/test/testassets/temp/testMemToFs.txt b/test/testassets/temp/testMemToFs.txt
new file mode 100644
index 0000000..68ef103
--- /dev/null
+++ b/test/testassets/temp/testMemToFs.txt
@@ -0,0 +1 @@
+myString
\ No newline at end of file
diff --git a/test/testassets/temp/testMemToFsSync.txt b/test/testassets/temp/testMemToFsSync.txt
new file mode 100644
index 0000000..68ef103
--- /dev/null
+++ b/test/testassets/temp/testMemToFsSync.txt
@@ -0,0 +1 @@
+myString
\ No newline at end of file
diff --git a/test/testfolder/testfile1.txt b/test/testassets/temp/testfile1.txt
similarity index 100%
rename from test/testfolder/testfile1.txt
rename to test/testassets/temp/testfile1.txt
diff --git a/test/testfolder/testfile2.txt b/test/testassets/temp/testfile2.txt
similarity index 100%
rename from test/testfolder/testfile2.txt
rename to test/testassets/temp/testfile2.txt
diff --git a/test/testassets/temp/testoutput/testfile1.txt b/test/testassets/temp/testoutput/testfile1.txt
new file mode 100644
index 0000000..e69de29
diff --git a/test/testassets/temp/testoutput/testfile2.txt b/test/testassets/temp/testoutput/testfile2.txt
new file mode 100644
index 0000000..e69de29
diff --git a/test/testassets/testfolder/subfolder/deepsubfolder/deepsubtestfile.txt b/test/testassets/testfolder/subfolder/deepsubfolder/deepsubtestfile.txt
new file mode 100644
index 0000000..c7e5f92
--- /dev/null
+++ b/test/testassets/testfolder/subfolder/deepsubfolder/deepsubtestfile.txt
@@ -0,0 +1 @@
+okidoks
\ No newline at end of file
diff --git a/test/testassets/testfolder/subfolder/subtestfile.txt b/test/testassets/testfolder/subfolder/subtestfile.txt
new file mode 100644
index 0000000..32f95c0
--- /dev/null
+++ b/test/testassets/testfolder/subfolder/subtestfile.txt
@@ -0,0 +1 @@
+hi
\ No newline at end of file
diff --git a/test/testassets/testfolder/testfile1.txt b/test/testassets/testfolder/testfile1.txt
new file mode 100644
index 0000000..e69de29
diff --git a/test/testassets/testfolder/testfile2.txt b/test/testassets/testfolder/testfile2.txt
new file mode 100644
index 0000000..e69de29
diff --git a/ts/smartfile.fs.ts b/ts/smartfile.fs.ts
index 2bcd274..0624dc1 100644
--- a/ts/smartfile.fs.ts
+++ b/ts/smartfile.fs.ts
@@ -210,7 +210,7 @@ export let toStringSync = function(filePath: string): string {
return fileString;
};
-export let fileTreeToObject = async (dirPathArg: string, miniMatchFilter: string) => {
+export const fileTreeToObject = async (dirPathArg: string, miniMatchFilter: string) => {
// handle absolute miniMatchFilter
let dirPath: string;
if (plugins.path.isAbsolute(miniMatchFilter)) {
@@ -219,8 +219,8 @@ export let fileTreeToObject = async (dirPathArg: string, miniMatchFilter: string
dirPath = dirPathArg;
}
- let fileTree = await listFileTree(dirPath, miniMatchFilter);
- let smartfileArray: Smartfile[] = [];
+ const fileTree = await listFileTree(dirPath, miniMatchFilter);
+ const smartfileArray: Smartfile[] = [];
for (let filePath of fileTree) {
let readPath = ((): string => {
if (!plugins.path.isAbsolute(filePath)) {
@@ -234,7 +234,7 @@ export let fileTreeToObject = async (dirPathArg: string, miniMatchFilter: string
// push a read file as Smartfile
smartfileArray.push(
new Smartfile({
- contentBuffer: new Buffer(fileContentString),
+ contentBuffer: Buffer.from(fileContentString),
base: dirPath,
path: filePath
})
@@ -331,7 +331,7 @@ export let listAllItemsSync = (pathArg: string, regexFilter?: RegExp): string[]
* note: if the miniMatch Filter is an absolute path, the cwdArg will be omitted
* @returns Promise string array with the absolute paths of all matching files
*/
-export let listFileTree = (dirPathArg: string, miniMatchFilter: string): Promise => {
+export const listFileTree = async (dirPathArg: string, miniMatchFilter: string, absolutePathsBool: boolean = false): Promise => {
const done = plugins.smartpromise.defer();
// handle absolute miniMatchFilter
@@ -354,5 +354,13 @@ export let listFileTree = (dirPathArg: string, miniMatchFilter: string): Promise
}
done.resolve(files);
});
- return done.promise;
+
+ let fileList = await done.promise;
+ if (absolutePathsBool) {
+ fileList = fileList.map(filePath => {
+ return plugins.path.resolve(plugins.path.join(dirPath, filePath));
+ });
+ }
+
+ return fileList;
};