@Anatoliy çözümüne göre, MacOS XI'de arama yollarını yapıyor bulduk
require('module')._resolveLookupPaths('myModule')
bu yüzden çözülmüş arama yollarını alıyorum
[ 'myModule',
[ '/Users/admin/.node_modules',
'/Users/admin/.node_libraries',
'/usr/local/lib/node' ] ]
oysa
require('module')._resolveFilename('myModule')
zaten aradığım modülü çözmeyecek, aslında çılgınca olan şey _loadmodülü çözmeyecek olmasıdır:
> 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)
requirevasiyet sırasında :
> require('myModule')
ama bu modül bende yok
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/
peki bu modül nerede ???
Önce bir yapmak zorunda kaldım $ sudo /usr/libexec/locate.updatedb
Sonra biraz kahveden sonra yaptım locate myModuleya da daha iyisilocate myModule/someFile.js
et voilà, projemin üst klasöründe, yani proje kök klasörümün dışında olduğu ortaya çıktı:
$pwd
/Users/admin/Projects/Node/myProject
$ ls ../../node_modules/myModule/
Dolayısıyla da kaçınamaz rm -rf ../../node_modules/myModule/ve taze bir npm install.
Hiç kimsenin npm, çalışmasının beklendiği proje kök klasörümden veya varsayılan modül arama yolundan başka bir yerde modülleri aramak için bilgisayarımı taramasını istemediğini iddia edebilirim .