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.2 to 2.1.3

2

@types/bundler.d.ts

@@ -22,3 +22,3 @@ export interface FileRegistry {

constructor(fileRegistry?: FileRegistry);
BundleAll(files: string[], dedupeGlobs: string[]): Promise<BundleResult[]>;
BundleAll(files: string[], dedupeGlobs?: string[]): Promise<BundleResult[]>;
Bundle(file: string, dedupeGlobs?: string[], includePaths?: string[]): Promise<BundleResult>;

@@ -25,0 +25,0 @@ private bundle(filePath, content, dedupeFiles, includePaths);

@@ -28,6 +28,6 @@ "use strict";

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

@@ -43,3 +43,3 @@ }

const [content, dedupeFiles] = yield Promise.all([contentPromise, dedupeFilesPromise]);
return yield this.bundle(file, content, dedupeFiles, includePaths);
return this.bundle(file, content, dedupeFiles, includePaths);
}

@@ -229,2 +229,2 @@ catch (error) {

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 \"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 = /\\/\\/.*$/gm;\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, \"\"));\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"]}
//# 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 \"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 = /\\/\\/.*$/gm;\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 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 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, \"\"));\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"]}
{
"name": "scss-bundle",
"version": "2.1.2",
"version": "2.1.3",
"description": "Bundling SCSS files to one bundled file.",

@@ -5,0 +5,0 @@ "types": "@types/index.d.ts",

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