From 31ed87b0a964a9989c56a6e08906b96c492186ee Mon Sep 17 00:00:00 2001 From: Trevor Burnham Date: Sun, 1 May 2011 14:03:08 -0400 Subject: [PATCH] Documenting `require.main`, fixing #997 --- doc/api/modules.markdown | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/doc/api/modules.markdown b/doc/api/modules.markdown index 07ff31fe54d..89490ebafc9 100644 --- a/doc/api/modules.markdown +++ b/doc/api/modules.markdown @@ -305,6 +305,21 @@ the same process. As the application stack grows, we tend to assemble functionality, and it is a problem with those parts interact in ways that are difficult to predict. +### Accessing the main module + +When a file is run directly from Node, `require.main` is set to its +`module`. That means that you can determine whether a file has been run +directly by testing + + require.main === module + +For a file `foo.js`, this will be `true` if run via `node foo.js`, but +`false` if run by `require('./foo')`. + +Because `module` provides a `filename` property (normally equivalent to +`__filename`), the entry point of the current application can be obtained +by checking `require.main.filename`. + ## Addenda: Package Manager Tips The semantics of Node's `require()` function were designed to be general