diff --git a/doc/api/modules.markdown b/doc/api/modules.markdown index 5f2b747eec3..f07fcd252d0 100644 --- a/doc/api/modules.markdown +++ b/doc/api/modules.markdown @@ -212,6 +212,10 @@ the `NODE_PATH` environment variable might have been set to: /home/micheil/.node_modules:/usr/local/lib/node_modules +Loading from the `require.paths` locations is only performed if the +module could not be found using the `node_modules` algorithm above. +Global modules are lower priority than bundled dependencies. + #### **Note:** Please Avoid Modifying `require.paths` For compatibility reasons, `require.paths` is still given first priority diff --git a/lib/module.js b/lib/module.js index 304387d0308..ff5ce856781 100644 --- a/lib/module.js +++ b/lib/module.js @@ -202,7 +202,10 @@ Module._resolveLookupPaths = function(request, parent) { var start = request.substring(0, 2); if (start !== './' && start !== '..') { var paths = Module._paths; - if (parent) paths = paths.concat(parent.paths); + if (parent) { + if (!parent.paths) parent.paths = []; + paths = parent.paths.concat(paths); + } return [request, paths]; } @@ -211,7 +214,7 @@ Module._resolveLookupPaths = function(request, parent) { // make require('./path/to/foo') work - normally the path is taken // from realpath(__filename) but with eval there is no filename var mainPaths = ['.'].concat(Module._paths); - mainPaths = mainPaths.concat(Module._nodeModulePaths('.')); + mainPaths = Module._nodeModulePaths('.').concat(mainPaths); return [request, mainPaths]; }