@matter/tools
Advanced tools
Comparing version 0.12.0-alpha.0-20241228-9f74a0273 to 0.12.0-alpha.0-20241229-9d9c99934
@@ -74,4 +74,5 @@ /** | ||
}; | ||
scripts?: Record<string, string>; | ||
[key: string]: any; | ||
}; | ||
//# sourceMappingURL=package.d.ts.map |
@@ -74,4 +74,5 @@ /** | ||
}; | ||
scripts?: Record<string, string>; | ||
[key: string]: any; | ||
}; | ||
//# sourceMappingURL=package.d.ts.map |
@@ -420,2 +420,2 @@ /** | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/util/package.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { existsSync, readFileSync, statSync } from \"fs\";\nimport { readdir, readFile, stat, writeFile } from \"fs/promises\";\nimport { dirname, join, relative, resolve } from \"path\";\nimport { ignoreError, ignoreErrorSync } from \"./errors.js\";\nimport { isFile, maybeReadJsonSync, maybeStatSync } from \"./file.js\";\nimport { globSync } from \"./glob.js\";\nimport { Progress } from \"./progress.js\";\nimport { toolsPath } from \"./tools-path.cjs\";\n\nexport class JsonNotFoundError extends Error {}\n\nexport const CONFIG_PATH = `src/build.config.ts`;\nexport const CODEGEN_PATH = `codegen`;\n\nconst packageForPath = {} as Record<string, Package | undefined | null>;\n\nfunction findJson(filename: string, path: string = \".\", title?: string) {\n    path = resolve(path);\n    while (true) {\n        const json = ignoreErrorSync([\"ENOENT\", \"ENOTDIR\"], () =>\n            JSON.parse(readFileSync(resolve(path, filename)).toString()),\n        );\n\n        if (json) {\n            if (title === undefined || json.name === title) {\n                return { root: path, json };\n            }\n        }\n        const parent = dirname(path);\n        if (parent === path) {\n            throw new JsonNotFoundError(`Could not locate ${title ?? filename}`);\n        }\n        path = parent;\n    }\n}\n\nfunction isDirectory(path: string) {\n    return !!ignoreErrorSync(\"ENOENT\", () => statSync(path).isDirectory());\n}\n\nexport class Package {\n    path: string;\n    json: PackageJson;\n    supportsEsm: boolean;\n    supportsCjs: boolean;\n    hasSrc: boolean;\n    hasTests: boolean;\n    hasConfig: boolean;\n    isLibrary: boolean;\n    #aliases?: Record<string, string>;\n\n    constructor({\n        path = \".\",\n        name,\n    }: {\n        path?: string;\n        name?: string;\n    } = {}) {\n        const { root, json } = findJson(\"package.json\", path, name);\n        this.path = root;\n        this.json = json;\n\n        const { esm, cjs } = selectFormats(this.json);\n        this.supportsEsm = esm;\n        this.supportsCjs = cjs;\n\n        this.hasSrc = isDirectory(this.resolve(\"src\"));\n        this.hasTests = isDirectory(this.resolve(\"test\"));\n\n        const refs = maybeReadJsonSync(this.resolve(\"tsconfig.json\"))?.references as undefined | { path: string }[];\n        if (refs !== undefined) {\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"src\"))) {\n                this.hasSrc = false;\n            }\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"test\"))) {\n                this.hasTests = false;\n            }\n        }\n\n        this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);\n\n        this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));\n    }\n\n    get name() {\n        return this.json.name;\n    }\n\n    get version() {\n        return this.json.version;\n    }\n\n    get exports() {\n        return this.json.exports;\n    }\n\n    get hasCodegen() {\n        return this.hasDirectory(CODEGEN_PATH);\n    }\n\n    resolve(...paths: string[]) {\n        return resolve(this.path, ...paths);\n    }\n\n    relative(path: string) {\n        return relative(this.path, path);\n    }\n\n    async glob(pattern: string | string[]) {\n        // Glob only understands forward-slash as separator because reasons\n        if (typeof pattern === \"string\") {\n            pattern = this.resolve(pattern).replace(/\\\\/g, \"/\");\n        } else {\n            pattern = pattern.map(s => this.resolve(s).replace(/\\\\/g, \"/\"));\n        }\n\n        // Current glob implementation isn't actually async as this is faster and we only walk small directory trees\n        return globSync(pattern);\n    }\n\n    start(what: string) {\n        const progress = new Progress();\n        progress.startup(what, this);\n        return progress;\n    }\n\n    async lastModified(...paths: string[]) {\n        return this.lastModifiedAbsolute(paths.map(p => this.resolve(p)));\n    }\n\n    private async lastModifiedAbsolute(paths: string[]) {\n        let mtime = 0;\n        await Promise.all(\n            paths.map(async p => {\n                const stats = await ignoreError(\"ENOENT\", async () => await stat(p));\n                if (!stats) {\n                    return;\n                }\n\n                let thisMtime;\n                if (stats.isDirectory()) {\n                    const paths = (await readdir(p)).map(p2 => resolve(p, p2));\n                    thisMtime = await this.lastModifiedAbsolute(paths);\n                } else {\n                    thisMtime = stats.mtimeMs;\n                }\n                if (thisMtime > mtime) {\n                    mtime = thisMtime;\n                }\n            }),\n        );\n        return mtime;\n    }\n\n    get dependencies() {\n        let result = Array<string>();\n        for (const type of [\"dependencies\", \"optionalDependencies\", \"devDependencies\", \"peerDependencies\"]) {\n            if (typeof this.json[type] === \"object\" && this.json[type] !== null) {\n                result = [...result, ...Object.keys(this.json[type])];\n            }\n        }\n        return [...new Set(result)];\n    }\n\n    get workspace() {\n        return Package.workspaceFor(this.path);\n    }\n\n    get isWorkspace() {\n        return Array.isArray(this.json.workspaces);\n    }\n\n    get root(): Package {\n        try {\n            return this.workspace;\n        } catch (e) {\n            if (!(e instanceof JsonNotFoundError)) {\n                throw e;\n            }\n        }\n        return this;\n    }\n\n    static set workingDir(wd: string) {\n        workingDir = wd;\n    }\n\n    static get workspace() {\n        return this.workspaceFor(workingDir);\n    }\n\n    static workspaceFor(cwd: string) {\n        if (!workspace) {\n            workspace = find(cwd, pkg => Array.isArray(pkg.json.workspaces));\n        }\n        return workspace;\n    }\n\n    static get tools() {\n        if (!tools) {\n            tools = new Package({ path: toolsPath });\n        }\n        return tools;\n    }\n\n    static findExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        return this.workspace.resolveImport(name, type);\n    }\n\n    resolveExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        if (!name.startsWith(\".\")) {\n            name = `./${name}`;\n        }\n        const exportDetail = this.exports?.[name];\n\n        if (exportDetail) {\n            const exp = findExportCondition(exportDetail, type);\n            if (exp) {\n                return this.resolve(exp);\n            }\n        }\n\n        if (name === \".\") {\n            if (type === \"esm\" && this.json.module) {\n                return this.resolve(this.json.module);\n            }\n            if (this.json.main) {\n                return this.resolve(this.json.main);\n            }\n        }\n\n        throw new Error(`Cannot resolve export ${name} in package ${this.name}`);\n    }\n\n    findPackage(name: string) {\n        let resolveIn = this.path;\n        while (true) {\n            if (isDirectory(resolve(resolveIn, \"node_modules\", name))) {\n                break;\n            }\n            const nextResolveIn = dirname(resolveIn);\n            if (nextResolveIn === resolveIn) {\n                throw new Error(`Cannot find module ${name} from ${this.path}`);\n            }\n            resolveIn = nextResolveIn;\n        }\n\n        return Package.forPath(resolve(resolveIn, \"node_modules\", name));\n    }\n\n    resolveImport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        const segments = name.split(\"/\");\n        let packageName = segments.shift() as string;\n        if (packageName.startsWith(\"@\") && segments.length) {\n            packageName = `${packageName}/${segments.shift()}`;\n        }\n\n        const pkg = this.findPackage(packageName);\n\n        return pkg.resolveExport(segments.length ? segments.join(\"/\") : \".\", type);\n    }\n\n    hasFile(path: string) {\n        return !!this.#maybeStat(path)?.isFile();\n    }\n\n    hasDirectory(path: string) {\n        return !!this.#maybeStat(path)?.isDirectory();\n    }\n\n    async readFile(path: string) {\n        return readFile(this.resolve(path), \"utf-8\");\n    }\n\n    readFileSync(path: string) {\n        return readFileSync(this.resolve(path), \"utf-8\");\n    }\n\n    async writeFile(path: string, contents: unknown) {\n        await writeFile(this.resolve(path), `${contents}`);\n    }\n\n    async save() {\n        await this.writeFile(join(this.path, \"package.json\"), JSON.stringify(this.json, undefined, 4));\n    }\n\n    async readJson(path: string) {\n        const text = await this.readFile(path);\n        try {\n            return JSON.parse(text);\n        } catch (e) {\n            if (!(e instanceof Error)) {\n                e = new Error(`${e}`);\n            }\n            (e as Error).message = `Error parsing \"${this.resolve(path)}\": ${(e as Error).message}`;\n            throw e;\n        }\n    }\n\n    async writeJson(path: string, value: {}) {\n        await this.writeFile(path, JSON.stringify(value, undefined, 4));\n    }\n\n    static maybeForPath(path: string) {\n        function find(path: string): Package | null {\n            let result = packageForPath[path];\n            if (result === undefined) {\n                if (existsSync(join(path, \"package.json\"))) {\n                    result = new Package({ path });\n                } else {\n                    result = find(dirname(path));\n                }\n                packageForPath[path] = result;\n            }\n            return result;\n        }\n\n        const result = find(path);\n\n        return result ?? undefined;\n    }\n\n    static forPath(path: string) {\n        const result = this.maybeForPath(path);\n        if (result !== undefined) {\n            return result;\n        }\n        throw new Error(`Cannot find package.json for \"${path}\"`);\n    }\n\n    get aliases(): Record<string, string> {\n        if (this.#aliases !== undefined) {\n            return this.#aliases;\n        }\n\n        this.#aliases = {\n            ...Package.maybeForPath(dirname(this.path))?.aliases,\n            ...this.json.imports,\n        };\n\n        return this.#aliases;\n    }\n\n    get modules() {\n        return this.listModules(false);\n    }\n\n    get sourceModules() {\n        return this.listModules(true);\n    }\n\n    /**\n     * Create a map of module name -> implementation file.  If \"source\" is true, searches source files rather than\n     * transpiled files.  We do this rather than finding transpilation files then mapping to source files so this works\n     * even if there isn't a build.\n     */\n    listModules(source: boolean, ...conditions: string[]) {\n        if (!conditions.length) {\n            conditions = [this.supportsEsm ? \"import\" : \"require\", \"default\"];\n        }\n\n        const modules = {} as Record<string, string>;\n\n        const exports = this.exports;\n        if (typeof exports === \"object\" && exports !== null) {\n            findModules(source, new Set(conditions), modules, this.name, this.path, exports);\n        }\n\n        return modules;\n    }\n\n    #maybeStat(path: string) {\n        return maybeStatSync(this.resolve(path));\n    }\n}\n\nexport type PackageJson = {\n    name: string;\n    version: string;\n    imports: Record<string, string>;\n    matter?: {\n        test?: boolean;\n    };\n    [key: string]: any;\n};\n\nlet workingDir = \".\";\nlet workspace: Package | undefined;\nlet tools: Package | undefined;\n\nfunction find(startDir: string, selector: (pkg: Package) => boolean): Package {\n    let pkg = new Package({ path: startDir });\n    while (!selector(pkg)) {\n        pkg = new Package({ path: dirname(pkg.path) });\n    }\n    return pkg;\n}\n\nfunction selectFormats(json: any) {\n    let esm: boolean, cjs: boolean;\n\n    if (json.type === \"module\") {\n        esm = true;\n        cjs =\n            (json.main !== undefined && json.module !== undefined) ||\n            !!Object.values(json.exports ?? {}).find((exp: any) => exp.require);\n    } else {\n        cjs = true;\n        esm = !!json.module || !!Object.values(json.exports ?? {}).find((exp: any) => exp.import);\n    }\n\n    return { esm, cjs };\n}\n\nfunction findExportCondition(detail: Record<string, any>, type: \"esm\" | \"cjs\"): string | undefined {\n    if (type === \"esm\" && detail.import) {\n        let exp = detail.import;\n        if (exp && typeof exp !== \"string\") {\n            exp = findExportCondition(exp, type);\n        }\n        if (exp) {\n            return exp;\n        }\n    }\n\n    let exp = detail.require ?? detail.node ?? detail.default;\n    if (exp && typeof exp !== \"string\") {\n        exp = findExportCondition(exp, type);\n    }\n\n    if (typeof exp === \"string\") {\n        return exp;\n    }\n}\n\ntype Conditions = { [name: string]: Exports };\n\ntype Exports = string | Conditions | Record<string, Conditions>;\n\nfunction findModules(\n    source: boolean,\n    conditions: Set<string>,\n    target: Record<string, string>,\n    prefix: string,\n    path: string,\n    exports: Exports,\n) {\n    if (typeof exports === \"string\") {\n        addModuleGlobs(source, target, prefix, path, exports);\n    } else if (Array.isArray(exports)) {\n        for (const entry of exports) {\n            findModules(source, conditions, target, prefix, path, entry);\n        }\n    } else if (typeof exports === \"object\" && exports !== null) {\n        let selectedCondition = false;\n        for (const key in exports) {\n            if (key.startsWith(\".\")) {\n                findModules(source, conditions, target, join(prefix, key), path, exports[key]);\n            } else if (!selectedCondition && conditions.has(key)) {\n                findModules(source, conditions, target, prefix, path, exports[key]);\n                selectedCondition = true;\n            }\n        }\n    } else {\n        throw new Error(\"Malformed exports field in package.json\");\n    }\n}\n\nfunction addModuleGlobs(source: boolean, target: Record<string, string>, name: string, base: string, pattern: string) {\n    let path = join(base, pattern);\n    if (source) {\n        path = path.replace(/\\/dist\\/(?:esm|cjs)\\//, \"/src/\");\n    }\n\n    if (name.includes(\"*\")) {\n        // Wildcard\n        if (!name.endsWith(\"/*\")) {\n            throw new Error(`Wildcard in module ${name} does not appear as final path segment`);\n        }\n\n        name = name.substring(0, name.length - 2);\n        const paths = globSync(source ? path.replace(/\\.js$/, \".{ts,js,cjs,mjs}\") : path);\n        if (!paths.length) {\n            throw new Error(`No match for module ${name} pattern ${pattern}`);\n        }\n\n        const [prefix, suffix] = path.split(/\\*+/);\n        const prefixLength = prefix === undefined ? 0 : prefix.length;\n        const suffixLength = suffix === undefined ? 0 : suffix.length;\n\n        for (const thisPath of paths) {\n            const qualifier = thisPath.substring(prefixLength, thisPath.length - suffixLength);\n            const thisName = join(name, qualifier);\n            target[thisName] = thisPath;\n        }\n    } else if (path.includes(\"*\")) {\n        // A wildcard path is only valid with wildcard name\n        throw new Error(`Wildcard in module path \"${path}\" but not in module \"${name}\"`);\n    } else {\n        // No wildcard -- remove directory\n        name = name.replace(/\\/(?:export|index)$/, \"\");\n\n        // Look for source if file isn't present\n        let found = false;\n        if (isFile(path)) {\n            found = true;\n        } else if (source && path.endsWith(\".js\")) {\n            path = path.replace(/\\.js$/, \".ts\");\n            if (isFile(path)) {\n                found = true;\n            }\n        }\n\n        if (!found) {\n            throw new Error(`Module \"${name}\" path \"${path}\" not found`);\n        }\n\n        target[name] = path;\n    }\n}\n"],
  "mappings": "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",
  "names": ["paths", "find", "path", "result", "exp"]
}
 | ||
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/util/package.ts"],
  "sourcesContent": ["/**\n * @license\n * Copyright 2022-2024 Matter.js Authors\n * SPDX-License-Identifier: Apache-2.0\n */\n\nimport { existsSync, readFileSync, statSync } from \"fs\";\nimport { readdir, readFile, stat, writeFile } from \"fs/promises\";\nimport { dirname, join, relative, resolve } from \"path\";\nimport { ignoreError, ignoreErrorSync } from \"./errors.js\";\nimport { isFile, maybeReadJsonSync, maybeStatSync } from \"./file.js\";\nimport { globSync } from \"./glob.js\";\nimport { Progress } from \"./progress.js\";\nimport { toolsPath } from \"./tools-path.cjs\";\n\nexport class JsonNotFoundError extends Error {}\n\nexport const CONFIG_PATH = `src/build.config.ts`;\nexport const CODEGEN_PATH = `codegen`;\n\nconst packageForPath = {} as Record<string, Package | undefined | null>;\n\nfunction findJson(filename: string, path: string = \".\", title?: string) {\n    path = resolve(path);\n    while (true) {\n        const json = ignoreErrorSync([\"ENOENT\", \"ENOTDIR\"], () =>\n            JSON.parse(readFileSync(resolve(path, filename)).toString()),\n        );\n\n        if (json) {\n            if (title === undefined || json.name === title) {\n                return { root: path, json };\n            }\n        }\n        const parent = dirname(path);\n        if (parent === path) {\n            throw new JsonNotFoundError(`Could not locate ${title ?? filename}`);\n        }\n        path = parent;\n    }\n}\n\nfunction isDirectory(path: string) {\n    return !!ignoreErrorSync(\"ENOENT\", () => statSync(path).isDirectory());\n}\n\nexport class Package {\n    path: string;\n    json: PackageJson;\n    supportsEsm: boolean;\n    supportsCjs: boolean;\n    hasSrc: boolean;\n    hasTests: boolean;\n    hasConfig: boolean;\n    isLibrary: boolean;\n    #aliases?: Record<string, string>;\n\n    constructor({\n        path = \".\",\n        name,\n    }: {\n        path?: string;\n        name?: string;\n    } = {}) {\n        const { root, json } = findJson(\"package.json\", path, name);\n        this.path = root;\n        this.json = json;\n\n        const { esm, cjs } = selectFormats(this.json);\n        this.supportsEsm = esm;\n        this.supportsCjs = cjs;\n\n        this.hasSrc = isDirectory(this.resolve(\"src\"));\n        this.hasTests = isDirectory(this.resolve(\"test\"));\n\n        const refs = maybeReadJsonSync(this.resolve(\"tsconfig.json\"))?.references as undefined | { path: string }[];\n        if (refs !== undefined) {\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"src\"))) {\n                this.hasSrc = false;\n            }\n            if (!refs.find(ref => this.resolve(ref.path) === this.resolve(\"test\"))) {\n                this.hasTests = false;\n            }\n        }\n\n        this.isLibrary = !!(this.json.main || this.json.module || this.json.exports);\n\n        this.hasConfig = this.hasFile(this.resolve(CONFIG_PATH));\n    }\n\n    get name() {\n        return this.json.name;\n    }\n\n    get version() {\n        return this.json.version;\n    }\n\n    get exports() {\n        return this.json.exports;\n    }\n\n    get hasCodegen() {\n        return this.hasDirectory(CODEGEN_PATH);\n    }\n\n    resolve(...paths: string[]) {\n        return resolve(this.path, ...paths);\n    }\n\n    relative(path: string) {\n        return relative(this.path, path);\n    }\n\n    async glob(pattern: string | string[]) {\n        // Glob only understands forward-slash as separator because reasons\n        if (typeof pattern === \"string\") {\n            pattern = this.resolve(pattern).replace(/\\\\/g, \"/\");\n        } else {\n            pattern = pattern.map(s => this.resolve(s).replace(/\\\\/g, \"/\"));\n        }\n\n        // Current glob implementation isn't actually async as this is faster and we only walk small directory trees\n        return globSync(pattern);\n    }\n\n    start(what: string) {\n        const progress = new Progress();\n        progress.startup(what, this);\n        return progress;\n    }\n\n    async lastModified(...paths: string[]) {\n        return this.lastModifiedAbsolute(paths.map(p => this.resolve(p)));\n    }\n\n    private async lastModifiedAbsolute(paths: string[]) {\n        let mtime = 0;\n        await Promise.all(\n            paths.map(async p => {\n                const stats = await ignoreError(\"ENOENT\", async () => await stat(p));\n                if (!stats) {\n                    return;\n                }\n\n                let thisMtime;\n                if (stats.isDirectory()) {\n                    const paths = (await readdir(p)).map(p2 => resolve(p, p2));\n                    thisMtime = await this.lastModifiedAbsolute(paths);\n                } else {\n                    thisMtime = stats.mtimeMs;\n                }\n                if (thisMtime > mtime) {\n                    mtime = thisMtime;\n                }\n            }),\n        );\n        return mtime;\n    }\n\n    get dependencies() {\n        let result = Array<string>();\n        for (const type of [\"dependencies\", \"optionalDependencies\", \"devDependencies\", \"peerDependencies\"]) {\n            if (typeof this.json[type] === \"object\" && this.json[type] !== null) {\n                result = [...result, ...Object.keys(this.json[type])];\n            }\n        }\n        return [...new Set(result)];\n    }\n\n    get workspace() {\n        return Package.workspaceFor(this.path);\n    }\n\n    get isWorkspace() {\n        return Array.isArray(this.json.workspaces);\n    }\n\n    get root(): Package {\n        try {\n            return this.workspace;\n        } catch (e) {\n            if (!(e instanceof JsonNotFoundError)) {\n                throw e;\n            }\n        }\n        return this;\n    }\n\n    static set workingDir(wd: string) {\n        workingDir = wd;\n    }\n\n    static get workspace() {\n        return this.workspaceFor(workingDir);\n    }\n\n    static workspaceFor(cwd: string) {\n        if (!workspace) {\n            workspace = find(cwd, pkg => Array.isArray(pkg.json.workspaces));\n        }\n        return workspace;\n    }\n\n    static get tools() {\n        if (!tools) {\n            tools = new Package({ path: toolsPath });\n        }\n        return tools;\n    }\n\n    static findExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        return this.workspace.resolveImport(name, type);\n    }\n\n    resolveExport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        if (!name.startsWith(\".\")) {\n            name = `./${name}`;\n        }\n        const exportDetail = this.exports?.[name];\n\n        if (exportDetail) {\n            const exp = findExportCondition(exportDetail, type);\n            if (exp) {\n                return this.resolve(exp);\n            }\n        }\n\n        if (name === \".\") {\n            if (type === \"esm\" && this.json.module) {\n                return this.resolve(this.json.module);\n            }\n            if (this.json.main) {\n                return this.resolve(this.json.main);\n            }\n        }\n\n        throw new Error(`Cannot resolve export ${name} in package ${this.name}`);\n    }\n\n    findPackage(name: string) {\n        let resolveIn = this.path;\n        while (true) {\n            if (isDirectory(resolve(resolveIn, \"node_modules\", name))) {\n                break;\n            }\n            const nextResolveIn = dirname(resolveIn);\n            if (nextResolveIn === resolveIn) {\n                throw new Error(`Cannot find module ${name} from ${this.path}`);\n            }\n            resolveIn = nextResolveIn;\n        }\n\n        return Package.forPath(resolve(resolveIn, \"node_modules\", name));\n    }\n\n    resolveImport(name: string, type: \"cjs\" | \"esm\" = \"esm\") {\n        const segments = name.split(\"/\");\n        let packageName = segments.shift() as string;\n        if (packageName.startsWith(\"@\") && segments.length) {\n            packageName = `${packageName}/${segments.shift()}`;\n        }\n\n        const pkg = this.findPackage(packageName);\n\n        return pkg.resolveExport(segments.length ? segments.join(\"/\") : \".\", type);\n    }\n\n    hasFile(path: string) {\n        return !!this.#maybeStat(path)?.isFile();\n    }\n\n    hasDirectory(path: string) {\n        return !!this.#maybeStat(path)?.isDirectory();\n    }\n\n    async readFile(path: string) {\n        return readFile(this.resolve(path), \"utf-8\");\n    }\n\n    readFileSync(path: string) {\n        return readFileSync(this.resolve(path), \"utf-8\");\n    }\n\n    async writeFile(path: string, contents: unknown) {\n        await writeFile(this.resolve(path), `${contents}`);\n    }\n\n    async save() {\n        await this.writeFile(join(this.path, \"package.json\"), JSON.stringify(this.json, undefined, 4));\n    }\n\n    async readJson(path: string) {\n        const text = await this.readFile(path);\n        try {\n            return JSON.parse(text);\n        } catch (e) {\n            if (!(e instanceof Error)) {\n                e = new Error(`${e}`);\n            }\n            (e as Error).message = `Error parsing \"${this.resolve(path)}\": ${(e as Error).message}`;\n            throw e;\n        }\n    }\n\n    async writeJson(path: string, value: {}) {\n        await this.writeFile(path, JSON.stringify(value, undefined, 4));\n    }\n\n    static maybeForPath(path: string) {\n        function find(path: string): Package | null {\n            let result = packageForPath[path];\n            if (result === undefined) {\n                if (existsSync(join(path, \"package.json\"))) {\n                    result = new Package({ path });\n                } else {\n                    result = find(dirname(path));\n                }\n                packageForPath[path] = result;\n            }\n            return result;\n        }\n\n        const result = find(path);\n\n        return result ?? undefined;\n    }\n\n    static forPath(path: string) {\n        const result = this.maybeForPath(path);\n        if (result !== undefined) {\n            return result;\n        }\n        throw new Error(`Cannot find package.json for \"${path}\"`);\n    }\n\n    get aliases(): Record<string, string> {\n        if (this.#aliases !== undefined) {\n            return this.#aliases;\n        }\n\n        this.#aliases = {\n            ...Package.maybeForPath(dirname(this.path))?.aliases,\n            ...this.json.imports,\n        };\n\n        return this.#aliases;\n    }\n\n    get modules() {\n        return this.listModules(false);\n    }\n\n    get sourceModules() {\n        return this.listModules(true);\n    }\n\n    /**\n     * Create a map of module name -> implementation file.  If \"source\" is true, searches source files rather than\n     * transpiled files.  We do this rather than finding transpilation files then mapping to source files so this works\n     * even if there isn't a build.\n     */\n    listModules(source: boolean, ...conditions: string[]) {\n        if (!conditions.length) {\n            conditions = [this.supportsEsm ? \"import\" : \"require\", \"default\"];\n        }\n\n        const modules = {} as Record<string, string>;\n\n        const exports = this.exports;\n        if (typeof exports === \"object\" && exports !== null) {\n            findModules(source, new Set(conditions), modules, this.name, this.path, exports);\n        }\n\n        return modules;\n    }\n\n    #maybeStat(path: string) {\n        return maybeStatSync(this.resolve(path));\n    }\n}\n\nexport type PackageJson = {\n    name: string;\n    version: string;\n    imports: Record<string, string>;\n    matter?: {\n        test?: boolean;\n    };\n    scripts?: Record<string, string>;\n    [key: string]: any;\n};\n\nlet workingDir = \".\";\nlet workspace: Package | undefined;\nlet tools: Package | undefined;\n\nfunction find(startDir: string, selector: (pkg: Package) => boolean): Package {\n    let pkg = new Package({ path: startDir });\n    while (!selector(pkg)) {\n        pkg = new Package({ path: dirname(pkg.path) });\n    }\n    return pkg;\n}\n\nfunction selectFormats(json: any) {\n    let esm: boolean, cjs: boolean;\n\n    if (json.type === \"module\") {\n        esm = true;\n        cjs =\n            (json.main !== undefined && json.module !== undefined) ||\n            !!Object.values(json.exports ?? {}).find((exp: any) => exp.require);\n    } else {\n        cjs = true;\n        esm = !!json.module || !!Object.values(json.exports ?? {}).find((exp: any) => exp.import);\n    }\n\n    return { esm, cjs };\n}\n\nfunction findExportCondition(detail: Record<string, any>, type: \"esm\" | \"cjs\"): string | undefined {\n    if (type === \"esm\" && detail.import) {\n        let exp = detail.import;\n        if (exp && typeof exp !== \"string\") {\n            exp = findExportCondition(exp, type);\n        }\n        if (exp) {\n            return exp;\n        }\n    }\n\n    let exp = detail.require ?? detail.node ?? detail.default;\n    if (exp && typeof exp !== \"string\") {\n        exp = findExportCondition(exp, type);\n    }\n\n    if (typeof exp === \"string\") {\n        return exp;\n    }\n}\n\ntype Conditions = { [name: string]: Exports };\n\ntype Exports = string | Conditions | Record<string, Conditions>;\n\nfunction findModules(\n    source: boolean,\n    conditions: Set<string>,\n    target: Record<string, string>,\n    prefix: string,\n    path: string,\n    exports: Exports,\n) {\n    if (typeof exports === \"string\") {\n        addModuleGlobs(source, target, prefix, path, exports);\n    } else if (Array.isArray(exports)) {\n        for (const entry of exports) {\n            findModules(source, conditions, target, prefix, path, entry);\n        }\n    } else if (typeof exports === \"object\" && exports !== null) {\n        let selectedCondition = false;\n        for (const key in exports) {\n            if (key.startsWith(\".\")) {\n                findModules(source, conditions, target, join(prefix, key), path, exports[key]);\n            } else if (!selectedCondition && conditions.has(key)) {\n                findModules(source, conditions, target, prefix, path, exports[key]);\n                selectedCondition = true;\n            }\n        }\n    } else {\n        throw new Error(\"Malformed exports field in package.json\");\n    }\n}\n\nfunction addModuleGlobs(source: boolean, target: Record<string, string>, name: string, base: string, pattern: string) {\n    let path = join(base, pattern);\n    if (source) {\n        path = path.replace(/\\/dist\\/(?:esm|cjs)\\//, \"/src/\");\n    }\n\n    if (name.includes(\"*\")) {\n        // Wildcard\n        if (!name.endsWith(\"/*\")) {\n            throw new Error(`Wildcard in module ${name} does not appear as final path segment`);\n        }\n\n        name = name.substring(0, name.length - 2);\n        const paths = globSync(source ? path.replace(/\\.js$/, \".{ts,js,cjs,mjs}\") : path);\n        if (!paths.length) {\n            throw new Error(`No match for module ${name} pattern ${pattern}`);\n        }\n\n        const [prefix, suffix] = path.split(/\\*+/);\n        const prefixLength = prefix === undefined ? 0 : prefix.length;\n        const suffixLength = suffix === undefined ? 0 : suffix.length;\n\n        for (const thisPath of paths) {\n            const qualifier = thisPath.substring(prefixLength, thisPath.length - suffixLength);\n            const thisName = join(name, qualifier);\n            target[thisName] = thisPath;\n        }\n    } else if (path.includes(\"*\")) {\n        // A wildcard path is only valid with wildcard name\n        throw new Error(`Wildcard in module path \"${path}\" but not in module \"${name}\"`);\n    } else {\n        // No wildcard -- remove directory\n        name = name.replace(/\\/(?:export|index)$/, \"\");\n\n        // Look for source if file isn't present\n        let found = false;\n        if (isFile(path)) {\n            found = true;\n        } else if (source && path.endsWith(\".js\")) {\n            path = path.replace(/\\.js$/, \".ts\");\n            if (isFile(path)) {\n                found = true;\n            }\n        }\n\n        if (!found) {\n            throw new Error(`Module \"${name}\" path \"${path}\" not found`);\n        }\n\n        target[name] = path;\n    }\n}\n"],
  "mappings": "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",
  "names": ["paths", "find", "path", "result", "exp"]
}
 |
{ | ||
"name": "@matter/tools", | ||
"version": "0.12.0-alpha.0-20241228-9f74a0273", | ||
"version": "0.12.0-alpha.0-20241229-9d9c99934", | ||
"description": "Matter.js tooling", | ||
@@ -5,0 +5,0 @@ "type": "module", |
@@ -390,2 +390,3 @@ /** | ||
}; | ||
scripts?: Record<string, string>; | ||
[key: string]: any; | ||
@@ -392,0 +393,0 @@ }; |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
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
681908
10366