make sure the check doesn't blow up

pull/21833/head
Bruno Windels 2019-05-29 12:03:38 +02:00
parent ba54b16275
commit 5c8e280a45
1 changed files with 16 additions and 12 deletions

View File

@ -22,18 +22,22 @@ limitations under the License.
*/ */
function safariVersionCheck(ua) { function safariVersionCheck(ua) {
const safariVersionMatch = ua.match(/Mac OS X ([\d|_]+).*Version\/([\d|\.]+) Safari/); try {
if (safariVersionMatch) { const safariVersionMatch = ua.match(/Mac OS X ([\d|_]+).*Version\/([\d|\.]+) Safari/);
const macOSVersionStr = safariVersionMatch[1]; if (safariVersionMatch) {
const safariVersionStr = safariVersionMatch[2]; const macOSVersionStr = safariVersionMatch[1];
const macOSVersion = macOSVersionStr.split("_").map(n => parseInt(n, 10)); const safariVersionStr = safariVersionMatch[2];
const safariVersion = safariVersionStr.split(".").map(n => parseInt(n, 10)); const macOSVersion = macOSVersionStr.split("_").map(n => parseInt(n, 10));
const colrFontSupported = macOSVersion[0] >= 10 && macOSVersion[1] >= 14 && safariVersion[0] >= 12; const safariVersion = safariVersionStr.split(".").map(n => parseInt(n, 10));
// https://www.colorfonts.wtf/ states safari supports COLR fonts from this version on const colrFontSupported = macOSVersion[0] >= 10 && macOSVersion[1] >= 14 && safariVersion[0] >= 12;
console.log(`Browser is Safari - requiring macOS 10.14 and Safari 12,` + // https://www.colorfonts.wtf/ states safari supports COLR fonts from this version on
`detected Safari ${safariVersionStr} on macOS ${macOSVersionStr},` + console.log(`Browser is Safari - requiring macOS 10.14 and Safari 12,` +
`supported: ${colrFontSupported}`); `detected Safari ${safariVersionStr} on macOS ${macOSVersionStr},` +
return colrFontSupported; `supported: ${colrFontSupported}`);
return colrFontSupported;
}
} catch (err) {
console.error("Couldn't determine Safari version to check COLR font support, assuming no.", err);
} }
return false; return false;
} }