PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` 'use strict'; exports.type = 'visitor'; exports.name = 'sortDefsChildren'; exports.active = true; exports.description = 'Sorts children of 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). * * @author David Leston * * @type {import('../lib/types').Plugin} */ exports.fn = () => { return { element: { enter: (node) => { if (node.name === 'defs') { /** * @type {Map} */ const frequencies = new Map(); for (const child of node.children) { if (child.type === 'element') { const frequency = frequencies.get(child.name); if (frequency == null) { frequencies.set(child.name, 1); } else { frequencies.set(child.name, frequency + 1); } } } node.children.sort((a, b) => { if (a.type !== 'element' || b.type !== 'element') { return 0; } const aFrequency = frequencies.get(a.name); const bFrequency = frequencies.get(b.name); if (aFrequency != null && bFrequency != null) { const frequencyComparison = bFrequency - aFrequency; if (frequencyComparison !== 0) { return frequencyComparison; } } const lengthComparison = b.name.length - a.name.length; if (lengthComparison !== 0) { return lengthComparison; } if (a.name !== b.name) { return a.name > b.name ? -1 : 1; } return 0; }); } }, }, }; };