@mapl/router 0.5.2 → 0.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/constants.js +1 -1
- package/method/compiler.d.ts +1 -1
- package/method/compiler.js +1 -1
- package/method/index.d.ts +3 -2
- package/method/index.js +1 -1
- package/package.json +21 -37
- package/path/compiler.d.ts +1 -1
- package/path/compiler.js +1 -1
- package/path/index.d.ts +2 -2
- package/path/index.js +1 -1
- package/tree/compiler.d.ts +2 -2
- package/tree/compiler.js +1 -1
- package/tree/node.d.ts +2 -11
- package/tree/node.js +1 -1
package/constants.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export let REQ=`r`;export let PATH=`p`;export let PATH_START=`s`;export let PATH_END=`e`;export let URL=`u`;export let PATH_LEN=`l`;export let PARAMS=`q`;export let PREV_PARAM_IDX=`i`;export let CURRENT_PARAM_IDX=`j`;export let TMP=`t`;export let DEP=`f`;export let CTX=`c`;
|
package/method/compiler.d.ts
CHANGED
package/method/compiler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export default (router,methodInput,parsePath,startIndex)=>{let
|
|
1
|
+
import compilePath from"../path/compiler.js";export default (router,methodInput,parsePath,startIndex)=>{let allRouter=router[``];let str=``;for(let key in router)if(key!==``)str+=(str===``?`if(`:`else if(`)+methodInput+`==="`+key+`"){`+(allRouter==null?parsePath:``)+compilePath(router[key],startIndex)+`}`;return allRouter==null?str:parsePath+str+compilePath(allRouter,startIndex)};
|
package/method/index.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import type { Router as PathRouter } from
|
|
2
|
-
export type Router<T = unknown> =
|
|
1
|
+
import type { Router as PathRouter } from "../path/index.js";
|
|
2
|
+
export type Router<T = unknown> = Record<string, PathRouter<T>>;
|
|
3
|
+
export declare const createRouter: <T>() => Router<T>;
|
|
3
4
|
export declare const insertItem: <T>(router: Router<T>, method: string, path: string, item: T) => void;
|
package/method/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{createRouter as createPathRouter,insertItem as insertItemToPath}from"../path/index.js";export
|
|
1
|
+
import{createRouter as createPathRouter,insertItem as insertItemToPath}from"../path/index.js";export let createRouter=()=>({});export let insertItem=(router,method,path,item)=>{insertItemToPath(router[method]??=createPathRouter(),path,item)};
|
package/package.json
CHANGED
|
@@ -1,39 +1,23 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
"compiled",
|
|
23
|
-
"router",
|
|
24
|
-
"node",
|
|
25
|
-
"bun",
|
|
26
|
-
"deno"
|
|
27
|
-
],
|
|
28
|
-
"license": "MIT",
|
|
29
|
-
"scripts": {
|
|
30
|
-
"build:test": "bun scripts/build.ts && bun test",
|
|
31
|
-
"bench": "bun scripts/bench.ts",
|
|
32
|
-
"build:publish": "bun build:test && bun scripts/publish.ts",
|
|
33
|
-
"lint": "eslint ./src",
|
|
34
|
-
"lint:fix": "eslint ./src --fix"
|
|
35
|
-
},
|
|
36
|
-
"sideEffects": false,
|
|
37
|
-
"type": "module",
|
|
38
|
-
"types": "./index.d.ts"
|
|
2
|
+
"name": "@mapl/router",
|
|
3
|
+
"version": "0.5.5",
|
|
4
|
+
"description": "The fastest possible JS router",
|
|
5
|
+
"repository": {
|
|
6
|
+
"type": "git",
|
|
7
|
+
"url": "git+https://github.com/mapljs/router.git"
|
|
8
|
+
},
|
|
9
|
+
"license": "MIT",
|
|
10
|
+
"type": "module",
|
|
11
|
+
"main": "./index.js",
|
|
12
|
+
"types": "./index.d.ts",
|
|
13
|
+
"packageManager": "pnpm@10.12.1+sha512.f0dda8580f0ee9481c5c79a1d927b9164f2c478e90992ad268bbb2465a736984391d6333d2c327913578b2804af33474ca554ba29c04a8b13060a717675ae3ac",
|
|
14
|
+
"exports": {
|
|
15
|
+
"./constants": "./constants.js",
|
|
16
|
+
"./path/compiler": "./path/compiler.js",
|
|
17
|
+
"./method": "./method/index.js",
|
|
18
|
+
"./method/compiler": "./method/compiler.js",
|
|
19
|
+
"./path": "./path/index.js",
|
|
20
|
+
"./tree/node": "./tree/node.js",
|
|
21
|
+
"./tree/compiler": "./tree/compiler.js"
|
|
39
22
|
}
|
|
23
|
+
}
|
package/path/compiler.d.ts
CHANGED
package/path/compiler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export default (router,startIndex)=>{let str
|
|
1
|
+
import{compile}from"../tree/compiler.js";export default (router,startIndex)=>{let str=``;for(let i=0,pairs=router[0];i<pairs.length;i++)str+=(str===``?`if(`:`else if(`)+`p==="`+pairs[i][0].slice(startIndex)+`"){`+pairs[i][1]+`}`;return str+(router[1]===null?``:`{let l=p.length;`+compile(router[1],0,-startIndex,``))+`}`};
|
package/path/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { type Node } from
|
|
1
|
+
import { type Node } from "../tree/node.js";
|
|
2
2
|
export type Router<T = unknown> = [staticMap: [path: string, item: T][], root: Node<T> | null];
|
|
3
3
|
export declare const createRouter: <T>() => Router<T>;
|
|
4
|
-
export declare const insertItem: <T>(router: Router
|
|
4
|
+
export declare const insertItem: <T>(router: Router<T>, path: string, item: T) => void;
|
|
5
5
|
export declare const countParams: (path: string) => number;
|
package/path/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{createNode,insertItem as nodeInsertItem}from"../tree/node.js";export
|
|
1
|
+
import{createNode,insertItem as nodeInsertItem}from"../tree/node.js";export let createRouter=()=>[[],null];export let insertItem=(router,path,item)=>{if(path.includes(`*`))nodeInsertItem(router[1]??=createNode(`/`),path,item);else router[0].push([path,item])};export let countParams=path=>{let cnt=path.endsWith(`**`)?2:0;for(let i=path.length-cnt;(i=path.lastIndexOf(`*`,i-1))!==-1;cnt++);return cnt};
|
package/tree/compiler.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import type { Node } from
|
|
2
|
-
export declare const compile: (node: Node<string>, paramCount: number,
|
|
1
|
+
import type { Node } from "./node.js";
|
|
2
|
+
export declare const compile: (node: Node<string>, paramCount: number, idx: number, idxPrefix: string) => string;
|
package/tree/compiler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
let toChar=
|
|
1
|
+
let toChar=c=>String.fromCharCode(+c[0]);export let compile=(node,paramCount,idx,idxPrefix)=>{let builder=`{`;let noStore=node[1]===null;let partLen=node[0].length;let currentIdx=idxPrefix+(idx+partLen);if(partLen>1){let start=idxPrefix+(idx+1);builder=partLen===2?`if(l`+(noStore?`>`:`>=`)+currentIdx+`)if(p[`+start+`]==="`+node[0][1]+`"){`:(noStore?`if(l>`+currentIdx+`)if(`:`if(`)+`p.startsWith("`+node[0].slice(1)+`",`+start+`)){`}else if(noStore)builder=`if(l>`+currentIdx+`){`;idx+=partLen;if(!noStore)builder+=`if(l===`+currentIdx+`){`+node[1]+`}`;if(node[2]!==null){let childrenEntries=Object.entries(node[2]);if(childrenEntries.length===1)builder+=`if(p[`+currentIdx+`]==="`+toChar(childrenEntries[0])+`"){`+compile(childrenEntries[0][1],paramCount,idx,idxPrefix)+`}`;else{builder+=`switch(p[`+currentIdx+`]){`;for(let i=0;i<childrenEntries.length;i++)builder+=`case"`+toChar(childrenEntries[i])+`":`+compile(childrenEntries[i][1],paramCount,idx,idxPrefix)+`break;`;builder+=`}`}}if(node[3]!==null){let params=node[3];let hasStore=params[1]!==null;let hasChild=params[0]!==null;if(paramCount>0){builder+=`let i=`+currentIdx+`;`;currentIdx=`i`}let slashIndex=`p.indexOf("/"`+(currentIdx===`0`?``:`,`+currentIdx)+`)`;if(hasChild||!hasStore){builder+=(paramCount>0?``:`let `)+`j=`+slashIndex+`;`;slashIndex=`j`}if(hasStore)builder+=`if(`+slashIndex+`===-1){let q`+paramCount+`=`+(currentIdx===`0`?`p`:`p.slice(`+currentIdx+`)`)+`;`+params[1]+`}`;if(hasChild)builder+=(hasStore?`else if(`:`if(`)+`j>`+currentIdx+`){let q`+paramCount+`=p.slice(`+currentIdx+`,j);`+compile(params[0],paramCount+1,0,`j+`)+`}`}if(node[4]!==null)builder+=`let q`+paramCount+`=`+(currentIdx===`0`?`p`:`p.slice(`+currentIdx+`)`)+`;`+node[4];return builder+`}`};
|
package/tree/node.d.ts
CHANGED
|
@@ -1,14 +1,5 @@
|
|
|
1
|
-
export type Node<T = unknown> = [
|
|
2
|
-
|
|
3
|
-
store: T | null,
|
|
4
|
-
children: Node<T>[] | null,
|
|
5
|
-
params: ParamNode<T> | null,
|
|
6
|
-
wildcardStore: T | null
|
|
7
|
-
];
|
|
8
|
-
export type ParamNode<T = unknown> = [
|
|
9
|
-
child: Node<T> | null,
|
|
10
|
-
store: T | null
|
|
11
|
-
];
|
|
1
|
+
export type Node<T = unknown> = [part: string, store: T | null, children: Node<T>[] | null, params: ParamNode<T> | null, wildcardStore: T | null];
|
|
2
|
+
export type ParamNode<T = unknown> = [child: Node<T> | null, store: T | null];
|
|
12
3
|
export declare const createNode: <T>(part: string) => Node<T>;
|
|
13
4
|
export declare const createParamNode: (nextNode: ParamNode[0]) => ParamNode;
|
|
14
5
|
export declare const cloneNode: (node: Node, part: string) => Node;
|
package/tree/node.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export
|
|
1
|
+
export let createNode=part=>[part,null,null,null,null];export let createParamNode=nextNode=>[nextNode,null];export let cloneNode=(node,part)=>[part,node[1],node[2],node[3],node[4]];export let resetNode=(node,part,children)=>{node[0]=part;node[2]=children;node[1]=null;node[3]=null;node[4]=null};export let visitNode=(node,parts)=>{for(let i=0;i<parts.length;++i){let pathPart=parts[i];if(i!==0)if(node[3]===null){let nextNode=createNode(pathPart);node[3]=createParamNode(nextNode);node=nextNode}else node=node[3][0]??=createNode(pathPart);for(let j=0;;++j){let nodePart=node[0];if(j===pathPart.length){if(j<nodePart.length){let children=[];children[nodePart.charCodeAt(j)]=cloneNode(node,nodePart.slice(j));resetNode(node,pathPart,children)}break}if(j===nodePart.length){if(node[2]===null)node[2]=[];else{let nextNode=node[2][pathPart.charCodeAt(j)];if(nextNode!=null){node=nextNode;pathPart=pathPart.slice(j);j=0;continue}}let nextNode=createNode(pathPart.slice(j));node[2][pathPart.charCodeAt(j)]=nextNode;node=nextNode;break}if(pathPart[j]!==nodePart[j]){let children=[];children[nodePart.charCodeAt(j)]=cloneNode(node,nodePart.slice(j));let nextNode=createNode(pathPart.slice(j));children[pathPart.charCodeAt(j)]=nextNode;resetNode(node,nodePart.substring(0,j),children);node=nextNode;break}}}return node};export let insertItem=(node,path,item)=>{if(path[path.length-1]===`*`)if(path[path.length-2]===`*`)visitNode(node,path.slice(0,-2).split(`*`))[4]=item;else (visitNode(node,path.slice(0,-1).split(`*`))[3]??=createParamNode(null))[1]=item;else visitNode(node,path.split(`*`))[1]=item};
|