| /** | |
| * Evaluates a mathematical expression provided as a string and returns the result. | |
| * | |
| * If the input is already a number, it returns the number as is. | |
| * If the input is not a string or contains invalid characters, an error is thrown. | |
| * If the evaluated result is not a number, an error is thrown. | |
| * | |
| * @param {string|number} str - The mathematical expression to evaluate, or a number. | |
| * @param {number} [fallbackValue] - The default value to return if the input is not a string or number, or if the evaluated result is not a number. | |
| * | |
| * @returns {number} The result of the evaluated expression or the input number. | |
| * | |
| * @throws {Error} Throws an error if the input is not a string or number, contains invalid characters, or does not evaluate to a number. | |
| */ | |
| function math(str, fallbackValue) { | |
| const fallback = typeof fallbackValue !== 'undefined' && typeof fallbackValue === 'number'; | |
| if (typeof str !== 'string' && typeof str === 'number') { | |
| return str; | |
| } else if (typeof str !== 'string') { | |
| if (fallback) { | |
| return fallbackValue; | |
| } | |
| throw new Error(`str is ${typeof str}, but should be a string`); | |
| } | |
| const validStr = /^[+\-\d.\s*/%()]+$/.test(str); | |
| if (!validStr) { | |
| if (fallback) { | |
| return fallbackValue; | |
| } | |
| throw new Error('Invalid characters in string'); | |
| } | |
| const value = eval(str); | |
| if (typeof value !== 'number') { | |
| if (fallback) { | |
| return fallbackValue; | |
| } | |
| console.error('str', str); | |
| throw new Error(`str did not evaluate to a number but to a ${typeof value}`); | |
| } | |
| return value; | |
| } | |
| module.exports = math; | |