Blame view

node_modules/hash-sum/hash-sum.js 1.21 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
  'use strict';
  
  function pad (hash, len) {
    while (hash.length < len) {
      hash = '0' + hash;
    }
    return hash;
  }
  
  function fold (hash, text) {
    var i;
    var chr;
    var len;
    if (text.length === 0) {
      return hash;
    }
    for (i = 0, len = text.length; i < len; i++) {
      chr = text.charCodeAt(i);
      hash = ((hash << 5) - hash) + chr;
      hash |= 0;
    }
    return hash < 0 ? hash * -2 : hash;
  }
  
  function foldObject (hash, o, seen) {
    return Object.keys(o).sort().reduce(foldKey, hash);
    function foldKey (hash, key) {
      return foldValue(hash, o[key], key, seen);
    }
  }
  
  function foldValue (input, value, key, seen) {
    var hash = fold(fold(fold(input, key), toString(value)), typeof value);
    if (value === null) {
      return fold(hash, 'null');
    }
    if (value === undefined) {
      return fold(hash, 'undefined');
    }
    if (typeof value === 'object') {
      if (seen.indexOf(value) !== -1) {
        return fold(hash, '[Circular]' + key);
      }
      seen.push(value);
      return foldObject(hash, value, seen);
    }
    return fold(hash, value.toString());
  }
  
  function toString (o) {
    return Object.prototype.toString.call(o);
  }
  
  function sum (o) {
    return pad(foldValue(0, o, '', []).toString(16), 8);
  }
  
  module.exports = sum;