runtime-compiler 3.0.0 → 3.0.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/derive.d.ts ADDED
@@ -0,0 +1,59 @@
1
+ import { type Expression, type Value } from "./index.ts";
2
+ /**
3
+ * Derive a value from other expressions.
4
+ * Use in `default` and `build` mode.
5
+ *
6
+ * @example
7
+ * const newValue = derive(
8
+ * ['Math.random()' as Expression<number>],
9
+ * (rand) => rand * 10
10
+ * ); // '$[0](Math.random())'
11
+ *
12
+ * // In hydrate mode
13
+ * injectExternal((rand) => rand * 10);
14
+ */
15
+ export declare const derive: <
16
+ const Expressions extends Expression<any>[],
17
+ R
18
+ >(values: Expressions, fn: (...args: { [K in keyof Expressions] : Expressions[K]["~type"] }) => R) => Value<R>;
19
+ /**
20
+ * Derive a value from other expressions.
21
+ * Use in `default` and `build` mode.
22
+ *
23
+ * @example
24
+ * const newValue = deriveAsync(
25
+ * ['await fetch("http://example.com")' as Expression<Response>],
26
+ * async (res) => await res.text()
27
+ * ); // 'await $[0](await fetch("http://example.com"))'
28
+ *
29
+ * // In hydrate mode
30
+ * injectExternal((rand) => rand * 10);
31
+ */
32
+ export declare const deriveAsync: <
33
+ const Expressions extends Expression<any>[],
34
+ R
35
+ >(values: Expressions, fn: (...args: { [K in keyof Expressions] : Expressions[K]["~type"] }) => Promise<R>) => Expression<R>;
36
+ /**
37
+ * Describe an injected call.
38
+ */
39
+ export declare class InjectedCall<
40
+ const Args extends any[],
41
+ const R
42
+ > {
43
+ args: Expression<any>[];
44
+ fn: (...args: Args) => R;
45
+ constructor(args: Expression<any>[], fn: (...args: Args) => R);
46
+ }
47
+ /**
48
+ * @param values
49
+ * @param fn
50
+ */
51
+ export declare const inject: <
52
+ const Expressions extends Expression<any>[],
53
+ Args extends any[],
54
+ R
55
+ >(values: Expressions, fn: (...args: [...{ [K in keyof Expressions] : Expressions[K]["~type"] }, ...Args]) => R) => InjectedCall<Args, R>;
56
+ /**
57
+ * Inject the external function, cache the access to a local dependency and run with provided args.
58
+ */
59
+ export declare const cacheCall: <R>(fn: (...args: any[]) => R, args: string) => Value<R>;
package/derive.js ADDED
@@ -0,0 +1 @@
1
+ import{injectDependency,injectExternal}from"./index.js";export let derive=(e,a)=>injectExternal(a)+`(`+e.join()+`)`;export let deriveAsync=(e,a)=>`await `+injectExternal(a)+`(`+e.join()+`)`;export class InjectedCall{args;fn;constructor(e,i){this.args=e;this.fn=i}}export let inject=(e,i)=>new InjectedCall(e,i);export let cacheCall=(a,o)=>injectDependency(injectExternal(a))+`(`+o+`)`;
package/index.d.ts CHANGED
@@ -1,26 +1,15 @@
1
- declare const _01: unique symbol;
2
- export type Statements = string & {
3
- [_01]: 0
1
+ export type Expression<T> = string & {
2
+ "~type": T
4
3
  };
5
- declare const _02: unique symbol;
6
- export type Statement = Statements & {
7
- [_02]: 0
4
+ export type Value<T> = Expression<T> & {
5
+ "~value": 0
8
6
  };
9
- declare const _: unique symbol;
10
- export type Expression<T> = Statement & {
11
- [_]: T
7
+ export type Identifier<T> = Value<T> & {
8
+ "~id": 0
12
9
  };
13
- declare const _11: unique symbol;
14
- export type Identifier<T> = Expression<T> & {
15
- [_11]: 0
16
- };
17
- declare const _20: unique symbol;
18
10
  export type ExportedDependency<T> = number & {
19
- [_20]: 0
11
+ "~type": T
20
12
  };
21
- export type InferExpression<T extends {
22
- [_]: any
23
- }> = T[typeof _];
24
13
  interface InjectDependencyFn {
25
14
  <T>(val: Expression<T>): Identifier<T>;
26
15
  <T>(val: string): Identifier<T>;
@@ -33,56 +22,47 @@ export declare const injectDependency: InjectDependencyFn;
33
22
  /**
34
23
  * Export a local dependency.
35
24
  * Use in `default` and `build` mode.
36
- * @param name
25
+ * @param value
37
26
  */
38
- export declare const exportDependency: <T>(name: Expression<T>) => ExportedDependency<T>;
27
+ export declare const exportDependency: <T>(value: Expression<T>) => ExportedDependency<T>;
39
28
  /**
40
- * Mark a slot in compiled dependencies.
29
+ * Mark a slot to export a dependency.
41
30
  * Use in `hydrate` mode.
42
31
  */
43
32
  export declare const markExported: <T>() => ExportedDependency<T>;
44
33
  /**
45
- * Get the value of a dependency.
34
+ * Get the value of an exported dependency.
46
35
  * @param idx
47
36
  */
48
37
  export declare const getDependency: <T>(idx: ExportedDependency<T>) => T;
49
38
  /**
50
- * Add extra code after dependency building
51
- */
52
- export declare const addExtraCode: (str: string) => void;
53
- /**
54
39
  * Inject an external dependency.
55
40
  */
56
- export declare const injectExternalDependency: <T>(val: T) => Identifier<T>;
41
+ export declare const injectExternal: <T>(val: T) => Value<T>;
57
42
  /**
58
- * Get external dependency names.
43
+ * Evaluate to statements instead of a function.
59
44
  * Use in `default` and `build` mode.
60
45
  */
61
- export declare const externalDependencyNames: () => string;
62
- /**
63
- * Equivalent to calling `evaluate`/`evaluateSync` in `default` or `build` mode.
64
- * Return the args that needs to be passed in.
65
- * Use in `hydrate` mode.
66
- *
67
- * @example
68
- * (() => {
69
- * // Built content
70
- * })(finishHydration())
71
- */
72
- export declare const hydrate: () => any[];
46
+ export declare const evaluateToStatements: () => string;
73
47
  /**
74
- * Get evaluated code.
75
- * Use in `default` and `build` mode.
48
+ * Evaluate code to a function.
49
+ * Use in `build` mode.
76
50
  */
77
- export declare const evaluateCode: () => Statements;
51
+ export declare const evaluateToFn: (extraCode: string) => Expression<(...args: any[]) => any>;
78
52
  /**
79
- * Evaluate code to string.
80
- * Use in `default` and `build` mode.
53
+ * Run evaluated code.
54
+ * Use in `default` mode.
81
55
  */
82
- export declare const evaluateToString: () => Expression<(...args: any[]) => any>;
56
+ export declare const evaluate: (extraCode: string) => any;
83
57
  /**
84
- * Run evaluated code.
85
- * Use in `default` and `build` mode.
58
+ * Hydrate a built function.
59
+ * Use in `hydrate` mode.
60
+ *
61
+ * @example
62
+ * hydratedCode += `
63
+ * import { hydrate } from 'runtime-compiler';
64
+ * const compiled = hydrate(${evaluateToFn(app)});
65
+ * `;
86
66
  */
87
- export declare const evaluate: () => any;
67
+ export declare const hydrate: <T>(compiledFn: (externalDependencies: any[]) => T) => T;
88
68
  export {};
package/index.js CHANGED
@@ -1 +1 @@
1
- export let compiledDependencies=[];export let externalDependencies=[];export let localDeps=``;let localDepsCnt=0;export let injectDependency=e=>{localDeps+=`,$`+localDepsCnt+`=`+e;return`$`+ localDepsCnt++};export let exportedDeps=``;let exportedDepsCnt=0;export let exportDependency=e=>(exportedDeps+=e+`,`,exportedDepsCnt++);export let markExported=()=>exportedDepsCnt++;export let getDependency=g=>compiledDependencies[g];export let extraCode=``;export let addExtraCode=e=>{extraCode+=e};export let injectExternalDependency=e=>`_`+externalDependencies.push(e);export let externalDependencyNames=()=>{let e=`_,`;for(let _=0;_<externalDependencies.length;_++)e+=`_`+(_+1)+`,`;return e};export let hydrate=()=>[compiledDependencies].concat(externalDependencies);export let evaluateCode=()=>`var $`+localDeps+`;_.push(`+exportedDeps+`);`+extraCode;export let evaluateToString=()=>`(`+externalDependencyNames()+`)=>{`+evaluateCode()+`}`;export let evaluate=()=>{try{return Function(externalDependencyNames(),evaluateCode())(compiledDependencies,...externalDependencies)}finally{localDeps=``;localDepsCnt=0;exportedDeps=``;extraCode=``}};
1
+ let externals=[];let localDeps=``;let localDepsCnt=0;let exportDeps=``;export let injectDependency=e=>{localDeps+=`,$`+localDepsCnt+`=`+e;return`$`+ localDepsCnt++};export let exportDependency=d=>(exportDeps+=`;$[`+externals.length+`]=`+d,externals.push(null)-1);export let markExported=()=>externals.push(null)-1;export let getDependency=d=>externals[d];export let injectExternal=d=>`$[`+(externals.push(d)-1)+`]`;export let evaluateToStatements=()=>localDeps.length===0?exportDeps:`let `+localDeps.slice(1)+exportDeps;export let evaluateToFn=e=>`$=>{var _`+localDeps+exportDeps+e+`}`;export let evaluate=f=>{try{return Function(`$`,`var _`+localDeps+exportDeps+f)(externals)}finally{localDeps=``;localDepsCnt=0;exportDeps=``}};export let hydrate=d=>d(externals);
package/package.json CHANGED
@@ -1 +1 @@
1
- {"name":"runtime-compiler","version":"3.0.0","description":"Universal compiler system","keywords":[],"repository":{},"homepage":"","license":"MIT","type":"module","exports":{"./config":"./config/index.js","./config/mode/hydrate":"./config/mode/hydrate.js","./config/loader/build":"./config/loader/build.js","./config/loader/hydrate":"./config/loader/hydrate.js","./config/mode/build":"./config/mode/build.js","./call":"./call.js","./utils":"./utils.js",".":"./index.js","./scope":"./scope.js"}}
1
+ {"name":"runtime-compiler","version":"3.0.1","description":"Universal compiler system","keywords":[],"repository":{},"homepage":"","license":"MIT","type":"module","exports":{".":"./index.js","./config":"./config/index.js","./utils":"./utils.js","./derive":"./derive.js","./config/mode/build":"./config/mode/build.js","./config/loader/build":"./config/loader/build.js","./config/mode/hydrate":"./config/mode/hydrate.js","./config/loader/hydrate":"./config/loader/hydrate.js"}}
package/call.d.ts DELETED
@@ -1,23 +0,0 @@
1
- import type { Identifier, InferExpression } from "./index.ts";
2
- declare const sym: unique symbol;
3
- type sym = typeof sym;
4
- export interface InjectedCall<Deps extends Identifier<any>[]> {
5
- [sym]: Deps;
6
- }
7
- /**
8
- * Inject dependency to an fn for later compilation
9
- */
10
- export declare const inject: <
11
- const Deps extends Identifier<any>[],
12
- const Args extends any[],
13
- const Ret
14
- >(deps: Deps, fn: (...args: [...{ [K in keyof Deps] : InferExpression<Deps[K]> }, ...Args]) => Ret) => ((...args: Args) => Ret) & InjectedCall<Deps>;
15
- interface GetDepsFn {
16
- <Deps extends Identifier<any>[]>(fn: InjectedCall<Deps>): Deps;
17
- (fn: any): Identifier<any>[] | undefined;
18
- }
19
- /**
20
- * Get fn injected dependency list
21
- */
22
- export declare const getDeps: GetDepsFn;
23
- export {};
package/call.js DELETED
@@ -1 +0,0 @@
1
- let sym=Symbol();export let inject=(t,n)=>(n[sym]=t,n);export let getDeps=t=>t[sym];
package/scope.d.ts DELETED
@@ -1,4 +0,0 @@
1
- export type Scope = [nextId: number];
2
- export declare const init: () => Scope;
3
- export declare const nextId: (scope: Scope) => string;
4
- export declare const idCount: (scope: Scope) => number;
package/scope.js DELETED
@@ -1 +0,0 @@
1
- export let init=()=>[0];export let nextId=e=>`l`+ e[0]++;export let idCount=e=>e[0];