Blame view

node_modules/lazy-cache/index.js 1.58 KB
aaac7fed   liuqimichale   add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
  '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;