Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

scss-bundle

Package Overview
Dependencies
Maintainers
2
Versions
55
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

scss-bundle - npm Package Compare versions

Comparing version 2.1.0 to 2.1.1

2

@types/arguments.d.ts
import * as Contracts from "./contracts";
export declare let argv: Contracts.ArgumentsValues;
export declare const argv: Contracts.ArgumentsValues;

@@ -25,4 +25,5 @@ export interface FileRegistry {

private bundle(filePath, content, dedupeFiles, includePaths);
private removeImportsFromComments(text);
private resolveImport(importData, includePaths);
private globFilesOrEmpty(globsList);
}

@@ -0,1 +1,2 @@

import * as yargs from "yargs";
export interface Config {

@@ -13,3 +14,3 @@ Entry: string;

}
export interface ArgumentsValues {
export interface ArgumentsValues extends yargs.Arguments {
config?: string;

@@ -16,0 +17,0 @@ entry: string;

@@ -5,4 +5,4 @@ "use strict";

const Contracts = require("./contracts");
let verbosityValues = [];
for (let key in Contracts.Verbosity) {
const verbosityValues = [];
for (const key in Contracts.Verbosity) {
if (Number(key) % 1 !== 0) {

@@ -16,5 +16,3 @@ verbosityValues.push(key);

.alias("h", "help")
.version(() => {
return `Current version: ${require("../package.json").version}.`;
})
.version()
.alias("v", "version")

@@ -47,2 +45,2 @@ .config("config")

.argv;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJndW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FyZ3VtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLCtCQUErQjtBQUUvQix5Q0FBeUM7QUFFekMsSUFBSSxlQUFlLEdBQWEsRUFBRSxDQUFDO0FBQ25DLEdBQUcsQ0FBQyxDQUFDLElBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ2xDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDO0FBRWpCLFFBQUEsSUFBSSxHQUFHLEtBQUs7S0FDbEIsSUFBSSxDQUFDLEdBQUcsRUFBRSxZQUFZLENBQUM7S0FDdkIsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUM7S0FDbEIsT0FBTyxDQUFDO0lBQ0wsTUFBTSxDQUFDLG9CQUFvQixPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxPQUFPLEdBQUcsQ0FBQztBQUNyRSxDQUFDLENBQUM7S0FDRCxLQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQztLQUNyQixNQUFNLENBQUMsUUFBUSxDQUFDO0tBQ2hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDO0tBQ3BCLE9BQU8sQ0FBQyxHQUFHLEVBQUU7SUFDVixLQUFLLEVBQUUsT0FBTztJQUNkLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsR0FBRyxFQUFFO0lBQ1YsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsMkJBQTJCO0lBQ3JDLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsV0FBVyxFQUFFO0lBQ2xCLFFBQVEsRUFBRSxzQkFBc0I7SUFDaEMsT0FBTyxFQUFFLGVBQWU7SUFDeEIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7Q0FDNUQsQ0FBQztLQUNELE9BQU8sQ0FBQyxjQUFjLEVBQUU7SUFDckIsUUFBUSxFQUFFLHNDQUFzQztJQUNoRCxJQUFJLEVBQUUsT0FBTztDQUNoQixDQUFDO0tBQ0QsS0FBSyxDQUFDLFVBQVUsQ0FBQztLQUNqQixPQUFPLENBQUMsVUFBVSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUM7S0FDN0IsS0FBSyxDQUFDLDhCQUE4QixDQUFDO0tBQ3JDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7S0FDdkIsSUFBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHlhcmdzIGZyb20gXCJ5YXJnc1wiO1xyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5cclxubGV0IHZlcmJvc2l0eVZhbHVlczogc3RyaW5nW10gPSBbXTtcclxuZm9yIChsZXQga2V5IGluIENvbnRyYWN0cy5WZXJib3NpdHkpIHtcclxuICAgIGlmIChOdW1iZXIoa2V5KSAlIDEgIT09IDApIHtcclxuICAgICAgICB2ZXJib3NpdHlWYWx1ZXMucHVzaChrZXkpO1xyXG4gICAgfVxyXG59XHJcblxyXG5jb25zdCBERURVUEVfS0VZID0gXCJkZWR1cGVcIjtcclxuXHJcbmV4cG9ydCBsZXQgYXJndiA9IHlhcmdzXHJcbiAgICAuaGVscChcImhcIiwgXCJTaG93IGhlbHAuXCIpXHJcbiAgICAuYWxpYXMoXCJoXCIsIFwiaGVscFwiKVxyXG4gICAgLnZlcnNpb24oKCkgPT4ge1xyXG4gICAgICAgIHJldHVybiBgQ3VycmVudCB2ZXJzaW9uOiAke3JlcXVpcmUoXCIuLi9wYWNrYWdlLmpzb25cIikudmVyc2lvbn0uYDtcclxuICAgIH0pXHJcbiAgICAuYWxpYXMoXCJ2XCIsIFwidmVyc2lvblwiKVxyXG4gICAgLmNvbmZpZyhcImNvbmZpZ1wiKVxyXG4gICAgLmFsaWFzKFwiY1wiLCBcImNvbmZpZ1wiKVxyXG4gICAgLm9wdGlvbnMoXCJlXCIsIHtcclxuICAgICAgICBhbGlhczogXCJlbnRyeVwiLFxyXG4gICAgICAgIGRlc2NyaWJlOiBcIkVudHJ5IGZpbGUuXCIsXHJcbiAgICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwiZFwiLCB7XHJcbiAgICAgICAgYWxpYXM6IFwiZGVzdFwiLFxyXG4gICAgICAgIGRlc2NyaWJlOiBcIkJ1bmRsZWQgZmlsZSBkZXN0aW5hdGlvbi5cIixcclxuICAgICAgICB0eXBlOiBcInN0cmluZ1wiXHJcbiAgICB9KVxyXG4gICAgLm9wdGlvbnMoXCJ2ZXJib3NpdHlcIiwge1xyXG4gICAgICAgIGRlc2NyaWJlOiBcIlZlcmJvc2l0eSBvZiBvdXRwdXQuXCIsXHJcbiAgICAgICAgY2hvaWNlczogdmVyYm9zaXR5VmFsdWVzLFxyXG4gICAgICAgIGRlZmF1bHQ6IENvbnRyYWN0cy5WZXJib3NpdHlbQ29udHJhY3RzLlZlcmJvc2l0eS5WZXJib3NlXVxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwiaW5jbHVkZVBhdGhzXCIsIHtcclxuICAgICAgICBkZXNjcmliZTogXCJJbmNsdWRlIHBhdGhzIGZvciByZXNvbHZpbmcgaW1wb3J0cy5cIixcclxuICAgICAgICB0eXBlOiBcImFycmF5XCJcclxuICAgIH0pXHJcbiAgICAuYXJyYXkoREVEVVBFX0tFWSlcclxuICAgIC5kZWZhdWx0KERFRFVQRV9LRVksIFtdLCBcIltdXCIpXHJcbiAgICAudXNhZ2UoXCJVc2FnZTogc2Nzcy1idW5kbGUgW29wdGlvbnNdXCIpXHJcbiAgICAuc3RyaW5nKFtcImNcIiwgXCJlXCIsIFwiZFwiXSlcclxuICAgIC5hcmd2IGFzIENvbnRyYWN0cy5Bcmd1bWVudHNWYWx1ZXM7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJndW1lbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2FyZ3VtZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLCtCQUErQjtBQUUvQix5Q0FBeUM7QUFFekMsTUFBTSxlQUFlLEdBQWEsRUFBRSxDQUFDO0FBQ3JDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sR0FBRyxJQUFJLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ3BDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4QixlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsUUFBUSxDQUFDO0FBRWYsUUFBQSxJQUFJLEdBQUcsS0FBSztLQUNwQixJQUFJLENBQUMsR0FBRyxFQUFFLFlBQVksQ0FBQztLQUN2QixLQUFLLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQztLQUNsQixPQUFPLEVBQUU7S0FDVCxLQUFLLENBQUMsR0FBRyxFQUFFLFNBQVMsQ0FBQztLQUNyQixNQUFNLENBQUMsUUFBUSxDQUFDO0tBQ2hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDO0tBQ3BCLE9BQU8sQ0FBQyxHQUFHLEVBQUU7SUFDVixLQUFLLEVBQUUsT0FBTztJQUNkLFFBQVEsRUFBRSxhQUFhO0lBQ3ZCLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsR0FBRyxFQUFFO0lBQ1YsS0FBSyxFQUFFLE1BQU07SUFDYixRQUFRLEVBQUUsMkJBQTJCO0lBQ3JDLElBQUksRUFBRSxRQUFRO0NBQ2pCLENBQUM7S0FDRCxPQUFPLENBQUMsV0FBVyxFQUFFO0lBQ2xCLFFBQVEsRUFBRSxzQkFBc0I7SUFDaEMsT0FBTyxFQUFFLGVBQWU7SUFDeEIsT0FBTyxFQUFFLFNBQVMsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7Q0FDNUQsQ0FBQztLQUNELE9BQU8sQ0FBQyxjQUFjLEVBQUU7SUFDckIsUUFBUSxFQUFFLHNDQUFzQztJQUNoRCxJQUFJLEVBQUUsT0FBTztDQUNoQixDQUFDO0tBQ0QsS0FBSyxDQUFDLFVBQVUsQ0FBQztLQUNqQixPQUFPLENBQUMsVUFBVSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUM7S0FDN0IsS0FBSyxDQUFDLDhCQUE4QixDQUFDO0tBQ3JDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7S0FDdkIsSUFBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHlhcmdzIGZyb20gXCJ5YXJnc1wiO1xyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5cclxuY29uc3QgdmVyYm9zaXR5VmFsdWVzOiBzdHJpbmdbXSA9IFtdO1xyXG5mb3IgKGNvbnN0IGtleSBpbiBDb250cmFjdHMuVmVyYm9zaXR5KSB7XHJcbiAgICBpZiAoTnVtYmVyKGtleSkgJSAxICE9PSAwKSB7XHJcbiAgICAgICAgdmVyYm9zaXR5VmFsdWVzLnB1c2goa2V5KTtcclxuICAgIH1cclxufVxyXG5cclxuY29uc3QgREVEVVBFX0tFWSA9IFwiZGVkdXBlXCI7XHJcblxyXG5leHBvcnQgY29uc3QgYXJndiA9IHlhcmdzXHJcbiAgICAuaGVscChcImhcIiwgXCJTaG93IGhlbHAuXCIpXHJcbiAgICAuYWxpYXMoXCJoXCIsIFwiaGVscFwiKVxyXG4gICAgLnZlcnNpb24oKVxyXG4gICAgLmFsaWFzKFwidlwiLCBcInZlcnNpb25cIilcclxuICAgIC5jb25maWcoXCJjb25maWdcIilcclxuICAgIC5hbGlhcyhcImNcIiwgXCJjb25maWdcIilcclxuICAgIC5vcHRpb25zKFwiZVwiLCB7XHJcbiAgICAgICAgYWxpYXM6IFwiZW50cnlcIixcclxuICAgICAgICBkZXNjcmliZTogXCJFbnRyeSBmaWxlLlwiLFxyXG4gICAgICAgIHR5cGU6IFwic3RyaW5nXCJcclxuICAgIH0pXHJcbiAgICAub3B0aW9ucyhcImRcIiwge1xyXG4gICAgICAgIGFsaWFzOiBcImRlc3RcIixcclxuICAgICAgICBkZXNjcmliZTogXCJCdW5kbGVkIGZpbGUgZGVzdGluYXRpb24uXCIsXHJcbiAgICAgICAgdHlwZTogXCJzdHJpbmdcIlxyXG4gICAgfSlcclxuICAgIC5vcHRpb25zKFwidmVyYm9zaXR5XCIsIHtcclxuICAgICAgICBkZXNjcmliZTogXCJWZXJib3NpdHkgb2Ygb3V0cHV0LlwiLFxyXG4gICAgICAgIGNob2ljZXM6IHZlcmJvc2l0eVZhbHVlcyxcclxuICAgICAgICBkZWZhdWx0OiBDb250cmFjdHMuVmVyYm9zaXR5W0NvbnRyYWN0cy5WZXJib3NpdHkuVmVyYm9zZV1cclxuICAgIH0pXHJcbiAgICAub3B0aW9ucyhcImluY2x1ZGVQYXRoc1wiLCB7XHJcbiAgICAgICAgZGVzY3JpYmU6IFwiSW5jbHVkZSBwYXRocyBmb3IgcmVzb2x2aW5nIGltcG9ydHMuXCIsXHJcbiAgICAgICAgdHlwZTogXCJhcnJheVwiXHJcbiAgICB9KVxyXG4gICAgLmFycmF5KERFRFVQRV9LRVkpXHJcbiAgICAuZGVmYXVsdChERURVUEVfS0VZLCBbXSwgXCJbXVwiKVxyXG4gICAgLnVzYWdlKFwiVXNhZ2U6IHNjc3MtYnVuZGxlIFtvcHRpb25zXVwiKVxyXG4gICAgLnN0cmluZyhbXCJjXCIsIFwiZVwiLCBcImRcIl0pXHJcbiAgICAuYXJndiBhcyBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzO1xyXG4iXX0=

@@ -41,2 +41,2 @@ #!/usr/bin/env node

new BundleCli(arguments_1.argv);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVuZGxlLWNsaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9idW5kbGUtY2xpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUEseUNBQXlDO0FBQ3pDLDJDQUFtQztBQUNuQyx5Q0FBc0M7QUFFdEM7SUFDSSxZQUFZLGNBQXlDO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVhLE1BQU0sQ0FBQyxjQUF5Qzs7WUFDMUQsTUFBTSxJQUFJLG1CQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hFLENBQUM7S0FBQTtJQUVPLFNBQVMsQ0FBQyxjQUF5QztRQUN2RCxNQUFNLENBQUM7WUFDSCxXQUFXLEVBQUUsY0FBYyxDQUFDLElBQUk7WUFDaEMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxLQUFLO1lBQzNCLFdBQVcsRUFBRSxjQUFjLENBQUMsTUFBTTtZQUNsQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUM7WUFDMUQsWUFBWSxFQUFFLGNBQWMsQ0FBQyxZQUFZO1NBQzVDLENBQUM7SUFDTixDQUFDO0lBRU8sZ0JBQWdCLENBQUMsU0FBYztRQUNuQyw4REFBOEQ7UUFDOUQsdURBQXVEO1FBQ3ZELG9FQUFvRTtRQUNwRSxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQWtCLENBQUM7SUFDM0QsQ0FBQztDQUNKO0FBRUQsSUFBSSxTQUFTLENBQUMsZ0JBQUksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgbm9kZVxyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5pbXBvcnQgeyBhcmd2IH0gZnJvbSBcIi4vYXJndW1lbnRzXCI7XHJcbmltcG9ydCB7IExhdW5jaGVyIH0gZnJvbSBcIi4vbGF1bmNoZXJcIjtcclxuXHJcbmNsYXNzIEJ1bmRsZUNsaSB7XHJcbiAgICBjb25zdHJ1Y3Rvcihhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcykge1xyXG4gICAgICAgIHRoaXMuYnVuZGxlKGFyZ3VtZW50VmFsdWVzKTtcclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIGFzeW5jIGJ1bmRsZShhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcykge1xyXG4gICAgICAgIGF3YWl0IG5ldyBMYXVuY2hlcih0aGlzLmdldENvbmZpZyhhcmd1bWVudFZhbHVlcykpLkJ1bmRsZSgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgZ2V0Q29uZmlnKGFyZ3VtZW50VmFsdWVzOiBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzKTogQ29udHJhY3RzLkNvbmZpZyB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgRGVzdGluYXRpb246IGFyZ3VtZW50VmFsdWVzLmRlc3QsXHJcbiAgICAgICAgICAgIEVudHJ5OiBhcmd1bWVudFZhbHVlcy5lbnRyeSxcclxuICAgICAgICAgICAgRGVkdXBlR2xvYnM6IGFyZ3VtZW50VmFsdWVzLmRlZHVwZSxcclxuICAgICAgICAgICAgVmVyYm9zaXR5OiB0aGlzLnJlc29sdmVWZXJib3NpdHkoYXJndW1lbnRWYWx1ZXMudmVyYm9zaXR5KSxcclxuICAgICAgICAgICAgSW5jbHVkZVBhdGhzOiBhcmd1bWVudFZhbHVlcy5pbmNsdWRlUGF0aHNcclxuICAgICAgICB9O1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcmVzb2x2ZVZlcmJvc2l0eSh2ZXJib3NpdHk6IGFueSk6IG51bWJlciB7XHJcbiAgICAgICAgLy8gQ29udmVydCBnaXZlbiB2YWx1ZSB0byBhbiBhcHByb3ByaWF0ZSBWZXJib3NpdHkgZW51bSB2YWx1ZS5cclxuICAgICAgICAvLyAnYXMgYW55IGFzIG51bWJlcicgaXMgdXNlZCBiZWNhdXNlIFR5cGVTY3JpcHQgdGhpbmtzXHJcbiAgICAgICAgLy8gIHRoYXQgd2UgY2FzdCBzdHJpbmcgdG8gbnVtYmVyLCBldmVuIHRob3VnaCB3ZSBnZXQgYSBudW1iZXIgdGhlcmVcclxuICAgICAgICByZXR1cm4gQ29udHJhY3RzLlZlcmJvc2l0eVt2ZXJib3NpdHldIGFzIGFueSBhcyBudW1iZXI7XHJcbiAgICB9XHJcbn1cclxuXHJcbm5ldyBCdW5kbGVDbGkoYXJndik7XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVuZGxlLWNsaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9idW5kbGUtY2xpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBRUEseUNBQXlDO0FBQ3pDLDJDQUFtQztBQUNuQyx5Q0FBc0M7QUFFdEM7SUFDSSxZQUFZLGNBQXlDO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDaEMsQ0FBQztJQUVhLE1BQU0sQ0FBQyxjQUF5Qzs7WUFDMUQsTUFBTSxJQUFJLG1CQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2hFLENBQUM7S0FBQTtJQUVPLFNBQVMsQ0FBQyxjQUF5QztRQUN2RCxNQUFNLENBQUM7WUFDSCxXQUFXLEVBQUUsY0FBYyxDQUFDLElBQUk7WUFDaEMsS0FBSyxFQUFFLGNBQWMsQ0FBQyxLQUFLO1lBQzNCLFdBQVcsRUFBRSxjQUFjLENBQUMsTUFBTTtZQUNsQyxTQUFTLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUM7WUFDMUQsWUFBWSxFQUFFLGNBQWMsQ0FBQyxZQUFZO1NBQzVDLENBQUM7SUFDTixDQUFDO0lBRU8sZ0JBQWdCLENBQUMsU0FBYztRQUNuQyw4REFBOEQ7UUFDOUQsdURBQXVEO1FBQ3ZELG9FQUFvRTtRQUNwRSxNQUFNLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQWtCLENBQUM7SUFDM0QsQ0FBQztDQUNKO0FBRUQsSUFBSSxTQUFTLENBQUMsZ0JBQUksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiIyEvdXNyL2Jpbi9lbnYgbm9kZVxyXG5cclxuaW1wb3J0ICogYXMgQ29udHJhY3RzIGZyb20gXCIuL2NvbnRyYWN0c1wiO1xyXG5pbXBvcnQgeyBhcmd2IH0gZnJvbSBcIi4vYXJndW1lbnRzXCI7XHJcbmltcG9ydCB7IExhdW5jaGVyIH0gZnJvbSBcIi4vbGF1bmNoZXJcIjtcclxuXHJcbmNsYXNzIEJ1bmRsZUNsaSB7XHJcbiAgICBjb25zdHJ1Y3Rvcihhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcykge1xyXG4gICAgICAgIHRoaXMuYnVuZGxlKGFyZ3VtZW50VmFsdWVzKTtcclxuICAgIH1cclxuXHJcbiAgICBwcml2YXRlIGFzeW5jIGJ1bmRsZShhcmd1bWVudFZhbHVlczogQ29udHJhY3RzLkFyZ3VtZW50c1ZhbHVlcyk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgICAgIGF3YWl0IG5ldyBMYXVuY2hlcih0aGlzLmdldENvbmZpZyhhcmd1bWVudFZhbHVlcykpLkJ1bmRsZSgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgZ2V0Q29uZmlnKGFyZ3VtZW50VmFsdWVzOiBDb250cmFjdHMuQXJndW1lbnRzVmFsdWVzKTogQ29udHJhY3RzLkNvbmZpZyB7XHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgRGVzdGluYXRpb246IGFyZ3VtZW50VmFsdWVzLmRlc3QsXHJcbiAgICAgICAgICAgIEVudHJ5OiBhcmd1bWVudFZhbHVlcy5lbnRyeSxcclxuICAgICAgICAgICAgRGVkdXBlR2xvYnM6IGFyZ3VtZW50VmFsdWVzLmRlZHVwZSxcclxuICAgICAgICAgICAgVmVyYm9zaXR5OiB0aGlzLnJlc29sdmVWZXJib3NpdHkoYXJndW1lbnRWYWx1ZXMudmVyYm9zaXR5KSxcclxuICAgICAgICAgICAgSW5jbHVkZVBhdGhzOiBhcmd1bWVudFZhbHVlcy5pbmNsdWRlUGF0aHNcclxuICAgICAgICB9O1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcmVzb2x2ZVZlcmJvc2l0eSh2ZXJib3NpdHk6IGFueSk6IG51bWJlciB7XHJcbiAgICAgICAgLy8gQ29udmVydCBnaXZlbiB2YWx1ZSB0byBhbiBhcHByb3ByaWF0ZSBWZXJib3NpdHkgZW51bSB2YWx1ZS5cclxuICAgICAgICAvLyAnYXMgYW55IGFzIG51bWJlcicgaXMgdXNlZCBiZWNhdXNlIFR5cGVTY3JpcHQgdGhpbmtzXHJcbiAgICAgICAgLy8gIHRoYXQgd2UgY2FzdCBzdHJpbmcgdG8gbnVtYmVyLCBldmVuIHRob3VnaCB3ZSBnZXQgYSBudW1iZXIgdGhlcmVcclxuICAgICAgICByZXR1cm4gQ29udHJhY3RzLlZlcmJvc2l0eVt2ZXJib3NpdHldIGFzIGFueSBhcyBudW1iZXI7XHJcbiAgICB9XHJcbn1cclxuXHJcbm5ldyBCdW5kbGVDbGkoYXJndik7XHJcbiJdfQ==

@@ -11,3 +11,3 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
const fs = require("mz/fs");
const fs = require("fs-extra");
const os = require("os");

@@ -18,3 +18,4 @@ const path = require("path");

const IMPORT_PATTERN = /@import ['"](.+)['"];/g;
const COMMENTED_IMPORT_PATTERN = /\/\/@import '(.+)';/g;
const COMMENT_PATTERN = /\/\/.+?[\r\n|\n]/g;
const MULTILINE_COMMENT_PATTERN = /\/\*[\s\S]*?\*\//g;
const FILE_EXTENSION = ".scss";

@@ -31,3 +32,3 @@ class Bundler {

return __awaiter(this, void 0, void 0, function* () {
const resultsPromises = files.map(file => this.Bundle(file, dedupeGlobs));
const resultsPromises = files.map((file) => __awaiter(this, void 0, void 0, function* () { return this.Bundle(file, dedupeGlobs); }));
return yield Promise.all(resultsPromises);

@@ -57,3 +58,3 @@ });

// Remove commented imports
content = content.replace(COMMENTED_IMPORT_PATTERN, "");
content = this.removeImportsFromComments(content);
// Resolve path to work only with full paths

@@ -105,5 +106,5 @@ filePath = path.resolve(filePath);

// Read
let impContent = yield fs.readFile(imp.fullPath, "utf-8");
const impContent = yield fs.readFile(imp.fullPath, "utf-8");
// and bundle it
let bundledImport = yield this.bundle(imp.fullPath, impContent, dedupeFiles, includePaths);
const bundledImport = yield this.bundle(imp.fullPath, impContent, dedupeFiles, includePaths);
// Then add its bundled content to the registry

@@ -170,2 +171,12 @@ this.fileRegistry[imp.fullPath] = bundledImport.bundledContent;

}
removeImportsFromComments(text) {
const patterns = [
COMMENT_PATTERN,
MULTILINE_COMMENT_PATTERN
];
for (const pattern of patterns) {
text = text.replace(pattern, x => x.replace(IMPORT_PATTERN, "").trim());
}
return text;
}
resolveImport(importData, includePaths) {

@@ -222,2 +233,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[] = [], 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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundler.js","sourceRoot":"","sources":["../src/bundler.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,+BAA+B;AAC/B,yBAAyB;AACzB,6BAA6B;AAC7B,+BAA+B;AAE/B,qCAAqC;AAErC,MAAM,cAAc,GAAG,wBAAwB,CAAC;AAChD,MAAM,eAAe,GAAG,mBAAmB,CAAC;AAC5C,MAAM,yBAAyB,GAAG,mBAAmB,CAAC;AACtD,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,CAAM,IAAI,EAAC,EAAE,gDAAC,MAAM,CAAN,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,WAAW,CAAC,CAAA,GAAA,CAAC,CAAC;YAChF,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,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC;YAElD,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,EAAC,EAAE;gBACrF,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,MAAM,UAAU,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;oBAE5D,gBAAgB;oBAChB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;oBAE7F,+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;IAEO,yBAAyB,CAAC,IAAY;QAC1C,MAAM,QAAQ,GAAG;YACb,eAAe;YACf,yBAAyB;SAC5B,CAAC;QAEF,GAAG,CAAC,CAAC,MAAM,OAAO,IAAI,QAAQ,CAAC,CAAC,CAAC;YAC7B,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAC5E,CAAC;QAED,MAAM,CAAC,IAAI,CAAC;IAChB,CAAC;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,EAAE,EAAE;gBAC7C,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,EAAE,EAAE;oBAC7C,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,CAAC,EAAE,CAAC,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;AA7OD,0BA6OC","sourcesContent":["import * as fs from \"fs-extra\";\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 COMMENT_PATTERN = /\\/\\/.+?[\\r\\n|\\n]/g;\r\nconst MULTILINE_COMMENT_PATTERN = /\\/\\*[\\s\\S]*?\\*\\//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(async 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 = this.removeImportsFromComments(content);\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                const impContent = await fs.readFile(imp.fullPath, \"utf-8\");\r\n\r\n                // and bundle it\r\n                const 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 removeImportsFromComments(text: string): string {\r\n        const patterns = [\r\n            COMMENT_PATTERN,\r\n            MULTILINE_COMMENT_PATTERN\r\n        ];\r\n\r\n        for (const pattern of patterns) {\r\n            text = text.replace(pattern, x => x.replace(IMPORT_PATTERN, \"\").trim());\r\n        }\r\n\r\n        return text;\r\n    }\r\n\r\n    private async resolveImport(importData, includePaths): Promise<any> {\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[]): Promise<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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnRyYWN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVFBLElBQVksU0FJWDtBQUpELFdBQVksU0FBUztJQUNqQix5Q0FBUSxDQUFBO0lBQ1IsNkNBQVUsQ0FBQTtJQUNWLGlEQUFhLENBQUE7QUFDakIsQ0FBQyxFQUpXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBDb25maWcge1xyXG4gICAgRW50cnk6IHN0cmluZztcclxuICAgIERlc3RpbmF0aW9uOiBzdHJpbmc7XHJcbiAgICBWZXJib3NpdHk6IFZlcmJvc2l0eTtcclxuICAgIERlZHVwZUdsb2JzPzogc3RyaW5nW107XHJcbiAgICBJbmNsdWRlUGF0aHM/OiBzdHJpbmdbXTtcclxufVxyXG5cclxuZXhwb3J0IGVudW0gVmVyYm9zaXR5IHtcclxuICAgIE5vbmUgPSAwLFxyXG4gICAgRXJyb3JzID0gOCxcclxuICAgIFZlcmJvc2UgPSAyNTZcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBcmd1bWVudHNWYWx1ZXMge1xyXG4gICAgY29uZmlnPzogc3RyaW5nO1xyXG4gICAgZW50cnk6IHN0cmluZztcclxuICAgIGRlc3Q6IHN0cmluZztcclxuICAgIHZlcmJvc2l0eTogVmVyYm9zaXR5O1xyXG4gICAgZGVkdXBlPzogc3RyaW5nW107XHJcbiAgICBpbmNsdWRlUGF0aHM/OiBzdHJpbmdbXTtcclxufVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJhY3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnRyYWN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQVVBLElBQVksU0FJWDtBQUpELFdBQVksU0FBUztJQUNqQix5Q0FBUSxDQUFBO0lBQ1IsNkNBQVUsQ0FBQTtJQUNWLGlEQUFhLENBQUE7QUFDakIsQ0FBQyxFQUpXLFNBQVMsR0FBVCxpQkFBUyxLQUFULGlCQUFTLFFBSXBCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgeWFyZ3MgZnJvbSBcInlhcmdzXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIENvbmZpZyB7XHJcbiAgICBFbnRyeTogc3RyaW5nO1xyXG4gICAgRGVzdGluYXRpb246IHN0cmluZztcclxuICAgIFZlcmJvc2l0eTogVmVyYm9zaXR5O1xyXG4gICAgRGVkdXBlR2xvYnM/OiBzdHJpbmdbXTtcclxuICAgIEluY2x1ZGVQYXRocz86IHN0cmluZ1tdO1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBWZXJib3NpdHkge1xyXG4gICAgTm9uZSA9IDAsXHJcbiAgICBFcnJvcnMgPSA4LFxyXG4gICAgVmVyYm9zZSA9IDI1NlxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFyZ3VtZW50c1ZhbHVlcyBleHRlbmRzIHlhcmdzLkFyZ3VtZW50cyB7XHJcbiAgICBjb25maWc/OiBzdHJpbmc7XHJcbiAgICBlbnRyeTogc3RyaW5nO1xyXG4gICAgZGVzdDogc3RyaW5nO1xyXG4gICAgdmVyYm9zaXR5OiBWZXJib3NpdHk7XHJcbiAgICBkZWR1cGU/OiBzdHJpbmdbXTtcclxuICAgIGluY2x1ZGVQYXRocz86IHN0cmluZ1tdO1xyXG59XHJcbiJdfQ==
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
function getAllMatches(text, regex) {
let matches = [];
const matches = [];
let match;

@@ -12,2 +12,2 @@ while (match = regex.exec(text)) {

exports.getAllMatches = getAllMatches;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsdUJBQThCLElBQVksRUFBRSxLQUFhO0lBQ3JELElBQUksT0FBTyxHQUFzQixFQUFFLENBQUM7SUFDcEMsSUFBSSxLQUFzQixDQUFDO0lBQzNCLE9BQU8sS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFvQixFQUFFLENBQUM7UUFDakQsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4QixDQUFDO0lBQ0QsTUFBTSxDQUFDLE9BQU8sQ0FBQztBQUNuQixDQUFDO0FBUEQsc0NBT0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gZ2V0QWxsTWF0Y2hlcyh0ZXh0OiBzdHJpbmcsIHJlZ2V4OiBSZWdFeHApOiBSZWdFeHBFeGVjQXJyYXlbXSB7XHJcbiAgICBsZXQgbWF0Y2hlczogUmVnRXhwRXhlY0FycmF5W10gPSBbXTtcclxuICAgIGxldCBtYXRjaDogUmVnRXhwRXhlY0FycmF5O1xyXG4gICAgd2hpbGUgKG1hdGNoID0gcmVnZXguZXhlYyh0ZXh0KSBhcyBSZWdFeHBFeGVjQXJyYXkpIHtcclxuICAgICAgICBtYXRjaGVzLnB1c2gobWF0Y2gpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIG1hdGNoZXM7XHJcbn1cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9oZWxwZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsdUJBQThCLElBQVksRUFBRSxLQUFhO0lBQ3JELE1BQU0sT0FBTyxHQUFzQixFQUFFLENBQUM7SUFDdEMsSUFBSSxLQUFzQixDQUFDO0lBQzNCLE9BQU8sS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUM5QixPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxNQUFNLENBQUMsT0FBTyxDQUFDO0FBQ25CLENBQUM7QUFQRCxzQ0FPQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBnZXRBbGxNYXRjaGVzKHRleHQ6IHN0cmluZywgcmVnZXg6IFJlZ0V4cCk6IFJlZ0V4cEV4ZWNBcnJheVtdIHtcclxuICAgIGNvbnN0IG1hdGNoZXM6IFJlZ0V4cEV4ZWNBcnJheVtdID0gW107XHJcbiAgICBsZXQgbWF0Y2g6IFJlZ0V4cEV4ZWNBcnJheTtcclxuICAgIHdoaWxlIChtYXRjaCA9IHJlZ2V4LmV4ZWModGV4dCkpIHtcclxuICAgICAgICBtYXRjaGVzLnB1c2gobWF0Y2gpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIG1hdGNoZXM7XHJcbn1cclxuIl19

@@ -11,3 +11,3 @@ "use strict";

Object.defineProperty(exports, "__esModule", { value: true });
const fs = require("mz/fs");
const fs = require("fs-extra");
const path = require("path");

@@ -18,3 +18,2 @@ const os = require("os");

const nodeSass = require("node-sass");
const mkdirp = require("mkdirp");
const Contracts = require("./contracts");

@@ -59,3 +58,3 @@ const bundler_1 = require("./bundler");

// Ensure the directory exists
mkdirp.sync(path.dirname(this.config.Destination));
fs.mkdirpSync(path.dirname(this.config.Destination));
yield fs.writeFile(this.config.Destination, bundleResult.bundledContent);

@@ -134,2 +133,2 @@ const fullPath = path.resolve(this.config.Destination);

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, 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"]}
//# 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 \"fs-extra\";\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\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(): Promise<void> {\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            fs.mkdirpSync(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): Promise<{}> {\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): archy.Data {\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): number {\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): void {\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.1.0",
"version": "2.1.1",
"description": "Bundling SCSS files to one bundled file.",

@@ -8,9 +8,11 @@ "types": "@types/index.d.ts",

"scripts": {
"test": "tsc -p . --noEmit && npm run tslint-test",
"tslint-test": "tslint --config ./tslint.json --project . --exclude test/**/* && echo TsLint test successfully passed.",
"pretest": "npm run build -- --noEmit && npm run build-tests && npm run tslint",
"test": "jest",
"test-ci": "npm run pretest && npm run tslint && jest --maxWorkers=4 -b",
"test-watch": "start npm run build-tests -- --watchAll && jest --watchAll",
"tslint": "tslint --config ./tslint.json --project . --exclude test/**/* && echo TsLint test successfully passed.",
"build": "tsc -p . --newLine lf",
"watch": "tsc -w",
"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"
"prepublishOnly": "npm run build",
"build-tests": "test-generator-cli"
},

@@ -36,11 +38,15 @@ "keywords": [

"devDependencies": {
"@types/archy": "0.0.30",
"@types/mkdirp": "^0.3.29",
"@types/mz": "0.0.30",
"@types/node": "^7.0.8",
"@simplrjs/test-generator-cli": "^0.1.2",
"@types/archy": "0.0.31",
"@types/fs-extra": "^5.0.0",
"@types/jest": "^22.0.1",
"@types/node": "^8.5.7",
"@types/node-sass": "3.10.32",
"@types/promise": "^7.1.27",
"@types/yargs": "6.6.0",
"tslint": "^4.5.1",
"typescript": "^2.2.2"
"@types/promise": "^7.1.30",
"@types/yargs": "10.0.1",
"jest": "^22.0.4",
"simplr-tslint": "0.0.1",
"ts-jest": "^22.0.1",
"tslint": "^5.8.0",
"typescript": "^2.6.2"
},

@@ -52,10 +58,36 @@ "bin": {

"archy": "^1.0.0",
"fs-extra": "^5.0.0",
"globs": "^0.1.3",
"mkdirp": "^0.5.1",
"mz": "^2.6.0",
"node-sass": "^4.5.0",
"node-sass": "^4.7.2",
"pretty-bytes": "^4.0.2",
"promise": "^7.1.1",
"yargs": "^7.0.2"
"promise": "^8.0.1",
"yargs": "^10.0.3"
},
"jest": {
"collectCoverage": true,
"mapCoverage": true,
"transform": {
".(ts|tsx)": "<rootDir>/node_modules/ts-jest/preprocessor.js"
},
"globals": {
"ts-jest": {
"skipBabel": true,
"tsConfigFile": "tests/tsconfig.json"
}
},
"testRegex": "/__tests__/.*\\.(test|spec).(ts|tsx|js)$",
"moduleNameMapper": {
"@src/(.*)": "<rootDir>/src/$1"
},
"coveragePathIgnorePatterns": [
"/node_modules/",
"/tests/"
],
"moduleFileExtensions": [
"ts",
"tsx",
"js"
],
"verbose": true
}
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc