Some checks failed
Test Suite / unit-tests (3.11) (push) Has been cancelled
Test Suite / unit-tests (3.12) (push) Has been cancelled
Test Suite / code-quality (push) Has been cancelled
Test Suite / security-scan (push) Has been cancelled
Test Suite / integration-tests (push) Has been cancelled
Test Suite / e2e-tests (push) Has been cancelled
Test Suite / performance-tests (push) Has been cancelled
Test Suite / test-summary (push) Has been cancelled
- Add comprehensive image test document with various image types - Update project structure with development artifacts - Prepare foundation for image support enhancement phase - Include test files for validating image editing workflows 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
25 lines
1.4 KiB
JavaScript
25 lines
1.4 KiB
JavaScript
'use strict';
|
|
const path = require('path');
|
|
const {fileURLToPath} = require('url');
|
|
const resolveCwd = require('resolve-cwd');
|
|
const pkgDir = require('pkg-dir');
|
|
|
|
module.exports = filename => {
|
|
const normalizedFilename = filename.startsWith('file://') ? fileURLToPath(filename) : filename;
|
|
const globalDir = pkgDir.sync(path.dirname(normalizedFilename));
|
|
const relativePath = path.relative(globalDir, normalizedFilename);
|
|
const pkg = require(path.join(globalDir, 'package.json'));
|
|
const localFile = resolveCwd.silent(path.join(pkg.name, relativePath));
|
|
const localNodeModules = path.join(process.cwd(), 'node_modules');
|
|
|
|
const filenameInLocalNodeModules = !path.relative(localNodeModules, normalizedFilename).startsWith('..') &&
|
|
// On Windows, if `localNodeModules` and `normalizedFilename` are on different partitions, `path.relative()` returns the value of `normalizedFilename`, resulting in `filenameInLocalNodeModules` incorrectly becoming `true`.
|
|
path.parse(localNodeModules).root === path.parse(normalizedFilename).root;
|
|
|
|
// Use `path.relative()` to detect local package installation,
|
|
// because __filename's case is inconsistent on Windows
|
|
// Can use `===` when targeting Node.js 8
|
|
// See https://github.com/nodejs/node/issues/6624
|
|
return !filenameInLocalNodeModules && localFile && path.relative(localFile, normalizedFilename) !== '' && require(localFile);
|
|
};
|