@mapl/router 0.2.0 → 0.2.2

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 CHANGED
@@ -1,3 +1,3 @@
1
1
  # `@mapl/router`
2
2
 
3
- A fast compiled radix tree router.
3
+ A fast radix tree router.
package/compile.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ import type { Router } from './index.js';
2
+ declare const _default: (router: Router) => string;
3
+ export default _default;
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/constants.d.ts CHANGED
@@ -4,3 +4,4 @@ export declare const PATH_LEN = "l";
4
4
  export declare const PARAMS = "q";
5
5
  export declare const PREV_PARAM_IDX = "i";
6
6
  export declare const CURRENT_PARAM_IDX = "j";
7
+ export declare const TMP = "t";
package/constants.js CHANGED
@@ -1 +1 @@
1
- export var REQ="r";export var PATH="p";export var PATH_LEN="l";export var PARAMS="q";export var PREV_PARAM_IDX="i";export var CURRENT_PARAM_IDX="j";
1
+ export var REQ="r";export var PATH="p";export var PATH_LEN="l";export var PARAMS="q";export var PREV_PARAM_IDX="i";export var CURRENT_PARAM_IDX="j";export var TMP="t";
@@ -0,0 +1,6 @@
1
+ import type { Router } from './index.js';
2
+ /**
3
+ * Compile the router but with no pattern matching code
4
+ */
5
+ declare const _default: (router: Router, decls: string[], deps: any[], captures: string) => string;
6
+ export default _default;
@@ -0,0 +1 @@
1
+ export default (router,decls,deps,captures)=>{let builder=router[0].length===0?"":`switch(p){${router[0].map((pair)=>`case "${pair[0].slice(1).replace(/"/g,"\\\"")}":{${pair[1]}break;}`).join("")}}`;if(router[1]===null)return builder;let fns=[];f(router[1],fns);return`${builder}let q=[],t=f${deps.push(matcher)}(f${deps.push(router[1])},p,q,-1,p.length);if(t!==null){t=d${decls.push(`(t,q${captures})=>{switch(t){${fns.map((fn,i)=>`case ${i+1}:{${fn}break;}`).join("")}}}`)}(t,q${captures});if(t!=null)return t;}`};import matcher from"./tree/matcher.js";let f=(node,fns)=>{if(node[1]!==null)node[1]=fns.push(node[1]);if(node[2]!==null){let children=node[2];for(let key in children)f(children[key],fns)}if(node[3]!==null){let params=node[3];if(params[1]!==null)params[1]=fns.push(params[1]);if(params[0]!==null)f(params[0],fns)}if(node[4]!==null)node[4]=fns.push(node[4])};
package/index.d.ts CHANGED
@@ -1,3 +1,3 @@
1
1
  import { type Node } from './tree/node.js';
2
- export type Router = [staticMap: [path: string, item: string][], root: Node | null];
3
- export declare const createRouter: () => Router, insertItem: (router: Router, path: string, item: string) => void, compileRouter: (router: Router) => string;
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 compileNode from"./tree/compiler.js";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])};export var compileRouter=(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,"")}`};
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/package.json CHANGED
@@ -1,15 +1,15 @@
1
1
  {
2
2
  "name": "@mapl/router",
3
- "version": "0.2.0",
3
+ "version": "0.2.2",
4
4
  "main": "./index.js",
5
5
  "devDependencies": {
6
6
  "@stylistic/eslint-plugin": "latest",
7
+ "@types/bun": "latest",
7
8
  "eslint": "latest",
8
- "typescript-eslint": "latest",
9
9
  "eslint-plugin-jsdoc": "latest",
10
- "@types/bun": "latest",
11
10
  "mitata": "latest",
12
- "typescript": "latest"
11
+ "typescript": "latest",
12
+ "typescript-eslint": "latest"
13
13
  },
14
14
  "description": "Fast compiled router for all runtimes",
15
15
  "keywords": [
package/tree/compiler.js CHANGED
@@ -1 +1 @@
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;
1
+ let f=(node,hasParam,hasMultipleParams,startIndexValue,startIndexPrefix)=>{let builder="";if(node[0].length!==1){let part=node[0];let len=part.length;builder+=`if(l>${startIndexPrefix}${startIndexValue+len-1})`;for(let i=1;i<len;i++)builder+=`if(p.charCodeAt(${startIndexPrefix}${startIndexValue+i})===${part.charCodeAt(i)})`;builder+="{";startIndexValue+=len}else startIndexValue++;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 node[0].length===1?builder:builder+"}"};export default f;
@@ -0,0 +1,6 @@
1
+ import type { Node } from './node.js';
2
+ /**
3
+ * Match a pathname and returns the result
4
+ */
5
+ declare const f: (node: Node<unknown>, path: string, params: string[], start: number, len: number) => unknown;
6
+ export default f;
@@ -0,0 +1 @@
1
+ let f=(node,path,params,start,len)=>{let part=node[0];let tmp=part.length;if(tmp!==1&&(start+tmp>len||path.indexOf(part,start)!==start))return null;start+=tmp;if(start===len&&node[1]!==null)return node[1];if(node[2]!==null){tmp=node[2][path.charCodeAt(start)];if(typeof tmp!=="undefined"){tmp=f(tmp,path,params,start,len);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,len);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: string | null,
3
+ store: T | null,
4
4
  children: Node[] | null,
5
- params: ParamNode | null,
6
- wildcardStore: string | null
5
+ params: ParamNode<T> | null,
6
+ wildcardStore: T | null
7
7
  ];
8
- export type ParamNode = [
9
- child: Node | null,
10
- store: string | null
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;