From 3f1568b51aa215d2797b736ec6778ca38ec1799e Mon Sep 17 00:00:00 2001 From: Jonas Jenwald Date: Thu, 13 Feb 2020 17:20:52 +0100 Subject: [PATCH] A couple of small improvements of the `Metadata._repair` method - Remove the "capturing group" in the regular expression that removes leading "junk" from the raw metadata, since it's not necessary here (it's simply a case of too much copy-pasting in a prior patch). According to [MDN](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions/Cheatsheet#Groups_and_ranges) you want to, for performance reasons, avoid "capturing groups" unless actually needed. - Add inline comments to document a bunch of magic values in the code. --- src/display/metadata.js | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/src/display/metadata.js b/src/display/metadata.js index fc09b13e6..39ec932de 100644 --- a/src/display/metadata.js +++ b/src/display/metadata.js @@ -37,7 +37,7 @@ class Metadata { _repair(data) { // Start by removing any "junk" before the first tag (see issue 10395). return data - .replace(/^([^<]+)/, "") + .replace(/^[^<]+/, "") .replace(/>\\376\\377([^<]+)/g, function(all, codes) { const bytes = codes .replace(/\\([0-3])([0-7])([0-7])/g, function(code, d1, d2, d3) { @@ -63,11 +63,11 @@ class Metadata { for (let i = 0, ii = bytes.length; i < ii; i += 2) { const code = bytes.charCodeAt(i) * 256 + bytes.charCodeAt(i + 1); if ( - code >= 32 && - code < 127 && - code !== 60 && - code !== 62 && - code !== 38 + code >= /* Space = */ 32 && + code < /* Delete = */ 127 && + code !== /* '<' = */ 60 && + code !== /* '>' = */ 62 && + code !== /* '&' = */ 38 ) { chars += String.fromCharCode(code); } else {