doc: add require.extensions to globals
[platform/upstream/nodejs.git] / doc / api / globals.markdown
1 # Global Objects
2
3 <!-- type=misc -->
4
5 These objects are available in all modules. Some of these objects aren't
6 actually in the global scope but in the module scope - this will be noted.
7
8 ## global
9
10 <!-- type=global -->
11
12 * {Object} The global namespace object.
13
14 In browsers, the top-level scope is the global scope. That means that in
15 browsers if you're in the global scope `var something` will define a global
16 variable. In Node this is different. The top-level scope is not the global
17 scope; `var something` inside a Node module will be local to that module.
18
19 ## process
20
21 <!-- type=global -->
22
23 * {Object}
24
25 The process object. See the [process object](process.html#process) section.
26
27 ## console
28
29 <!-- type=global -->
30
31 * {Object}
32
33 Used to print to stdout and stderr. See the [stdio](stdio.html) section.
34
35 ## Class: Buffer
36
37 <!-- type=global -->
38
39 * {Function}
40
41 Used to handle binary data. See the [buffer section](buffer.html).
42
43 ## require()
44
45 <!-- type=var -->
46
47 * {Function}
48
49 To require modules. See the [Modules](modules.html#modules) section.
50 `require` isn't actually a global but rather local to each module.
51
52 ### require.resolve()
53
54 Use the internal `require()` machinery to look up the location of a module,
55 but rather than loading the module, just return the resolved filename.
56
57 ### require.cache
58
59 * {Object}
60
61 Modules are cached in this object when they are required. By deleting a key
62 value from this object, the next `require` will reload the module.
63
64 ### require.extensions
65
66 * {Array}
67
68 Instruct `require` on how to handle certain file extensions.
69
70 Process files with the extension `.sjs` as `.js`:
71
72     require.extensions['.sjs'] = require.extensions['.js'];
73
74 Write your own extension handler:
75
76     require.extensions['.sjs'] = function(module, filename) {
77       var content = fs.readFileSync(filename, 'utf8');
78       // Parse the file content and give to module.exports
79       module.exports = content;
80     };
81
82 ## __filename
83
84 <!-- type=var -->
85
86 * {String}
87
88 The filename of the code being executed.  This is the resolved absolute path
89 of this code file.  For a main program this is not necessarily the same
90 filename used in the command line.  The value inside a module is the path
91 to that module file.
92
93 Example: running `node example.js` from `/Users/mjr`
94
95     console.log(__filename);
96     // /Users/mjr/example.js
97
98 `__filename` isn't actually a global but rather local to each module.
99
100 ## __dirname
101
102 <!-- type=var -->
103
104 * {String}
105
106 The name of the directory that the currently executing script resides in.
107
108 Example: running `node example.js` from `/Users/mjr`
109
110     console.log(__dirname);
111     // /Users/mjr
112
113 `__dirname` isn't actually a global but rather local to each module.
114
115
116 ## module
117
118 <!-- type=var -->
119
120 * {Object}
121
122 A reference to the current module. In particular
123 `module.exports` is the same as the `exports` object.
124 `module` isn't actually a global but rather local to each module.
125
126 See the [module system documentation](modules.html) for more
127 information.
128
129 ## exports
130
131 <!-- type=var -->
132
133 An object which is shared between all instances of the current module and
134 made accessible through `require()`.
135 `exports` is the same as the `module.exports` object.
136 `exports` isn't actually a global but rather local to each module.
137
138 See the [module system documentation](modules.html) for more
139 information.
140
141 See the [module section](modules.html) for more information.
142
143 ## setTimeout(cb, ms)
144 ## clearTimeout(t)
145 ## setInterval(cb, ms)
146 ## clearInterval(t)
147
148 <!--type=global-->
149
150 The timer functions are global variables. See the [timers](timers.html) section.