You need to sign in before continuing.

Blame view

node_modules/html-minifier/src/tokenchain.js 1.77 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
68
69
70
71
  'use strict';
  
  function Sorter() {
  }
  
  Sorter.prototype.sort = function(tokens, fromIndex) {
    fromIndex = fromIndex || 0;
    for (var i = 0, len = this.keys.length; i < len; i++) {
      var key = this.keys[i];
      var token = key.slice(1);
      var index = tokens.indexOf(token, fromIndex);
      if (index !== -1) {
        do {
          if (index !== fromIndex) {
            tokens.splice(index, 1);
            tokens.splice(fromIndex, 0, token);
          }
          fromIndex++;
        } while ((index = tokens.indexOf(token, fromIndex)) !== -1);
        return this[key].sort(tokens, fromIndex);
      }
    }
    return tokens;
  };
  
  function TokenChain() {
  }
  
  TokenChain.prototype = {
    add: function(tokens) {
      var self = this;
      tokens.forEach(function(token) {
        var key = '$' + token;
        if (!self[key]) {
          self[key] = [];
          self[key].processed = 0;
        }
        self[key].push(tokens);
      });
    },
    createSorter: function() {
      var self = this;
      var sorter = new Sorter();
      sorter.keys = Object.keys(self).sort(function(j, k) {
        var m = self[j].length;
        var n = self[k].length;
        return m < n ? 1 : m > n ? -1 : j < k ? -1 : j > k ? 1 : 0;
      }).filter(function(key) {
        if (self[key].processed < self[key].length) {
          var token = key.slice(1);
          var chain = new TokenChain();
          self[key].forEach(function(tokens) {
            var index;
            while ((index = tokens.indexOf(token)) !== -1) {
              tokens.splice(index, 1);
            }
            tokens.forEach(function(token) {
              self['$' + token].processed++;
            });
            chain.add(tokens.slice(0));
          });
          sorter[key] = chain.createSorter();
          return true;
        }
        return false;
      });
      return sorter;
    }
  };
  
  module.exports = TokenChain;