Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cannot find package 'mem-fs' imported from #800

Open
chk4658 opened this issue Dec 19, 2023 · 14 comments
Open

Cannot find package 'mem-fs' imported from #800

chk4658 opened this issue Dec 19, 2023 · 14 comments

Comments

@chk4658
Copy link

chk4658 commented Dec 19, 2023

Type of issue

npm install -g yo generator-code

and yo code failed

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>yo code
Error [ERR_MODULE_NOT_FOUND]: Cannot find package 'mem-fs' imported from C:\Users\KHC1SZH\chenkai\node-v14.17.2-win-x64\node_global\node_modules\yo\node_modules\yeoman-environment\dist\environment-base.js
at packageResolve (internal/modules/esm/resolve.js:650:9)
at moduleResolve (internal/modules/esm/resolve.js:691:18)
at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:805:11)
at Loader.resolve (internal/modules/esm/loader.js:88:40)
at Loader.getModuleJob (internal/modules/esm/loader.js:241:28)
at ModuleWrap. (internal/modules/esm/module_job.js:72:40)
at link (internal/modules/esm/module_job.js:71:36)


My environment

  • OS version/details: eg. Windows 10 64-bit
  • Node version: x.x.x (run node --version in your terminal)
  • npm version: x.x.x (run npm --version in your terminal)
  • Version of yo : x.x.x (run yo --version in your terminal)

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>node --version
v14.17.2

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>npm --version
6.14.13

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>yo --version
5.0.0

Expected behavior

Need an upgrade for node? or downgrade yo. What should I do?

Current behavior

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>npm install -g mem-fs
npm WARN notsup Unsupported engine for [email protected]: wanted: {"node":">=18.0.0"} (current: {"node":"14.17.2","npm":"6.14.13"})
npm WARN notsup Not compatible with your version of node/npm: [email protected]

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>yo code
Error [ERR_MODULE_NOT_FOUND]: Cannot find package 'stream' imported from C:\Users\KHC1SZH\chenkai\node-v14.17.2-win-x64\node_global\node_modules\mem-fs\dist\index.js
at packageResolve (internal/modules/esm/resolve.js:650:9)
at moduleResolve (internal/modules/esm/resolve.js:691:18)
at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:805:11)
at Loader.resolve (internal/modules/esm/loader.js:88:40)
at Loader.getModuleJob (internal/modules/esm/loader.js:241:28)
at ModuleWrap. (internal/modules/esm/module_job.js:72:40)
at link (internal/modules/esm/module_job.js:71:36)

Steps to reproduce the behavior

Command line output

Paste your error output over here
@1071125093
Copy link

same

@1071125093
Copy link

stiff but fixed
1.need nvm, install node 20.5.0
2.reinstall yo generator-code

@filipboca
Copy link

Same for me, still does not work on 20.5

@atulbhatt-system32
Copy link

I am also facing the same issue

@mshima
Copy link
Member

mshima commented Jan 3, 2024

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>node --version v14.17.2

C:\Users\KHC1SZH\chenkai\Projects\vscodePluginsDemo>npm --version 6.14.13

yo@5 requires node 18 and npm should be at least v7, latest is recommended.

@atulbhatt-system32
Copy link

I tried with node -v (21.5.0) and npm -v (10.2.4) but what worked for me was downgrading yo to version 4.3.1

@atulbhatt-system32
Copy link

@mshima is node 18 the minimum requirement or greater also works for yo@5 as in my case it didn't.
node -v (21.5.0) and npm -v (10.2.4)

@mshima
Copy link
Member

mshima commented Jan 4, 2024

yo must be installed with newer npm (must support peer dependencies).

npm install -g npm@latest
npm uninstall -g yo generator-code
npm install -g yo generator-code
npm uninstall yo generator-code # make sure it’s not installed locally
yo code

@isMattCoding
Copy link

Playing with the npm and node versions didn't work for me.

It seems that this issue still persists, but what allowed me to continue was running:

npm install -g yo generator-code mem-fs
yo code

@erikJonsberg
Copy link

Playing with the npm and node versions didn't work for me.

It seems that this issue still persists, but what allowed me to continue was running:

npm install -g yo generator-code mem-fs
yo code

This worked for me as well. However, I need to reinstall mem-fs globally each time I run yo code. Does anyone know why? It should already be installed, right?

@schroeder-g
Copy link

Playing with the npm and node versions didn't work for me.
It seems that this issue still persists, but what allowed me to continue was running:

npm install -g yo generator-code mem-fs
yo code

This worked for me as well. However, I need to reinstall mem-fs globally each time I run yo code. Does anyone know why? It should already be installed, right?

The above alone didn't resolve the issue for me. The fix that I found was to:

  1. Uninstall all the relevant packages, nvm use v20.14.0, npm install -g yo generator-code mem-fs
  2. navigate to the install location for yeoman indicated in the error: code /path/to/node_modules/yeoman-generator
  3. npm install mem-fs
  4. npm run build to recompile dist with tsc.
  5. yo > choose generator.

Hilariously, there's no tsconfig.json in the project, so the build step resulted in me transpiling all TypeScript files in my home directory. Would recommend just copying theirs into the project root to avoid this issue.

@wesleyscholl
Copy link

npm install -g yo generator-code mem-fs

This worked for me, thanks!

@JoshuaKGoldberg
Copy link

This doesn't reproduce for me.

  • OS: macOS Ventura 13.2
  • Node.js: 20, 22, and 23

But, I think it's really an issue with generators and not with yo itself. I think the root of this issue is as follows:

  • The mem-fs project is not a production dependency (dependencies) of yeoman-generator, just a peer dependency (peerDependencies)
    • This is good and expected because it allows generators to define their expected mem-fs dependency range themselves
  • Some generators don't explicitly declare a production dependency on mem-fs, instead assuming it to be coincidentally available in node_modules/
  • That assumption used to be reliable, but in more recent versions of package, is not - resulting in Cannot find package 'mem-fs'

If I'm right, the correct resolution for this issue is to get generators such as https://github.com/microsoft/vscode-generator-code to explicitly declare their dependency on mem-fs. I.e. running npm i mem-fs (or equivalent).

Tagging in @UlisesGascon for another set of eyes, does that seem right to you?

See also: yeoman/generator#1493, yeoman/generator#1502.

@UlisesGascon
Copy link
Member

the correct resolution for this issue is to get generators such as microsoft/vscode-generator-code to explicitly declare their dependency on mem-fs.

+1 I think is the best solution

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Up Next
Development

No branches or pull requests