@pumped-fn/core-next 0.5.36 → 0.5.37

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/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var v=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var V=Object.getOwnPropertyNames;var P=Object.prototype.hasOwnProperty;var R=(o,e)=>{for(var t in e)v(o,t,{get:e[t],enumerable:!0})},O=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of V(e))!P.call(o,r)&&r!==t&&v(o,r,{get:()=>e[r],enumerable:!(n=D(e,r))||n.enumerable});return o};var U=o=>O(v({},"__esModule",{value:!0}),o);var K={};R(K,{SchemaError:()=>p,createScope:()=>L,custom:()=>z,derive:()=>I,executorSymbol:()=>u,findValue:()=>T,findValues:()=>E,getValue:()=>k,isExecutor:()=>g,isLazyExecutor:()=>h,isReactiveExecutor:()=>y,isStaticExecutor:()=>m,meta:()=>j,metaSymbol:()=>x,provide:()=>F,validate:()=>C,validateAsync:()=>B});module.exports=U(K);var u=Symbol.for("@pumped-fn/core/executor"),x=Symbol.for("@pumped-fn/core/meta"),p=class extends Error{issues;constructor(e){super(e[0].message),this.name="SchemaError",this.issues=e}};function M(o,e,t){let n={[u]:"base",factory:(f,s)=>e===void 0?o(s):o(f,s),dependencies:e,metas:t},r={[u]:"lazy",dependencies:void 0,executor:n,factory:void 0,metas:t},c={[u]:"reactive",executor:n,factory:void 0,dependencies:void 0,metas:t},i={[u]:"static",dependencies:void 0,factory:void 0,metas:t,executor:n};return Object.defineProperties(n,{lazy:{value:r,writable:!1,configurable:!1,enumerable:!1},reactive:{value:c,writable:!1,configurable:!1,enumerable:!1},static:{value:i,writable:!1,configurable:!1,enumerable:!1}}),n}function h(o){return o[u]==="lazy"}function y(o){return o[u]==="reactive"}function m(o){return o[u]==="static"}function F(o,...e){return M(o,void 0,e)}function I(o,e,...t){return M(e,o,t)}function C(o,e){let t=o["~standard"].validate(e);if("then"in t)throw new Error("validating async is not supported");if(t.issues)throw new p(t.issues);return t.value}async function B(o,e){let t=o["~standard"].validate(e);if("then"in t){let n=await t;if(n.issues)throw new p(n.issues);return n.value}if(t.issues)throw new p(t.issues);return Promise.resolve(t.value)}function z(){return{"~standard":{vendor:"pumped-fn",version:1,validate:o=>({value:o})}}}var j=(o,e)=>{let t=typeof o=="string"?Symbol(o):o,n=r=>({[x]:!0,key:t,schema:e,value:r});return Object.defineProperty(n,"key",{value:t,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperty(n,x,{value:!0,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperties(n,{partial:{value:r=>Object.assign({},n({}),r),configurable:!1,enumerable:!1,writable:!1},some:{value:r=>E(r,n),configurable:!1,enumerable:!1,writable:!1},find:{value:r=>T(r,n),configurable:!1,enumerable:!1,writable:!1},get:{value:r=>k(T(r,n)),configurable:!1,enumerable:!1,writable:!1}}),n};function k(o){return C(o.schema,o.value)}function E(o,e){return o?(Array.isArray(o)?o:o.metas??[]).filter(r=>r.key===e.key).map(r=>k(r)):[]}function T(o,e){return E(o,e).at(0)}function g(o){return typeof o=="object"&&o!==null&&u in o}var S=class{isDisposed=!1;cache=new Map;valueCache=new Map;reactiveness=new Map;cleanups=new Map;onUpdates=new Map;"~appendReactive"(e,t){let n=this.reactiveness.get(e)??new Set;this.reactiveness.set(e,n),n.add(t)}async"~resolveDependencies"(e,t){if(e===void 0)return;if(g(e)){if(h(e))return this["~resolveLazy"](e);let r=await this["~resolveStatic"](e);return y(e)&&this["~appendReactive"](e.executor,t),await r.resolve(!1),m(e)?r:r.get()}if(Array.isArray(e))return await Promise.all(e.map(r=>this["~resolveDependencies"](r,t)));let n={};for(let r of Object.keys(e)){let c=e[r],i=await this["~resolveDependencies"](c,t);n[r]=i}return n}"~resolveLazy"(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e.executor);return t||this["~makeAccessor"](e.executor)}async"~resolveStatic"(e){let t=this.cache.get(e);return t||this["~makeAccessor"](e,!0)}"~makeController"(e){return{cleanup:t=>{let n=this.cleanups.get(e)??new Set;this.cleanups.set(e,n),n.add(t)},release:async()=>{this.release(e)},scope:this}}"~makeAccessor"(e,t=!1){let n={},r=h(e)||y(e)?e.executor:e,c=this.cache.get(r);if(c)return c;let i=r.factory,f=this["~makeController"](r),s=async a=>{if(this.isDisposed)throw new Error("Scope is disposed");let d=this.valueCache.get(r);if(d&&!a){if(d.kind==="resolved")return d.value;if(d.kind==="rejected")throw d.error;return d.promise}let w=new Promise((b,A)=>{this["~resolveDependencies"](r.dependencies,r).then(l=>i(l,f)).then(l=>{this.valueCache.set(r,{kind:"resolved",value:l}),b(l)}).catch(l=>{this.valueCache.set(r,{kind:"rejected",error:l}),A(l)})});return this.valueCache.set(r,{kind:"resolving",promise:w}),this.cache.set(r,n),w};return(!h(e)||t)&&s(!1),Object.assign(n,{get:()=>{if(this.isDisposed)throw new Error("Scope is disposed");let a=this.valueCache.get(r);if(!a||a.kind==="resolving")throw new Error("Executor not found");if(a.kind==="rejected")throw a.error;return a.value},lookup:()=>{if(this.isDisposed)throw new Error("Scope is disposed");return this.valueCache.get(r)},metas:e.metas,resolve:s,release:async(a=!1)=>{this.release(r)},update:a=>this.update(r,a)})}accessor(e){if(this.isDisposed)throw new Error("Scope is disposed");return this["~makeAccessor"](e,!1)}async resolve(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.valueCache.get(e);if(t){if(t.kind==="resolved")return t.value;if(t.kind==="rejected")throw t.error;return await t.promise}let n=this["~makeAccessor"](e,!0);return await n.resolve(!1),n.get()}async resolveAccessor(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e);if(!t){let n=this["~makeAccessor"](e,!0);return await n.resolve(),n}return await t.resolve(),t}"~findAffectedTargets"(e,t=new Set){let n=this.reactiveness.get(e);if(n&&n.size>0)for(let r of n)t.has(r)&&t.delete(r),t.add(r),this.reactiveness.has(r)&&this["~findAffectedTargets"](r,t);return t}async update(e,t){if(this.isDisposed)throw new Error("Scope is disposed");let n=this.cache.get(e);if(!n)throw new Error("Executor is not yet resolved");let r=await n.resolve(!1),c=this.cleanups.get(e);if(c)for(let s of Array.from(c.values()).reverse())await s();if(typeof t=="function"){let a=t(r);this.valueCache.set(e,{kind:"resolved",value:a})}else this.valueCache.set(e,{kind:"resolved",value:t});let i=this["~findAffectedTargets"](e);for(let s of i){let a=this.cache.get(s);if(a){await a.resolve(!0);let d=this.onUpdates.get(s);if(d)for(let w of Array.from(d.values()))await w(a)}}let f=this.onUpdates.get(e);if(f)for(let s of Array.from(f.values()))await s(n)}async reset(e){if(this.isDisposed)throw new Error("Scope is disposed");await this.release(e,!0),await this.resolve(e)}async release(e,t=!1){if(this.isDisposed)throw new Error("Scope is disposed");if(!this.cache.get(e)&&!t)throw new Error("Executor is not yet resolved");let r=this["~findAffectedTargets"](e);for(let i of r)await this.release(i,!0);let c=this.cleanups.get(e);if(c)for(let i of Array.from(c.values()).reverse())await i();this.cache.delete(e),this.valueCache.delete(e),this.reactiveness.delete(e),this.onUpdates.delete(e)}async dispose(){let e=this.cache.keys();for(let t of e)await this.release(t,!0);this.isDisposed=!0,this.cache.clear(),this.valueCache.clear(),this.reactiveness.clear(),this.cleanups.clear()}onUpdate(e,t){if(this.isDisposed)throw new Error("scope is disposed");let n=this.onUpdates.get(e)??new Set;return this.onUpdates.set(e,n),n.add(t),()=>{if(this.isDisposed)throw new Error("scope is disposed");let r=this.onUpdates.get(e);r&&(r.delete(t),r.size===0&&this.onUpdates.delete(e))}}getCache(){return this.cache}getValueCache(){return this.valueCache}getReactiveness(){return this.reactiveness}};function L(){return new S}0&&(module.exports={SchemaError,createScope,custom,derive,executorSymbol,findValue,findValues,getValue,isExecutor,isLazyExecutor,isReactiveExecutor,isStaticExecutor,meta,metaSymbol,provide,validate,validateAsync});
1
+ "use strict";var m=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var V=Object.getOwnPropertyNames;var P=Object.prototype.hasOwnProperty;var R=(o,e)=>{for(var t in e)m(o,t,{get:e[t],enumerable:!0})},O=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of V(e))!P.call(o,r)&&r!==t&&m(o,r,{get:()=>e[r],enumerable:!(n=D(e,r))||n.enumerable});return o};var U=o=>O(m({},"__esModule",{value:!0}),o);var K={};R(K,{SchemaError:()=>p,createScope:()=>L,custom:()=>z,derive:()=>I,executorSymbol:()=>u,findValue:()=>T,findValues:()=>E,getValue:()=>k,isExecutor:()=>g,isLazyExecutor:()=>h,isReactiveExecutor:()=>y,isStaticExecutor:()=>v,meta:()=>j,metaSymbol:()=>x,provide:()=>F,validate:()=>C,validateAsync:()=>B});module.exports=U(K);var u=Symbol.for("@pumped-fn/core/executor"),x=Symbol.for("@pumped-fn/core/meta"),p=class extends Error{issues;constructor(e){super(e[0].message),this.name="SchemaError",this.issues=e}};function M(o,e,t){let n={[u]:"base",factory:(f,s)=>e===void 0?o(s):o(f,s),dependencies:e,metas:t},r={[u]:"lazy",dependencies:void 0,executor:n,factory:void 0,metas:t},c={[u]:"reactive",executor:n,factory:void 0,dependencies:void 0,metas:t},i={[u]:"static",dependencies:void 0,factory:void 0,metas:t,executor:n};return Object.defineProperties(n,{lazy:{value:r,writable:!1,configurable:!1,enumerable:!1},reactive:{value:c,writable:!1,configurable:!1,enumerable:!1},static:{value:i,writable:!1,configurable:!1,enumerable:!1}}),n}function h(o){return o[u]==="lazy"}function y(o){return o[u]==="reactive"}function v(o){return o[u]==="static"}function F(o,...e){return M(o,void 0,e)}function I(o,e,...t){return M(e,o,t)}function C(o,e){let t=o["~standard"].validate(e);if("then"in t)throw new Error("validating async is not supported");if(t.issues)throw new p(t.issues);return t.value}async function B(o,e){let t=o["~standard"].validate(e);if("then"in t){let n=await t;if(n.issues)throw new p(n.issues);return n.value}if(t.issues)throw new p(t.issues);return Promise.resolve(t.value)}function z(){return{"~standard":{vendor:"pumped-fn",version:1,validate:o=>({value:o})}}}var j=(o,e)=>{let t=typeof o=="string"?Symbol(o):o,n=r=>({[x]:!0,key:t,schema:e,value:r});return Object.defineProperty(n,"key",{value:t,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperty(n,x,{value:!0,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperties(n,{partial:{value:r=>Object.assign({},n({}),r),configurable:!1,enumerable:!1,writable:!1},some:{value:r=>E(r,n),configurable:!1,enumerable:!1,writable:!1},find:{value:r=>T(r,n),configurable:!1,enumerable:!1,writable:!1},get:{value:r=>k(T(r,n)),configurable:!1,enumerable:!1,writable:!1}}),n};function k(o){return C(o.schema,o.value)}function E(o,e){return o?(Array.isArray(o)?o:o.metas??[]).filter(r=>r.key===e.key).map(r=>k(r)):[]}function T(o,e){return E(o,e).at(0)}function g(o){return typeof o=="object"&&o!==null&&u in o}var S=class{isDisposed=!1;cache=new Map;valueCache=new Map;reactiveness=new Map;cleanups=new Map;onUpdates=new Map;"~appendReactive"(e,t){let n=this.reactiveness.get(e)??new Set;this.reactiveness.set(e,n),n.add(t)}async"~resolveDependencies"(e,t){if(e===void 0)return;if(g(e)){if(h(e))return this["~resolveLazy"](e);let r=await this["~resolveStatic"](e);return y(e)&&this["~appendReactive"](e.executor,t),await r.resolve(!1),v(e)?r:r.get()}if(Array.isArray(e))return await Promise.all(e.map(r=>this["~resolveDependencies"](r,t)));let n={};for(let r of Object.keys(e)){let c=e[r],i=await this["~resolveDependencies"](c,t);n[r]=i}return n}"~resolveLazy"(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e.executor);return t||this["~makeAccessor"](e.executor)}async"~resolveStatic"(e){let t=this.cache.get(e);return t||this["~makeAccessor"](e,!0)}"~makeController"(e){return{cleanup:t=>{let n=this.cleanups.get(e)??new Set;this.cleanups.set(e,n),n.add(t)},release:async()=>{this.release(e)},scope:this}}"~makeAccessor"(e,t=!1){let n={},r=h(e)||y(e)||v(e)?e.executor:e,c=this.cache.get(r);if(c)return c;let i=r.factory,f=this["~makeController"](r),s=async a=>{if(this.isDisposed)throw new Error("Scope is disposed");let d=this.valueCache.get(r);if(d&&!a){if(d.kind==="resolved")return d.value;if(d.kind==="rejected")throw d.error;return d.promise}let w=new Promise((b,A)=>{this["~resolveDependencies"](r.dependencies,r).then(l=>i(l,f)).then(l=>{this.valueCache.set(r,{kind:"resolved",value:l}),b(l)}).catch(l=>{this.valueCache.set(r,{kind:"rejected",error:l}),A(l)})});return this.valueCache.set(r,{kind:"resolving",promise:w}),this.cache.set(r,n),w};return(!h(e)||t)&&s(!1),Object.assign(n,{get:()=>{if(this.isDisposed)throw new Error("Scope is disposed");let a=this.valueCache.get(r);if(!a||a.kind==="resolving")throw new Error("Executor not found");if(a.kind==="rejected")throw a.error;return a.value},lookup:()=>{if(this.isDisposed)throw new Error("Scope is disposed");return this.valueCache.get(r)},metas:e.metas,resolve:s,release:async(a=!1)=>{this.release(r)},update:a=>this.update(r,a)})}accessor(e){if(this.isDisposed)throw new Error("Scope is disposed");return this["~makeAccessor"](e,!1)}async resolve(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.valueCache.get(e);if(t){if(t.kind==="resolved")return t.value;if(t.kind==="rejected")throw t.error;return await t.promise}let n=this["~makeAccessor"](e,!0);return await n.resolve(!1),n.get()}async resolveAccessor(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e);if(!t){let n=this["~makeAccessor"](e,!0);return await n.resolve(),n}return await t.resolve(),t}"~findAffectedTargets"(e,t=new Set){let n=this.reactiveness.get(e);if(n&&n.size>0)for(let r of n)t.has(r)&&t.delete(r),t.add(r),this.reactiveness.has(r)&&this["~findAffectedTargets"](r,t);return t}async update(e,t){if(this.isDisposed)throw new Error("Scope is disposed");let n=this.cache.get(e);if(!n)throw new Error("Executor is not yet resolved");let r=await n.resolve(!1),c=this.cleanups.get(e);if(c)for(let s of Array.from(c.values()).reverse())await s();if(typeof t=="function"){let a=t(r);this.valueCache.set(e,{kind:"resolved",value:a})}else this.valueCache.set(e,{kind:"resolved",value:t});let i=this["~findAffectedTargets"](e);for(let s of i){let a=this.cache.get(s);if(a){await a.resolve(!0);let d=this.onUpdates.get(s);if(d)for(let w of Array.from(d.values()))await w(a)}}let f=this.onUpdates.get(e);if(f)for(let s of Array.from(f.values()))await s(n)}async reset(e){if(this.isDisposed)throw new Error("Scope is disposed");await this.release(e,!0),await this.resolve(e)}async release(e,t=!1){if(this.isDisposed)throw new Error("Scope is disposed");if(!this.cache.get(e)&&!t)throw new Error("Executor is not yet resolved");let r=this["~findAffectedTargets"](e);for(let i of r)await this.release(i,!0);let c=this.cleanups.get(e);if(c)for(let i of Array.from(c.values()).reverse())await i();this.cache.delete(e),this.valueCache.delete(e),this.reactiveness.delete(e),this.onUpdates.delete(e)}async dispose(){let e=this.cache.keys();for(let t of e)await this.release(t,!0);this.isDisposed=!0,this.cache.clear(),this.valueCache.clear(),this.reactiveness.clear(),this.cleanups.clear()}onUpdate(e,t){if(this.isDisposed)throw new Error("scope is disposed");let n=this.onUpdates.get(e)??new Set;return this.onUpdates.set(e,n),n.add(t),()=>{if(this.isDisposed)throw new Error("scope is disposed");let r=this.onUpdates.get(e);r&&(r.delete(t),r.size===0&&this.onUpdates.delete(e))}}getCache(){return this.cache}getValueCache(){return this.valueCache}getReactiveness(){return this.reactiveness}};function L(){return new S}0&&(module.exports={SchemaError,createScope,custom,derive,executorSymbol,findValue,findValues,getValue,isExecutor,isLazyExecutor,isReactiveExecutor,isStaticExecutor,meta,metaSymbol,provide,validate,validateAsync});
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/types.ts","../src/executor.ts","../src/ssch.ts","../src/meta.ts","../src/scope.ts"],"sourcesContent":["export * from \"./executor\";\nexport * from \"./meta\";\nexport * from \"./scope\";\nexport * from \"./types\";\nexport * from \"./ssch\";\n","export const executorSymbol = Symbol.for(\"@pumped-fn/core/executor\");\nexport const metaSymbol = Symbol.for(\"@pumped-fn/core/meta\");\n\nexport interface StandardSchemaV1<Input = unknown, Output = Input> {\n readonly \"~standard\": StandardSchemaV1.Props<Input, Output>;\n}\n\nexport declare namespace StandardSchemaV1 {\n export interface Props<Input = unknown, Output = Input> {\n readonly version: 1;\n readonly vendor: string;\n readonly validate: (\n value: unknown\n ) => Result<Output> | Promise<Result<Output>>;\n readonly types?: Types<Input, Output> | undefined;\n }\n\n export type Result<Output> = SuccessResult<Output> | FailureResult;\n\n export interface SuccessResult<Output> {\n readonly value: Output;\n readonly issues?: undefined;\n }\n\n export interface FailureResult {\n readonly issues: ReadonlyArray<Issue>;\n }\n\n export interface Issue {\n readonly message: string;\n readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;\n }\n\n export interface PathSegment {\n readonly key: PropertyKey;\n }\n\n export interface Types<Input = unknown, Output = Input> {\n readonly input: Input;\n readonly output: Output;\n }\n\n export type InferInput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"input\"];\n\n export type InferOutput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"output\"];\n}\n\nexport class SchemaError extends Error {\n public readonly issues: ReadonlyArray<StandardSchemaV1.Issue>;\n\n constructor(issues: ReadonlyArray<StandardSchemaV1.Issue>) {\n super(issues[0].message);\n this.name = \"SchemaError\";\n this.issues = issues;\n }\n}\n\nexport declare namespace Meta {\n export interface MetaContainer {\n metas: Meta[] | undefined;\n }\n\n export interface Meta<V = unknown> {\n readonly [metaSymbol]: true;\n readonly key: string | symbol;\n readonly schema: StandardSchemaV1<V>;\n readonly value: V;\n }\n\n export interface MetaFn<V> {\n (value: V): Meta<V>;\n readonly key: string | symbol;\n partial: <D extends Partial<V>>(d: D) => D;\n some: (source: MetaContainer | Meta[] | undefined) => V[];\n find: (source: MetaContainer | Meta[] | undefined) => V | undefined;\n get: (source: MetaContainer | Meta[] | undefined) => V;\n }\n}\n\nexport declare namespace Core {\n export type Output<T> = T | Promise<T>;\n\n export type NoDependencyFn<T> = (scope: Controller) => Output<T>;\n export type DependentFn<T, D> = (\n dependencies: D,\n scope: Controller\n ) => Output<T>;\n export type RecordLike = Record<string, unknown>;\n export type UExecutor = BaseExecutor<unknown>;\n\n export type Cleanup = () => void | Promise<void>;\n\n export type Controller = {\n cleanup: (cleanup: Cleanup) => void;\n release: () => Promise<void>;\n scope: Scope;\n };\n\n export type Kind = \"base\" | \"main\" | \"reactive\" | \"lazy\" | \"static\";\n\n export interface BaseExecutor<T> extends Meta.MetaContainer {\n [executorSymbol]: Kind;\n factory: NoDependencyFn<T> | DependentFn<T, unknown> | undefined;\n dependencies:\n | undefined\n | UExecutor\n | Array<UExecutor>\n | Record<string, UExecutor>;\n }\n\n export interface Executor<T> extends BaseExecutor<T> {\n [executorSymbol]: \"main\";\n factory: NoDependencyFn<T> | DependentFn<T, unknown>;\n\n /** Return an executor controller without resolving Executor */\n readonly lazy: Lazy<T>;\n\n /** Return an resolved executor, and mark the user to be reactived for future changes */\n readonly reactive: Reactive<T>;\n\n /** Return an resolved executor with its controller */\n readonly static: Static<T>;\n }\n\n export interface Reactive<T> extends BaseExecutor<T> {\n [executorSymbol]: \"reactive\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Lazy<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"lazy\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Static<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"static\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Accessor<T> extends Meta.MetaContainer {\n lookup(): T;\n get(): T;\n resolve(force?: boolean): Promise<T>;\n release(soft?: boolean): Promise<void>;\n update(updateFn: T | ((current: T) => T)): Promise<void>;\n }\n\n export type InferOutput<T> = T extends Executor<infer U> | Reactive<infer U>\n ? Awaited<U>\n : T extends Lazy<infer U> | Static<infer U>\n ? Accessor<Awaited<U>>\n : never;\n\n export interface Scope {\n accessor<T>(executor: Core.Executor<T>, eager?: boolean): Accessor<T>;\n\n resolve<T>(executor: Core.Executor<T>): Promise<T>;\n resolveAccessor<T>(executor: Core.Executor<T>): Promise<Accessor<T>>;\n\n update<T>(\n executor: Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void>;\n\n reset<T>(executor: Executor<T>): void;\n release(executor: Executor<any>, soft?: boolean): Promise<void>;\n\n dispose(): Promise<void>;\n\n onUpdate<T>(\n executor: Executor<T>,\n callback: (accessor: Accessor<T>) => void\n ): Cleanup;\n // onRelease<T>(executor: Executor<T>, callback: () => void): () => void;\n }\n}\n","import { Core, executorSymbol, Meta, metaSymbol } from \"./types\";\n\nfunction createExecutor<T>(\n factory: Core.NoDependencyFn<T> | Core.DependentFn<T, unknown>,\n dependencies:\n | undefined\n | Core.UExecutor\n | Array<Core.UExecutor>\n | Record<string, Core.UExecutor>,\n metas: Meta.Meta[] | undefined\n): Core.Executor<T> {\n const executor = {\n [executorSymbol]: \"base\",\n factory: (_: unknown, controller: Core.Controller) => {\n if (dependencies === undefined) {\n const f = factory as Core.NoDependencyFn<T>;\n return f(controller);\n }\n\n const f = factory as Core.DependentFn<T, unknown>;\n return f(_, controller);\n },\n dependencies,\n metas: metas,\n } as unknown as Core.Executor<T>;\n\n const lazyExecutor = {\n [executorSymbol]: \"lazy\",\n dependencies: undefined,\n executor,\n factory: undefined,\n metas: metas,\n } satisfies Core.Lazy<T>;\n\n const reactiveExecutor = {\n [executorSymbol]: \"reactive\",\n executor,\n factory: undefined,\n dependencies: undefined,\n metas: metas,\n } satisfies Core.Reactive<T>;\n\n const staticExecutor = {\n [executorSymbol]: \"static\",\n dependencies: undefined,\n factory: undefined,\n metas: metas,\n executor,\n } satisfies Core.Static<T>;\n\n Object.defineProperties(executor, {\n lazy: {\n value: lazyExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n reactive: {\n value: reactiveExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n static: {\n value: staticExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n });\n\n return executor;\n}\n\nexport function isLazyExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Lazy<unknown> {\n return executor[executorSymbol] === \"lazy\";\n}\n\nexport function isReactiveExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Reactive<unknown> {\n return executor[executorSymbol] === \"reactive\";\n}\n\nexport function isStaticExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Static<unknown> {\n return executor[executorSymbol] === \"static\";\n}\n\nexport function provide<T>(\n factory: Core.NoDependencyFn<T>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(factory, undefined, metas);\n}\n\nexport function derive<T, D extends Core.BaseExecutor<unknown>>(\n dependencies: D,\n factory: Core.DependentFn<T, Core.InferOutput<D>>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<\n T,\n D extends\n | ReadonlyArray<Core.BaseExecutor<unknown>>\n | Record<string, Core.BaseExecutor<unknown>>\n>(\n dependencies: { [K in keyof D]: D[K] },\n factory: Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<T, D>(\n pdependencies:\n | Core.BaseExecutor<D>\n | Array<Core.BaseExecutor<D>>\n | Record<string, Core.BaseExecutor<unknown>>,\n pfactory:\n | Core.DependentFn<T, Core.InferOutput<D>>\n | Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(pfactory as any, pdependencies, metas);\n}\n","import { SchemaError, StandardSchemaV1 } from \"./types\";\n\nexport function validate<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Awaited<StandardSchemaV1.InferOutput<TSchema>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n throw new Error(\"validating async is not supported\");\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n return result.value as any;\n}\n\nexport async function validateAsync<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Promise<Awaited<StandardSchemaV1.InferOutput<TSchema>>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n const result_1 = await result;\n if (result_1.issues) {\n throw new SchemaError(result_1.issues);\n }\n return result_1.value as any;\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n\n return Promise.resolve(result.value as any);\n}\n\nexport function custom<T>(): StandardSchemaV1<T, T> {\n return {\n \"~standard\": {\n vendor: \"pumped-fn\",\n version: 1,\n validate: (value) => {\n return { value: value as T };\n },\n },\n };\n}\n","import { validate } from \"./ssch\";\nimport { metaSymbol, StandardSchemaV1, type Meta } from \"./types\";\n\nexport const meta = <V>(\n key: string | symbol,\n schema: StandardSchemaV1<V>\n): Meta.MetaFn<V> => {\n const _key = typeof key === \"string\" ? Symbol(key) : key;\n\n const fn = (value: V) =>\n ({\n [metaSymbol]: true,\n key: _key,\n schema,\n value,\n } as unknown as Meta.MetaFn<V>);\n\n Object.defineProperty(fn, \"key\", {\n value: _key,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperty(fn, metaSymbol, {\n value: true,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperties(fn, {\n partial: {\n value: (d: Partial<V>) => {\n return Object.assign({}, fn({} as V), d);\n },\n configurable: false,\n enumerable: false,\n writable: false,\n },\n some: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValues(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n find: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValue(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n get: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n getValue(\n findValue(\n source,\n fn as unknown as Meta.MetaFn<unknown>\n ) as Meta.Meta<V>\n ),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n });\n\n return fn as any;\n};\n\nexport function getValue<V>(meta: Meta.Meta<V>) {\n return validate(meta.schema, meta.value);\n}\n\nexport function findValues<V = unknown>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V[] {\n if (!executor) return [];\n\n const metas = Array.isArray(executor) ? executor : executor.metas ?? [];\n\n const maybeMeta = metas.filter((m) => m.key === meta.key);\n return maybeMeta.map((m) => getValue(m as Meta.Meta<V>));\n}\n\nexport function findValue<V>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V | undefined {\n const values = findValues(executor, meta);\n return values.at(0);\n}\n","import {\n isLazyExecutor,\n isReactiveExecutor,\n isStaticExecutor,\n} from \"./executor\";\nimport { Core, executorSymbol } from \"./types\";\n\nexport interface ScopeInner {\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>>;\n getValueCache(): Map<Core.Executor<unknown>, unknown>;\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>>;\n}\n\nexport function isExecutor<T>(input: unknown): input is Core.BaseExecutor<T> {\n return typeof input === \"object\" && input !== null && executorSymbol in input;\n}\n\ntype Value =\n | { kind: \"resolving\"; promise: Promise<unknown> }\n | { kind: \"resolved\"; value: unknown }\n | { kind: \"rejected\"; error: unknown };\n\nclass Scope implements Core.Scope, ScopeInner {\n private isDisposed: boolean = false;\n private cache: Map<Core.Executor<unknown>, Core.Accessor<unknown>> =\n new Map();\n private valueCache: Map<Core.Executor<unknown>, Value> = new Map();\n private reactiveness = new Map<\n Core.Executor<unknown>,\n Set<Core.Executor<unknown>>\n >();\n private cleanups = new Map<Core.Executor<unknown>, Set<Core.Cleanup>>();\n private onUpdates = new Map<\n Core.Executor<unknown>,\n Set<(accessor: Core.Accessor<unknown>) => void | Promise<void>>\n >();\n\n private \"~appendReactive\"(\n reactive: Core.Executor<unknown>,\n ref: Core.Executor<unknown>\n ) {\n const currentSet = this.reactiveness.get(reactive) ?? new Set();\n this.reactiveness.set(reactive, currentSet);\n\n currentSet.add(ref);\n }\n\n private async \"~resolveDependencies\"(\n e:\n | undefined\n | Core.BaseExecutor<unknown>\n | Core.BaseExecutor<unknown>[]\n | Record<string, Core.BaseExecutor<unknown>>,\n ref: Core.Executor<unknown>\n ): Promise<undefined | unknown | unknown[] | Record<string, unknown>> {\n if (e === undefined) {\n return undefined;\n }\n\n if (isExecutor(e)) {\n if (isLazyExecutor(e)) {\n return this[\"~resolveLazy\"](e);\n }\n\n const staticResult = await this[\"~resolveStatic\"](\n e as Core.Executor<unknown>\n );\n\n if (isReactiveExecutor(e)) {\n this[\"~appendReactive\"](e.executor, ref);\n }\n\n await staticResult.resolve(false);\n if (isStaticExecutor(e)) {\n return staticResult;\n }\n\n return staticResult.get();\n }\n\n if (Array.isArray(e)) {\n return await Promise.all(\n e.map((item) => this[\"~resolveDependencies\"](item, ref))\n );\n }\n\n const result: Record<string, unknown> = {};\n for (const key of Object.keys(e)) {\n const target = e[key];\n const resolvedResult = await this[\"~resolveDependencies\"](target, ref);\n\n result[key] = resolvedResult;\n }\n\n return result;\n }\n\n private \"~resolveLazy\"(e: Core.Lazy<unknown>): Core.Accessor<unknown> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(e.executor);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e.executor);\n\n return accessor;\n }\n\n private async \"~resolveStatic\"(\n e: Core.Executor<unknown>\n ): Promise<Core.Accessor<unknown>> {\n const cached = this.cache.get(e);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e, true);\n return accessor;\n }\n\n private \"~makeController\"(e: Core.Executor<unknown>): Core.Controller {\n return {\n cleanup: (cleanup: Core.Cleanup) => {\n const currentSet = this.cleanups.get(e) ?? new Set();\n this.cleanups.set(e, currentSet);\n\n currentSet.add(cleanup);\n },\n release: async () => {\n this.release(e);\n },\n scope: this,\n };\n }\n\n private \"~makeAccessor\"(\n e: Core.BaseExecutor<unknown>,\n eager: boolean = false\n ): Core.Accessor<unknown> {\n const accessor = {} as Core.Accessor<unknown>;\n const requestor =\n isLazyExecutor(e) || isReactiveExecutor(e)\n ? e.executor\n : (e as Core.Executor<unknown>);\n\n const cachedAccessor = this.cache.get(requestor);\n if (cachedAccessor) {\n return cachedAccessor;\n }\n\n const factory = requestor.factory;\n const controller = this[\"~makeController\"](requestor);\n\n const resolve = async (force: boolean): Promise<unknown> => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(requestor);\n if (cached && !force) {\n if (cached.kind === \"resolved\") {\n return cached.value;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return cached.promise;\n }\n }\n\n const promise = new Promise((resolve, reject) => {\n this[\"~resolveDependencies\"](requestor.dependencies, requestor)\n .then((dependencies) => factory(dependencies as any, controller))\n .then((result) => {\n this.valueCache.set(requestor, { kind: \"resolved\", value: result });\n resolve(result);\n })\n .catch((error) => {\n this.valueCache.set(requestor, { kind: \"rejected\", error });\n reject(error);\n });\n });\n\n this.valueCache.set(requestor, { kind: \"resolving\", promise });\n this.cache.set(requestor, accessor);\n return promise;\n };\n\n if (!isLazyExecutor(e) || eager) {\n resolve(false);\n }\n\n return Object.assign(accessor, {\n get: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const valueCached = this.valueCache.get(requestor);\n\n if (!valueCached || valueCached.kind === \"resolving\") {\n throw new Error(\"Executor not found\");\n }\n\n if (valueCached.kind === \"rejected\") {\n throw valueCached.error;\n }\n\n return valueCached.value;\n },\n lookup: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this.valueCache.get(requestor);\n },\n metas: e.metas,\n resolve,\n release: async (soft: boolean = false) => {\n this.release(requestor);\n },\n update: (updateFn: unknown | ((current: unknown) => unknown)) => {\n return this.update(requestor, updateFn);\n },\n } satisfies Partial<Core.Accessor<unknown>>);\n }\n\n accessor<T>(executor: Core.Executor<T>): Core.Accessor<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this[\"~makeAccessor\"](executor, false) as Core.Accessor<T>;\n }\n\n async resolve<T>(executor: Core.Executor<T>): Promise<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(executor);\n if (cached) {\n if (cached.kind === \"resolved\") {\n return cached.value as T;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return (await cached.promise) as T;\n }\n }\n\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve(false);\n\n return accessor.get() as T;\n }\n\n async resolveAccessor<T>(\n executor: Core.Executor<T>\n ): Promise<Core.Accessor<T>> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cachedAccessor = this.cache.get(executor);\n if (!cachedAccessor) {\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve();\n\n return accessor as Core.Accessor<T>;\n }\n\n await cachedAccessor.resolve();\n return cachedAccessor as Core.Accessor<T>;\n }\n\n private \"~findAffectedTargets\"(\n target: Core.Executor<unknown>,\n updateSet: Set<Core.Executor<unknown>> = new Set()\n ): Set<Core.Executor<unknown>> {\n const triggerTargets = this.reactiveness.get(target);\n if (triggerTargets && triggerTargets.size > 0) {\n for (const target of triggerTargets) {\n if (updateSet.has(target)) {\n updateSet.delete(target);\n }\n updateSet.add(target);\n\n if (this.reactiveness.has(target)) {\n this[\"~findAffectedTargets\"](target, updateSet);\n }\n }\n }\n\n return updateSet;\n }\n\n async update<T>(\n executor: Core.Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const current = (await cached.resolve(false)) as T;\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n if (typeof updateFn === \"function\") {\n const fn = updateFn as (current: T) => T;\n const newValue = fn(current);\n this.valueCache.set(executor, { kind: \"resolved\", value: newValue });\n } else {\n this.valueCache.set(executor, {\n kind: \"resolved\",\n value: updateFn,\n });\n }\n\n const updateSet = this[\"~findAffectedTargets\"](executor);\n for (const target of updateSet) {\n const cached = this.cache.get(target);\n if (cached) {\n await cached.resolve(true);\n const onUpdateSet = this.onUpdates.get(target);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n }\n\n const onUpdateSet = this.onUpdates.get(executor);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n\n async reset<T>(executor: Core.Executor<T>): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n await this.release(executor, true);\n await this.resolve(executor);\n }\n\n async release(\n executor: Core.Executor<any>,\n soft: boolean = false\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached && !soft) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const affectedTargets = this[\"~findAffectedTargets\"](executor);\n for (const target of affectedTargets) {\n await this.release(target, true);\n }\n\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n this.cache.delete(executor);\n this.valueCache.delete(executor);\n this.reactiveness.delete(executor);\n this.onUpdates.delete(executor);\n }\n\n async dispose(): Promise<void> {\n const currents = this.cache.keys();\n for (const current of currents) {\n await this.release(current, true);\n }\n\n this.isDisposed = true;\n this.cache.clear();\n this.valueCache.clear();\n this.reactiveness.clear();\n this.cleanups.clear();\n }\n\n onUpdate<T>(\n executor: Core.Executor<T>,\n callback: (accessor: Core.Accessor<T>) => void | Promise<void>\n ): Core.Cleanup {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const onUpdateSet = this.onUpdates.get(executor) ?? new Set();\n this.onUpdates.set(executor, onUpdateSet);\n onUpdateSet.add(callback as any);\n\n return () => {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const currentSet = this.onUpdates.get(executor);\n if (currentSet) {\n currentSet.delete(callback as any);\n if (currentSet.size === 0) {\n this.onUpdates.delete(executor);\n }\n }\n };\n }\n\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>> {\n return this.cache;\n }\n\n getValueCache(): Map<Core.Executor<unknown>, unknown> {\n return this.valueCache;\n }\n\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>> {\n return this.reactiveness;\n }\n}\n\nexport function createScope(): Core.Scope {\n return new Scope();\n}\n"],"mappings":"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","names":["index_exports","__export","SchemaError","createScope","custom","derive","executorSymbol","findValue","findValues","getValue","isExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","meta","metaSymbol","provide","validate","validateAsync","__toCommonJS","executorSymbol","metaSymbol","SchemaError","issues","createExecutor","factory","dependencies","metas","executor","executorSymbol","_","controller","lazyExecutor","reactiveExecutor","staticExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","provide","derive","pdependencies","pfactory","validate","schema","data","result","SchemaError","validateAsync","result_1","custom","value","meta","key","schema","_key","fn","value","metaSymbol","d","source","findValues","findValue","getValue","validate","executor","m","isExecutor","input","executorSymbol","Scope","reactive","ref","currentSet","isLazyExecutor","staticResult","isReactiveExecutor","isStaticExecutor","item","result","key","target","resolvedResult","cached","cleanup","eager","accessor","requestor","cachedAccessor","factory","controller","resolve","force","promise","reject","dependencies","error","valueCached","soft","updateFn","executor","updateSet","triggerTargets","current","cleanups","newValue","onUpdateSet","callback","affectedTargets","currents","createScope"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/types.ts","../src/executor.ts","../src/ssch.ts","../src/meta.ts","../src/scope.ts"],"sourcesContent":["export * from \"./executor\";\nexport * from \"./meta\";\nexport * from \"./scope\";\nexport * from \"./types\";\nexport * from \"./ssch\";\n","export const executorSymbol = Symbol.for(\"@pumped-fn/core/executor\");\nexport const metaSymbol = Symbol.for(\"@pumped-fn/core/meta\");\n\nexport interface StandardSchemaV1<Input = unknown, Output = Input> {\n readonly \"~standard\": StandardSchemaV1.Props<Input, Output>;\n}\n\nexport declare namespace StandardSchemaV1 {\n export interface Props<Input = unknown, Output = Input> {\n readonly version: 1;\n readonly vendor: string;\n readonly validate: (\n value: unknown\n ) => Result<Output> | Promise<Result<Output>>;\n readonly types?: Types<Input, Output> | undefined;\n }\n\n export type Result<Output> = SuccessResult<Output> | FailureResult;\n\n export interface SuccessResult<Output> {\n readonly value: Output;\n readonly issues?: undefined;\n }\n\n export interface FailureResult {\n readonly issues: ReadonlyArray<Issue>;\n }\n\n export interface Issue {\n readonly message: string;\n readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;\n }\n\n export interface PathSegment {\n readonly key: PropertyKey;\n }\n\n export interface Types<Input = unknown, Output = Input> {\n readonly input: Input;\n readonly output: Output;\n }\n\n export type InferInput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"input\"];\n\n export type InferOutput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"output\"];\n}\n\nexport class SchemaError extends Error {\n public readonly issues: ReadonlyArray<StandardSchemaV1.Issue>;\n\n constructor(issues: ReadonlyArray<StandardSchemaV1.Issue>) {\n super(issues[0].message);\n this.name = \"SchemaError\";\n this.issues = issues;\n }\n}\n\nexport declare namespace Meta {\n export interface MetaContainer {\n metas: Meta[] | undefined;\n }\n\n export interface Meta<V = unknown> {\n readonly [metaSymbol]: true;\n readonly key: string | symbol;\n readonly schema: StandardSchemaV1<V>;\n readonly value: V;\n }\n\n export interface MetaFn<V> {\n (value: V): Meta<V>;\n readonly key: string | symbol;\n partial: <D extends Partial<V>>(d: D) => D;\n some: (source: MetaContainer | Meta[] | undefined) => V[];\n find: (source: MetaContainer | Meta[] | undefined) => V | undefined;\n get: (source: MetaContainer | Meta[] | undefined) => V;\n }\n}\n\nexport declare namespace Core {\n export type Output<T> = T | Promise<T>;\n\n export type NoDependencyFn<T> = (scope: Controller) => Output<T>;\n export type DependentFn<T, D> = (\n dependencies: D,\n scope: Controller\n ) => Output<T>;\n export type RecordLike = Record<string, unknown>;\n export type UExecutor = BaseExecutor<unknown>;\n\n export type Cleanup = () => void | Promise<void>;\n\n export type Controller = {\n cleanup: (cleanup: Cleanup) => void;\n release: () => Promise<void>;\n scope: Scope;\n };\n\n export type Kind = \"base\" | \"main\" | \"reactive\" | \"lazy\" | \"static\";\n\n export interface BaseExecutor<T> extends Meta.MetaContainer {\n [executorSymbol]: Kind;\n factory: NoDependencyFn<T> | DependentFn<T, unknown> | undefined;\n dependencies:\n | undefined\n | UExecutor\n | Array<UExecutor>\n | Record<string, UExecutor>;\n }\n\n export interface Executor<T> extends BaseExecutor<T> {\n [executorSymbol]: \"main\";\n factory: NoDependencyFn<T> | DependentFn<T, unknown>;\n\n /** Return an executor controller without resolving Executor */\n readonly lazy: Lazy<T>;\n\n /** Return an resolved executor, and mark the user to be reactived for future changes */\n readonly reactive: Reactive<T>;\n\n /** Return an resolved executor with its controller */\n readonly static: Static<T>;\n }\n\n export interface Reactive<T> extends BaseExecutor<T> {\n [executorSymbol]: \"reactive\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Lazy<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"lazy\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Static<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"static\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Accessor<T> extends Meta.MetaContainer {\n lookup(): T;\n get(): T;\n resolve(force?: boolean): Promise<T>;\n release(soft?: boolean): Promise<void>;\n update(updateFn: T | ((current: T) => T)): Promise<void>;\n }\n\n export type InferOutput<T> = T extends Executor<infer U> | Reactive<infer U>\n ? Awaited<U>\n : T extends Lazy<infer U> | Static<infer U>\n ? Accessor<Awaited<U>>\n : never;\n\n export interface Scope {\n accessor<T>(executor: Core.Executor<T>, eager?: boolean): Accessor<T>;\n\n resolve<T>(executor: Core.Executor<T>): Promise<T>;\n resolveAccessor<T>(executor: Core.Executor<T>): Promise<Accessor<T>>;\n\n update<T>(\n executor: Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void>;\n\n reset<T>(executor: Executor<T>): void;\n release(executor: Executor<any>, soft?: boolean): Promise<void>;\n\n dispose(): Promise<void>;\n\n onUpdate<T>(\n executor: Executor<T>,\n callback: (accessor: Accessor<T>) => void\n ): Cleanup;\n // onRelease<T>(executor: Executor<T>, callback: () => void): () => void;\n }\n}\n","import { Core, executorSymbol, Meta, metaSymbol } from \"./types\";\n\nfunction createExecutor<T>(\n factory: Core.NoDependencyFn<T> | Core.DependentFn<T, unknown>,\n dependencies:\n | undefined\n | Core.UExecutor\n | Array<Core.UExecutor>\n | Record<string, Core.UExecutor>,\n metas: Meta.Meta[] | undefined\n): Core.Executor<T> {\n const executor = {\n [executorSymbol]: \"base\",\n factory: (_: unknown, controller: Core.Controller) => {\n if (dependencies === undefined) {\n const f = factory as Core.NoDependencyFn<T>;\n return f(controller);\n }\n\n const f = factory as Core.DependentFn<T, unknown>;\n return f(_, controller);\n },\n dependencies,\n metas: metas,\n } as unknown as Core.Executor<T>;\n\n const lazyExecutor = {\n [executorSymbol]: \"lazy\",\n dependencies: undefined,\n executor,\n factory: undefined,\n metas: metas,\n } satisfies Core.Lazy<T>;\n\n const reactiveExecutor = {\n [executorSymbol]: \"reactive\",\n executor,\n factory: undefined,\n dependencies: undefined,\n metas: metas,\n } satisfies Core.Reactive<T>;\n\n const staticExecutor = {\n [executorSymbol]: \"static\",\n dependencies: undefined,\n factory: undefined,\n metas: metas,\n executor,\n } satisfies Core.Static<T>;\n\n Object.defineProperties(executor, {\n lazy: {\n value: lazyExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n reactive: {\n value: reactiveExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n static: {\n value: staticExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n });\n\n return executor;\n}\n\nexport function isLazyExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Lazy<unknown> {\n return executor[executorSymbol] === \"lazy\";\n}\n\nexport function isReactiveExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Reactive<unknown> {\n return executor[executorSymbol] === \"reactive\";\n}\n\nexport function isStaticExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Static<unknown> {\n return executor[executorSymbol] === \"static\";\n}\n\nexport function provide<T>(\n factory: Core.NoDependencyFn<T>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(factory, undefined, metas);\n}\n\nexport function derive<T, D extends Core.BaseExecutor<unknown>>(\n dependencies: D,\n factory: Core.DependentFn<T, Core.InferOutput<D>>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<\n T,\n D extends\n | ReadonlyArray<Core.BaseExecutor<unknown>>\n | Record<string, Core.BaseExecutor<unknown>>\n>(\n dependencies: { [K in keyof D]: D[K] },\n factory: Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<T, D>(\n pdependencies:\n | Core.BaseExecutor<D>\n | Array<Core.BaseExecutor<D>>\n | Record<string, Core.BaseExecutor<unknown>>,\n pfactory:\n | Core.DependentFn<T, Core.InferOutput<D>>\n | Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(pfactory as any, pdependencies, metas);\n}\n","import { SchemaError, StandardSchemaV1 } from \"./types\";\n\nexport function validate<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Awaited<StandardSchemaV1.InferOutput<TSchema>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n throw new Error(\"validating async is not supported\");\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n return result.value as any;\n}\n\nexport async function validateAsync<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Promise<Awaited<StandardSchemaV1.InferOutput<TSchema>>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n const result_1 = await result;\n if (result_1.issues) {\n throw new SchemaError(result_1.issues);\n }\n return result_1.value as any;\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n\n return Promise.resolve(result.value as any);\n}\n\nexport function custom<T>(): StandardSchemaV1<T, T> {\n return {\n \"~standard\": {\n vendor: \"pumped-fn\",\n version: 1,\n validate: (value) => {\n return { value: value as T };\n },\n },\n };\n}\n","import { validate } from \"./ssch\";\nimport { metaSymbol, StandardSchemaV1, type Meta } from \"./types\";\n\nexport const meta = <V>(\n key: string | symbol,\n schema: StandardSchemaV1<V>\n): Meta.MetaFn<V> => {\n const _key = typeof key === \"string\" ? Symbol(key) : key;\n\n const fn = (value: V) =>\n ({\n [metaSymbol]: true,\n key: _key,\n schema,\n value,\n } as unknown as Meta.MetaFn<V>);\n\n Object.defineProperty(fn, \"key\", {\n value: _key,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperty(fn, metaSymbol, {\n value: true,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperties(fn, {\n partial: {\n value: (d: Partial<V>) => {\n return Object.assign({}, fn({} as V), d);\n },\n configurable: false,\n enumerable: false,\n writable: false,\n },\n some: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValues(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n find: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValue(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n get: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n getValue(\n findValue(\n source,\n fn as unknown as Meta.MetaFn<unknown>\n ) as Meta.Meta<V>\n ),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n });\n\n return fn as any;\n};\n\nexport function getValue<V>(meta: Meta.Meta<V>) {\n return validate(meta.schema, meta.value);\n}\n\nexport function findValues<V = unknown>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V[] {\n if (!executor) return [];\n\n const metas = Array.isArray(executor) ? executor : executor.metas ?? [];\n\n const maybeMeta = metas.filter((m) => m.key === meta.key);\n return maybeMeta.map((m) => getValue(m as Meta.Meta<V>));\n}\n\nexport function findValue<V>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V | undefined {\n const values = findValues(executor, meta);\n return values.at(0);\n}\n","import {\n isLazyExecutor,\n isReactiveExecutor,\n isStaticExecutor,\n} from \"./executor\";\nimport { Core, executorSymbol } from \"./types\";\n\nexport interface ScopeInner {\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>>;\n getValueCache(): Map<Core.Executor<unknown>, unknown>;\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>>;\n}\n\nexport function isExecutor<T>(input: unknown): input is Core.BaseExecutor<T> {\n return typeof input === \"object\" && input !== null && executorSymbol in input;\n}\n\ntype Value =\n | { kind: \"resolving\"; promise: Promise<unknown> }\n | { kind: \"resolved\"; value: unknown }\n | { kind: \"rejected\"; error: unknown };\n\nclass Scope implements Core.Scope, ScopeInner {\n private isDisposed: boolean = false;\n private cache: Map<Core.Executor<unknown>, Core.Accessor<unknown>> =\n new Map();\n private valueCache: Map<Core.Executor<unknown>, Value> = new Map();\n private reactiveness = new Map<\n Core.Executor<unknown>,\n Set<Core.Executor<unknown>>\n >();\n private cleanups = new Map<Core.Executor<unknown>, Set<Core.Cleanup>>();\n private onUpdates = new Map<\n Core.Executor<unknown>,\n Set<(accessor: Core.Accessor<unknown>) => void | Promise<void>>\n >();\n\n private \"~appendReactive\"(\n reactive: Core.Executor<unknown>,\n ref: Core.Executor<unknown>\n ) {\n const currentSet = this.reactiveness.get(reactive) ?? new Set();\n this.reactiveness.set(reactive, currentSet);\n\n currentSet.add(ref);\n }\n\n private async \"~resolveDependencies\"(\n e:\n | undefined\n | Core.BaseExecutor<unknown>\n | Core.BaseExecutor<unknown>[]\n | Record<string, Core.BaseExecutor<unknown>>,\n ref: Core.Executor<unknown>\n ): Promise<undefined | unknown | unknown[] | Record<string, unknown>> {\n if (e === undefined) {\n return undefined;\n }\n\n if (isExecutor(e)) {\n if (isLazyExecutor(e)) {\n return this[\"~resolveLazy\"](e);\n }\n\n const staticResult = await this[\"~resolveStatic\"](\n e as Core.Executor<unknown>\n );\n\n if (isReactiveExecutor(e)) {\n this[\"~appendReactive\"](e.executor, ref);\n }\n\n await staticResult.resolve(false);\n if (isStaticExecutor(e)) {\n return staticResult;\n }\n\n return staticResult.get();\n }\n\n if (Array.isArray(e)) {\n return await Promise.all(\n e.map((item) => this[\"~resolveDependencies\"](item, ref))\n );\n }\n\n const result: Record<string, unknown> = {};\n for (const key of Object.keys(e)) {\n const target = e[key];\n const resolvedResult = await this[\"~resolveDependencies\"](target, ref);\n\n result[key] = resolvedResult;\n }\n\n return result;\n }\n\n private \"~resolveLazy\"(e: Core.Lazy<unknown>): Core.Accessor<unknown> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(e.executor);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e.executor);\n\n return accessor;\n }\n\n private async \"~resolveStatic\"(\n e: Core.Executor<unknown>\n ): Promise<Core.Accessor<unknown>> {\n const cached = this.cache.get(e);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e, true);\n return accessor;\n }\n\n private \"~makeController\"(e: Core.Executor<unknown>): Core.Controller {\n return {\n cleanup: (cleanup: Core.Cleanup) => {\n const currentSet = this.cleanups.get(e) ?? new Set();\n this.cleanups.set(e, currentSet);\n\n currentSet.add(cleanup);\n },\n release: async () => {\n this.release(e);\n },\n scope: this,\n };\n }\n\n private \"~makeAccessor\"(\n e: Core.BaseExecutor<unknown>,\n eager: boolean = false\n ): Core.Accessor<unknown> {\n const accessor = {} as Core.Accessor<unknown>;\n const requestor =\n isLazyExecutor(e) || isReactiveExecutor(e) || isStaticExecutor(e)\n ? e.executor\n : (e as Core.Executor<unknown>);\n\n const cachedAccessor = this.cache.get(requestor);\n if (cachedAccessor) {\n return cachedAccessor;\n }\n\n const factory = requestor.factory;\n const controller = this[\"~makeController\"](requestor);\n\n const resolve = async (force: boolean): Promise<unknown> => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(requestor);\n if (cached && !force) {\n if (cached.kind === \"resolved\") {\n return cached.value;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return cached.promise;\n }\n }\n\n const promise = new Promise((resolve, reject) => {\n this[\"~resolveDependencies\"](requestor.dependencies, requestor)\n .then((dependencies) => factory(dependencies as any, controller))\n .then((result) => {\n this.valueCache.set(requestor, { kind: \"resolved\", value: result });\n resolve(result);\n })\n .catch((error) => {\n this.valueCache.set(requestor, { kind: \"rejected\", error });\n reject(error);\n });\n });\n\n this.valueCache.set(requestor, { kind: \"resolving\", promise });\n this.cache.set(requestor, accessor);\n return promise;\n };\n\n if (!isLazyExecutor(e) || eager) {\n resolve(false);\n }\n\n return Object.assign(accessor, {\n get: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const valueCached = this.valueCache.get(requestor);\n\n if (!valueCached || valueCached.kind === \"resolving\") {\n throw new Error(\"Executor not found\");\n }\n\n if (valueCached.kind === \"rejected\") {\n throw valueCached.error;\n }\n\n return valueCached.value;\n },\n lookup: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this.valueCache.get(requestor);\n },\n metas: e.metas,\n resolve,\n release: async (soft: boolean = false) => {\n this.release(requestor);\n },\n update: (updateFn: unknown | ((current: unknown) => unknown)) => {\n return this.update(requestor, updateFn);\n },\n } satisfies Partial<Core.Accessor<unknown>>);\n }\n\n accessor<T>(executor: Core.Executor<T>): Core.Accessor<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this[\"~makeAccessor\"](executor, false) as Core.Accessor<T>;\n }\n\n async resolve<T>(executor: Core.Executor<T>): Promise<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(executor);\n if (cached) {\n if (cached.kind === \"resolved\") {\n return cached.value as T;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return (await cached.promise) as T;\n }\n }\n\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve(false);\n\n return accessor.get() as T;\n }\n\n async resolveAccessor<T>(\n executor: Core.Executor<T>\n ): Promise<Core.Accessor<T>> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cachedAccessor = this.cache.get(executor);\n if (!cachedAccessor) {\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve();\n\n return accessor as Core.Accessor<T>;\n }\n\n await cachedAccessor.resolve();\n return cachedAccessor as Core.Accessor<T>;\n }\n\n private \"~findAffectedTargets\"(\n target: Core.Executor<unknown>,\n updateSet: Set<Core.Executor<unknown>> = new Set()\n ): Set<Core.Executor<unknown>> {\n const triggerTargets = this.reactiveness.get(target);\n if (triggerTargets && triggerTargets.size > 0) {\n for (const target of triggerTargets) {\n if (updateSet.has(target)) {\n updateSet.delete(target);\n }\n updateSet.add(target);\n\n if (this.reactiveness.has(target)) {\n this[\"~findAffectedTargets\"](target, updateSet);\n }\n }\n }\n\n return updateSet;\n }\n\n async update<T>(\n executor: Core.Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const current = (await cached.resolve(false)) as T;\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n if (typeof updateFn === \"function\") {\n const fn = updateFn as (current: T) => T;\n const newValue = fn(current);\n this.valueCache.set(executor, { kind: \"resolved\", value: newValue });\n } else {\n this.valueCache.set(executor, {\n kind: \"resolved\",\n value: updateFn,\n });\n }\n\n const updateSet = this[\"~findAffectedTargets\"](executor);\n for (const target of updateSet) {\n const cached = this.cache.get(target);\n if (cached) {\n await cached.resolve(true);\n const onUpdateSet = this.onUpdates.get(target);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n }\n\n const onUpdateSet = this.onUpdates.get(executor);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n\n async reset<T>(executor: Core.Executor<T>): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n await this.release(executor, true);\n await this.resolve(executor);\n }\n\n async release(\n executor: Core.Executor<any>,\n soft: boolean = false\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached && !soft) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const affectedTargets = this[\"~findAffectedTargets\"](executor);\n for (const target of affectedTargets) {\n await this.release(target, true);\n }\n\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n this.cache.delete(executor);\n this.valueCache.delete(executor);\n this.reactiveness.delete(executor);\n this.onUpdates.delete(executor);\n }\n\n async dispose(): Promise<void> {\n const currents = this.cache.keys();\n for (const current of currents) {\n await this.release(current, true);\n }\n\n this.isDisposed = true;\n this.cache.clear();\n this.valueCache.clear();\n this.reactiveness.clear();\n this.cleanups.clear();\n }\n\n onUpdate<T>(\n executor: Core.Executor<T>,\n callback: (accessor: Core.Accessor<T>) => void | Promise<void>\n ): Core.Cleanup {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const onUpdateSet = this.onUpdates.get(executor) ?? new Set();\n this.onUpdates.set(executor, onUpdateSet);\n onUpdateSet.add(callback as any);\n\n return () => {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const currentSet = this.onUpdates.get(executor);\n if (currentSet) {\n currentSet.delete(callback as any);\n if (currentSet.size === 0) {\n this.onUpdates.delete(executor);\n }\n }\n };\n }\n\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>> {\n return this.cache;\n }\n\n getValueCache(): Map<Core.Executor<unknown>, unknown> {\n return this.valueCache;\n }\n\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>> {\n return this.reactiveness;\n }\n}\n\nexport function createScope(): Core.Scope {\n return new Scope();\n}\n"],"mappings":"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","names":["index_exports","__export","SchemaError","createScope","custom","derive","executorSymbol","findValue","findValues","getValue","isExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","meta","metaSymbol","provide","validate","validateAsync","__toCommonJS","executorSymbol","metaSymbol","SchemaError","issues","createExecutor","factory","dependencies","metas","executor","executorSymbol","_","controller","lazyExecutor","reactiveExecutor","staticExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","provide","derive","pdependencies","pfactory","validate","schema","data","result","SchemaError","validateAsync","result_1","custom","value","meta","key","schema","_key","fn","value","metaSymbol","d","source","findValues","findValue","getValue","validate","executor","m","isExecutor","input","executorSymbol","Scope","reactive","ref","currentSet","isLazyExecutor","staticResult","isReactiveExecutor","isStaticExecutor","item","result","key","target","resolvedResult","cached","cleanup","eager","accessor","requestor","cachedAccessor","factory","controller","resolve","force","promise","reject","dependencies","error","valueCached","soft","updateFn","executor","updateSet","triggerTargets","current","cleanups","newValue","onUpdateSet","callback","affectedTargets","currents","createScope"]}
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- var d=Symbol.for("@pumped-fn/core/executor"),x=Symbol.for("@pumped-fn/core/meta"),f=class extends Error{issues;constructor(e){super(e[0].message),this.name="SchemaError",this.issues=e}};function m(o,e,t){let n={[d]:"base",factory:(p,s)=>e===void 0?o(s):o(p,s),dependencies:e,metas:t},r={[d]:"lazy",dependencies:void 0,executor:n,factory:void 0,metas:t},c={[d]:"reactive",executor:n,factory:void 0,dependencies:void 0,metas:t},i={[d]:"static",dependencies:void 0,factory:void 0,metas:t,executor:n};return Object.defineProperties(n,{lazy:{value:r,writable:!1,configurable:!1,enumerable:!1},reactive:{value:c,writable:!1,configurable:!1,enumerable:!1},static:{value:i,writable:!1,configurable:!1,enumerable:!1}}),n}function w(o){return o[d]==="lazy"}function y(o){return o[d]==="reactive"}function C(o){return o[d]==="static"}function O(o,...e){return m(o,void 0,e)}function U(o,e,...t){return m(e,o,t)}function T(o,e){let t=o["~standard"].validate(e);if("then"in t)throw new Error("validating async is not supported");if(t.issues)throw new f(t.issues);return t.value}async function z(o,e){let t=o["~standard"].validate(e);if("then"in t){let n=await t;if(n.issues)throw new f(n.issues);return n.value}if(t.issues)throw new f(t.issues);return Promise.resolve(t.value)}function j(){return{"~standard":{vendor:"pumped-fn",version:1,validate:o=>({value:o})}}}var q=(o,e)=>{let t=typeof o=="string"?Symbol(o):o,n=r=>({[x]:!0,key:t,schema:e,value:r});return Object.defineProperty(n,"key",{value:t,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperty(n,x,{value:!0,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperties(n,{partial:{value:r=>Object.assign({},n({}),r),configurable:!1,enumerable:!1,writable:!1},some:{value:r=>S(r,n),configurable:!1,enumerable:!1,writable:!1},find:{value:r=>k(r,n),configurable:!1,enumerable:!1,writable:!1},get:{value:r=>E(k(r,n)),configurable:!1,enumerable:!1,writable:!1}}),n};function E(o){return T(o.schema,o.value)}function S(o,e){return o?(Array.isArray(o)?o:o.metas??[]).filter(r=>r.key===e.key).map(r=>E(r)):[]}function k(o,e){return S(o,e).at(0)}function b(o){return typeof o=="object"&&o!==null&&d in o}var v=class{isDisposed=!1;cache=new Map;valueCache=new Map;reactiveness=new Map;cleanups=new Map;onUpdates=new Map;"~appendReactive"(e,t){let n=this.reactiveness.get(e)??new Set;this.reactiveness.set(e,n),n.add(t)}async"~resolveDependencies"(e,t){if(e===void 0)return;if(b(e)){if(w(e))return this["~resolveLazy"](e);let r=await this["~resolveStatic"](e);return y(e)&&this["~appendReactive"](e.executor,t),await r.resolve(!1),C(e)?r:r.get()}if(Array.isArray(e))return await Promise.all(e.map(r=>this["~resolveDependencies"](r,t)));let n={};for(let r of Object.keys(e)){let c=e[r],i=await this["~resolveDependencies"](c,t);n[r]=i}return n}"~resolveLazy"(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e.executor);return t||this["~makeAccessor"](e.executor)}async"~resolveStatic"(e){let t=this.cache.get(e);return t||this["~makeAccessor"](e,!0)}"~makeController"(e){return{cleanup:t=>{let n=this.cleanups.get(e)??new Set;this.cleanups.set(e,n),n.add(t)},release:async()=>{this.release(e)},scope:this}}"~makeAccessor"(e,t=!1){let n={},r=w(e)||y(e)?e.executor:e,c=this.cache.get(r);if(c)return c;let i=r.factory,p=this["~makeController"](r),s=async a=>{if(this.isDisposed)throw new Error("Scope is disposed");let u=this.valueCache.get(r);if(u&&!a){if(u.kind==="resolved")return u.value;if(u.kind==="rejected")throw u.error;return u.promise}let h=new Promise((M,g)=>{this["~resolveDependencies"](r.dependencies,r).then(l=>i(l,p)).then(l=>{this.valueCache.set(r,{kind:"resolved",value:l}),M(l)}).catch(l=>{this.valueCache.set(r,{kind:"rejected",error:l}),g(l)})});return this.valueCache.set(r,{kind:"resolving",promise:h}),this.cache.set(r,n),h};return(!w(e)||t)&&s(!1),Object.assign(n,{get:()=>{if(this.isDisposed)throw new Error("Scope is disposed");let a=this.valueCache.get(r);if(!a||a.kind==="resolving")throw new Error("Executor not found");if(a.kind==="rejected")throw a.error;return a.value},lookup:()=>{if(this.isDisposed)throw new Error("Scope is disposed");return this.valueCache.get(r)},metas:e.metas,resolve:s,release:async(a=!1)=>{this.release(r)},update:a=>this.update(r,a)})}accessor(e){if(this.isDisposed)throw new Error("Scope is disposed");return this["~makeAccessor"](e,!1)}async resolve(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.valueCache.get(e);if(t){if(t.kind==="resolved")return t.value;if(t.kind==="rejected")throw t.error;return await t.promise}let n=this["~makeAccessor"](e,!0);return await n.resolve(!1),n.get()}async resolveAccessor(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e);if(!t){let n=this["~makeAccessor"](e,!0);return await n.resolve(),n}return await t.resolve(),t}"~findAffectedTargets"(e,t=new Set){let n=this.reactiveness.get(e);if(n&&n.size>0)for(let r of n)t.has(r)&&t.delete(r),t.add(r),this.reactiveness.has(r)&&this["~findAffectedTargets"](r,t);return t}async update(e,t){if(this.isDisposed)throw new Error("Scope is disposed");let n=this.cache.get(e);if(!n)throw new Error("Executor is not yet resolved");let r=await n.resolve(!1),c=this.cleanups.get(e);if(c)for(let s of Array.from(c.values()).reverse())await s();if(typeof t=="function"){let a=t(r);this.valueCache.set(e,{kind:"resolved",value:a})}else this.valueCache.set(e,{kind:"resolved",value:t});let i=this["~findAffectedTargets"](e);for(let s of i){let a=this.cache.get(s);if(a){await a.resolve(!0);let u=this.onUpdates.get(s);if(u)for(let h of Array.from(u.values()))await h(a)}}let p=this.onUpdates.get(e);if(p)for(let s of Array.from(p.values()))await s(n)}async reset(e){if(this.isDisposed)throw new Error("Scope is disposed");await this.release(e,!0),await this.resolve(e)}async release(e,t=!1){if(this.isDisposed)throw new Error("Scope is disposed");if(!this.cache.get(e)&&!t)throw new Error("Executor is not yet resolved");let r=this["~findAffectedTargets"](e);for(let i of r)await this.release(i,!0);let c=this.cleanups.get(e);if(c)for(let i of Array.from(c.values()).reverse())await i();this.cache.delete(e),this.valueCache.delete(e),this.reactiveness.delete(e),this.onUpdates.delete(e)}async dispose(){let e=this.cache.keys();for(let t of e)await this.release(t,!0);this.isDisposed=!0,this.cache.clear(),this.valueCache.clear(),this.reactiveness.clear(),this.cleanups.clear()}onUpdate(e,t){if(this.isDisposed)throw new Error("scope is disposed");let n=this.onUpdates.get(e)??new Set;return this.onUpdates.set(e,n),n.add(t),()=>{if(this.isDisposed)throw new Error("scope is disposed");let r=this.onUpdates.get(e);r&&(r.delete(t),r.size===0&&this.onUpdates.delete(e))}}getCache(){return this.cache}getValueCache(){return this.valueCache}getReactiveness(){return this.reactiveness}};function W(){return new v}export{f as SchemaError,W as createScope,j as custom,U as derive,d as executorSymbol,k as findValue,S as findValues,E as getValue,b as isExecutor,w as isLazyExecutor,y as isReactiveExecutor,C as isStaticExecutor,q as meta,x as metaSymbol,O as provide,T as validate,z as validateAsync};
1
+ var d=Symbol.for("@pumped-fn/core/executor"),x=Symbol.for("@pumped-fn/core/meta"),f=class extends Error{issues;constructor(e){super(e[0].message),this.name="SchemaError",this.issues=e}};function C(o,e,t){let n={[d]:"base",factory:(p,s)=>e===void 0?o(s):o(p,s),dependencies:e,metas:t},r={[d]:"lazy",dependencies:void 0,executor:n,factory:void 0,metas:t},c={[d]:"reactive",executor:n,factory:void 0,dependencies:void 0,metas:t},i={[d]:"static",dependencies:void 0,factory:void 0,metas:t,executor:n};return Object.defineProperties(n,{lazy:{value:r,writable:!1,configurable:!1,enumerable:!1},reactive:{value:c,writable:!1,configurable:!1,enumerable:!1},static:{value:i,writable:!1,configurable:!1,enumerable:!1}}),n}function w(o){return o[d]==="lazy"}function y(o){return o[d]==="reactive"}function v(o){return o[d]==="static"}function O(o,...e){return C(o,void 0,e)}function U(o,e,...t){return C(e,o,t)}function T(o,e){let t=o["~standard"].validate(e);if("then"in t)throw new Error("validating async is not supported");if(t.issues)throw new f(t.issues);return t.value}async function z(o,e){let t=o["~standard"].validate(e);if("then"in t){let n=await t;if(n.issues)throw new f(n.issues);return n.value}if(t.issues)throw new f(t.issues);return Promise.resolve(t.value)}function j(){return{"~standard":{vendor:"pumped-fn",version:1,validate:o=>({value:o})}}}var q=(o,e)=>{let t=typeof o=="string"?Symbol(o):o,n=r=>({[x]:!0,key:t,schema:e,value:r});return Object.defineProperty(n,"key",{value:t,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperty(n,x,{value:!0,configurable:!1,enumerable:!1,writable:!1}),Object.defineProperties(n,{partial:{value:r=>Object.assign({},n({}),r),configurable:!1,enumerable:!1,writable:!1},some:{value:r=>S(r,n),configurable:!1,enumerable:!1,writable:!1},find:{value:r=>k(r,n),configurable:!1,enumerable:!1,writable:!1},get:{value:r=>E(k(r,n)),configurable:!1,enumerable:!1,writable:!1}}),n};function E(o){return T(o.schema,o.value)}function S(o,e){return o?(Array.isArray(o)?o:o.metas??[]).filter(r=>r.key===e.key).map(r=>E(r)):[]}function k(o,e){return S(o,e).at(0)}function b(o){return typeof o=="object"&&o!==null&&d in o}var m=class{isDisposed=!1;cache=new Map;valueCache=new Map;reactiveness=new Map;cleanups=new Map;onUpdates=new Map;"~appendReactive"(e,t){let n=this.reactiveness.get(e)??new Set;this.reactiveness.set(e,n),n.add(t)}async"~resolveDependencies"(e,t){if(e===void 0)return;if(b(e)){if(w(e))return this["~resolveLazy"](e);let r=await this["~resolveStatic"](e);return y(e)&&this["~appendReactive"](e.executor,t),await r.resolve(!1),v(e)?r:r.get()}if(Array.isArray(e))return await Promise.all(e.map(r=>this["~resolveDependencies"](r,t)));let n={};for(let r of Object.keys(e)){let c=e[r],i=await this["~resolveDependencies"](c,t);n[r]=i}return n}"~resolveLazy"(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e.executor);return t||this["~makeAccessor"](e.executor)}async"~resolveStatic"(e){let t=this.cache.get(e);return t||this["~makeAccessor"](e,!0)}"~makeController"(e){return{cleanup:t=>{let n=this.cleanups.get(e)??new Set;this.cleanups.set(e,n),n.add(t)},release:async()=>{this.release(e)},scope:this}}"~makeAccessor"(e,t=!1){let n={},r=w(e)||y(e)||v(e)?e.executor:e,c=this.cache.get(r);if(c)return c;let i=r.factory,p=this["~makeController"](r),s=async a=>{if(this.isDisposed)throw new Error("Scope is disposed");let u=this.valueCache.get(r);if(u&&!a){if(u.kind==="resolved")return u.value;if(u.kind==="rejected")throw u.error;return u.promise}let h=new Promise((M,g)=>{this["~resolveDependencies"](r.dependencies,r).then(l=>i(l,p)).then(l=>{this.valueCache.set(r,{kind:"resolved",value:l}),M(l)}).catch(l=>{this.valueCache.set(r,{kind:"rejected",error:l}),g(l)})});return this.valueCache.set(r,{kind:"resolving",promise:h}),this.cache.set(r,n),h};return(!w(e)||t)&&s(!1),Object.assign(n,{get:()=>{if(this.isDisposed)throw new Error("Scope is disposed");let a=this.valueCache.get(r);if(!a||a.kind==="resolving")throw new Error("Executor not found");if(a.kind==="rejected")throw a.error;return a.value},lookup:()=>{if(this.isDisposed)throw new Error("Scope is disposed");return this.valueCache.get(r)},metas:e.metas,resolve:s,release:async(a=!1)=>{this.release(r)},update:a=>this.update(r,a)})}accessor(e){if(this.isDisposed)throw new Error("Scope is disposed");return this["~makeAccessor"](e,!1)}async resolve(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.valueCache.get(e);if(t){if(t.kind==="resolved")return t.value;if(t.kind==="rejected")throw t.error;return await t.promise}let n=this["~makeAccessor"](e,!0);return await n.resolve(!1),n.get()}async resolveAccessor(e){if(this.isDisposed)throw new Error("Scope is disposed");let t=this.cache.get(e);if(!t){let n=this["~makeAccessor"](e,!0);return await n.resolve(),n}return await t.resolve(),t}"~findAffectedTargets"(e,t=new Set){let n=this.reactiveness.get(e);if(n&&n.size>0)for(let r of n)t.has(r)&&t.delete(r),t.add(r),this.reactiveness.has(r)&&this["~findAffectedTargets"](r,t);return t}async update(e,t){if(this.isDisposed)throw new Error("Scope is disposed");let n=this.cache.get(e);if(!n)throw new Error("Executor is not yet resolved");let r=await n.resolve(!1),c=this.cleanups.get(e);if(c)for(let s of Array.from(c.values()).reverse())await s();if(typeof t=="function"){let a=t(r);this.valueCache.set(e,{kind:"resolved",value:a})}else this.valueCache.set(e,{kind:"resolved",value:t});let i=this["~findAffectedTargets"](e);for(let s of i){let a=this.cache.get(s);if(a){await a.resolve(!0);let u=this.onUpdates.get(s);if(u)for(let h of Array.from(u.values()))await h(a)}}let p=this.onUpdates.get(e);if(p)for(let s of Array.from(p.values()))await s(n)}async reset(e){if(this.isDisposed)throw new Error("Scope is disposed");await this.release(e,!0),await this.resolve(e)}async release(e,t=!1){if(this.isDisposed)throw new Error("Scope is disposed");if(!this.cache.get(e)&&!t)throw new Error("Executor is not yet resolved");let r=this["~findAffectedTargets"](e);for(let i of r)await this.release(i,!0);let c=this.cleanups.get(e);if(c)for(let i of Array.from(c.values()).reverse())await i();this.cache.delete(e),this.valueCache.delete(e),this.reactiveness.delete(e),this.onUpdates.delete(e)}async dispose(){let e=this.cache.keys();for(let t of e)await this.release(t,!0);this.isDisposed=!0,this.cache.clear(),this.valueCache.clear(),this.reactiveness.clear(),this.cleanups.clear()}onUpdate(e,t){if(this.isDisposed)throw new Error("scope is disposed");let n=this.onUpdates.get(e)??new Set;return this.onUpdates.set(e,n),n.add(t),()=>{if(this.isDisposed)throw new Error("scope is disposed");let r=this.onUpdates.get(e);r&&(r.delete(t),r.size===0&&this.onUpdates.delete(e))}}getCache(){return this.cache}getValueCache(){return this.valueCache}getReactiveness(){return this.reactiveness}};function W(){return new m}export{f as SchemaError,W as createScope,j as custom,U as derive,d as executorSymbol,k as findValue,S as findValues,E as getValue,b as isExecutor,w as isLazyExecutor,y as isReactiveExecutor,v as isStaticExecutor,q as meta,x as metaSymbol,O as provide,T as validate,z as validateAsync};
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts","../src/executor.ts","../src/ssch.ts","../src/meta.ts","../src/scope.ts"],"sourcesContent":["export const executorSymbol = Symbol.for(\"@pumped-fn/core/executor\");\nexport const metaSymbol = Symbol.for(\"@pumped-fn/core/meta\");\n\nexport interface StandardSchemaV1<Input = unknown, Output = Input> {\n readonly \"~standard\": StandardSchemaV1.Props<Input, Output>;\n}\n\nexport declare namespace StandardSchemaV1 {\n export interface Props<Input = unknown, Output = Input> {\n readonly version: 1;\n readonly vendor: string;\n readonly validate: (\n value: unknown\n ) => Result<Output> | Promise<Result<Output>>;\n readonly types?: Types<Input, Output> | undefined;\n }\n\n export type Result<Output> = SuccessResult<Output> | FailureResult;\n\n export interface SuccessResult<Output> {\n readonly value: Output;\n readonly issues?: undefined;\n }\n\n export interface FailureResult {\n readonly issues: ReadonlyArray<Issue>;\n }\n\n export interface Issue {\n readonly message: string;\n readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;\n }\n\n export interface PathSegment {\n readonly key: PropertyKey;\n }\n\n export interface Types<Input = unknown, Output = Input> {\n readonly input: Input;\n readonly output: Output;\n }\n\n export type InferInput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"input\"];\n\n export type InferOutput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"output\"];\n}\n\nexport class SchemaError extends Error {\n public readonly issues: ReadonlyArray<StandardSchemaV1.Issue>;\n\n constructor(issues: ReadonlyArray<StandardSchemaV1.Issue>) {\n super(issues[0].message);\n this.name = \"SchemaError\";\n this.issues = issues;\n }\n}\n\nexport declare namespace Meta {\n export interface MetaContainer {\n metas: Meta[] | undefined;\n }\n\n export interface Meta<V = unknown> {\n readonly [metaSymbol]: true;\n readonly key: string | symbol;\n readonly schema: StandardSchemaV1<V>;\n readonly value: V;\n }\n\n export interface MetaFn<V> {\n (value: V): Meta<V>;\n readonly key: string | symbol;\n partial: <D extends Partial<V>>(d: D) => D;\n some: (source: MetaContainer | Meta[] | undefined) => V[];\n find: (source: MetaContainer | Meta[] | undefined) => V | undefined;\n get: (source: MetaContainer | Meta[] | undefined) => V;\n }\n}\n\nexport declare namespace Core {\n export type Output<T> = T | Promise<T>;\n\n export type NoDependencyFn<T> = (scope: Controller) => Output<T>;\n export type DependentFn<T, D> = (\n dependencies: D,\n scope: Controller\n ) => Output<T>;\n export type RecordLike = Record<string, unknown>;\n export type UExecutor = BaseExecutor<unknown>;\n\n export type Cleanup = () => void | Promise<void>;\n\n export type Controller = {\n cleanup: (cleanup: Cleanup) => void;\n release: () => Promise<void>;\n scope: Scope;\n };\n\n export type Kind = \"base\" | \"main\" | \"reactive\" | \"lazy\" | \"static\";\n\n export interface BaseExecutor<T> extends Meta.MetaContainer {\n [executorSymbol]: Kind;\n factory: NoDependencyFn<T> | DependentFn<T, unknown> | undefined;\n dependencies:\n | undefined\n | UExecutor\n | Array<UExecutor>\n | Record<string, UExecutor>;\n }\n\n export interface Executor<T> extends BaseExecutor<T> {\n [executorSymbol]: \"main\";\n factory: NoDependencyFn<T> | DependentFn<T, unknown>;\n\n /** Return an executor controller without resolving Executor */\n readonly lazy: Lazy<T>;\n\n /** Return an resolved executor, and mark the user to be reactived for future changes */\n readonly reactive: Reactive<T>;\n\n /** Return an resolved executor with its controller */\n readonly static: Static<T>;\n }\n\n export interface Reactive<T> extends BaseExecutor<T> {\n [executorSymbol]: \"reactive\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Lazy<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"lazy\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Static<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"static\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Accessor<T> extends Meta.MetaContainer {\n lookup(): T;\n get(): T;\n resolve(force?: boolean): Promise<T>;\n release(soft?: boolean): Promise<void>;\n update(updateFn: T | ((current: T) => T)): Promise<void>;\n }\n\n export type InferOutput<T> = T extends Executor<infer U> | Reactive<infer U>\n ? Awaited<U>\n : T extends Lazy<infer U> | Static<infer U>\n ? Accessor<Awaited<U>>\n : never;\n\n export interface Scope {\n accessor<T>(executor: Core.Executor<T>, eager?: boolean): Accessor<T>;\n\n resolve<T>(executor: Core.Executor<T>): Promise<T>;\n resolveAccessor<T>(executor: Core.Executor<T>): Promise<Accessor<T>>;\n\n update<T>(\n executor: Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void>;\n\n reset<T>(executor: Executor<T>): void;\n release(executor: Executor<any>, soft?: boolean): Promise<void>;\n\n dispose(): Promise<void>;\n\n onUpdate<T>(\n executor: Executor<T>,\n callback: (accessor: Accessor<T>) => void\n ): Cleanup;\n // onRelease<T>(executor: Executor<T>, callback: () => void): () => void;\n }\n}\n","import { Core, executorSymbol, Meta, metaSymbol } from \"./types\";\n\nfunction createExecutor<T>(\n factory: Core.NoDependencyFn<T> | Core.DependentFn<T, unknown>,\n dependencies:\n | undefined\n | Core.UExecutor\n | Array<Core.UExecutor>\n | Record<string, Core.UExecutor>,\n metas: Meta.Meta[] | undefined\n): Core.Executor<T> {\n const executor = {\n [executorSymbol]: \"base\",\n factory: (_: unknown, controller: Core.Controller) => {\n if (dependencies === undefined) {\n const f = factory as Core.NoDependencyFn<T>;\n return f(controller);\n }\n\n const f = factory as Core.DependentFn<T, unknown>;\n return f(_, controller);\n },\n dependencies,\n metas: metas,\n } as unknown as Core.Executor<T>;\n\n const lazyExecutor = {\n [executorSymbol]: \"lazy\",\n dependencies: undefined,\n executor,\n factory: undefined,\n metas: metas,\n } satisfies Core.Lazy<T>;\n\n const reactiveExecutor = {\n [executorSymbol]: \"reactive\",\n executor,\n factory: undefined,\n dependencies: undefined,\n metas: metas,\n } satisfies Core.Reactive<T>;\n\n const staticExecutor = {\n [executorSymbol]: \"static\",\n dependencies: undefined,\n factory: undefined,\n metas: metas,\n executor,\n } satisfies Core.Static<T>;\n\n Object.defineProperties(executor, {\n lazy: {\n value: lazyExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n reactive: {\n value: reactiveExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n static: {\n value: staticExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n });\n\n return executor;\n}\n\nexport function isLazyExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Lazy<unknown> {\n return executor[executorSymbol] === \"lazy\";\n}\n\nexport function isReactiveExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Reactive<unknown> {\n return executor[executorSymbol] === \"reactive\";\n}\n\nexport function isStaticExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Static<unknown> {\n return executor[executorSymbol] === \"static\";\n}\n\nexport function provide<T>(\n factory: Core.NoDependencyFn<T>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(factory, undefined, metas);\n}\n\nexport function derive<T, D extends Core.BaseExecutor<unknown>>(\n dependencies: D,\n factory: Core.DependentFn<T, Core.InferOutput<D>>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<\n T,\n D extends\n | ReadonlyArray<Core.BaseExecutor<unknown>>\n | Record<string, Core.BaseExecutor<unknown>>\n>(\n dependencies: { [K in keyof D]: D[K] },\n factory: Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<T, D>(\n pdependencies:\n | Core.BaseExecutor<D>\n | Array<Core.BaseExecutor<D>>\n | Record<string, Core.BaseExecutor<unknown>>,\n pfactory:\n | Core.DependentFn<T, Core.InferOutput<D>>\n | Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(pfactory as any, pdependencies, metas);\n}\n","import { SchemaError, StandardSchemaV1 } from \"./types\";\n\nexport function validate<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Awaited<StandardSchemaV1.InferOutput<TSchema>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n throw new Error(\"validating async is not supported\");\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n return result.value as any;\n}\n\nexport async function validateAsync<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Promise<Awaited<StandardSchemaV1.InferOutput<TSchema>>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n const result_1 = await result;\n if (result_1.issues) {\n throw new SchemaError(result_1.issues);\n }\n return result_1.value as any;\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n\n return Promise.resolve(result.value as any);\n}\n\nexport function custom<T>(): StandardSchemaV1<T, T> {\n return {\n \"~standard\": {\n vendor: \"pumped-fn\",\n version: 1,\n validate: (value) => {\n return { value: value as T };\n },\n },\n };\n}\n","import { validate } from \"./ssch\";\nimport { metaSymbol, StandardSchemaV1, type Meta } from \"./types\";\n\nexport const meta = <V>(\n key: string | symbol,\n schema: StandardSchemaV1<V>\n): Meta.MetaFn<V> => {\n const _key = typeof key === \"string\" ? Symbol(key) : key;\n\n const fn = (value: V) =>\n ({\n [metaSymbol]: true,\n key: _key,\n schema,\n value,\n } as unknown as Meta.MetaFn<V>);\n\n Object.defineProperty(fn, \"key\", {\n value: _key,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperty(fn, metaSymbol, {\n value: true,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperties(fn, {\n partial: {\n value: (d: Partial<V>) => {\n return Object.assign({}, fn({} as V), d);\n },\n configurable: false,\n enumerable: false,\n writable: false,\n },\n some: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValues(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n find: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValue(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n get: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n getValue(\n findValue(\n source,\n fn as unknown as Meta.MetaFn<unknown>\n ) as Meta.Meta<V>\n ),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n });\n\n return fn as any;\n};\n\nexport function getValue<V>(meta: Meta.Meta<V>) {\n return validate(meta.schema, meta.value);\n}\n\nexport function findValues<V = unknown>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V[] {\n if (!executor) return [];\n\n const metas = Array.isArray(executor) ? executor : executor.metas ?? [];\n\n const maybeMeta = metas.filter((m) => m.key === meta.key);\n return maybeMeta.map((m) => getValue(m as Meta.Meta<V>));\n}\n\nexport function findValue<V>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V | undefined {\n const values = findValues(executor, meta);\n return values.at(0);\n}\n","import {\n isLazyExecutor,\n isReactiveExecutor,\n isStaticExecutor,\n} from \"./executor\";\nimport { Core, executorSymbol } from \"./types\";\n\nexport interface ScopeInner {\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>>;\n getValueCache(): Map<Core.Executor<unknown>, unknown>;\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>>;\n}\n\nexport function isExecutor<T>(input: unknown): input is Core.BaseExecutor<T> {\n return typeof input === \"object\" && input !== null && executorSymbol in input;\n}\n\ntype Value =\n | { kind: \"resolving\"; promise: Promise<unknown> }\n | { kind: \"resolved\"; value: unknown }\n | { kind: \"rejected\"; error: unknown };\n\nclass Scope implements Core.Scope, ScopeInner {\n private isDisposed: boolean = false;\n private cache: Map<Core.Executor<unknown>, Core.Accessor<unknown>> =\n new Map();\n private valueCache: Map<Core.Executor<unknown>, Value> = new Map();\n private reactiveness = new Map<\n Core.Executor<unknown>,\n Set<Core.Executor<unknown>>\n >();\n private cleanups = new Map<Core.Executor<unknown>, Set<Core.Cleanup>>();\n private onUpdates = new Map<\n Core.Executor<unknown>,\n Set<(accessor: Core.Accessor<unknown>) => void | Promise<void>>\n >();\n\n private \"~appendReactive\"(\n reactive: Core.Executor<unknown>,\n ref: Core.Executor<unknown>\n ) {\n const currentSet = this.reactiveness.get(reactive) ?? new Set();\n this.reactiveness.set(reactive, currentSet);\n\n currentSet.add(ref);\n }\n\n private async \"~resolveDependencies\"(\n e:\n | undefined\n | Core.BaseExecutor<unknown>\n | Core.BaseExecutor<unknown>[]\n | Record<string, Core.BaseExecutor<unknown>>,\n ref: Core.Executor<unknown>\n ): Promise<undefined | unknown | unknown[] | Record<string, unknown>> {\n if (e === undefined) {\n return undefined;\n }\n\n if (isExecutor(e)) {\n if (isLazyExecutor(e)) {\n return this[\"~resolveLazy\"](e);\n }\n\n const staticResult = await this[\"~resolveStatic\"](\n e as Core.Executor<unknown>\n );\n\n if (isReactiveExecutor(e)) {\n this[\"~appendReactive\"](e.executor, ref);\n }\n\n await staticResult.resolve(false);\n if (isStaticExecutor(e)) {\n return staticResult;\n }\n\n return staticResult.get();\n }\n\n if (Array.isArray(e)) {\n return await Promise.all(\n e.map((item) => this[\"~resolveDependencies\"](item, ref))\n );\n }\n\n const result: Record<string, unknown> = {};\n for (const key of Object.keys(e)) {\n const target = e[key];\n const resolvedResult = await this[\"~resolveDependencies\"](target, ref);\n\n result[key] = resolvedResult;\n }\n\n return result;\n }\n\n private \"~resolveLazy\"(e: Core.Lazy<unknown>): Core.Accessor<unknown> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(e.executor);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e.executor);\n\n return accessor;\n }\n\n private async \"~resolveStatic\"(\n e: Core.Executor<unknown>\n ): Promise<Core.Accessor<unknown>> {\n const cached = this.cache.get(e);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e, true);\n return accessor;\n }\n\n private \"~makeController\"(e: Core.Executor<unknown>): Core.Controller {\n return {\n cleanup: (cleanup: Core.Cleanup) => {\n const currentSet = this.cleanups.get(e) ?? new Set();\n this.cleanups.set(e, currentSet);\n\n currentSet.add(cleanup);\n },\n release: async () => {\n this.release(e);\n },\n scope: this,\n };\n }\n\n private \"~makeAccessor\"(\n e: Core.BaseExecutor<unknown>,\n eager: boolean = false\n ): Core.Accessor<unknown> {\n const accessor = {} as Core.Accessor<unknown>;\n const requestor =\n isLazyExecutor(e) || isReactiveExecutor(e)\n ? e.executor\n : (e as Core.Executor<unknown>);\n\n const cachedAccessor = this.cache.get(requestor);\n if (cachedAccessor) {\n return cachedAccessor;\n }\n\n const factory = requestor.factory;\n const controller = this[\"~makeController\"](requestor);\n\n const resolve = async (force: boolean): Promise<unknown> => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(requestor);\n if (cached && !force) {\n if (cached.kind === \"resolved\") {\n return cached.value;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return cached.promise;\n }\n }\n\n const promise = new Promise((resolve, reject) => {\n this[\"~resolveDependencies\"](requestor.dependencies, requestor)\n .then((dependencies) => factory(dependencies as any, controller))\n .then((result) => {\n this.valueCache.set(requestor, { kind: \"resolved\", value: result });\n resolve(result);\n })\n .catch((error) => {\n this.valueCache.set(requestor, { kind: \"rejected\", error });\n reject(error);\n });\n });\n\n this.valueCache.set(requestor, { kind: \"resolving\", promise });\n this.cache.set(requestor, accessor);\n return promise;\n };\n\n if (!isLazyExecutor(e) || eager) {\n resolve(false);\n }\n\n return Object.assign(accessor, {\n get: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const valueCached = this.valueCache.get(requestor);\n\n if (!valueCached || valueCached.kind === \"resolving\") {\n throw new Error(\"Executor not found\");\n }\n\n if (valueCached.kind === \"rejected\") {\n throw valueCached.error;\n }\n\n return valueCached.value;\n },\n lookup: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this.valueCache.get(requestor);\n },\n metas: e.metas,\n resolve,\n release: async (soft: boolean = false) => {\n this.release(requestor);\n },\n update: (updateFn: unknown | ((current: unknown) => unknown)) => {\n return this.update(requestor, updateFn);\n },\n } satisfies Partial<Core.Accessor<unknown>>);\n }\n\n accessor<T>(executor: Core.Executor<T>): Core.Accessor<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this[\"~makeAccessor\"](executor, false) as Core.Accessor<T>;\n }\n\n async resolve<T>(executor: Core.Executor<T>): Promise<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(executor);\n if (cached) {\n if (cached.kind === \"resolved\") {\n return cached.value as T;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return (await cached.promise) as T;\n }\n }\n\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve(false);\n\n return accessor.get() as T;\n }\n\n async resolveAccessor<T>(\n executor: Core.Executor<T>\n ): Promise<Core.Accessor<T>> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cachedAccessor = this.cache.get(executor);\n if (!cachedAccessor) {\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve();\n\n return accessor as Core.Accessor<T>;\n }\n\n await cachedAccessor.resolve();\n return cachedAccessor as Core.Accessor<T>;\n }\n\n private \"~findAffectedTargets\"(\n target: Core.Executor<unknown>,\n updateSet: Set<Core.Executor<unknown>> = new Set()\n ): Set<Core.Executor<unknown>> {\n const triggerTargets = this.reactiveness.get(target);\n if (triggerTargets && triggerTargets.size > 0) {\n for (const target of triggerTargets) {\n if (updateSet.has(target)) {\n updateSet.delete(target);\n }\n updateSet.add(target);\n\n if (this.reactiveness.has(target)) {\n this[\"~findAffectedTargets\"](target, updateSet);\n }\n }\n }\n\n return updateSet;\n }\n\n async update<T>(\n executor: Core.Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const current = (await cached.resolve(false)) as T;\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n if (typeof updateFn === \"function\") {\n const fn = updateFn as (current: T) => T;\n const newValue = fn(current);\n this.valueCache.set(executor, { kind: \"resolved\", value: newValue });\n } else {\n this.valueCache.set(executor, {\n kind: \"resolved\",\n value: updateFn,\n });\n }\n\n const updateSet = this[\"~findAffectedTargets\"](executor);\n for (const target of updateSet) {\n const cached = this.cache.get(target);\n if (cached) {\n await cached.resolve(true);\n const onUpdateSet = this.onUpdates.get(target);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n }\n\n const onUpdateSet = this.onUpdates.get(executor);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n\n async reset<T>(executor: Core.Executor<T>): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n await this.release(executor, true);\n await this.resolve(executor);\n }\n\n async release(\n executor: Core.Executor<any>,\n soft: boolean = false\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached && !soft) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const affectedTargets = this[\"~findAffectedTargets\"](executor);\n for (const target of affectedTargets) {\n await this.release(target, true);\n }\n\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n this.cache.delete(executor);\n this.valueCache.delete(executor);\n this.reactiveness.delete(executor);\n this.onUpdates.delete(executor);\n }\n\n async dispose(): Promise<void> {\n const currents = this.cache.keys();\n for (const current of currents) {\n await this.release(current, true);\n }\n\n this.isDisposed = true;\n this.cache.clear();\n this.valueCache.clear();\n this.reactiveness.clear();\n this.cleanups.clear();\n }\n\n onUpdate<T>(\n executor: Core.Executor<T>,\n callback: (accessor: Core.Accessor<T>) => void | Promise<void>\n ): Core.Cleanup {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const onUpdateSet = this.onUpdates.get(executor) ?? new Set();\n this.onUpdates.set(executor, onUpdateSet);\n onUpdateSet.add(callback as any);\n\n return () => {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const currentSet = this.onUpdates.get(executor);\n if (currentSet) {\n currentSet.delete(callback as any);\n if (currentSet.size === 0) {\n this.onUpdates.delete(executor);\n }\n }\n };\n }\n\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>> {\n return this.cache;\n }\n\n getValueCache(): Map<Core.Executor<unknown>, unknown> {\n return this.valueCache;\n }\n\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>> {\n return this.reactiveness;\n }\n}\n\nexport function createScope(): Core.Scope {\n return new Scope();\n}\n"],"mappings":"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","names":["executorSymbol","metaSymbol","SchemaError","issues","createExecutor","factory","dependencies","metas","executor","executorSymbol","_","controller","lazyExecutor","reactiveExecutor","staticExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","provide","derive","pdependencies","pfactory","validate","schema","data","result","SchemaError","validateAsync","result_1","custom","value","meta","key","schema","_key","fn","value","metaSymbol","d","source","findValues","findValue","getValue","validate","executor","m","isExecutor","input","executorSymbol","Scope","reactive","ref","currentSet","isLazyExecutor","staticResult","isReactiveExecutor","isStaticExecutor","item","result","key","target","resolvedResult","cached","cleanup","eager","accessor","requestor","cachedAccessor","factory","controller","resolve","force","promise","reject","dependencies","error","valueCached","soft","updateFn","executor","updateSet","triggerTargets","current","cleanups","newValue","onUpdateSet","callback","affectedTargets","currents","createScope"]}
1
+ {"version":3,"sources":["../src/types.ts","../src/executor.ts","../src/ssch.ts","../src/meta.ts","../src/scope.ts"],"sourcesContent":["export const executorSymbol = Symbol.for(\"@pumped-fn/core/executor\");\nexport const metaSymbol = Symbol.for(\"@pumped-fn/core/meta\");\n\nexport interface StandardSchemaV1<Input = unknown, Output = Input> {\n readonly \"~standard\": StandardSchemaV1.Props<Input, Output>;\n}\n\nexport declare namespace StandardSchemaV1 {\n export interface Props<Input = unknown, Output = Input> {\n readonly version: 1;\n readonly vendor: string;\n readonly validate: (\n value: unknown\n ) => Result<Output> | Promise<Result<Output>>;\n readonly types?: Types<Input, Output> | undefined;\n }\n\n export type Result<Output> = SuccessResult<Output> | FailureResult;\n\n export interface SuccessResult<Output> {\n readonly value: Output;\n readonly issues?: undefined;\n }\n\n export interface FailureResult {\n readonly issues: ReadonlyArray<Issue>;\n }\n\n export interface Issue {\n readonly message: string;\n readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;\n }\n\n export interface PathSegment {\n readonly key: PropertyKey;\n }\n\n export interface Types<Input = unknown, Output = Input> {\n readonly input: Input;\n readonly output: Output;\n }\n\n export type InferInput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"input\"];\n\n export type InferOutput<Schema extends StandardSchemaV1> = NonNullable<\n Schema[\"~standard\"][\"types\"]\n >[\"output\"];\n}\n\nexport class SchemaError extends Error {\n public readonly issues: ReadonlyArray<StandardSchemaV1.Issue>;\n\n constructor(issues: ReadonlyArray<StandardSchemaV1.Issue>) {\n super(issues[0].message);\n this.name = \"SchemaError\";\n this.issues = issues;\n }\n}\n\nexport declare namespace Meta {\n export interface MetaContainer {\n metas: Meta[] | undefined;\n }\n\n export interface Meta<V = unknown> {\n readonly [metaSymbol]: true;\n readonly key: string | symbol;\n readonly schema: StandardSchemaV1<V>;\n readonly value: V;\n }\n\n export interface MetaFn<V> {\n (value: V): Meta<V>;\n readonly key: string | symbol;\n partial: <D extends Partial<V>>(d: D) => D;\n some: (source: MetaContainer | Meta[] | undefined) => V[];\n find: (source: MetaContainer | Meta[] | undefined) => V | undefined;\n get: (source: MetaContainer | Meta[] | undefined) => V;\n }\n}\n\nexport declare namespace Core {\n export type Output<T> = T | Promise<T>;\n\n export type NoDependencyFn<T> = (scope: Controller) => Output<T>;\n export type DependentFn<T, D> = (\n dependencies: D,\n scope: Controller\n ) => Output<T>;\n export type RecordLike = Record<string, unknown>;\n export type UExecutor = BaseExecutor<unknown>;\n\n export type Cleanup = () => void | Promise<void>;\n\n export type Controller = {\n cleanup: (cleanup: Cleanup) => void;\n release: () => Promise<void>;\n scope: Scope;\n };\n\n export type Kind = \"base\" | \"main\" | \"reactive\" | \"lazy\" | \"static\";\n\n export interface BaseExecutor<T> extends Meta.MetaContainer {\n [executorSymbol]: Kind;\n factory: NoDependencyFn<T> | DependentFn<T, unknown> | undefined;\n dependencies:\n | undefined\n | UExecutor\n | Array<UExecutor>\n | Record<string, UExecutor>;\n }\n\n export interface Executor<T> extends BaseExecutor<T> {\n [executorSymbol]: \"main\";\n factory: NoDependencyFn<T> | DependentFn<T, unknown>;\n\n /** Return an executor controller without resolving Executor */\n readonly lazy: Lazy<T>;\n\n /** Return an resolved executor, and mark the user to be reactived for future changes */\n readonly reactive: Reactive<T>;\n\n /** Return an resolved executor with its controller */\n readonly static: Static<T>;\n }\n\n export interface Reactive<T> extends BaseExecutor<T> {\n [executorSymbol]: \"reactive\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Lazy<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"lazy\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Static<T> extends BaseExecutor<Accessor<T>> {\n [executorSymbol]: \"static\";\n factory: undefined;\n readonly executor: Executor<T>;\n }\n\n export interface Accessor<T> extends Meta.MetaContainer {\n lookup(): T;\n get(): T;\n resolve(force?: boolean): Promise<T>;\n release(soft?: boolean): Promise<void>;\n update(updateFn: T | ((current: T) => T)): Promise<void>;\n }\n\n export type InferOutput<T> = T extends Executor<infer U> | Reactive<infer U>\n ? Awaited<U>\n : T extends Lazy<infer U> | Static<infer U>\n ? Accessor<Awaited<U>>\n : never;\n\n export interface Scope {\n accessor<T>(executor: Core.Executor<T>, eager?: boolean): Accessor<T>;\n\n resolve<T>(executor: Core.Executor<T>): Promise<T>;\n resolveAccessor<T>(executor: Core.Executor<T>): Promise<Accessor<T>>;\n\n update<T>(\n executor: Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void>;\n\n reset<T>(executor: Executor<T>): void;\n release(executor: Executor<any>, soft?: boolean): Promise<void>;\n\n dispose(): Promise<void>;\n\n onUpdate<T>(\n executor: Executor<T>,\n callback: (accessor: Accessor<T>) => void\n ): Cleanup;\n // onRelease<T>(executor: Executor<T>, callback: () => void): () => void;\n }\n}\n","import { Core, executorSymbol, Meta, metaSymbol } from \"./types\";\n\nfunction createExecutor<T>(\n factory: Core.NoDependencyFn<T> | Core.DependentFn<T, unknown>,\n dependencies:\n | undefined\n | Core.UExecutor\n | Array<Core.UExecutor>\n | Record<string, Core.UExecutor>,\n metas: Meta.Meta[] | undefined\n): Core.Executor<T> {\n const executor = {\n [executorSymbol]: \"base\",\n factory: (_: unknown, controller: Core.Controller) => {\n if (dependencies === undefined) {\n const f = factory as Core.NoDependencyFn<T>;\n return f(controller);\n }\n\n const f = factory as Core.DependentFn<T, unknown>;\n return f(_, controller);\n },\n dependencies,\n metas: metas,\n } as unknown as Core.Executor<T>;\n\n const lazyExecutor = {\n [executorSymbol]: \"lazy\",\n dependencies: undefined,\n executor,\n factory: undefined,\n metas: metas,\n } satisfies Core.Lazy<T>;\n\n const reactiveExecutor = {\n [executorSymbol]: \"reactive\",\n executor,\n factory: undefined,\n dependencies: undefined,\n metas: metas,\n } satisfies Core.Reactive<T>;\n\n const staticExecutor = {\n [executorSymbol]: \"static\",\n dependencies: undefined,\n factory: undefined,\n metas: metas,\n executor,\n } satisfies Core.Static<T>;\n\n Object.defineProperties(executor, {\n lazy: {\n value: lazyExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n reactive: {\n value: reactiveExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n static: {\n value: staticExecutor,\n writable: false,\n configurable: false,\n enumerable: false,\n },\n });\n\n return executor;\n}\n\nexport function isLazyExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Lazy<unknown> {\n return executor[executorSymbol] === \"lazy\";\n}\n\nexport function isReactiveExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Reactive<unknown> {\n return executor[executorSymbol] === \"reactive\";\n}\n\nexport function isStaticExecutor(\n executor: Core.BaseExecutor<unknown>\n): executor is Core.Static<unknown> {\n return executor[executorSymbol] === \"static\";\n}\n\nexport function provide<T>(\n factory: Core.NoDependencyFn<T>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(factory, undefined, metas);\n}\n\nexport function derive<T, D extends Core.BaseExecutor<unknown>>(\n dependencies: D,\n factory: Core.DependentFn<T, Core.InferOutput<D>>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<\n T,\n D extends\n | ReadonlyArray<Core.BaseExecutor<unknown>>\n | Record<string, Core.BaseExecutor<unknown>>\n>(\n dependencies: { [K in keyof D]: D[K] },\n factory: Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T>;\n\nexport function derive<T, D>(\n pdependencies:\n | Core.BaseExecutor<D>\n | Array<Core.BaseExecutor<D>>\n | Record<string, Core.BaseExecutor<unknown>>,\n pfactory:\n | Core.DependentFn<T, Core.InferOutput<D>>\n | Core.DependentFn<T, { [K in keyof D]: Core.InferOutput<D[K]> }>,\n ...metas: Meta.Meta[]\n): Core.Executor<T> {\n return createExecutor(pfactory as any, pdependencies, metas);\n}\n","import { SchemaError, StandardSchemaV1 } from \"./types\";\n\nexport function validate<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Awaited<StandardSchemaV1.InferOutput<TSchema>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n throw new Error(\"validating async is not supported\");\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n return result.value as any;\n}\n\nexport async function validateAsync<TSchema extends StandardSchemaV1>(\n schema: TSchema,\n data: unknown\n): Promise<Awaited<StandardSchemaV1.InferOutput<TSchema>>> {\n const result = schema[\"~standard\"].validate(data);\n\n if (\"then\" in result) {\n const result_1 = await result;\n if (result_1.issues) {\n throw new SchemaError(result_1.issues);\n }\n return result_1.value as any;\n }\n\n if (result.issues) {\n throw new SchemaError(result.issues);\n }\n\n return Promise.resolve(result.value as any);\n}\n\nexport function custom<T>(): StandardSchemaV1<T, T> {\n return {\n \"~standard\": {\n vendor: \"pumped-fn\",\n version: 1,\n validate: (value) => {\n return { value: value as T };\n },\n },\n };\n}\n","import { validate } from \"./ssch\";\nimport { metaSymbol, StandardSchemaV1, type Meta } from \"./types\";\n\nexport const meta = <V>(\n key: string | symbol,\n schema: StandardSchemaV1<V>\n): Meta.MetaFn<V> => {\n const _key = typeof key === \"string\" ? Symbol(key) : key;\n\n const fn = (value: V) =>\n ({\n [metaSymbol]: true,\n key: _key,\n schema,\n value,\n } as unknown as Meta.MetaFn<V>);\n\n Object.defineProperty(fn, \"key\", {\n value: _key,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperty(fn, metaSymbol, {\n value: true,\n configurable: false,\n enumerable: false,\n writable: false,\n });\n\n Object.defineProperties(fn, {\n partial: {\n value: (d: Partial<V>) => {\n return Object.assign({}, fn({} as V), d);\n },\n configurable: false,\n enumerable: false,\n writable: false,\n },\n some: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValues(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n find: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n findValue(source, fn as unknown as Meta.MetaFn<unknown>),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n get: {\n value: (source: Meta.MetaContainer | Meta.Meta[] | undefined) =>\n getValue(\n findValue(\n source,\n fn as unknown as Meta.MetaFn<unknown>\n ) as Meta.Meta<V>\n ),\n configurable: false,\n enumerable: false,\n writable: false,\n },\n });\n\n return fn as any;\n};\n\nexport function getValue<V>(meta: Meta.Meta<V>) {\n return validate(meta.schema, meta.value);\n}\n\nexport function findValues<V = unknown>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V[] {\n if (!executor) return [];\n\n const metas = Array.isArray(executor) ? executor : executor.metas ?? [];\n\n const maybeMeta = metas.filter((m) => m.key === meta.key);\n return maybeMeta.map((m) => getValue(m as Meta.Meta<V>));\n}\n\nexport function findValue<V>(\n executor: Meta.MetaContainer | Meta.Meta[] | undefined,\n meta: Meta.MetaFn<V>\n): V | undefined {\n const values = findValues(executor, meta);\n return values.at(0);\n}\n","import {\n isLazyExecutor,\n isReactiveExecutor,\n isStaticExecutor,\n} from \"./executor\";\nimport { Core, executorSymbol } from \"./types\";\n\nexport interface ScopeInner {\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>>;\n getValueCache(): Map<Core.Executor<unknown>, unknown>;\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>>;\n}\n\nexport function isExecutor<T>(input: unknown): input is Core.BaseExecutor<T> {\n return typeof input === \"object\" && input !== null && executorSymbol in input;\n}\n\ntype Value =\n | { kind: \"resolving\"; promise: Promise<unknown> }\n | { kind: \"resolved\"; value: unknown }\n | { kind: \"rejected\"; error: unknown };\n\nclass Scope implements Core.Scope, ScopeInner {\n private isDisposed: boolean = false;\n private cache: Map<Core.Executor<unknown>, Core.Accessor<unknown>> =\n new Map();\n private valueCache: Map<Core.Executor<unknown>, Value> = new Map();\n private reactiveness = new Map<\n Core.Executor<unknown>,\n Set<Core.Executor<unknown>>\n >();\n private cleanups = new Map<Core.Executor<unknown>, Set<Core.Cleanup>>();\n private onUpdates = new Map<\n Core.Executor<unknown>,\n Set<(accessor: Core.Accessor<unknown>) => void | Promise<void>>\n >();\n\n private \"~appendReactive\"(\n reactive: Core.Executor<unknown>,\n ref: Core.Executor<unknown>\n ) {\n const currentSet = this.reactiveness.get(reactive) ?? new Set();\n this.reactiveness.set(reactive, currentSet);\n\n currentSet.add(ref);\n }\n\n private async \"~resolveDependencies\"(\n e:\n | undefined\n | Core.BaseExecutor<unknown>\n | Core.BaseExecutor<unknown>[]\n | Record<string, Core.BaseExecutor<unknown>>,\n ref: Core.Executor<unknown>\n ): Promise<undefined | unknown | unknown[] | Record<string, unknown>> {\n if (e === undefined) {\n return undefined;\n }\n\n if (isExecutor(e)) {\n if (isLazyExecutor(e)) {\n return this[\"~resolveLazy\"](e);\n }\n\n const staticResult = await this[\"~resolveStatic\"](\n e as Core.Executor<unknown>\n );\n\n if (isReactiveExecutor(e)) {\n this[\"~appendReactive\"](e.executor, ref);\n }\n\n await staticResult.resolve(false);\n if (isStaticExecutor(e)) {\n return staticResult;\n }\n\n return staticResult.get();\n }\n\n if (Array.isArray(e)) {\n return await Promise.all(\n e.map((item) => this[\"~resolveDependencies\"](item, ref))\n );\n }\n\n const result: Record<string, unknown> = {};\n for (const key of Object.keys(e)) {\n const target = e[key];\n const resolvedResult = await this[\"~resolveDependencies\"](target, ref);\n\n result[key] = resolvedResult;\n }\n\n return result;\n }\n\n private \"~resolveLazy\"(e: Core.Lazy<unknown>): Core.Accessor<unknown> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(e.executor);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e.executor);\n\n return accessor;\n }\n\n private async \"~resolveStatic\"(\n e: Core.Executor<unknown>\n ): Promise<Core.Accessor<unknown>> {\n const cached = this.cache.get(e);\n if (cached) {\n return cached;\n }\n\n const accessor = this[\"~makeAccessor\"](e, true);\n return accessor;\n }\n\n private \"~makeController\"(e: Core.Executor<unknown>): Core.Controller {\n return {\n cleanup: (cleanup: Core.Cleanup) => {\n const currentSet = this.cleanups.get(e) ?? new Set();\n this.cleanups.set(e, currentSet);\n\n currentSet.add(cleanup);\n },\n release: async () => {\n this.release(e);\n },\n scope: this,\n };\n }\n\n private \"~makeAccessor\"(\n e: Core.BaseExecutor<unknown>,\n eager: boolean = false\n ): Core.Accessor<unknown> {\n const accessor = {} as Core.Accessor<unknown>;\n const requestor =\n isLazyExecutor(e) || isReactiveExecutor(e) || isStaticExecutor(e)\n ? e.executor\n : (e as Core.Executor<unknown>);\n\n const cachedAccessor = this.cache.get(requestor);\n if (cachedAccessor) {\n return cachedAccessor;\n }\n\n const factory = requestor.factory;\n const controller = this[\"~makeController\"](requestor);\n\n const resolve = async (force: boolean): Promise<unknown> => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(requestor);\n if (cached && !force) {\n if (cached.kind === \"resolved\") {\n return cached.value;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return cached.promise;\n }\n }\n\n const promise = new Promise((resolve, reject) => {\n this[\"~resolveDependencies\"](requestor.dependencies, requestor)\n .then((dependencies) => factory(dependencies as any, controller))\n .then((result) => {\n this.valueCache.set(requestor, { kind: \"resolved\", value: result });\n resolve(result);\n })\n .catch((error) => {\n this.valueCache.set(requestor, { kind: \"rejected\", error });\n reject(error);\n });\n });\n\n this.valueCache.set(requestor, { kind: \"resolving\", promise });\n this.cache.set(requestor, accessor);\n return promise;\n };\n\n if (!isLazyExecutor(e) || eager) {\n resolve(false);\n }\n\n return Object.assign(accessor, {\n get: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const valueCached = this.valueCache.get(requestor);\n\n if (!valueCached || valueCached.kind === \"resolving\") {\n throw new Error(\"Executor not found\");\n }\n\n if (valueCached.kind === \"rejected\") {\n throw valueCached.error;\n }\n\n return valueCached.value;\n },\n lookup: () => {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this.valueCache.get(requestor);\n },\n metas: e.metas,\n resolve,\n release: async (soft: boolean = false) => {\n this.release(requestor);\n },\n update: (updateFn: unknown | ((current: unknown) => unknown)) => {\n return this.update(requestor, updateFn);\n },\n } satisfies Partial<Core.Accessor<unknown>>);\n }\n\n accessor<T>(executor: Core.Executor<T>): Core.Accessor<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n return this[\"~makeAccessor\"](executor, false) as Core.Accessor<T>;\n }\n\n async resolve<T>(executor: Core.Executor<T>): Promise<T> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.valueCache.get(executor);\n if (cached) {\n if (cached.kind === \"resolved\") {\n return cached.value as T;\n } else if (cached.kind === \"rejected\") {\n throw cached.error;\n } else {\n return (await cached.promise) as T;\n }\n }\n\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve(false);\n\n return accessor.get() as T;\n }\n\n async resolveAccessor<T>(\n executor: Core.Executor<T>\n ): Promise<Core.Accessor<T>> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cachedAccessor = this.cache.get(executor);\n if (!cachedAccessor) {\n const accessor = this[\"~makeAccessor\"](executor, true);\n await accessor.resolve();\n\n return accessor as Core.Accessor<T>;\n }\n\n await cachedAccessor.resolve();\n return cachedAccessor as Core.Accessor<T>;\n }\n\n private \"~findAffectedTargets\"(\n target: Core.Executor<unknown>,\n updateSet: Set<Core.Executor<unknown>> = new Set()\n ): Set<Core.Executor<unknown>> {\n const triggerTargets = this.reactiveness.get(target);\n if (triggerTargets && triggerTargets.size > 0) {\n for (const target of triggerTargets) {\n if (updateSet.has(target)) {\n updateSet.delete(target);\n }\n updateSet.add(target);\n\n if (this.reactiveness.has(target)) {\n this[\"~findAffectedTargets\"](target, updateSet);\n }\n }\n }\n\n return updateSet;\n }\n\n async update<T>(\n executor: Core.Executor<T>,\n updateFn: T | ((current: T) => T)\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const current = (await cached.resolve(false)) as T;\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n if (typeof updateFn === \"function\") {\n const fn = updateFn as (current: T) => T;\n const newValue = fn(current);\n this.valueCache.set(executor, { kind: \"resolved\", value: newValue });\n } else {\n this.valueCache.set(executor, {\n kind: \"resolved\",\n value: updateFn,\n });\n }\n\n const updateSet = this[\"~findAffectedTargets\"](executor);\n for (const target of updateSet) {\n const cached = this.cache.get(target);\n if (cached) {\n await cached.resolve(true);\n const onUpdateSet = this.onUpdates.get(target);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n }\n\n const onUpdateSet = this.onUpdates.get(executor);\n if (onUpdateSet) {\n for (const callback of Array.from(onUpdateSet.values())) {\n await callback(cached);\n }\n }\n }\n\n async reset<T>(executor: Core.Executor<T>): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n await this.release(executor, true);\n await this.resolve(executor);\n }\n\n async release(\n executor: Core.Executor<any>,\n soft: boolean = false\n ): Promise<void> {\n if (this.isDisposed) {\n throw new Error(\"Scope is disposed\");\n }\n\n const cached = this.cache.get(executor);\n if (!cached && !soft) {\n throw new Error(\"Executor is not yet resolved\");\n }\n\n const affectedTargets = this[\"~findAffectedTargets\"](executor);\n for (const target of affectedTargets) {\n await this.release(target, true);\n }\n\n const cleanups = this.cleanups.get(executor);\n if (cleanups) {\n for (const cleanup of Array.from(cleanups.values()).reverse()) {\n await cleanup();\n }\n }\n\n this.cache.delete(executor);\n this.valueCache.delete(executor);\n this.reactiveness.delete(executor);\n this.onUpdates.delete(executor);\n }\n\n async dispose(): Promise<void> {\n const currents = this.cache.keys();\n for (const current of currents) {\n await this.release(current, true);\n }\n\n this.isDisposed = true;\n this.cache.clear();\n this.valueCache.clear();\n this.reactiveness.clear();\n this.cleanups.clear();\n }\n\n onUpdate<T>(\n executor: Core.Executor<T>,\n callback: (accessor: Core.Accessor<T>) => void | Promise<void>\n ): Core.Cleanup {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const onUpdateSet = this.onUpdates.get(executor) ?? new Set();\n this.onUpdates.set(executor, onUpdateSet);\n onUpdateSet.add(callback as any);\n\n return () => {\n if (this.isDisposed) {\n throw new Error(\"scope is disposed\");\n }\n\n const currentSet = this.onUpdates.get(executor);\n if (currentSet) {\n currentSet.delete(callback as any);\n if (currentSet.size === 0) {\n this.onUpdates.delete(executor);\n }\n }\n };\n }\n\n getCache(): Map<Core.Executor<unknown>, Core.Accessor<unknown>> {\n return this.cache;\n }\n\n getValueCache(): Map<Core.Executor<unknown>, unknown> {\n return this.valueCache;\n }\n\n getReactiveness(): Map<Core.Executor<unknown>, Set<Core.Executor<unknown>>> {\n return this.reactiveness;\n }\n}\n\nexport function createScope(): Core.Scope {\n return new Scope();\n}\n"],"mappings":"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","names":["executorSymbol","metaSymbol","SchemaError","issues","createExecutor","factory","dependencies","metas","executor","executorSymbol","_","controller","lazyExecutor","reactiveExecutor","staticExecutor","isLazyExecutor","isReactiveExecutor","isStaticExecutor","provide","derive","pdependencies","pfactory","validate","schema","data","result","SchemaError","validateAsync","result_1","custom","value","meta","key","schema","_key","fn","value","metaSymbol","d","source","findValues","findValue","getValue","validate","executor","m","isExecutor","input","executorSymbol","Scope","reactive","ref","currentSet","isLazyExecutor","staticResult","isReactiveExecutor","isStaticExecutor","item","result","key","target","resolvedResult","cached","cleanup","eager","accessor","requestor","cachedAccessor","factory","controller","resolve","force","promise","reject","dependencies","error","valueCached","soft","updateFn","executor","updateSet","triggerTargets","current","cleanups","newValue","onUpdateSet","callback","affectedTargets","currents","createScope"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pumped-fn/core-next",
3
- "version": "0.5.36",
3
+ "version": "0.5.37",
4
4
  "description": "Enhanced function utilities for TypeScript",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",