37 lines
		
	
	
		
			954 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			954 B
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var Token = require('../../tokenizer/token');
 | |
| 
 | |
| var serializeBody = require('../../writer/one-time').body;
 | |
| var serializeRules = require('../../writer/one-time').rules;
 | |
| 
 | |
| function removeDuplicates(tokens) {
 | |
|   var matched = {};
 | |
|   var moreThanOnce = [];
 | |
|   var id, token;
 | |
|   var body, bodies;
 | |
| 
 | |
|   for (var i = 0, l = tokens.length; i < l; i++) {
 | |
|     token = tokens[i];
 | |
|     if (token[0] != Token.RULE) { continue; }
 | |
| 
 | |
|     id = serializeRules(token[1]);
 | |
| 
 | |
|     if (matched[id] && matched[id].length == 1) { moreThanOnce.push(id); } else { matched[id] = matched[id] || []; }
 | |
| 
 | |
|     matched[id].push(i);
 | |
|   }
 | |
| 
 | |
|   for (i = 0, l = moreThanOnce.length; i < l; i++) {
 | |
|     id = moreThanOnce[i];
 | |
|     bodies = [];
 | |
| 
 | |
|     for (var j = matched[id].length - 1; j >= 0; j--) {
 | |
|       token = tokens[matched[id][j]];
 | |
|       body = serializeBody(token[2]);
 | |
| 
 | |
|       if (bodies.indexOf(body) > -1) { token[2] = []; } else { bodies.push(body); }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| module.exports = removeDuplicates;
 |