mirror of
				https://github.com/StackExchange/dnscontrol.git
				synced 2025-10-25 21:46:57 +08:00 
			
		
		
		
	Documentation: Clarify require() name and usage (#690)
* Clarify require() doc * fixup! Co-authored-by: Tom Limoncelli <tlimoncelli@stackoverflow.com>
This commit is contained in:
		
							parent
							
								
									14e48b9b07
								
							
						
					
					
						commit
						01b6669dfa
					
				
					 1 changed files with 27 additions and 3 deletions
				
			
		|  | @ -4,9 +4,19 @@ parameters: | ||||||
|   - path |   - path | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| `require(...)` behaves similarly to its equivalent in node.js. You can use it | `require(...)` loads the specified JavaScript or JSON file, allowing | ||||||
| to split your configuration across multiple files. If the path starts with a | to split your configuration across multiple files. | ||||||
| `.`, it is calculated relative to the current file. For example: | 
 | ||||||
|  | If the supplied `path` string ends with `.js`, the file is interpreted | ||||||
|  | as JavaScript code, almost as though its contents had been included in | ||||||
|  | the currently-executing file.  If  the path string ends with `.json`, | ||||||
|  | `require()` returns the `JSON.parse()` of the file's contents. | ||||||
|  | 
 | ||||||
|  | If the path string begins with a `.`, it is interpreted relative to | ||||||
|  | the currently-loading file (which may not be the file where the | ||||||
|  | `require()` statement is, if called within a function), otherwise it | ||||||
|  | is interpreted relative to the program's working directory at the time | ||||||
|  | of the call. | ||||||
| 
 | 
 | ||||||
| {% include startExample.html %} | {% include startExample.html %} | ||||||
| {% highlight js %} | {% highlight js %} | ||||||
|  | @ -76,3 +86,17 @@ for (var domain in domains) { | ||||||
| } | } | ||||||
| {%endhighlight} | {%endhighlight} | ||||||
| {% include endExample.html %} | {% include endExample.html %} | ||||||
|  | 
 | ||||||
|  | # Future | ||||||
|  | 
 | ||||||
|  | It might be better to rename the function to something like | ||||||
|  | `include()` instead, (leaving `require` as a deprecated alias) because | ||||||
|  | by analogy it is *much* closer to PHP's `include()` function than it | ||||||
|  | is to node's `require()`.  After all, the reason node.js calls it | ||||||
|  | "require" is because it's a declarative statement saying the file is | ||||||
|  | needed, and so should be loaded if it hasn't already been loaded. | ||||||
|  | 
 | ||||||
|  | In contrast, dnscontrol's require is actually an imperative command to | ||||||
|  | load the file and execute the code or parse the data from it.  (So if | ||||||
|  | two files both `require("./tools.js")`, for example, then it will be | ||||||
|  | loaded twice, whereas in node.js it would only be loaded once.) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue