Zgodnie z rozwiązaniem @anatoliy, na MacOS XI znalazłem ścieżki wyszukiwania
require('module')._resolveLookupPaths('myModule')
więc otrzymuję rozwiązane ścieżki wyszukiwania
[ 'myModule',
[ '/Users/admin/.node_modules',
'/Users/admin/.node_libraries',
'/usr/local/lib/node' ] ]
natomiast
require('module')._resolveFilename('myModule')
i tak nie rozwiąże modułu, którego szukałem, w rzeczywistości szalone jest to, że _loadnie rozwiąże modułu:
> 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)
podczas gdy requirewola:
> require('myModule')
ale nie mam tego modułu w
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/
więc gdzie jest ten moduł ???
Najpierw musiałem zrobić a $ sudo /usr/libexec/locate.updatedb
potem po kawie zrobiłem locate myModulelub lepiejlocate myModule/someFile.js
et voilà, okazuje się, że znajdował się on w folderze nadrzędnym mojego projektu, tj. poza folderem głównym mojego projektu:
$pwd
/Users/admin/Projects/Node/myProject
$ ls ../../node_modules/myModule/
więc nie możesz uniknąć rm -rf ../../node_modules/myModule/i świeżego npm install.
Mogę argumentować, że nikt nie polecił npmprzeskanować mojego komputera w poszukiwaniu modułów w innym miejscu niż folder główny mojego projektu, w którym miał on zostać uruchomiony, lub w domyślnej ścieżce wyszukiwania modułów.