From 61e6ea1e9b7af01baf19ab0c0a63c8e3ebfac97c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Vinicius=20Louren=C3=A7o?= <12551007+H4ad@users.noreply.github.com> Date: Mon, 10 Apr 2023 14:56:11 -0300 Subject: [PATCH] fix: faster cache key factory for range (#536) --- classes/range.js | 8 ++++++-- internal/constants.js | 2 ++ 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/classes/range.js b/classes/range.js index a791d912..d9e866de 100644 --- a/classes/range.js +++ b/classes/range.js @@ -81,8 +81,10 @@ class Range { // memoize range parsing for performance. // this is a very hot path, and fully deterministic. - const memoOpts = Object.keys(this.options).join(',') - const memoKey = `parseRange:${memoOpts}:${range}` + const memoOpts = + (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) | + (this.options.loose && FLAG_LOOSE) + const memoKey = memoOpts + ':' + range const cached = cache.get(memoKey) if (cached) { return cached @@ -190,6 +192,7 @@ class Range { return false } } + module.exports = Range const LRU = require('lru-cache') @@ -206,6 +209,7 @@ const { tildeTrimReplace, caretTrimReplace, } = require('../internal/re') +const { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = require('../internal/constants') const isNullSet = c => c.value === '<0.0.0-0' const isAny = c => c.value === '' diff --git a/internal/constants.js b/internal/constants.js index cb2d76c2..25fab1ea 100644 --- a/internal/constants.js +++ b/internal/constants.js @@ -25,4 +25,6 @@ module.exports = { MAX_SAFE_INTEGER, RELEASE_TYPES, SEMVER_SPEC_VERSION, + FLAG_INCLUDE_PRERELEASE: 0b001, + FLAG_LOOSE: 0b010, }