You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
48 lines
1.4 KiB
48 lines
1.4 KiB
'use strict';
|
|
|
|
exports.type = 'perItem';
|
|
|
|
exports.active = true;
|
|
|
|
exports.description = 'Sorts children of <defs> to improve compression';
|
|
|
|
/**
|
|
* Sorts children of defs in order to improve compression.
|
|
* Sorted first by frequency then by element name length then by element name (to ensure grouping).
|
|
*
|
|
* @param {Object} item current iteration item
|
|
* @return {Boolean} if false, item will be filtered out
|
|
*
|
|
* @author David Leston
|
|
*/
|
|
exports.fn = function(item) {
|
|
|
|
if (item.isElem('defs')) {
|
|
|
|
if (item.content) {
|
|
var frequency = item.content.reduce(function (frequency, child) {
|
|
if (child.elem in frequency) {
|
|
frequency[child.elem]++;
|
|
} else {
|
|
frequency[child.elem] = 1;
|
|
}
|
|
return frequency;
|
|
}, {});
|
|
item.content.sort(function (a, b) {
|
|
var frequencyComparison = frequency[b.elem] - frequency[a.elem];
|
|
if (frequencyComparison !== 0 ) {
|
|
return frequencyComparison;
|
|
}
|
|
var lengthComparison = b.elem.length - a.elem.length;
|
|
if (lengthComparison !== 0) {
|
|
return lengthComparison;
|
|
}
|
|
return a.elem != b.elem ? a.elem > b.elem ? -1 : 1 : 0;
|
|
});
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
};
|