From 9d1b40debe8d9ce53672bce85c0b373524e009eb Mon Sep 17 00:00:00 2001 From: Wylie Conlon Date: Tue, 15 Jun 2021 13:33:57 -0400 Subject: [PATCH] Fix tinymath memoization --- packages/kbn-tinymath/src/index.js | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/packages/kbn-tinymath/src/index.js b/packages/kbn-tinymath/src/index.js index b5807ce79e9eb..6fde4c202e2a7 100644 --- a/packages/kbn-tinymath/src/index.js +++ b/packages/kbn-tinymath/src/index.js @@ -12,8 +12,6 @@ const memoizeOne = require('memoize-one'); const { parse: parseFn } = require('../grammar'); const { functions: includedFunctions } = require('./functions'); -module.exports = { parse, evaluate, interpret }; - function parse(input, options) { if (input == null) { throw new Error('Missing expression'); @@ -24,15 +22,17 @@ function parse(input, options) { } try { - return memoizeOne(parseFn)(input, options); + return parseFn(input, options); } catch (e) { throw new Error(`Failed to parse expression. ${e.message}`); } } +const memoizedParse = memoizeOne(parse); + function evaluate(expression, scope = {}, injectedFunctions = {}) { scope = scope || {}; - return interpret(parse(expression), scope, injectedFunctions); + return interpret(memoizedParse(expression), scope, injectedFunctions); } function interpret(node, scope, injectedFunctions) { @@ -80,3 +80,5 @@ function isOperable(args) { return typeof arg === 'number' && !isNaN(arg); }); } + +module.exports = { parse: memoizedParse, evaluate, interpret };