@mapl/web 0.2.0 → 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/compiler/jit.js +1 -1
- package/core/handler.d.ts +3 -3
- package/core/handler.js +1 -1
- package/package.json +9 -9
package/compiler/jit.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{compileGroup,createArgSet,AsyncFunction,setHooks,contextInit,setContextInit}from"@mapl/framework";import compile from"@mapl/router/method/compiler";import{countParams}from"@mapl/router/path";import{insertItem}from"@mapl/router/method";import{exportDependency,getDependency,injectDependency,injectExternalDependency}from"runtime-compiler";import{evaluate,evaluateSync}from"runtime-compiler/jit";let urlRouter;let paramArgs=createArgSet(new Array(16).fill(0).map((_1,i)=>`q`+i));let compileReturn=(dat,fnAsync,scopeAsync,contextCreated,result)=>{let typ=dat
|
|
1
|
+
import{compileGroup,createArgSet,AsyncFunction,setHooks,contextInit,setContextInit}from"@mapl/framework";import compile from"@mapl/router/method/compiler";import{countParams}from"@mapl/router/path";import{insertItem}from"@mapl/router/method";import{exportDependency,getDependency,injectDependency,injectExternalDependency}from"runtime-compiler";import{evaluate,evaluateSync}from"runtime-compiler/jit";let urlRouter;let paramArgs=createArgSet(new Array(16).fill(0).map((_1,i)=>`q`+i));let compileReturn=(dat,fnAsync,scopeAsync,contextCreated,result)=>{let typ=dat?.type;if(typ===`raw`)return`return `+result;fnAsync&&(result=`await `+result);let str=typ==null?`return new Response(`+result+(contextCreated?`,c)`:`)`):contextCreated?`hd.push(`+(typ===`json`?`j`:`h`)+`);return new Response(`+(typ===`json`?`JSON.stringify(`+result+`)`:result)+`,c)`:`return new Response(`+(typ===`json`?`JSON.stringify(`+result+`),oj`:result+`,oh`)+`)`;return fnAsync&&!scopeAsync?`return (async()=>{`+str+`})()`:str};let compileToState=router=>{urlRouter={};setHooks({compileHandler:(fn,dat,path,scope)=>{let call=injectExternalDependency(fn)+`(`;let paramCount=countParams(path);paramCount>0&&(call+=paramArgs[paramCount]);if(fn.length>paramCount){call+=paramCount===0?`c`:`,c`;if(!scope[1])return contextInit+compileReturn(dat,fn instanceof AsyncFunction,scope[0],true,call+`)`)}return compileReturn(dat,fn instanceof AsyncFunction,scope[0],scope[1],call+`)`)},compileErrorHandler:(fn,dat,scope)=>{let call=injectExternalDependency(fn)+`(t`;if(fn.length>1){call+=`,c`;if(!scope[1])return contextInit+compileReturn(dat,fn instanceof AsyncFunction,scope[0],true,call+`)`)}return compileReturn(dat,fn instanceof AsyncFunction,scope[0],scope[1],call+`)`)},registerCompiled:(method,path,content)=>insertItem(urlRouter,method,path,content)});setContextInit(`let hd=[],c={status:200,req:r,headers:hd};`);compileGroup(router,[false,false,,`return b`,false],``,``)};export let compileToString=router=>{compileToState(router);return`()=>{var t=["text/html","application/json"].map(c=>["Content-Type",c]),[h,j]=t,[oh,oj]=t.map(c=>({headers:[c]})),[n,b]=[404,400].map(s=>new Response(null,{status:s}));return(r)=>{`+compile(urlRouter,`r.method`,`let u=r.url,s=u.indexOf("/",12)+1,e=u.indexOf("?",s),p=e===-1?u.slice(s):u.slice(s,e);`,1)+`return n}}`};export let compileToDependency=router=>exportDependency(injectDependency(`(`+compileToString(router)+`)()`));export let compileToHandler=async router=>{let id=compileToDependency(router);await evaluate();return getDependency(id)};export let compileToHandlerSync=router=>{let id=compileToDependency(router);evaluateSync();return getDependency(id)};
|
package/core/handler.d.ts
CHANGED
|
@@ -10,7 +10,7 @@ export type Handler<
|
|
|
10
10
|
export type DefineHandler = <
|
|
11
11
|
P extends string,
|
|
12
12
|
S = {}
|
|
13
|
-
>(path: P, handler: Handler<InferPath<P>, Required<S>>,
|
|
13
|
+
>(path: P, handler: Handler<InferPath<P>, Required<S>>, dat?: HandlerData) => HandlerTag<S>;
|
|
14
14
|
export interface HandlerData extends Record<symbol, any> {
|
|
15
15
|
type?: "json" | "html" | "raw" | null;
|
|
16
16
|
}
|
|
@@ -41,7 +41,7 @@ export declare const raw: {
|
|
|
41
41
|
* Handle errors of a router
|
|
42
42
|
* @param f
|
|
43
43
|
*/
|
|
44
|
-
export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandler<E>,
|
|
44
|
+
export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandler<E>, dat?: HandlerData) => RouterTag<never>;
|
|
45
45
|
/**
|
|
46
46
|
* Handle requests to a path with a specific method
|
|
47
47
|
* @param method
|
|
@@ -52,7 +52,7 @@ export declare const error: <const E extends Err>(r: RouterTag<E>, f: ErrorHandl
|
|
|
52
52
|
export declare const route: <
|
|
53
53
|
P extends string,
|
|
54
54
|
S = {}
|
|
55
|
-
>(method: RequestMethod, path: P, handler: Handler<InferPath<P>, Required<S>>,
|
|
55
|
+
>(method: RequestMethod, path: P, handler: Handler<InferPath<P>, Required<S>>, dat: HandlerData) => HandlerTag<S>;
|
|
56
56
|
export declare const any: DefineHandler;
|
|
57
57
|
export declare const get: DefineHandler;
|
|
58
58
|
export declare const post: DefineHandler;
|
package/core/handler.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export let json={type:`json`};export let html={type:`html`};export let raw={type:`raw`};
|
|
1
|
+
export let json={type:`json`};export let html={type:`html`};export let raw={type:`raw`};export let error=(r,f,dat)=>{r[2]=[f,dat];return r};export let route=(method,path,handler,dat)=>[method,path,handler,dat];export let any=(path,handler,dat)=>[``,path,handler,dat];export let get=(path,handler,dat)=>[`GET`,path,handler,dat];export let post=(path,handler,dat)=>[`POST`,path,handler,dat];export let put=(path,handler,dat)=>[`PUT`,path,handler,dat];export let del=(path,handler,dat)=>[`DELETE`,path,handler,dat];export let patch=(path,handler,dat)=>[`PATCH`,path,handler,dat];export let options=(path,handler,dat)=>[`OPTIONS`,path,handler,dat];export let trace=(path,handler,dat)=>[`TRACE`,path,handler,dat];
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mapl/web",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.1",
|
|
4
4
|
"description": "A compiled web framework for all runtimes",
|
|
5
5
|
"keywords": ["fast", "lightweight", "cross-runtime", "framework", "web", "backend"],
|
|
6
6
|
"repository": {
|
|
@@ -21,17 +21,17 @@
|
|
|
21
21
|
"secure-headers": "^0.0.6"
|
|
22
22
|
},
|
|
23
23
|
"exports": {
|
|
24
|
-
"./core/middleware": "./core/middleware.js",
|
|
25
|
-
"./core/context": "./core/context.js",
|
|
26
24
|
"./constants": "./constants.js",
|
|
27
|
-
"./utils/static-headers": "./utils/static-headers.js",
|
|
28
|
-
"./utils/cors": "./utils/cors.js",
|
|
29
|
-
"./core": "./core/index.js",
|
|
30
|
-
"./compiler/aot": "./compiler/aot.js",
|
|
31
|
-
"./core/handler": "./core/handler.js",
|
|
32
25
|
"./core/utils": "./core/utils.js",
|
|
33
26
|
".": "./index.js",
|
|
27
|
+
"./core/handler": "./core/handler.js",
|
|
28
|
+
"./core/context": "./core/context.js",
|
|
29
|
+
"./core": "./core/index.js",
|
|
30
|
+
"./utils/static-headers": "./utils/static-headers.js",
|
|
31
|
+
"./utils/cors": "./utils/cors.js",
|
|
32
|
+
"./core/middleware": "./core/middleware.js",
|
|
34
33
|
"./utils/secure-headers": "./utils/secure-headers.js",
|
|
35
|
-
"./compiler/jit": "./compiler/jit.js"
|
|
34
|
+
"./compiler/jit": "./compiler/jit.js",
|
|
35
|
+
"./compiler/aot": "./compiler/aot.js"
|
|
36
36
|
}
|
|
37
37
|
}
|