scss-bundle
Advanced tools
Comparing version 2.0.1-beta.7 to 2.1.0
@@ -23,5 +23,6 @@ export interface FileRegistry { | ||
BundleAll(files: string[], dedupeGlobs: string[]): Promise<BundleResult[]>; | ||
Bundle(file: string, dedupeGlobs?: string[]): Promise<BundleResult>; | ||
private bundle(filePath, content, dedupeFiles); | ||
Bundle(file: string, dedupeGlobs?: string[], includePaths?: string[]): Promise<BundleResult>; | ||
private bundle(filePath, content, dedupeFiles, includePaths); | ||
private resolveImport(importData, includePaths); | ||
private globFilesOrEmpty(globsList); | ||
} |
@@ -6,2 +6,3 @@ export interface Config { | ||
DedupeGlobs?: string[]; | ||
IncludePaths?: string[]; | ||
} | ||
@@ -19,2 +20,3 @@ export declare enum Verbosity { | ||
dedupe?: string[]; | ||
includePaths?: string[]; | ||
} |
@@ -36,2 +36,6 @@ "use strict"; | ||
}) | ||
.options("includePaths", { | ||
describe: "Include paths for resolving imports.", | ||
type: "array" | ||
}) | ||
.array(DEDUPE_KEY) | ||
@@ -42,2 +46,2 @@ .default(DEDUPE_KEY, [], "[]") | ||
.argv; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJndW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FyZ3VtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLCtCQUErQjtBQUUvQix5Q0FBeUM7QUFFekMsSUFBSSxlQUFlLEdBQWEsRUFBRSxDQUFDO0FBQ25DLEdBQUcsQ0FBQyxDQUFDLElBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ2xDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDO0FBRWpCLFFBQUEsSUFBSSxHQUFHLEtBQUs7S0FDbEIsSUFBSSxDQUFDLEdBQUcsRUFBRSxZQUFZLENBQUM7S0FDdkIsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUM7S0FDbEIsT0FBTyxDQUFDO0lBQ0wsTUFBTSxDQUFDLG9CQUFvQixPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxPQUFPLEdBQUcsQ0FBQztBQUNyRSxDQUFDLENBQUM7S0FDRCxLQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQztLQUNyQixNQUFNLENBQUMsUUFBUSxDQUFDO0tBQ2hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDO0tBQ3BCLE9BQU8sQ0FBQyxHQUFHLEVBQUU7SUFDVixLQUFLLEVBQUUsT0FBTztJQUNkLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsR0FBRyxFQUFFO0lBQ1YsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsMkJBQTJCO0lBQ3JDLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsV0FBVyxFQUFFO0lBQ2xCLFFBQVEsRUFBRSxzQkFBc0I7SUFDaEMsT0FBTyxFQUFFLGVBQWU7SUFDeEIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7Q0FDNUQsQ0FBQztLQUNELEtBQUssQ0FBQyxVQUFVLENBQUM7S0FDakIsT0FBTyxDQUFDLFVBQVUsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDO0tBQzdCLEtBQUssQ0FBQyw4QkFBOEIsQ0FBQztLQUNyQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0tBQ3ZCLElBQWlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB5YXJncyBmcm9tIFwieWFyZ3NcIjtcclxuXHJcbmltcG9ydCAqIGFzIENvbnRyYWN0cyBmcm9tIFwiLi9jb250cmFjdHNcIjtcclxuXHJcbmxldCB2ZXJib3NpdHlWYWx1ZXM6IHN0cmluZ1tdID0gW107XHJcbmZvciAobGV0IGtleSBpbiBDb250cmFjdHMuVmVyYm9zaXR5KSB7XHJcbiAgICBpZiAoTnVtYmVyKGtleSkgJSAxICE9PSAwKSB7XHJcbiAgICAgICAgdmVyYm9zaXR5VmFsdWVzLnB1c2goa2V5KTtcclxuICAgIH1cclxufVxyXG5cclxuY29uc3QgREVEVVBFX0tFWSA9IFwiZGVkdXBlXCI7XHJcblxyXG5leHBvcnQgbGV0IGFyZ3YgPSB5YXJnc1xyXG4gICAgLmhlbHAoXCJoXCIsIFwiU2hvdyBoZWxwLlwiKVxyXG4gICAgLmFsaWFzKFwiaFwiLCBcImhlbHBcIilcclxuICAgIC52ZXJzaW9uKCgpID0+IHtcclxuICAgICAgICByZXR1cm4gYEN1cnJlbnQgdmVyc2lvbjogJHtyZXF1aXJlKFwiLi4vcGFja2FnZS5qc29uXCIpLnZlcnNpb259LmA7XHJcbiAgICB9KVxyXG4gICAgLmFsaWFzKFwidlwiLCBcInZlcnNpb25cIilcclxuICAgIC5jb25maWcoXCJjb25maWdcIilcclxuICAgIC5hbGlhcyhcImNcIiwgXCJjb25maWdcIilcclxuICAgIC5vcHRpb25zKFwiZVwiLCB7XHJcbiAgICAgICAgYWxpYXM6IFwiZW50cnlcIixcclxuICAgICAgICBkZXNjcmliZTogXCJFbnRyeSBmaWxlLlwiLFxyXG4gICAgICAgIHR5cGU6IFwic3RyaW5nXCJcclxuICAgIH0pXHJcbiAgICAub3B0aW9ucyhcImRcIiwge1xyXG4gICAgICAgIGFsaWFzOiBcImRlc3RcIixcclxuICAgICAgICBkZXNjcmliZTogXCJCdW5kbGVkIGZpbGUgZGVzdGluYXRpb24uXCIsXHJcbiAgICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwidmVyYm9zaXR5XCIsIHtcclxuICAgICAgICBkZXNjcmliZTogXCJWZXJib3NpdHkgb2Ygb3V0cHV0LlwiLFxyXG4gICAgICAgIGNob2ljZXM6IHZlcmJvc2l0eVZhbHVlcyxcclxuICAgICAgICBkZWZhdWx0OiBDb250cmFjdHMuVmVyYm9zaXR5W0NvbnRyYWN0cy5WZXJib3NpdHkuVmVyYm9zZV1cclxuICAgIH0pXHJcbiAgICAuYXJyYXkoREVEVVBFX0tFWSlcclxuICAgIC5kZWZhdWx0KERFRFVQRV9LRVksIFtdLCBcIltdXCIpXHJcbiAgICAudXNhZ2UoXCJVc2FnZTogc2Nzcy1idW5kbGUgW29wdGlvbnNdXCIpXHJcbiAgICAuc3RyaW5nKFtcImNcIiwgXCJlXCIsIFwiZFwiXSlcclxuICAgIC5hcmd2IGFzIENvbnRyYWN0cy5Bcmd1bWVudHNWYWx1ZXM7XHJcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJndW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FyZ3VtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLCtCQUErQjtBQUUvQix5Q0FBeUM7QUFFekMsSUFBSSxlQUFlLEdBQWEsRUFBRSxDQUFDO0FBQ25DLEdBQUcsQ0FBQyxDQUFDLElBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ2xDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDO0FBRWpCLFFBQUEsSUFBSSxHQUFHLEtBQUs7S0FDbEIsSUFBSSxDQUFDLEdBQUcsRUFBRSxZQUFZLENBQUM7S0FDdkIsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUM7S0FDbEIsT0FBTyxDQUFDO0lBQ0wsTUFBTSxDQUFDLG9CQUFvQixPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxPQUFPLEdBQUcsQ0FBQztBQUNyRSxDQUFDLENBQUM7S0FDRCxLQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQztLQUNyQixNQUFNLENBQUMsUUFBUSxDQUFDO0tBQ2hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDO0tBQ3BCLE9BQU8sQ0FBQyxHQUFHLEVBQUU7SUFDVixLQUFLLEVBQUUsT0FBTztJQUNkLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsR0FBRyxFQUFFO0lBQ1YsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsMkJBQTJCO0lBQ3JDLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsV0FBVyxFQUFFO0lBQ2xCLFFBQVEsRUFBRSxzQkFBc0I7SUFDaEMsT0FBTyxFQUFFLGVBQWU7SUFDeEIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7Q0FDNUQsQ0FBQztLQUNELE9BQU8sQ0FBQyxjQUFjLEVBQUU7SUFDckIsUUFBUSxFQUFFLHNDQUFzQztJQUNoRCxJQUFJLEVBQUUsT0FBTztDQUNoQixDQUFDO0tBQ0QsS0FBSyxDQUFDLFVBQVUsQ0FBQztLQUNqQixPQUFPLENBQUMsVUFBVSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUM7S0FDN0IsS0FBSyxDQUFDLDhCQUE4QixDQUFDO0tBQ3JDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7S0FDdkIsSUFBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHlhcmdzIGZyb20gXCJ5YXJnc1wiO1xyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5cclxubGV0IHZlcmJvc2l0eVZhbHVlczogc3RyaW5nW10gPSBbXTtcclxuZm9yIChsZXQga2V5IGluIENvbnRyYWN0cy5WZXJib3NpdHkpIHtcclxuICAgIGlmIChOdW1iZXIoa2V5KSAlIDEgIT09IDApIHtcclxuICAgICAgICB2ZXJib3NpdHlWYWx1ZXMucHVzaChrZXkpO1xyXG4gICAgfVxyXG59XHJcblxyXG5jb25zdCBERURVUEVfS0VZID0gXCJkZWR1cGVcIjtcclxuXHJcbmV4cG9ydCBsZXQgYXJndiA9IHlhcmdzXHJcbiAgICAuaGVscChcImhcIiwgXCJTaG93IGhlbHAuXCIpXHJcbiAgICAuYWxpYXMoXCJoXCIsIFwiaGVscFwiKVxyXG4gICAgLnZlcnNpb24oKCkgPT4ge1xyXG4gICAgICAgIHJldHVybiBgQ3VycmVudCB2ZXJzaW9uOiAke3JlcXVpcmUoXCIuLi9wYWNrYWdlLmpzb25cIikudmVyc2lvbn0uYDtcclxuICAgIH0pXHJcbiAgICAuYWxpYXMoXCJ2XCIsIFwidmVyc2lvblwiKVxyXG4gICAgLmNvbmZpZyhcImNvbmZpZ1wiKVxyXG4gICAgLmFsaWFzKFwiY1wiLCBcImNvbmZpZ1wiKVxyXG4gICAgLm9wdGlvbnMoXCJlXCIsIHtcclxuICAgICAgICBhbGlhczogXCJlbnRyeVwiLFxyXG4gICAgICAgIGRlc2NyaWJlOiBcIkVudHJ5IGZpbGUuXCIsXHJcbiAgICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwiZFwiLCB7XHJcbiAgICAgICAgYWxpYXM6IFwiZGVzdFwiLFxyXG4gICAgICAgIGRlc2NyaWJlOiBcIkJ1bmRsZWQgZmlsZSBkZXN0aW5hdGlvbi5cIixcclxuICAgICAgICB0eXBlOiBcInN0cmluZ1wiXHJcbiAgICB9KVxyXG4gICAgLm9wdGlvbnMoXCJ2ZXJib3NpdHlcIiwge1xyXG4gICAgICAgIGRlc2NyaWJlOiBcIlZlcmJvc2l0eSBvZiBvdXRwdXQuXCIsXHJcbiAgICAgICAgY2hvaWNlczogdmVyYm9zaXR5VmFsdWVzLFxyXG4gICAgICAgIGRlZmF1bHQ6IENvbnRyYWN0cy5WZXJib3NpdHlbQ29udHJhY3RzLlZlcmJvc2l0eS5WZXJib3NlXVxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwiaW5jbHVkZVBhdGhzXCIsIHtcclxuICAgICAgICBkZXNjcmliZTogXCJJbmNsdWRlIHBhdGhzIGZvciByZXNvbHZpbmcgaW1wb3J0cy5cIixcclxuICAgICAgICB0eXBlOiBcImFycmF5XCJcclxuICAgIH0pXHJcbiAgICAuYXJyYXkoREVEVVBFX0tFWSlcclxuICAgIC5kZWZhdWx0KERFRFVQRV9LRVksIFtdLCBcIltdXCIpXHJcbiAgICAudXNhZ2UoXCJVc2FnZTogc2Nzcy1idW5kbGUgW29wdGlvbnNdXCIpXHJcbiAgICAuc3RyaW5nKFtcImNcIiwgXCJlXCIsIFwiZFwiXSlcclxuICAgIC5hcmd2IGFzIENvbnRyYWN0cy5Bcmd1bWVudHNWYWx1ZXM7XHJcbiJdfQ== |
@@ -29,3 +29,4 @@ #!/usr/bin/env node | ||
DedupeGlobs: argumentValues.dedupe, | ||
Verbosity: this.resolveVerbosity(argumentValues.verbosity) | ||
Verbosity: this.resolveVerbosity(argumentValues.verbosity), | ||
IncludePaths: argumentValues.includePaths | ||
}; | ||
@@ -41,2 +42,2 @@ } | ||
new BundleCli(arguments_1.argv); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVuZGxlLWNsaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9idW5kbGUtY2xpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUEseUNBQXlDO0FBQ3pDLDJDQUFtQztBQUNuQyx5Q0FBc0M7QUFFdEM7SUFDSSxZQUFZLGNBQXlDO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVhLE1BQU0sQ0FBQyxjQUF5Qzs7WUFDMUQsTUFBTSxJQUFJLG1CQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hFLENBQUM7S0FBQTtJQUVPLFNBQVMsQ0FBQyxjQUF5QztRQUN2RCxNQUFNLENBQUM7WUFDSCxXQUFXLEVBQUUsY0FBYyxDQUFDLElBQUk7WUFDaEMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxLQUFLO1lBQzNCLFdBQVcsRUFBRSxjQUFjLENBQUMsTUFBTTtZQUNsQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUM7U0FDN0QsQ0FBQztJQUNOLENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxTQUFjO1FBQ25DLDhEQUE4RDtRQUM5RCx1REFBdUQ7UUFDdkQsb0VBQW9FO1FBQ3BFLE1BQU0sQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBa0IsQ0FBQztJQUMzRCxDQUFDO0NBQ0o7QUFFRCxJQUFJLFNBQVMsQ0FBQyxnQkFBSSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXHJcblxyXG5pbXBvcnQgKiBhcyBDb250cmFjdHMgZnJvbSBcIi4vY29udHJhY3RzXCI7XHJcbmltcG9ydCB7IGFyZ3YgfSBmcm9tIFwiLi9hcmd1bWVudHNcIjtcclxuaW1wb3J0IHsgTGF1bmNoZXIgfSBmcm9tIFwiLi9sYXVuY2hlclwiO1xyXG5cclxuY2xhc3MgQnVuZGxlQ2xpIHtcclxuICAgIGNvbnN0cnVjdG9yKGFyZ3VtZW50VmFsdWVzOiBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzKSB7XHJcbiAgICAgICAgdGhpcy5idW5kbGUoYXJndW1lbnRWYWx1ZXMpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgYXN5bmMgYnVuZGxlKGFyZ3VtZW50VmFsdWVzOiBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzKSB7XHJcbiAgICAgICAgYXdhaXQgbmV3IExhdW5jaGVyKHRoaXMuZ2V0Q29uZmlnKGFyZ3VtZW50VmFsdWVzKSkuQnVuZGxlKCk7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBnZXRDb25maWcoYXJndW1lbnRWYWx1ZXM6IENvbnRyYWN0cy5Bcmd1bWVudHNWYWx1ZXMpOiBDb250cmFjdHMuQ29uZmlnIHtcclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBEZXN0aW5hdGlvbjogYXJndW1lbnRWYWx1ZXMuZGVzdCxcclxuICAgICAgICAgICAgRW50cnk6IGFyZ3VtZW50VmFsdWVzLmVudHJ5LFxyXG4gICAgICAgICAgICBEZWR1cGVHbG9iczogYXJndW1lbnRWYWx1ZXMuZGVkdXBlLFxyXG4gICAgICAgICAgICBWZXJib3NpdHk6IHRoaXMucmVzb2x2ZVZlcmJvc2l0eShhcmd1bWVudFZhbHVlcy52ZXJib3NpdHkpXHJcbiAgICAgICAgfTtcclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIHJlc29sdmVWZXJib3NpdHkodmVyYm9zaXR5OiBhbnkpOiBudW1iZXIge1xyXG4gICAgICAgIC8vIENvbnZlcnQgZ2l2ZW4gdmFsdWUgdG8gYW4gYXBwcm9wcmlhdGUgVmVyYm9zaXR5IGVudW0gdmFsdWUuXHJcbiAgICAgICAgLy8gJ2FzIGFueSBhcyBudW1iZXInIGlzIHVzZWQgYmVjYXVzZSBUeXBlU2NyaXB0IHRoaW5rc1xyXG4gICAgICAgIC8vICB0aGF0IHdlIGNhc3Qgc3RyaW5nIHRvIG51bWJlciwgZXZlbiB0aG91Z2ggd2UgZ2V0IGEgbnVtYmVyIHRoZXJlXHJcbiAgICAgICAgcmV0dXJuIENvbnRyYWN0cy5WZXJib3NpdHlbdmVyYm9zaXR5XSBhcyBhbnkgYXMgbnVtYmVyO1xyXG4gICAgfVxyXG59XHJcblxyXG5uZXcgQnVuZGxlQ2xpKGFyZ3YpO1xyXG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVuZGxlLWNsaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9idW5kbGUtY2xpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUEseUNBQXlDO0FBQ3pDLDJDQUFtQztBQUNuQyx5Q0FBc0M7QUFFdEM7SUFDSSxZQUFZLGNBQXlDO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVhLE1BQU0sQ0FBQyxjQUF5Qzs7WUFDMUQsTUFBTSxJQUFJLG1CQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hFLENBQUM7S0FBQTtJQUVPLFNBQVMsQ0FBQyxjQUF5QztRQUN2RCxNQUFNLENBQUM7WUFDSCxXQUFXLEVBQUUsY0FBYyxDQUFDLElBQUk7WUFDaEMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxLQUFLO1lBQzNCLFdBQVcsRUFBRSxjQUFjLENBQUMsTUFBTTtZQUNsQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUM7WUFDMUQsWUFBWSxFQUFFLGNBQWMsQ0FBQyxZQUFZO1NBQzVDLENBQUM7SUFDTixDQUFDO0lBRU8sZ0JBQWdCLENBQUMsU0FBYztRQUNuQyw4REFBOEQ7UUFDOUQsdURBQXVEO1FBQ3ZELG9FQUFvRTtRQUNwRSxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQWtCLENBQUM7SUFDM0QsQ0FBQztDQUNKO0FBRUQsSUFBSSxTQUFTLENBQUMsZ0JBQUksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgbm9kZVxyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5pbXBvcnQgeyBhcmd2IH0gZnJvbSBcIi4vYXJndW1lbnRzXCI7XHJcbmltcG9ydCB7IExhdW5jaGVyIH0gZnJvbSBcIi4vbGF1bmNoZXJcIjtcclxuXHJcbmNsYXNzIEJ1bmRsZUNsaSB7XHJcbiAgICBjb25zdHJ1Y3Rvcihhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcykge1xyXG4gICAgICAgIHRoaXMuYnVuZGxlKGFyZ3VtZW50VmFsdWVzKTtcclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIGFzeW5jIGJ1bmRsZShhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcykge1xyXG4gICAgICAgIGF3YWl0IG5ldyBMYXVuY2hlcih0aGlzLmdldENvbmZpZyhhcmd1bWVudFZhbHVlcykpLkJ1bmRsZSgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgZ2V0Q29uZmlnKGFyZ3VtZW50VmFsdWVzOiBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzKTogQ29udHJhY3RzLkNvbmZpZyB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgRGVzdGluYXRpb246IGFyZ3VtZW50VmFsdWVzLmRlc3QsXHJcbiAgICAgICAgICAgIEVudHJ5OiBhcmd1bWVudFZhbHVlcy5lbnRyeSxcclxuICAgICAgICAgICAgRGVkdXBlR2xvYnM6IGFyZ3VtZW50VmFsdWVzLmRlZHVwZSxcclxuICAgICAgICAgICAgVmVyYm9zaXR5OiB0aGlzLnJlc29sdmVWZXJib3NpdHkoYXJndW1lbnRWYWx1ZXMudmVyYm9zaXR5KSxcclxuICAgICAgICAgICAgSW5jbHVkZVBhdGhzOiBhcmd1bWVudFZhbHVlcy5pbmNsdWRlUGF0aHNcclxuICAgICAgICB9O1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcmVzb2x2ZVZlcmJvc2l0eSh2ZXJib3NpdHk6IGFueSk6IG51bWJlciB7XHJcbiAgICAgICAgLy8gQ29udmVydCBnaXZlbiB2YWx1ZSB0byBhbiBhcHByb3ByaWF0ZSBWZXJib3NpdHkgZW51bSB2YWx1ZS5cclxuICAgICAgICAvLyAnYXMgYW55IGFzIG51bWJlcicgaXMgdXNlZCBiZWNhdXNlIFR5cGVTY3JpcHQgdGhpbmtzXHJcbiAgICAgICAgLy8gIHRoYXQgd2UgY2FzdCBzdHJpbmcgdG8gbnVtYmVyLCBldmVuIHRob3VnaCB3ZSBnZXQgYSBudW1iZXIgdGhlcmVcclxuICAgICAgICByZXR1cm4gQ29udHJhY3RzLlZlcmJvc2l0eVt2ZXJib3NpdHldIGFzIGFueSBhcyBudW1iZXI7XHJcbiAgICB9XHJcbn1cclxuXHJcbm5ldyBCdW5kbGVDbGkoYXJndik7XHJcbiJdfQ== |
@@ -33,3 +33,3 @@ "use strict"; | ||
} | ||
Bundle(file, dedupeGlobs = []) { | ||
Bundle(file, dedupeGlobs = [], includePaths = []) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
@@ -42,3 +42,3 @@ try { | ||
const [content, dedupeFiles] = yield Promise.all([contentPromise, dedupeFilesPromise]); | ||
return yield this.bundle(file, content, dedupeFiles); | ||
return yield this.bundle(file, content, dedupeFiles, includePaths); | ||
} | ||
@@ -53,3 +53,3 @@ catch (error) { | ||
} | ||
bundle(filePath, content, dedupeFiles) { | ||
bundle(filePath, content, dedupeFiles, includePaths) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
@@ -78,20 +78,3 @@ // Remove commented imports | ||
}; | ||
try { | ||
yield fs.access(fullPath); | ||
importData.found = true; | ||
} | ||
catch (error) { | ||
const underscoredDirname = path.dirname(fullPath); | ||
const underscoredBasename = path.basename(fullPath); | ||
const underscoredFilePath = path.join(underscoredDirname, `_${underscoredBasename}`); | ||
try { | ||
yield fs.access(underscoredFilePath); | ||
importData.fullPath = underscoredFilePath; | ||
importData.found = true; | ||
} | ||
catch (underscoreErr) { | ||
// Neither file, nor partial was found | ||
// Skipping... | ||
} | ||
} | ||
yield this.resolveImport(importData, includePaths); | ||
return importData; | ||
@@ -124,3 +107,3 @@ })); | ||
// and bundle it | ||
let bundledImport = yield this.bundle(imp.fullPath, impContent, dedupeFiles); | ||
let bundledImport = yield this.bundle(imp.fullPath, impContent, dedupeFiles, includePaths); | ||
// Then add its bundled content to the registry | ||
@@ -187,2 +170,31 @@ this.fileRegistry[imp.fullPath] = bundledImport.bundledContent; | ||
} | ||
resolveImport(importData, includePaths) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
try { | ||
yield fs.access(importData.fullPath); | ||
importData.found = true; | ||
} | ||
catch (error) { | ||
const underscoredDirname = path.dirname(importData.fullPath); | ||
const underscoredBasename = path.basename(importData.fullPath); | ||
const underscoredFilePath = path.join(underscoredDirname, `_${underscoredBasename}`); | ||
try { | ||
yield fs.access(underscoredFilePath); | ||
importData.fullPath = underscoredFilePath; | ||
importData.found = true; | ||
} | ||
catch (underscoreErr) { | ||
// If there are any includePaths | ||
if (includePaths.length) { | ||
// Resolve fullPath using its first entry | ||
importData.fullPath = path.resolve(includePaths[0], importData.path); | ||
// Try resolving import with the remaining includePaths | ||
const remainingIncludePaths = includePaths.slice(1); | ||
return this.resolveImport(importData, remainingIncludePaths); | ||
} | ||
} | ||
} | ||
return importData; | ||
}); | ||
} | ||
globFilesOrEmpty(globsList) { | ||
@@ -210,2 +222,2 @@ return __awaiter(this, void 0, void 0, function* () { | ||
exports.Bundler = Bundler; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from \"mz/fs\";\r\nimport * as os from \"os\";\r\nimport * as path from \"path\";\r\nimport * as globs from \"globs\";\r\n\r\nimport * as Helpers from \"./helpers\";\r\n\r\nconst IMPORT_PATTERN = /@import ['\"](.+)['\"];/g;\r\nconst COMMENTED_IMPORT_PATTERN = /\\/\\/@import '(.+)';/g;\r\nconst FILE_EXTENSION = \".scss\";\r\n\r\nexport interface FileRegistry {\r\n    [id: string]: string | undefined;\r\n}\r\n\r\nexport interface ImportData {\r\n    importString: string;\r\n    path: string;\r\n    fullPath: string;\r\n    found: boolean;\r\n}\r\n\r\nexport interface BundleResult {\r\n    // Child imports (if any)\r\n    imports?: BundleResult[];\r\n    deduped?: boolean;\r\n    // Full path of the file\r\n    filePath: string;\r\n    bundledContent?: string;\r\n    found: boolean;\r\n}\r\n\r\nexport class Bundler {\r\n    // Full paths of used imports and their count\r\n    private usedImports: { [key: string]: number } = {};\r\n    // Imports dictionary by file\r\n    private importsByFile: { [key: string]: BundleResult[] } = {};\r\n\r\n    constructor(private fileRegistry: FileRegistry = {}) { }\r\n\r\n    public async BundleAll(\r\n        files: string[],\r\n        dedupeGlobs: string[]\r\n    ): Promise<BundleResult[]> {\r\n        const resultsPromises = files.map(file => this.Bundle(file, dedupeGlobs));\r\n        return await Promise.all(resultsPromises);\r\n    }\r\n\r\n    public async Bundle(file: string, dedupeGlobs: string[] = []): Promise<BundleResult> {\r\n        try {\r\n            await fs.access(file);\r\n            const contentPromise = fs.readFile(file, \"utf-8\");\r\n            const dedupeFilesPromise = this.globFilesOrEmpty(dedupeGlobs);\r\n\r\n            // Await all async operations and extract results\r\n            const [content, dedupeFiles] = await Promise.all([contentPromise, dedupeFilesPromise]);\r\n\r\n            return await this.bundle(file, content, dedupeFiles);\r\n        } catch (error) {\r\n            return {\r\n                filePath: file,\r\n                found: false\r\n            };\r\n        }\r\n    }\r\n\r\n    private async bundle(\r\n        filePath: string,\r\n        content: string,\r\n        dedupeFiles: string[]\r\n    ): Promise<BundleResult> {\r\n        // Remove commented imports\r\n        content = content.replace(COMMENTED_IMPORT_PATTERN, \"\");\r\n\r\n        // Resolve path to work only with full paths\r\n        filePath = path.resolve(filePath);\r\n\r\n        const dirname = path.dirname(filePath);\r\n\r\n        if (this.fileRegistry[filePath] == null) {\r\n            this.fileRegistry[filePath] = content;\r\n        }\r\n\r\n        // Resolve imports file names (prepend underscore for partials)\r\n        const importsPromises = Helpers.getAllMatches(content, IMPORT_PATTERN).map(async match => {\r\n            let importName = match[1];\r\n            // Append extension if it's absent\r\n            if (importName.indexOf(FILE_EXTENSION) === -1) {\r\n                importName += FILE_EXTENSION;\r\n            }\r\n            const fullPath = path.resolve(dirname, importName);\r\n\r\n            const importData: ImportData = {\r\n                importString: match[0],\r\n                path: importName,\r\n                fullPath: fullPath,\r\n                found: false\r\n            };\r\n\r\n            try {\r\n                await fs.access(fullPath);\r\n                importData.found = true;\r\n            } catch (error) {\r\n                const underscoredDirname = path.dirname(fullPath);\r\n                const underscoredBasename = path.basename(fullPath);\r\n                const underscoredFilePath = path.join(underscoredDirname, `_${underscoredBasename}`);\r\n                try {\r\n                    await fs.access(underscoredFilePath);\r\n                    importData.fullPath = underscoredFilePath;\r\n                    importData.found = true;\r\n                } catch (underscoreErr) {\r\n                    // Neither file, nor partial was found\r\n                    // Skipping...\r\n                }\r\n            }\r\n\r\n            return importData;\r\n        });\r\n\r\n        // Wait for all imports file names to be resolved\r\n        const imports = await Promise.all(importsPromises);\r\n\r\n        const bundleResult: BundleResult = {\r\n            filePath: filePath,\r\n            found: true\r\n        };\r\n\r\n        const shouldCheckForDedupes = dedupeFiles != null && dedupeFiles.length > 0;\r\n\r\n        // Bundle all imports\r\n        const currentImports: BundleResult[] = [];\r\n        for (const imp of imports) {\r\n            let contentToReplace;\r\n\r\n            let currentImport: BundleResult;\r\n\r\n            // If neither import file, nor partial is found\r\n            if (!imp.found) {\r\n                // Add empty bundle result with found: false\r\n                currentImport = {\r\n                    filePath: imp.fullPath,\r\n                    found: false\r\n                };\r\n            } else if (this.fileRegistry[imp.fullPath] == null) {\r\n                // If file is not yet in the registry\r\n                // Read\r\n                let impContent = await fs.readFile(imp.fullPath, \"utf-8\");\r\n\r\n                // and bundle it\r\n                let bundledImport = await this.bundle(imp.fullPath, impContent, dedupeFiles);\r\n\r\n                // Then add its bundled content to the registry\r\n                this.fileRegistry[imp.fullPath] = bundledImport.bundledContent;\r\n\r\n                // Add it to used imports, if it's not there\r\n                if (this.usedImports != null && this.usedImports[imp.fullPath] == null) {\r\n                    this.usedImports[imp.fullPath] = 1;\r\n                }\r\n\r\n                // And whole BundleResult to current imports\r\n                currentImport = bundledImport;\r\n            } else {\r\n                // File is in the registry\r\n                // Increment it's usage count\r\n                if (this.usedImports != null) {\r\n                    this.usedImports[imp.fullPath]++;\r\n                }\r\n\r\n                // Resolve child imports, if there are any\r\n                let childImports: BundleResult[] = [];\r\n                if (this.importsByFile != null) {\r\n                    childImports = this.importsByFile[imp.fullPath];\r\n                }\r\n\r\n                // Construct and add result to current imports\r\n                currentImport = {\r\n                    filePath: imp.fullPath,\r\n                    found: true,\r\n                    imports: childImports\r\n                };\r\n            }\r\n\r\n            // Take contentToReplace from the fileRegistry\r\n            contentToReplace = this.fileRegistry[imp.fullPath];\r\n\r\n            // If the content is not found\r\n            if (contentToReplace == null) {\r\n                // Indicate this with a comment for easier debugging\r\n                contentToReplace = `/*** IMPORTED FILE NOT FOUND ***/${os.EOL}${imp.importString}/*** --- ***/`;\r\n            }\r\n\r\n            // If usedImports dictionary is defined\r\n            if (shouldCheckForDedupes && this.usedImports != null) {\r\n                // And current import path should be deduped and is used already\r\n                const timesUsed = this.usedImports[imp.fullPath];\r\n                if (dedupeFiles.indexOf(imp.fullPath) !== -1 &&\r\n                    timesUsed != null &&\r\n                    timesUsed > 1) {\r\n                    // Reset content to replace to an empty string to skip it\r\n                    contentToReplace = \"\";\r\n                    // And indicate that import was deduped\r\n                    currentImport.deduped = true;\r\n                }\r\n            }\r\n\r\n            // Finally, replace import string with bundled content or a debug message\r\n            content = content.replace(imp.importString, contentToReplace);\r\n\r\n            // And push current import into the list\r\n            currentImports.push(currentImport);\r\n        }\r\n\r\n        // Set result properties\r\n        bundleResult.bundledContent = content;\r\n        bundleResult.imports = currentImports;\r\n\r\n        if (this.importsByFile != null) {\r\n            this.importsByFile[filePath] = currentImports;\r\n        }\r\n\r\n        return bundleResult;\r\n    }\r\n\r\n    private async globFilesOrEmpty(globsList: string[]) {\r\n        return new Promise<string[]>((resolve, reject) => {\r\n            if (globsList == null || globsList.length === 0) {\r\n                resolve([]);\r\n                return;\r\n            }\r\n            globs(globsList, (err: Error, files: string[]) => {\r\n                // Reject if there's an error\r\n                if (err) {\r\n                    reject(err);\r\n                }\r\n\r\n                // Resolve full paths\r\n                const result = files.map(file => path.resolve(file));\r\n\r\n                // Resolve promise\r\n                resolve(result);\r\n            });\r\n        });\r\n    }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,4BAA4B;AAC5B,yBAAyB;AACzB,6BAA6B;AAC7B,+BAA+B;AAE/B,qCAAqC;AAErC,MAAM,cAAc,GAAG,wBAAwB,CAAC;AAChD,MAAM,wBAAwB,GAAG,sBAAsB,CAAC;AACxD,MAAM,cAAc,GAAG,OAAO,CAAC;AAuB/B;IAMI,YAAoB,eAA6B,EAAE;QAA/B,iBAAY,GAAZ,YAAY,CAAmB;QALnD,6CAA6C;QACrC,gBAAW,GAA8B,EAAE,CAAC;QACpD,6BAA6B;QACrB,kBAAa,GAAsC,EAAE,CAAC;IAEP,CAAC;IAE3C,SAAS,CAClB,KAAe,EACf,WAAqB;;YAErB,MAAM,eAAe,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;YAC1E,MAAM,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC9C,CAAC;KAAA;IAEY,MAAM,CAAC,IAAY,EAAE,cAAwB,EAAE,EAAE,eAAyB,EAAE;;YACrF,IAAI,CAAC;gBACD,MAAM,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;gBACtB,MAAM,cAAc,GAAG,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBAClD,MAAM,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;gBAE9D,iDAAiD;gBACjD,MAAM,CAAC,OAAO,EAAE,WAAW,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,cAAc,EAAE,kBAAkB,CAAC,CAAC,CAAC;gBAEvF,MAAM,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;YACvE,CAAC;YAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBACb,MAAM,CAAC;oBACH,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,KAAK;iBACf,CAAC;YACN,CAAC;QACL,CAAC;KAAA;IAEa,MAAM,CAChB,QAAgB,EAChB,OAAe,EACf,WAAqB,EACrB,YAAsB;;YAEtB,2BAA2B;YAC3B,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,wBAAwB,EAAE,EAAE,CAAC,CAAC;YAExD,4CAA4C;YAC5C,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAEvC,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC;YAC1C,CAAC;YAED,+DAA+D;YAC/D,MAAM,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC,GAAG,CAAC,CAAM,KAAK;gBAClF,IAAI,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;gBAC1B,kCAAkC;gBAClC,EAAE,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC5C,UAAU,IAAI,cAAc,CAAC;gBACjC,CAAC;gBACD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;gBAEnD,MAAM,UAAU,GAAe;oBAC3B,YAAY,EAAE,KAAK,CAAC,CAAC,CAAC;oBACtB,IAAI,EAAE,UAAU;oBAChB,QAAQ,EAAE,QAAQ;oBAClB,KAAK,EAAE,KAAK;iBACf,CAAC;gBAEF,MAAM,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;gBAEnD,MAAM,CAAC,UAAU,CAAC;YACtB,CAAC,CAAA,CAAC,CAAC;YAEH,iDAAiD;YACjD,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAEnD,MAAM,YAAY,GAAiB;gBAC/B,QAAQ,EAAE,QAAQ;gBAClB,KAAK,EAAE,IAAI;aACd,CAAC;YAEF,MAAM,qBAAqB,GAAG,WAAW,IAAI,IAAI,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;YAE5E,qBAAqB;YACrB,MAAM,cAAc,GAAmB,EAAE,CAAC;YAC1C,GAAG,CAAC,CAAC,MAAM,GAAG,IAAI,OAAO,CAAC,CAAC,CAAC;gBACxB,IAAI,gBAAgB,CAAC;gBAErB,IAAI,aAA2B,CAAC;gBAEhC,+CAA+C;gBAC/C,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;oBACb,4CAA4C;oBAC5C,aAAa,GAAG;wBACZ,QAAQ,EAAE,GAAG,CAAC,QAAQ;wBACtB,KAAK,EAAE,KAAK;qBACf,CAAC;gBACN,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;oBACjD,qCAAqC;oBACrC,OAAO;oBACP,IAAI,UAAU,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;oBAE1D,gBAAgB;oBAChB,IAAI,aAAa,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;oBAE3F,+CAA+C;oBAC/C,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,aAAa,CAAC,cAAc,CAAC;oBAE/D,4CAA4C;oBAC5C,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;wBACrE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;oBACvC,CAAC;oBAED,4CAA4C;oBAC5C,aAAa,GAAG,aAAa,CAAC;gBAClC,CAAC;gBAAC,IAAI,CAAC,CAAC;oBACJ,0BAA0B;oBAC1B,6BAA6B;oBAC7B,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC;wBAC3B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACrC,CAAC;oBAED,0CAA0C;oBAC1C,IAAI,YAAY,GAAmB,EAAE,CAAC;oBACtC,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC,CAAC;wBAC7B,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACpD,CAAC;oBAED,8CAA8C;oBAC9C,aAAa,GAAG;wBACZ,QAAQ,EAAE,GAAG,CAAC,QAAQ;wBACtB,KAAK,EAAE,IAAI;wBACX,OAAO,EAAE,YAAY;qBACxB,CAAC;gBACN,CAAC;gBAED,8CAA8C;gBAC9C,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAEnD,8BAA8B;gBAC9B,EAAE,CAAC,CAAC,gBAAgB,IAAI,IAAI,CAAC,CAAC,CAAC;oBAC3B,oDAAoD;oBACpD,gBAAgB,GAAG,oCAAoC,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,YAAY,eAAe,CAAC;gBACpG,CAAC;gBAED,uCAAuC;gBACvC,EAAE,CAAC,CAAC,qBAAqB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC,CAAC;oBACpD,gEAAgE;oBAChE,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACjD,EAAE,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;wBACxC,SAAS,IAAI,IAAI;wBACjB,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC;wBAChB,yDAAyD;wBACzD,gBAAgB,GAAG,EAAE,CAAC;wBACtB,uCAAuC;wBACvC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;oBACjC,CAAC;gBACL,CAAC;gBAED,yEAAyE;gBACzE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAC;gBAE9D,wCAAwC;gBACxC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACvC,CAAC;YAED,wBAAwB;YACxB,YAAY,CAAC,cAAc,GAAG,OAAO,CAAC;YACtC,YAAY,CAAC,OAAO,GAAG,cAAc,CAAC;YAEtC,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,cAAc,CAAC;YAClD,CAAC;YAED,MAAM,CAAC,YAAY,CAAC;QACxB,CAAC;KAAA;IAEa,aAAa,CAAC,UAAU,EAAE,YAAY;;YAChD,IAAI,CAAC;gBACD,MAAM,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;gBACrC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC;YAC5B,CAAC;YAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBACb,MAAM,kBAAkB,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;gBAC7D,MAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;gBAC/D,MAAM,mBAAmB,GAAG,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,mBAAmB,EAAE,CAAC,CAAC;gBACrF,IAAI,CAAC;oBACD,MAAM,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;oBACrC,UAAU,CAAC,QAAQ,GAAG,mBAAmB,CAAC;oBAC1C,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC;gBAC5B,CAAC;gBAAC,KAAK,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC;oBACrB,gCAAgC;oBAChC,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;wBACtB,yCAAyC;wBACzC,UAAU,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;wBACrE,uDAAuD;wBACvD,MAAM,qBAAqB,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;wBACpD,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,qBAAqB,CAAC,CAAC;oBACjE,CAAC;gBACL,CAAC;YACL,CAAC;YAED,MAAM,CAAC,UAAU,CAAC;QACtB,CAAC;KAAA;IAEa,gBAAgB,CAAC,SAAmB;;YAC9C,MAAM,CAAC,IAAI,OAAO,CAAW,CAAC,OAAO,EAAE,MAAM;gBACzC,EAAE,CAAC,CAAC,SAAS,IAAI,IAAI,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;oBAC9C,OAAO,CAAC,EAAE,CAAC,CAAC;oBACZ,MAAM,CAAC;gBACX,CAAC;gBACD,KAAK,CAAC,SAAS,EAAE,CAAC,GAAU,EAAE,KAAe;oBACzC,6BAA6B;oBAC7B,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;wBACN,MAAM,CAAC,GAAG,CAAC,CAAC;oBAChB,CAAC;oBAED,qBAAqB;oBACrB,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;oBAErD,kBAAkB;oBAClB,OAAO,CAAC,MAAM,CAAC,CAAC;gBACpB,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC;KAAA;CACJ;AAhOD,0BAgOC","sourcesContent":["import * as fs from \"mz/fs\";\r\nimport * as os from \"os\";\r\nimport * as path from \"path\";\r\nimport * as globs from \"globs\";\r\n\r\nimport * as Helpers from \"./helpers\";\r\n\r\nconst IMPORT_PATTERN = /@import ['\"](.+)['\"];/g;\r\nconst COMMENTED_IMPORT_PATTERN = /\\/\\/@import '(.+)';/g;\r\nconst FILE_EXTENSION = \".scss\";\r\n\r\nexport interface FileRegistry {\r\n    [id: string]: string | undefined;\r\n}\r\n\r\nexport interface ImportData {\r\n    importString: string;\r\n    path: string;\r\n    fullPath: string;\r\n    found: boolean;\r\n}\r\n\r\nexport interface BundleResult {\r\n    // Child imports (if any)\r\n    imports?: BundleResult[];\r\n    deduped?: boolean;\r\n    // Full path of the file\r\n    filePath: string;\r\n    bundledContent?: string;\r\n    found: boolean;\r\n}\r\n\r\nexport class Bundler {\r\n    // Full paths of used imports and their count\r\n    private usedImports: { [key: string]: number } = {};\r\n    // Imports dictionary by file\r\n    private importsByFile: { [key: string]: BundleResult[] } = {};\r\n\r\n    constructor(private fileRegistry: FileRegistry = {}) { }\r\n\r\n    public async BundleAll(\r\n        files: string[],\r\n        dedupeGlobs: string[]\r\n    ): Promise<BundleResult[]> {\r\n        const resultsPromises = files.map(file => this.Bundle(file, dedupeGlobs));\r\n        return await Promise.all(resultsPromises);\r\n    }\r\n\r\n    public async Bundle(file: string, dedupeGlobs: string[] = [], includePaths: string[] = []): Promise<BundleResult> {\r\n        try {\r\n            await fs.access(file);\r\n            const contentPromise = fs.readFile(file, \"utf-8\");\r\n            const dedupeFilesPromise = this.globFilesOrEmpty(dedupeGlobs);\r\n\r\n            // Await all async operations and extract results\r\n            const [content, dedupeFiles] = await Promise.all([contentPromise, dedupeFilesPromise]);\r\n\r\n            return await this.bundle(file, content, dedupeFiles, includePaths);\r\n        } catch (error) {\r\n            return {\r\n                filePath: file,\r\n                found: false\r\n            };\r\n        }\r\n    }\r\n\r\n    private async bundle(\r\n        filePath: string,\r\n        content: string,\r\n        dedupeFiles: string[],\r\n        includePaths: string[]\r\n    ): Promise<BundleResult> {\r\n        // Remove commented imports\r\n        content = content.replace(COMMENTED_IMPORT_PATTERN, \"\");\r\n\r\n        // Resolve path to work only with full paths\r\n        filePath = path.resolve(filePath);\r\n\r\n        const dirname = path.dirname(filePath);\r\n\r\n        if (this.fileRegistry[filePath] == null) {\r\n            this.fileRegistry[filePath] = content;\r\n        }\r\n\r\n        // Resolve imports file names (prepend underscore for partials)\r\n        const importsPromises = Helpers.getAllMatches(content, IMPORT_PATTERN).map(async match => {\r\n            let importName = match[1];\r\n            // Append extension if it's absent\r\n            if (importName.indexOf(FILE_EXTENSION) === -1) {\r\n                importName += FILE_EXTENSION;\r\n            }\r\n            const fullPath = path.resolve(dirname, importName);\r\n\r\n            const importData: ImportData = {\r\n                importString: match[0],\r\n                path: importName,\r\n                fullPath: fullPath,\r\n                found: false\r\n            };\r\n\r\n            await this.resolveImport(importData, includePaths);\r\n\r\n            return importData;\r\n        });\r\n\r\n        // Wait for all imports file names to be resolved\r\n        const imports = await Promise.all(importsPromises);\r\n\r\n        const bundleResult: BundleResult = {\r\n            filePath: filePath,\r\n            found: true\r\n        };\r\n\r\n        const shouldCheckForDedupes = dedupeFiles != null && dedupeFiles.length > 0;\r\n\r\n        // Bundle all imports\r\n        const currentImports: BundleResult[] = [];\r\n        for (const imp of imports) {\r\n            let contentToReplace;\r\n\r\n            let currentImport: BundleResult;\r\n\r\n            // If neither import file, nor partial is found\r\n            if (!imp.found) {\r\n                // Add empty bundle result with found: false\r\n                currentImport = {\r\n                    filePath: imp.fullPath,\r\n                    found: false\r\n                };\r\n            } else if (this.fileRegistry[imp.fullPath] == null) {\r\n                // If file is not yet in the registry\r\n                // Read\r\n                let impContent = await fs.readFile(imp.fullPath, \"utf-8\");\r\n\r\n                // and bundle it\r\n                let bundledImport = await this.bundle(imp.fullPath, impContent, dedupeFiles, includePaths);\r\n\r\n                // Then add its bundled content to the registry\r\n                this.fileRegistry[imp.fullPath] = bundledImport.bundledContent;\r\n\r\n                // Add it to used imports, if it's not there\r\n                if (this.usedImports != null && this.usedImports[imp.fullPath] == null) {\r\n                    this.usedImports[imp.fullPath] = 1;\r\n                }\r\n\r\n                // And whole BundleResult to current imports\r\n                currentImport = bundledImport;\r\n            } else {\r\n                // File is in the registry\r\n                // Increment it's usage count\r\n                if (this.usedImports != null) {\r\n                    this.usedImports[imp.fullPath]++;\r\n                }\r\n\r\n                // Resolve child imports, if there are any\r\n                let childImports: BundleResult[] = [];\r\n                if (this.importsByFile != null) {\r\n                    childImports = this.importsByFile[imp.fullPath];\r\n                }\r\n\r\n                // Construct and add result to current imports\r\n                currentImport = {\r\n                    filePath: imp.fullPath,\r\n                    found: true,\r\n                    imports: childImports\r\n                };\r\n            }\r\n\r\n            // Take contentToReplace from the fileRegistry\r\n            contentToReplace = this.fileRegistry[imp.fullPath];\r\n\r\n            // If the content is not found\r\n            if (contentToReplace == null) {\r\n                // Indicate this with a comment for easier debugging\r\n                contentToReplace = `/*** IMPORTED FILE NOT FOUND ***/${os.EOL}${imp.importString}/*** --- ***/`;\r\n            }\r\n\r\n            // If usedImports dictionary is defined\r\n            if (shouldCheckForDedupes && this.usedImports != null) {\r\n                // And current import path should be deduped and is used already\r\n                const timesUsed = this.usedImports[imp.fullPath];\r\n                if (dedupeFiles.indexOf(imp.fullPath) !== -1 &&\r\n                    timesUsed != null &&\r\n                    timesUsed > 1) {\r\n                    // Reset content to replace to an empty string to skip it\r\n                    contentToReplace = \"\";\r\n                    // And indicate that import was deduped\r\n                    currentImport.deduped = true;\r\n                }\r\n            }\r\n\r\n            // Finally, replace import string with bundled content or a debug message\r\n            content = content.replace(imp.importString, contentToReplace);\r\n\r\n            // And push current import into the list\r\n            currentImports.push(currentImport);\r\n        }\r\n\r\n        // Set result properties\r\n        bundleResult.bundledContent = content;\r\n        bundleResult.imports = currentImports;\r\n\r\n        if (this.importsByFile != null) {\r\n            this.importsByFile[filePath] = currentImports;\r\n        }\r\n\r\n        return bundleResult;\r\n    }\r\n\r\n    private async resolveImport(importData, includePaths) {\r\n        try {\r\n            await fs.access(importData.fullPath);\r\n            importData.found = true;\r\n        } catch (error) {\r\n            const underscoredDirname = path.dirname(importData.fullPath);\r\n            const underscoredBasename = path.basename(importData.fullPath);\r\n            const underscoredFilePath = path.join(underscoredDirname, `_${underscoredBasename}`);\r\n            try {\r\n                await fs.access(underscoredFilePath);\r\n                importData.fullPath = underscoredFilePath;\r\n                importData.found = true;\r\n            } catch (underscoreErr) {\r\n                // If there are any includePaths\r\n                if (includePaths.length) {\r\n                    // Resolve fullPath using its first entry\r\n                    importData.fullPath = path.resolve(includePaths[0], importData.path);\r\n                    // Try resolving import with the remaining includePaths\r\n                    const remainingIncludePaths = includePaths.slice(1);\r\n                    return this.resolveImport(importData, remainingIncludePaths);\r\n                }\r\n            }\r\n        }\r\n\r\n        return importData;\r\n    }\r\n\r\n    private async globFilesOrEmpty(globsList: string[]) {\r\n        return new Promise<string[]>((resolve, reject) => {\r\n            if (globsList == null || globsList.length === 0) {\r\n                resolve([]);\r\n                return;\r\n            }\r\n            globs(globsList, (err: Error, files: string[]) => {\r\n                // Reject if there's an error\r\n                if (err) {\r\n                    reject(err);\r\n                }\r\n\r\n                // Resolve full paths\r\n                const result = files.map(file => path.resolve(file));\r\n\r\n                // Resolve promise\r\n                resolve(result);\r\n            });\r\n        });\r\n    }\r\n}\r\n"]} |
@@ -9,2 +9,2 @@ "use strict"; | ||
})(Verbosity = exports.Verbosity || (exports.Verbosity = {})); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnRyYWN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQU9BLElBQVksU0FJWDtBQUpELFdBQVksU0FBUztJQUNqQix5Q0FBUSxDQUFBO0lBQ1IsNkNBQVUsQ0FBQTtJQUNWLGlEQUFhLENBQUE7QUFDakIsQ0FBQyxFQUpXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xyXG4gICAgRW50cnk6IHN0cmluZztcclxuICAgIERlc3RpbmF0aW9uOiBzdHJpbmc7XHJcbiAgICBWZXJib3NpdHk6IFZlcmJvc2l0eTtcclxuICAgIERlZHVwZUdsb2JzPzogc3RyaW5nW107XHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIFZlcmJvc2l0eSB7XHJcbiAgICBOb25lID0gMCxcclxuICAgIEVycm9ycyA9IDgsXHJcbiAgICBWZXJib3NlID0gMjU2XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQXJndW1lbnRzVmFsdWVzIHtcclxuICAgIGNvbmZpZz86IHN0cmluZztcclxuICAgIGVudHJ5OiBzdHJpbmc7XHJcbiAgICBkZXN0OiBzdHJpbmc7XHJcbiAgICB2ZXJib3NpdHk6IFZlcmJvc2l0eTtcclxuICAgIGRlZHVwZT86IHN0cmluZ1tdO1xyXG59XHJcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnRyYWN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVFBLElBQVksU0FJWDtBQUpELFdBQVksU0FBUztJQUNqQix5Q0FBUSxDQUFBO0lBQ1IsNkNBQVUsQ0FBQTtJQUNWLGlEQUFhLENBQUE7QUFDakIsQ0FBQyxFQUpXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xyXG4gICAgRW50cnk6IHN0cmluZztcclxuICAgIERlc3RpbmF0aW9uOiBzdHJpbmc7XHJcbiAgICBWZXJib3NpdHk6IFZlcmJvc2l0eTtcclxuICAgIERlZHVwZUdsb2JzPzogc3RyaW5nW107XHJcbiAgICBJbmNsdWRlUGF0aHM/OiBzdHJpbmdbXTtcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVmVyYm9zaXR5IHtcclxuICAgIE5vbmUgPSAwLFxyXG4gICAgRXJyb3JzID0gOCxcclxuICAgIFZlcmJvc2UgPSAyNTZcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBcmd1bWVudHNWYWx1ZXMge1xyXG4gICAgY29uZmlnPzogc3RyaW5nO1xyXG4gICAgZW50cnk6IHN0cmluZztcclxuICAgIGRlc3Q6IHN0cmluZztcclxuICAgIHZlcmJvc2l0eTogVmVyYm9zaXR5O1xyXG4gICAgZGVkdXBlPzogc3RyaW5nW107XHJcbiAgICBpbmNsdWRlUGF0aHM/OiBzdHJpbmdbXTtcclxufVxyXG4iXX0= |
@@ -29,3 +29,3 @@ "use strict"; | ||
const bundler = new bundler_1.Bundler(fileRegistry); | ||
const bundleResult = yield bundler.Bundle(this.config.Entry, this.config.DedupeGlobs); | ||
const bundleResult = yield bundler.Bundle(this.config.Entry, this.config.DedupeGlobs, this.config.IncludePaths); | ||
if (!bundleResult.found) { | ||
@@ -132,2 +132,2 @@ if (this.config.Verbosity !== Contracts.Verbosity.None) { | ||
exports.Launcher = Launcher; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"launcher.js","sourceRoot":"","sources":["../src/launcher.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from \"mz/fs\";\r\nimport * as path from \"path\";\r\nimport * as os from \"os\";\r\nimport * as archy from \"archy\";\r\nimport * as prettyBytes from \"pretty-bytes\";\r\n\r\nimport * as nodeSass from \"node-sass\";\r\nimport * as mkdirp from \"mkdirp\";\r\n\r\nimport * as Contracts from \"./contracts\";\r\nimport { Bundler, BundleResult, FileRegistry } from \"./bundler\";\r\n\r\nexport class Launcher {\r\n    constructor(private config: Contracts.Config) { }\r\n\r\n    public async Bundle() {\r\n        try {\r\n            const fileRegistry: FileRegistry = {};\r\n            const bundler = new Bundler(fileRegistry);\r\n            const bundleResult = await bundler.Bundle(this.config.Entry, this.config.DedupeGlobs);\r\n\r\n            if (!bundleResult.found) {\r\n                if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                    const resolvedPath = path.resolve(bundleResult.filePath);\r\n                    let errorMessage = `[Error] An error has occured${os.EOL}`;\r\n                    errorMessage += `Entry file was not found:${os.EOL}${bundleResult.filePath}${os.EOL}`;\r\n                    errorMessage += `Looked at (full path):${os.EOL}${resolvedPath}`;\r\n                    this.exitWithError(errorMessage);\r\n                }\r\n            }\r\n\r\n            if (this.config.Verbosity === Contracts.Verbosity.Verbose) {\r\n                console.info(\"Imports tree:\");\r\n                const archyData = this.getArchyData(bundleResult, path.dirname(this.config.Entry));\r\n                console.info(archy(archyData));\r\n            }\r\n\r\n            if (bundleResult.bundledContent == null) {\r\n                if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                    this.exitWithError(`[Error] An error has occured${os.EOL}Concatenation result has no content.`);\r\n                }\r\n                return;\r\n            }\r\n            try {\r\n                await this.renderScss(bundleResult.bundledContent);\r\n            } catch (scssError) {\r\n                this.exitWithError(`[Error] There is an error in your styles:${os.EOL}${scssError}`);\r\n            }\r\n\r\n            // Ensure the directory exists\r\n            mkdirp.sync(path.dirname(this.config.Destination));\r\n\r\n            await fs.writeFile(this.config.Destination, bundleResult.bundledContent);\r\n\r\n            const fullPath = path.resolve(this.config.Destination);\r\n            if (this.config.Verbosity === Contracts.Verbosity.Verbose) {\r\n                console.info(`[Done] Bundled into:${os.EOL}${fullPath}`);\r\n                console.info(`Total size       : ${prettyBytes(bundleResult.bundledContent.length)}`);\r\n                console.info(`Saved by deduping: ${prettyBytes(this.countSavedBytesByDeduping(bundleResult, fileRegistry))}`);\r\n            }\r\n        } catch (error) {\r\n            if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                this.exitWithError(`[Error] An error has occured${os.EOL}${error}`);\r\n            }\r\n        }\r\n    }\r\n\r\n    private async renderScss(content: string) {\r\n        return new Promise((resolve, reject) => {\r\n            nodeSass.render({\r\n                data: content\r\n            }, (error, result) => {\r\n                if (error != null) {\r\n                    reject(`${error.message} on line (${error.line}, ${error.column})`);\r\n                }\r\n                resolve(result);\r\n            });\r\n        });\r\n    }\r\n\r\n    private getArchyData(bundleResult: BundleResult, sourceDirectory?: string) {\r\n        if (sourceDirectory == null) {\r\n            sourceDirectory = process.cwd();\r\n        }\r\n        const archyData: archy.Data = {\r\n            label: path.relative(sourceDirectory, bundleResult.filePath)\r\n        };\r\n\r\n        if (!bundleResult.found) {\r\n            archyData.label += ` [NOT FOUND]`;\r\n        }\r\n        if (bundleResult.deduped) {\r\n            archyData.label += ` [DEDUPED]`;\r\n        }\r\n\r\n        if (bundleResult.imports != null) {\r\n            archyData.nodes = bundleResult.imports.map(x => {\r\n                if (x != null) {\r\n                    return this.getArchyData(x, sourceDirectory);\r\n                }\r\n                return \"\";\r\n            });\r\n        }\r\n        return archyData;\r\n    }\r\n\r\n    private countSavedBytesByDeduping(bundleResult: BundleResult, fileRegistry: FileRegistry) {\r\n        let savedBytes = 0;\r\n        const content = fileRegistry[bundleResult.filePath];\r\n        if (bundleResult.deduped === true && content != null) {\r\n            savedBytes = content.length;\r\n        }\r\n        if (bundleResult.imports != null && bundleResult.imports.length > 0) {\r\n            for (const importResult of bundleResult.imports) {\r\n                savedBytes += this.countSavedBytesByDeduping(importResult, fileRegistry);\r\n            }\r\n        }\r\n        return savedBytes;\r\n    }\r\n\r\n    private exitWithError(message: string) {\r\n        if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n            console.error(message);\r\n        }\r\n        process.exit(1);\r\n    }\r\n}\r\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"launcher.js","sourceRoot":"","sources":["../src/launcher.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from \"mz/fs\";\r\nimport * as path from \"path\";\r\nimport * as os from \"os\";\r\nimport * as archy from \"archy\";\r\nimport * as prettyBytes from \"pretty-bytes\";\r\n\r\nimport * as nodeSass from \"node-sass\";\r\nimport * as mkdirp from \"mkdirp\";\r\n\r\nimport * as Contracts from \"./contracts\";\r\nimport { Bundler, BundleResult, FileRegistry } from \"./bundler\";\r\n\r\nexport class Launcher {\r\n    constructor(private config: Contracts.Config) { }\r\n\r\n    public async Bundle() {\r\n        try {\r\n            const fileRegistry: FileRegistry = {};\r\n            const bundler = new Bundler(fileRegistry);\r\n            const bundleResult = await bundler.Bundle(this.config.Entry, this.config.DedupeGlobs, this.config.IncludePaths);\r\n\r\n            if (!bundleResult.found) {\r\n                if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                    const resolvedPath = path.resolve(bundleResult.filePath);\r\n                    let errorMessage = `[Error] An error has occured${os.EOL}`;\r\n                    errorMessage += `Entry file was not found:${os.EOL}${bundleResult.filePath}${os.EOL}`;\r\n                    errorMessage += `Looked at (full path):${os.EOL}${resolvedPath}`;\r\n                    this.exitWithError(errorMessage);\r\n                }\r\n            }\r\n\r\n            if (this.config.Verbosity === Contracts.Verbosity.Verbose) {\r\n                console.info(\"Imports tree:\");\r\n                const archyData = this.getArchyData(bundleResult, path.dirname(this.config.Entry));\r\n                console.info(archy(archyData));\r\n            }\r\n\r\n            if (bundleResult.bundledContent == null) {\r\n                if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                    this.exitWithError(`[Error] An error has occured${os.EOL}Concatenation result has no content.`);\r\n                }\r\n                return;\r\n            }\r\n            try {\r\n                await this.renderScss(bundleResult.bundledContent);\r\n            } catch (scssError) {\r\n                this.exitWithError(`[Error] There is an error in your styles:${os.EOL}${scssError}`);\r\n            }\r\n\r\n            // Ensure the directory exists\r\n            mkdirp.sync(path.dirname(this.config.Destination));\r\n\r\n            await fs.writeFile(this.config.Destination, bundleResult.bundledContent);\r\n\r\n            const fullPath = path.resolve(this.config.Destination);\r\n            if (this.config.Verbosity === Contracts.Verbosity.Verbose) {\r\n                console.info(`[Done] Bundled into:${os.EOL}${fullPath}`);\r\n                console.info(`Total size       : ${prettyBytes(bundleResult.bundledContent.length)}`);\r\n                console.info(`Saved by deduping: ${prettyBytes(this.countSavedBytesByDeduping(bundleResult, fileRegistry))}`);\r\n            }\r\n        } catch (error) {\r\n            if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n                this.exitWithError(`[Error] An error has occured${os.EOL}${error}`);\r\n            }\r\n        }\r\n    }\r\n\r\n    private async renderScss(content: string) {\r\n        return new Promise((resolve, reject) => {\r\n            nodeSass.render({\r\n                data: content\r\n            }, (error, result) => {\r\n                if (error != null) {\r\n                    reject(`${error.message} on line (${error.line}, ${error.column})`);\r\n                }\r\n                resolve(result);\r\n            });\r\n        });\r\n    }\r\n\r\n    private getArchyData(bundleResult: BundleResult, sourceDirectory?: string) {\r\n        if (sourceDirectory == null) {\r\n            sourceDirectory = process.cwd();\r\n        }\r\n        const archyData: archy.Data = {\r\n            label: path.relative(sourceDirectory, bundleResult.filePath)\r\n        };\r\n\r\n        if (!bundleResult.found) {\r\n            archyData.label += ` [NOT FOUND]`;\r\n        }\r\n        if (bundleResult.deduped) {\r\n            archyData.label += ` [DEDUPED]`;\r\n        }\r\n\r\n        if (bundleResult.imports != null) {\r\n            archyData.nodes = bundleResult.imports.map(x => {\r\n                if (x != null) {\r\n                    return this.getArchyData(x, sourceDirectory);\r\n                }\r\n                return \"\";\r\n            });\r\n        }\r\n        return archyData;\r\n    }\r\n\r\n    private countSavedBytesByDeduping(bundleResult: BundleResult, fileRegistry: FileRegistry) {\r\n        let savedBytes = 0;\r\n        const content = fileRegistry[bundleResult.filePath];\r\n        if (bundleResult.deduped === true && content != null) {\r\n            savedBytes = content.length;\r\n        }\r\n        if (bundleResult.imports != null && bundleResult.imports.length > 0) {\r\n            for (const importResult of bundleResult.imports) {\r\n                savedBytes += this.countSavedBytesByDeduping(importResult, fileRegistry);\r\n            }\r\n        }\r\n        return savedBytes;\r\n    }\r\n\r\n    private exitWithError(message: string) {\r\n        if (this.config.Verbosity !== Contracts.Verbosity.None) {\r\n            console.error(message);\r\n        }\r\n        process.exit(1);\r\n    }\r\n}\r\n"]} |
{ | ||
"name": "scss-bundle", | ||
"version": "2.0.1-beta.7", | ||
"version": "2.1.0", | ||
"description": "Bundling SCSS files to one bundled file.", | ||
@@ -12,3 +12,4 @@ "types": "@types/index.d.ts", | ||
"watch": "tsc -w", | ||
"test-scss": "node ./dist/bundle-cli.js -e ./example/simple/main.scss -d ./example/output/simple.scss", | ||
"test-scss": "node ./dist/bundle-cli.js -e ./examples/simple/main.scss -d ./examples/output/simple.scss", | ||
"test-scss-include-paths": "node ./dist/bundle-cli.js -e ./examples/include-paths/main.scss -d ./examples/output/include-paths.scss --includePaths ./examples ./node_modules", | ||
"prepublish": "npm run build" | ||
@@ -15,0 +16,0 @@ }, |
@@ -55,2 +55,3 @@ # `scss-bundle` | ||
| verbosity | string choices | Destination file when bundling is done. | None, Errors, Verbose | Verbose | | ||
| includePaths | array | Include paths for resolving imports | ` ` | ` ` | | ||
@@ -57,0 +58,0 @@ `*` - Required |
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
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
73150
517
0
162