From 064abbb45d22e74feb5f5c978e244df22f8bb7d5 Mon Sep 17 00:00:00 2001 From: Mark Gibson Date: Tue, 5 Dec 2023 17:01:57 +0000 Subject: [PATCH] Massive speed up of byPattern pre-construct URLPatterns and don't construct URL for each req --- README.md | 4 ++-- lib/by_pattern.ts | 9 +++++---- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index d993c42..8888560 100644 --- a/README.md +++ b/README.md @@ -131,8 +131,8 @@ Also, many handlers may also accept additional arguments beyond the first ### Argument shunting -Most of the `by*` helpers will pass arguments on as is, or shunt the -arguments along if they want to introduce their own, so for example, +Most of the `by*` helpers will pass arguments on as is, or shunt the arguments +along if they want to introduce their own, so for example, `byPattern(pattern, handler)` returns a handler with the type: ```ts diff --git a/lib/by_pattern.ts b/lib/by_pattern.ts index acca6fa..10d38e1 100644 --- a/lib/by_pattern.ts +++ b/lib/by_pattern.ts @@ -17,12 +17,13 @@ export function byPattern( ...args: A ) => Awaitable, ) { - return async (req: Request, ...args: A) => { - const patterns = Array.isArray(pattern) ? pattern : [pattern]; - const url = new URL(req.url); + const patterns = Array.isArray(pattern) + ? pattern.map(asURLPattern) + : [asURLPattern(pattern)]; + return async (req: Request, ...args: A) => { for (const pattern of patterns) { - const match = asURLPattern(pattern).exec(url); + const match = pattern.exec(req.url); if (match) { const res = await handler(req, match, ...args);