Согласно решению @anatoliy, в MacOS X я обнаружил, что пути поиска делают
require('module')._resolveLookupPaths('myModule')
поэтому я получаю разрешенные пути поиска
[ 'myModule',
[ '/Users/admin/.node_modules',
'/Users/admin/.node_libraries',
'/usr/local/lib/node' ] ]
тогда как
require('module')._resolveFilename('myModule')
в любом случае не разрешит модуль, который я искал, на самом деле безумно то, что _loadмодуль не разрешит:
> 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)
пока requireбудет:
> require('myModule')
но у меня нет этого модуля в
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/
так где этот модуль ???
Сначала мне нужно было сделать, $ sudo /usr/libexec/locate.updatedb
Затем, после кофе, я сделал locate myModuleили лучшеlocate myModule/someFile.js
et voilà, получается, что он был в родительской папке моего проекта, то есть вне корневой папки моего проекта:
$pwd
/Users/admin/Projects/Node/myProject
$ ls ../../node_modules/myModule/
так что вы не можете избежать rm -rf ../../node_modules/myModule/и свежего npm install.
Я могу утверждать, что никто не давал указаний npmсканировать мой компьютер в поисках модулей в другом месте, кроме корневой папки моего проекта, в которой он должен был запускаться, или в пути поиска модулей по умолчанию.