Closes GH-619 Make require.main be the main module

v0.7.4-release
isaacs 2011-02-02 09:56:32 -08:00 committed by Ryan Dahl
parent 807fca6803
commit f86ec1366f
3 changed files with 20 additions and 3 deletions

View File

@ -155,7 +155,7 @@ Module._resolveLookupPaths = function(request, parent) {
};
Module._load = function(request, parent) {
Module._load = function(request, parent, isMain) {
if (parent) {
debug('Module._load REQUEST ' + (request) + ' parent: ' + parent.id);
}
@ -183,6 +183,12 @@ Module._load = function(request, parent) {
}
var module = new Module(id, parent);
if (isMain) {
process.mainModule = module;
module.id = '.';
}
Module._cache[filename] = module;
module.load(filename);
return module.exports;
@ -306,8 +312,7 @@ Module._extensions['.node'] = function(module, filename) {
// bootstrap main module.
Module.runMain = function() {
// Load the main module--the command line argument.
process.mainModule = new Module('.');
Module._load(process.argv[1]);
Module._load(process.argv[1], null, true);
};
Module._initPaths = function() {

View File

@ -0,0 +1,4 @@
var assert = require('assert');
assert.notEqual(module, require.main, 'require.main should not == module');
assert.notEqual(module, process.mainModule,
'process.mainModule should not === module');

View File

@ -5,6 +5,14 @@ var fs = require('fs');
common.debug('load test-module-loading.js');
// assert that this is the main module.
assert.equal(require.main.id, '.', 'main module should have id of \'.\'');
assert.equal(require.main, module, 'require.main should === module');
assert.equal(process.mainModule, module,
'process.mainModule should === module');
// assert that it's *not* the main module in the required module.
require('../fixtures/not-main-module.js');
// require a file with a request that includes the extension
var a_js = require('../fixtures/a.js');
assert.equal(42, a_js.number);