@mapl/router 0.1.3 → 0.2.1
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/README.md +1 -1
- package/compile.d.ts +3 -0
- package/compile.js +1 -0
- package/index.d.ts +2 -4
- package/index.js +1 -1
- package/match.d.ts +4 -0
- package/match.js +1 -0
- package/package.json +1 -1
- package/tree/compiler.d.ts +1 -1
- package/tree/compiler.js +1 -1
- package/tree/matcher.d.ts +6 -0
- package/tree/matcher.js +1 -0
- package/tree/node.d.ts +7 -7
package/README.md
CHANGED
package/compile.d.ts
ADDED
package/compile.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default (router)=>{let builder=router[0].length===0?"":`switch(p){${router[0].map((pair)=>`case "${pair[0].slice(1).replace(/"/g,"\\\"")}":{${pair[1]}break;}`).join("")}}`;return router[1]===null?builder:`${builder}let l=p.length;${compileNode(router[1],false,false,-1,"")}`};import compileNode from"./tree/compiler.js";
|
package/index.d.ts
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
import { type Node } from './tree/node.js';
|
|
2
|
-
export type Router = [staticMap:
|
|
3
|
-
export declare
|
|
4
|
-
export declare function insertItem(router: Router, path: string, item: string): void;
|
|
5
|
-
export declare function compileRouter(router: Router, contentBuilder: string[]): void;
|
|
2
|
+
export type Router<T = string> = [staticMap: [path: string, item: T][], root: Node<T> | null];
|
|
3
|
+
export declare const createRouter: () => Router, insertItem: (router: Router, path: string, item: string) => void;
|
package/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import
|
|
1
|
+
import{createNode,insertItem as nodeInsertItem}from"./tree/node.js";export var createRouter=()=>[[],null];export var insertItem=(router,path,item)=>{if(path.includes("*"))nodeInsertItem(router[1]??=createNode("/"),path,item);else router[0].push([path,item])};
|
package/match.d.ts
ADDED
package/match.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default (router)=>{let staticMap={};router[0].forEach((item)=>{staticMap[item[0].slice(1)]=item[1]});let rootNode=router[1];return rootNode===null?(path)=>staticMap[path]??null:(path,params)=>staticMap[path]??matchNode(rootNode,path,params,-1)};import matchNode from"./tree/matcher.js";
|
package/package.json
CHANGED
package/tree/compiler.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import type { Node } from './node.js';
|
|
2
|
-
declare const f: (node: Node,
|
|
2
|
+
declare const f: (node: Node, hasParam: boolean, hasMultipleParams: boolean, startIndexValue: number, startIndexPrefix: string) => string;
|
|
3
3
|
export default f;
|
package/tree/compiler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
let f=(node,
|
|
1
|
+
let f=(node,hasParam,hasMultipleParams,startIndexValue,startIndexPrefix)=>{let builder="";let part=node[0];let partLen=part.length;if(partLen!==1){builder+=`if(l>${startIndexPrefix}${startIndexValue+partLen-1})`;for(let i=1;i<partLen;i++)builder+=`if(p.charCodeAt(${startIndexPrefix}${startIndexValue+i})===${part.charCodeAt(i)})`;builder+="{"}startIndexValue+=partLen;if(node[1]!==null)builder+=`if(l===${startIndexPrefix}${startIndexValue}){${node[1]}}`;if(node[2]!==null){let children=node[2];let childrenEntries=Object.entries(children);if(childrenEntries.length===1){builder+=`if(p.charCodeAt(${startIndexPrefix}${startIndexValue})===${childrenEntries[0][0]}){${f(childrenEntries[0][1],hasParam,hasMultipleParams,startIndexValue,startIndexPrefix)}}`}else{builder+=`switch(p.charCodeAt(${startIndexPrefix}${startIndexValue})){`;for(let i=0,l=childrenEntries.length;i<l;i++){builder+=`case ${childrenEntries[i][0]}:${f(childrenEntries[i][1],hasParam,hasMultipleParams,startIndexValue,startIndexPrefix)}break;`}builder+="}"}}if(node[3]!==null){let params=node[3];let hasStore=params[1]!==null;let hasChild=params[0]!==null;let requireAllocation=hasParam?hasMultipleParams:hasChild||!hasStore;if(requireAllocation)builder+="{";if(hasParam)builder+=`${hasMultipleParams?"":"let "}i=${startIndexPrefix}${startIndexValue};`;let currentIndex=hasParam?"i":startIndexPrefix+startIndexValue;let slashIndex=`p.indexOf('/'${currentIndex==="0"?"":","+currentIndex})`;if(hasChild||!hasStore)builder+=`${hasParam?"":"let "}j=${slashIndex};`;if(hasStore){let paramsVal=currentIndex==="0"?"p":`p.slice(${currentIndex})`;builder+=`if(${hasChild?"j":slashIndex}===-1){${hasParam?`q.push(${paramsVal})`:`let q=[${paramsVal}]`};${params[1]}}`}if(hasChild){let paramsVal=`p.substring(${currentIndex},j)`;builder+=`if(j${hasStore?"!==":">"}${currentIndex}){${hasParam?`q.push(${paramsVal})`:`let q=[${paramsVal}]`};${f(params[0],true,hasParam,0,"j+")}${requireAllocation?"":"q.pop();"}}`}if(requireAllocation)builder+="}"}if(node[4]!==null){let noStore=node[1]===null;let currentIndex=startIndexPrefix+startIndexValue;let paramsVal=currentIndex==="0"?"p":`p.slice(${currentIndex})`;let body=`${hasParam?`q.push(${paramsVal})`:`let q=[${paramsVal}]`};${node[4]}`;builder+=noStore?`if(l!==${currentIndex}){${body}}`:body}return partLen===1?builder:builder+"}"};export default f;
|
package/tree/matcher.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
let f=(node,path,params,start)=>{let part=node[0];let tmp=part.length;if(tmp>1&&(start+tmp>path.length||path.indexOf(part,start)!==start))return null;start+=tmp;if(start===path.length)return node[1];if(node[2]!==null){tmp=node[2][path.charCodeAt(start)];if(typeof tmp!=="undefined"){tmp=f(tmp,path,params,start);if(tmp!==null)return tmp}}if(node[3]!==null){tmp=path.indexOf("/",start);if(tmp===-1){if(node[3][1]!==null){params.push(path.substring(start));return node[3][1]}}else if(tmp!==start&&node[3][0]!==null){params.push(path.substring(start,tmp));tmp=f(node[3][0],path,params,tmp);if(tmp!==null)return tmp;params.pop()}}if(node[4]!==null){params.push(path.substring(start));return node[4]}return null};export default f;
|
package/tree/node.d.ts
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export type Node = [
|
|
1
|
+
export type Node<T = string> = [
|
|
2
2
|
part: string,
|
|
3
|
-
store:
|
|
3
|
+
store: T | null,
|
|
4
4
|
children: Node[] | null,
|
|
5
|
-
params: ParamNode | null,
|
|
6
|
-
wildcardStore:
|
|
5
|
+
params: ParamNode<T> | null,
|
|
6
|
+
wildcardStore: T | null
|
|
7
7
|
];
|
|
8
|
-
export type ParamNode = [
|
|
9
|
-
child: Node | null,
|
|
10
|
-
store:
|
|
8
|
+
export type ParamNode<T = string> = [
|
|
9
|
+
child: Node<T> | null,
|
|
10
|
+
store: T | null
|
|
11
11
|
];
|
|
12
12
|
export declare const createNode: (part: string) => Node, createParamNode: (nextNode: ParamNode[0]) => ParamNode, cloneNode: (node: Node, part: string) => Node, resetNode: (node: Node, part: string, children: Node[2]) => void, visitNode: (node: Node, path: string) => Node, insertItem: (node: Node, path: string, item: string) => void;
|