50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
|
/**
|
||
|
* @fileoverview Helpers for severity values (e.g. normalizing different types).
|
||
|
* @author Bryan Mishkin
|
||
|
*/
|
||
|
|
||
|
"use strict";
|
||
|
|
||
|
/**
|
||
|
* Convert severity value of different types to a string.
|
||
|
* @param {string|number} severity severity value
|
||
|
* @throws error if severity is invalid
|
||
|
* @returns {string} severity string
|
||
|
*/
|
||
|
function normalizeSeverityToString(severity) {
|
||
|
if ([2, "2", "error"].includes(severity)) {
|
||
|
return "error";
|
||
|
}
|
||
|
if ([1, "1", "warn"].includes(severity)) {
|
||
|
return "warn";
|
||
|
}
|
||
|
if ([0, "0", "off"].includes(severity)) {
|
||
|
return "off";
|
||
|
}
|
||
|
throw new Error(`Invalid severity value: ${severity}`);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Convert severity value of different types to a number.
|
||
|
* @param {string|number} severity severity value
|
||
|
* @throws error if severity is invalid
|
||
|
* @returns {number} severity number
|
||
|
*/
|
||
|
function normalizeSeverityToNumber(severity) {
|
||
|
if ([2, "2", "error"].includes(severity)) {
|
||
|
return 2;
|
||
|
}
|
||
|
if ([1, "1", "warn"].includes(severity)) {
|
||
|
return 1;
|
||
|
}
|
||
|
if ([0, "0", "off"].includes(severity)) {
|
||
|
return 0;
|
||
|
}
|
||
|
throw new Error(`Invalid severity value: ${severity}`);
|
||
|
}
|
||
|
|
||
|
module.exports = {
|
||
|
normalizeSeverityToString,
|
||
|
normalizeSeverityToNumber
|
||
|
};
|