68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| /**
 | |
|  * Cache results of the first function call to ensure only calling once.
 | |
|  *
 | |
|  * ```js
 | |
|  * var utils = require('lazy-cache')(require);
 | |
|  * // cache the call to `require('ansi-yellow')`
 | |
|  * utils('ansi-yellow', 'yellow');
 | |
|  * // use `ansi-yellow`
 | |
|  * console.log(utils.yellow('this is yellow'));
 | |
|  * ```
 | |
|  *
 | |
|  * @param  {Function} `fn` Function that will be called only once.
 | |
|  * @return {Function} Function that can be called to get the cached function
 | |
|  * @api public
 | |
|  */
 | |
| 
 | |
| function lazyCache(fn) {
 | |
|   var cache = {};
 | |
|   var proxy = function(mod, name) {
 | |
|     name = name || camelcase(mod);
 | |
| 
 | |
|     // check both boolean and string in case `process.env` cases to string
 | |
|     if (process.env.UNLAZY === 'true' || process.env.UNLAZY === true || process.env.TRAVIS) {
 | |
|       cache[name] = fn(mod);
 | |
|     }
 | |
| 
 | |
|     Object.defineProperty(proxy, name, {
 | |
|       enumerable: true,
 | |
|       configurable: true,
 | |
|       get: getter
 | |
|     });
 | |
| 
 | |
|     function getter() {
 | |
|       if (cache.hasOwnProperty(name)) {
 | |
|         return cache[name];
 | |
|       }
 | |
|       return (cache[name] = fn(mod));
 | |
|     }
 | |
|     return getter;
 | |
|   };
 | |
|   return proxy;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Used to camelcase the name to be stored on the `lazy` object.
 | |
|  *
 | |
|  * @param  {String} `str` String containing `_`, `.`, `-` or whitespace that will be camelcased.
 | |
|  * @return {String} camelcased string.
 | |
|  */
 | |
| 
 | |
| function camelcase(str) {
 | |
|   if (str.length === 1) {
 | |
|     return str.toLowerCase();
 | |
|   }
 | |
|   str = str.replace(/^[\W_]+|[\W_]+$/g, '').toLowerCase();
 | |
|   return str.replace(/[\W_]+(\w|$)/g, function(_, ch) {
 | |
|     return ch.toUpperCase();
 | |
|   });
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Expose `lazyCache`
 | |
|  */
 | |
| 
 | |
| module.exports = lazyCache;
 |