Laut @ anatoliy-Lösung hat On MacOS XI die Suchpfade gefunden
require('module')._resolveLookupPaths('myModule')
So erhalte ich die aufgelösten Suchpfade
[ 'myModule',
[ '/Users/admin/.node_modules',
'/Users/admin/.node_libraries',
'/usr/local/lib/node' ] ]
während die
require('module')._resolveFilename('myModule')
wird das Modul, nach dem ich gesucht habe, sowieso nicht auflösen, in der Tat ist das Verrückte, dass _load
das Modul nicht aufgelöst wird:
> require('module')._load('myModule')
Error: Cannot find module 'myModule'
at Function.Module._resolveFilename (module.js:440:15)
at Function.Module._load (module.js:388:25)
at repl:1:19
at sigintHandlersWrap (vm.js:32:31)
at sigintHandlersWrap (vm.js:96:12)
at ContextifyScript.Script.runInContext (vm.js:31:12)
at REPLServer.defaultEval (repl.js:308:29)
at bound (domain.js:280:14)
at REPLServer.runBound [as eval] (domain.js:293:12)
at REPLServer.<anonymous> (repl.js:489:10)
während der require
Wille:
> require('myModule')
aber ich habe dieses Modul nicht in
myProject/node_modules/
myProject/node_modules/@scope/
/usr/local/lib/node_modules/
/usr/local/lib/node_modules/@scope
/usr/local/lib/node_modules/npm/node_modules/
/usr/local/lib/node_modules/npm/node_modules/@scope
$HOME/.npm/
$HOME/.npm/@scope/
also wo ist dieses modul ???
Zuerst musste ich eine machen $ sudo /usr/libexec/locate.updatedb
Dann nach einem Kaffee machte ich locate myModule
oder besserlocate myModule/someFile.js
et voilà, es stellt sich heraus, dass es sich in einem übergeordneten Ordner meines Projekts befand, dh außerhalb meines Projektstammordners:
$pwd
/Users/admin/Projects/Node/myProject
$ ls ../../node_modules/myModule/
Sie können es also nicht vermeiden rm -rf ../../node_modules/myModule/
und ein frisches npm install
.
Ich kann argumentieren, dass niemand angewiesen hat npm
, meinen Computer bei der Suche nach Modulen zu scannen , die nicht in meinem Projektstammordner liegen, in dem er ausgeführt werden sollte, oder im Suchpfad für Standardmodule.