@selvajs/compute 1.5.3 → 2.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-3FH7FKLG.cjs +2 -0
- package/dist/chunk-3FH7FKLG.cjs.map +1 -0
- package/dist/chunk-DELOBV2Q.js +2 -0
- package/dist/chunk-DELOBV2Q.js.map +1 -0
- package/dist/chunk-GTTKNF4G.js +4 -0
- package/dist/chunk-GTTKNF4G.js.map +1 -0
- package/dist/chunk-JFLD2UCY.cjs +2 -0
- package/dist/chunk-JFLD2UCY.cjs.map +1 -0
- package/dist/chunk-MA6YB3YZ.cjs +4 -0
- package/dist/chunk-MA6YB3YZ.cjs.map +1 -0
- package/dist/chunk-MKW2KTPT.js +2 -0
- package/dist/chunk-MKW2KTPT.js.map +1 -0
- package/dist/core.cjs +1 -1
- package/dist/core.cjs.map +1 -1
- package/dist/core.d.cts +10 -15
- package/dist/core.d.ts +10 -15
- package/dist/core.js +1 -1
- package/dist/grasshopper.cjs +1 -1
- package/dist/grasshopper.cjs.map +1 -1
- package/dist/grasshopper.d.cts +77 -101
- package/dist/grasshopper.d.ts +77 -101
- package/dist/grasshopper.js +1 -1
- package/dist/handle-files-DsrxHKHP.d.cts +262 -0
- package/dist/handle-files-DsrxHKHP.d.ts +262 -0
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +4 -4
- package/dist/index.d.ts +4 -4
- package/dist/index.js +1 -1
- package/dist/{types-Dfeei0dD.d.cts → types-CJ092lxB.d.cts} +116 -73
- package/dist/types-D1SkNje_.d.cts +87 -0
- package/dist/types-D1SkNje_.d.ts +87 -0
- package/dist/{types-Dfeei0dD.d.ts → types-XCUrJGby.d.ts} +116 -73
- package/dist/visualization-GU7JIB4V.cjs +2 -0
- package/dist/visualization-GU7JIB4V.cjs.map +1 -0
- package/dist/visualization-WIUVT2FZ.js +2 -0
- package/dist/visualization.cjs +1 -1
- package/dist/visualization.cjs.map +1 -1
- package/dist/visualization.d.cts +16 -21
- package/dist/visualization.d.ts +16 -21
- package/dist/visualization.js +1 -1
- package/package.json +18 -7
- package/dist/chunk-GZYSQSLH.cjs +0 -2
- package/dist/chunk-GZYSQSLH.cjs.map +0 -1
- package/dist/chunk-JZYEMZZ5.js +0 -2
- package/dist/chunk-JZYEMZZ5.js.map +0 -1
- package/dist/chunk-OEDLGVIQ.js +0 -2
- package/dist/chunk-OEDLGVIQ.js.map +0 -1
- package/dist/chunk-OW6HV6QP.js +0 -2
- package/dist/chunk-OW6HV6QP.js.map +0 -1
- package/dist/chunk-RBNF6MNH.cjs +0 -3
- package/dist/chunk-RBNF6MNH.cjs.map +0 -1
- package/dist/chunk-SVEXPGHW.cjs +0 -2
- package/dist/chunk-SVEXPGHW.cjs.map +0 -1
- package/dist/chunk-XBIEAJBK.js +0 -3
- package/dist/chunk-XBIEAJBK.js.map +0 -1
- package/dist/chunk-ZRQRYG6F.cjs +0 -2
- package/dist/chunk-ZRQRYG6F.cjs.map +0 -1
- package/dist/errors-CEy4nM1J.d.cts +0 -149
- package/dist/errors-CEy4nM1J.d.ts +0 -149
- package/dist/types-COCuQEMk.d.cts +0 -93
- package/dist/types-COCuQEMk.d.ts +0 -93
- package/dist/visualization-ENMBHWIN.js +0 -2
- package/dist/visualization-TBPFFBFU.cjs +0 -2
- package/dist/visualization-TBPFFBFU.cjs.map +0 -1
- /package/dist/{visualization-ENMBHWIN.js.map → visualization-WIUVT2FZ.js.map} +0 -0
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _chunkMA6YB3YZcjs = require('./chunk-MA6YB3YZ.cjs');function b(r,e){e||typeof window<"u"&&_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Warning: ${r} is running on the client side. For better performance and security, consider running this on the server side.`)}var Te="Unable to load grasshopper definition";function Ce(r){return r instanceof _chunkMA6YB3YZcjs.d&&r.message.includes(Te)}async function x(r,e,t){t.debug&&b("solveGrasshopperDefinition",_nullishCoalesce(t.suppressBrowserWarning, () => (t.suppressClientSideWarning)));let{response:n}=await N(D(e,r),t);return n}async function Q(r,e,t){return t.debug&&b("solveGrasshopperDefinitionWithCacheKey",_nullishCoalesce(t.suppressBrowserWarning, () => (t.suppressClientSideWarning))),N(D(e,r),t)}async function X(r,e,t,n){n.debug&&b("solveByCacheKey",_nullishCoalesce(n.suppressBrowserWarning, () => (n.suppressClientSideWarning)));let s={algo:null,pointer:e,values:r};try{return{...await N(s,n),missed:!1}}catch(o){if(!Ce(o))throw o;return{...await N(D(t,r),n),missed:!0}}}async function N(r,e){Ie(r,e);let t=await _chunkMA6YB3YZcjs.h.call(void 0, "grasshopper",r,e);if("pointer"in t){let{pointer:n,...s}=t;return{response:s,cacheKey:typeof n=="string"?n:null}}return{response:t,cacheKey:null}}function D(r,e){let t={algo:null,pointer:null,values:e};return r instanceof Uint8Array?t.algo=_chunkMA6YB3YZcjs.p.call(void 0, r):/^https?:\/\//i.test(r)?t.pointer=r:_chunkMA6YB3YZcjs.n.call(void 0, r)?t.algo=r:t.algo=_chunkMA6YB3YZcjs.m.call(void 0, r),t}function Ie(r,e){e.cachesolve!=null&&(r.cachesolve=e.cachesolve),e.modelunits!=null&&(r.modelunits=e.modelunits),e.angletolerance!=null&&(r.angletolerance=e.angletolerance),e.absolutetolerance!=null&&(r.absolutetolerance=e.absolutetolerance),e.dataversion!=null&&(r.dataversion=e.dataversion)}function Z(r){let e=new WeakSet,t=n=>{if(n==null)return JSON.stringify(n);if(typeof n=="number")return Number.isFinite(n)?String(n):JSON.stringify(null);if(typeof n=="string"||typeof n=="boolean")return JSON.stringify(n);if(typeof n=="bigint")return JSON.stringify(n.toString());if(n instanceof Uint8Array){let s=n.length>64?Array.from(n.slice(0,32)).concat(Array.from(n.slice(-32))):Array.from(n);return JSON.stringify({__u8:!0,len:n.length,sample:s})}return Array.isArray(n)?`[${n.map(t).join(",")}]`:typeof n=="object"?e.has(n)?JSON.stringify("[Circular]"):(e.add(n),`{${Object.keys(n).sort().map(a=>`${JSON.stringify(a)}:${t(n[a])}`).join(",")}}`):JSON.stringify(null)};return t(r)}function ee(r,e){let t=2166136261;for(let n=0;n<r;n++)t^=e(n),t=t+((t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24))>>>0;return t.toString(16).padStart(8,"0")}function re(r){return ee(r.length,e=>r.charCodeAt(e))}function te(r){return ee(r.length,e=>r[e])}function O(r,e){return re(`${G(r)}|${Z(e)}`)}function G(r){return typeof r=="string"?r:`u8:${r.length}:${te(r)}`}function Se(r){return r instanceof Uint8Array?!0:!/^https?:\/\//i.test(r)}var T=class{constructor(e,t,n={},s){_chunkMA6YB3YZcjs.b.call(void 0, this,"executor");_chunkMA6YB3YZcjs.b.call(void 0, this,"baseConfig");_chunkMA6YB3YZcjs.b.call(void 0, this,"mode");_chunkMA6YB3YZcjs.b.call(void 0, this,"maxConcurrent");_chunkMA6YB3YZcjs.b.call(void 0, this,"timeoutMs");_chunkMA6YB3YZcjs.b.call(void 0, this,"retry");_chunkMA6YB3YZcjs.b.call(void 0, this,"cacheEnabled");_chunkMA6YB3YZcjs.b.call(void 0, this,"cacheMax");_chunkMA6YB3YZcjs.b.call(void 0, this,"cacheTtl");_chunkMA6YB3YZcjs.b.call(void 0, this,"cache",new Map);_chunkMA6YB3YZcjs.b.call(void 0, this,"cacheKeyExecutor");_chunkMA6YB3YZcjs.b.call(void 0, this,"reuseServerDefinitionCache");_chunkMA6YB3YZcjs.b.call(void 0, this,"serverCacheKeys",new Map);_chunkMA6YB3YZcjs.b.call(void 0, this,"onStart");_chunkMA6YB3YZcjs.b.call(void 0, this,"onSettle");_chunkMA6YB3YZcjs.b.call(void 0, this,"onSuperseded");_chunkMA6YB3YZcjs.b.call(void 0, this,"subscribers",new Set);_chunkMA6YB3YZcjs.b.call(void 0, this,"inFlight",new Set);_chunkMA6YB3YZcjs.b.call(void 0, this,"pendingForLatestWins",null);_chunkMA6YB3YZcjs.b.call(void 0, this,"fifoQueue",[]);_chunkMA6YB3YZcjs.b.call(void 0, this,"_lastResult",null);_chunkMA6YB3YZcjs.b.call(void 0, this,"_lastError",null);_chunkMA6YB3YZcjs.b.call(void 0, this,"_lastDurationMs",null);_chunkMA6YB3YZcjs.b.call(void 0, this,"disposed",!1);this.executor=e,this.cacheKeyExecutor=s,this.baseConfig=t,this.mode=_nullishCoalesce(n.mode, () => ("latest-wins")),this.maxConcurrent=Math.max(1,_nullishCoalesce(n.maxConcurrent, () => ((this.mode==="parallel"?4:1)))),this.timeoutMs=n.timeoutMs,this.retry=n.retry;let o=n.cache;this.cacheEnabled=o!==void 0&&o!==!1;let a=typeof o=="object"?o:{};this.cacheMax=_nullishCoalesce(a.maxEntries, () => (50)),this.cacheTtl=_nullishCoalesce(a.ttlMs, () => (0)),this.reuseServerDefinitionCache=!!s&&(_nullishCoalesce(n.reuseServerDefinitionCache, () => (!0))),this.onStart=n.onStart,this.onSettle=n.onSettle,this.onSuperseded=n.onSuperseded}get isSolving(){return this.inFlight.size>0}get hasPending(){return this.pendingForLatestWins!==null||this.fifoQueue.length>0}get inFlightCount(){return this.inFlight.size}get queueDepth(){return this.fifoQueue.length+(this.pendingForLatestWins?1:0)}get lastResult(){return this._lastResult}get lastError(){return this._lastError}get lastDurationMs(){return this._lastDurationMs}subscribe(e){return this.subscribers.add(e),()=>this.subscribers.delete(e)}notify(){for(let e of this.subscribers)try{e()}catch(t){_chunkMA6YB3YZcjs.e.call(void 0, ).error("[SolveScheduler] subscriber threw:",t)}}solve(e,t,n){if(this.disposed)return Promise.reject(new (0, _chunkMA6YB3YZcjs.d)("SolveScheduler has been disposed and cannot be used",_chunkMA6YB3YZcjs.c.INVALID_STATE));let s=O(e,t),o={key:s,enqueuedAt:Date.now(),startedAt:null};if(this.cacheEnabled){let a=this.readCache(s);if(a){let i={status:"success",response:a,durationMs:0,fromCache:!0};return this._lastResult=a,this._lastError=null,this._lastDurationMs=0,this.runHook(this.onStart,o),this.runHook(this.onSettle,o,i),this.notify(),Promise.resolve(a)}}return new Promise((a,i)=>{let u={definition:e,dataTree:t,ctx:o,resolve:a,reject:i,externalSignal:_optionalChain([n, 'optionalAccess', _2 => _2.signal])};if(_optionalChain([u, 'access', _3 => _3.externalSignal, 'optionalAccess', _4 => _4.aborted])){this.settleError(u,this.makeAbortError(o));return}this.enqueue(u)})}enqueue(e){switch(this.mode){case"latest-wins":{this.pendingForLatestWins&&(this.supersede(this.pendingForLatestWins),this.pendingForLatestWins=null);for(let t of this.inFlight)this.supersede(t),t.controller.abort();this.inFlight.size===0?this.execute(e):this.pendingForLatestWins=e;break}case"queue":case"parallel":{this.inFlight.size<this.maxConcurrent?this.execute(e):this.fifoQueue.push(e);break}}this.notify()}async execute(e){let t=new AbortController,n={...e,controller:t};this.inFlight.add(n),e.ctx.startedAt=Date.now();let s=()=>t.abort();_optionalChain([e, 'access', _5 => _5.externalSignal, 'optionalAccess', _6 => _6.addEventListener, 'call', _7 => _7("abort",s,{once:!0})]),this.runHook(this.onStart,e.ctx),this.notify();let o=performance.now();try{let a={...this.baseConfig,signal:t.signal,...this.timeoutMs!==void 0&&{timeoutMs:this.timeoutMs},...this.retry!==void 0&&{retry:this.retry}},i=await this.runExecutor(e.definition,e.dataTree,a),u=performance.now()-o;if(this.cacheEnabled&&this.writeCache(e.ctx.key,i),!this.settleSuccess(e,i))return;this._lastResult=i,this._lastError=null,this._lastDurationMs=u,this.runHook(this.onSettle,e.ctx,{status:"success",response:i,durationMs:u,fromCache:!1})}catch(a){let i=performance.now()-o,u=this.normalizeExecutionError(a,n);this._lastError=u,this._lastDurationMs=i,this.settleError(e,u)&&this.runHook(this.onSettle,e.ctx,{status:"error",error:u,durationMs:i})}finally{_optionalChain([e, 'access', _8 => _8.externalSignal, 'optionalAccess', _9 => _9.removeEventListener, 'call', _10 => _10("abort",s)]),this.inFlight.delete(n),this.drainNext(),this.notify()}}async runExecutor(e,t,n){if(!this.cacheKeyExecutor||!this.reuseServerDefinitionCache||!Se(e))return this.executor(e,t,n);let s=G(e),o=_nullishCoalesce(this.serverCacheKeys.get(s), () => (null)),a=await this.cacheKeyExecutor(e,t,o,n);return a.cacheKey?this.serverCacheKeys.set(s,a.cacheKey):this.serverCacheKeys.delete(s),a.response}drainNext(){if(!this.disposed){if(this.mode==="latest-wins"){if(this.pendingForLatestWins&&this.inFlight.size===0){let e=this.pendingForLatestWins;this.pendingForLatestWins=null,this.execute(e)}return}for(;this.fifoQueue.length>0&&this.inFlight.size<this.maxConcurrent;){let e=this.fifoQueue.shift();this.execute(e)}}}supersede(e){let t=new (0, _chunkMA6YB3YZcjs.d)("Superseded by newer solve",_chunkMA6YB3YZcjs.c.SUPERSEDED,{context:{key:e.ctx.key,enqueuedAt:e.ctx.enqueuedAt}});this.settleError(e,t)&&this.runHook(this.onSuperseded,e.ctx)}makeAbortError(e){return new (0, _chunkMA6YB3YZcjs.d)("Request aborted by caller",_chunkMA6YB3YZcjs.c.ABORTED,{context:{key:e.key,enqueuedAt:e.enqueuedAt}})}settleError(e,t){return e.settled?!1:(e.settled={error:t},e.reject(t),!0)}settleSuccess(e,t){return e.settled?!1:(e.settled={ok:!0},e.resolve(t),!0)}isAbortLikeError(e){if(e instanceof Error){if(e.name==="AbortError")return!0;if(typeof DOMException<"u"&&e instanceof DOMException)return e.name==="AbortError"}return!1}normalizeExecutionError(e,t){return t.settled&&"error"in t.settled?t.settled.error:e instanceof _chunkMA6YB3YZcjs.d?e:this.isAbortLikeError(e)?this.makeAbortError(t.ctx):new (0, _chunkMA6YB3YZcjs.d)(e instanceof Error?e.message:String(e),_chunkMA6YB3YZcjs.c.UNKNOWN_ERROR,{originalError:e instanceof Error?e:new Error(String(e))})}cancelAll(){for(this.pendingForLatestWins&&(this.rejectAsAborted(this.pendingForLatestWins),this.pendingForLatestWins=null);this.fifoQueue.length>0;){let e=this.fifoQueue.shift();this.rejectAsAborted(e)}for(let e of this.inFlight){let t=this.makeAbortError(e.ctx);this.settleError(e,t)&&this.runHook(this.onSettle,e.ctx,{status:"error",error:t,durationMs:e.ctx.startedAt?performance.now()-e.ctx.startedAt:0}),e.controller.abort()}this.notify()}rejectAsAborted(e){this.settleError(e,this.makeAbortError(e.ctx))}readCache(e){if(!this.cacheEnabled)return null;let t=this.cache.get(e);return t?this.cacheTtl>0&&Date.now()-t.insertedAt>this.cacheTtl?(this.cache.delete(e),null):(this.cache.delete(e),this.cache.set(e,t),t.response):null}writeCache(e,t){if(this.cacheEnabled)for(this.cache.set(e,{response:t,insertedAt:Date.now()});this.cache.size>this.cacheMax;){let n=this.cache.keys().next().value;if(n===void 0)break;this.cache.delete(n)}}clearCache(){this.cache.clear()}dispose(){this.disposed||(this.disposed=!0,this.cancelAll(),this.subscribers.clear(),this.cache.clear())}runHook(e,...t){if(e)try{e(...t)}catch(n){_chunkMA6YB3YZcjs.e.call(void 0, ).error("[SolveScheduler] hook threw:",n)}}};var P=class r{constructor(e){_chunkMA6YB3YZcjs.b.call(void 0, this,"config");_chunkMA6YB3YZcjs.b.call(void 0, this,"serverStats");_chunkMA6YB3YZcjs.b.call(void 0, this,"disposed",!1);this.config=this.normalizeComputeConfig(e),this.serverStats=new (0, _chunkMA6YB3YZcjs.j)(this.config.serverUrl,this.config.apiKey)}static async create(e){let t=new r(e);if(!await t.serverStats.isServerOnline())throw new (0, _chunkMA6YB3YZcjs.d)("Rhino Compute server is not online",_chunkMA6YB3YZcjs.c.NETWORK_ERROR,{context:{serverUrl:t.config.serverUrl}});return t}getConfig(){return this.ensureNotDisposed(),{...this.config}}async getIO(e){return this.ensureNotDisposed(),F(e,this.config)}async getRawIO(e){return this.ensureNotDisposed(),w(e,this.config)}async solve(e,t,n){this.ensureNotDisposed();try{if(typeof e=="string"&&!_optionalChain([e, 'optionalAccess', _11 => _11.trim, 'call', _12 => _12()]))throw new (0, _chunkMA6YB3YZcjs.d)("Definition URL/content is required",_chunkMA6YB3YZcjs.c.INVALID_INPUT,{context:{receivedUrl:e}});if(e instanceof Uint8Array&&e.length===0)throw new (0, _chunkMA6YB3YZcjs.d)("Definition content is empty",_chunkMA6YB3YZcjs.c.INVALID_INPUT);let s={...this.config,..._optionalChain([n, 'optionalAccess', _13 => _13.signal])!==void 0&&{signal:n.signal},..._optionalChain([n, 'optionalAccess', _14 => _14.timeoutMs])!==void 0&&{timeoutMs:n.timeoutMs},..._optionalChain([n, 'optionalAccess', _15 => _15.retry])!==void 0&&{retry:n.retry}},o=await x(t,e,s);if(_optionalChain([o, 'optionalAccess', _16 => _16.errors])&&o.errors.length>0)throw new (0, _chunkMA6YB3YZcjs.d)(o.errors.join("; ")||"Computation failed",_chunkMA6YB3YZcjs.c.COMPUTATION_ERROR,{context:{definition:typeof e=="string"&&e.length<200?e:"...content...",inputs:t,errors:o.errors,warnings:o.warnings}});return o}catch(s){throw this.config.debug&&_chunkMA6YB3YZcjs.e.call(void 0, ).error("Compute failed:",s),s instanceof _chunkMA6YB3YZcjs.d?s:new (0, _chunkMA6YB3YZcjs.d)(s instanceof Error?s.message:String(s),_chunkMA6YB3YZcjs.c.COMPUTATION_ERROR,{context:{definition:typeof e=="string"&&e.length<200?e:"...content...",inputs:t},originalError:s instanceof Error?s:new Error(String(s))})}}createScheduler(e){this.ensureNotDisposed();let t=(s,o,a)=>x(o,s,a),n=(s,o,a,i)=>a===null?Q(o,s,i).then(u=>({...u,missed:!1})):X(o,a,s,i);return new T(t,this.config,e,n)}async dispose(){this.disposed||(this.disposed=!0,await this.serverStats.dispose())}ensureNotDisposed(){if(this.disposed)throw new (0, _chunkMA6YB3YZcjs.d)("GrasshopperClient has been disposed and cannot be used",_chunkMA6YB3YZcjs.c.INVALID_STATE)}normalizeComputeConfig(e){return{...e,serverUrl:_chunkMA6YB3YZcjs.i.call(void 0, e.serverUrl),apiKey:e.apiKey,authToken:e.authToken,debug:_nullishCoalesce(e.debug, () => (!1)),suppressBrowserWarning:_nullishCoalesce(e.suppressBrowserWarning, () => (e.suppressClientSideWarning))}}};var V=new Map;function ne(r,e){V.set(r,e)}ne("Rhino.Geometry.Point3d",(r,e)=>{let t=e;return!t||typeof t.X!="number"?null:new r.Point([t.X,t.Y,t.Z])});ne("Rhino.Geometry.Line",(r,e)=>{let t=e;return!t||!t.From||!t.To?null:new r.Line([t.From.X,t.From.Y,t.From.Z],[t.To.X,t.To.Y,t.To.Z])});function xe(r){if(V.has(r))return V.get(r);for(let[e,t]of V)if(r.startsWith(e))return t}function De(r){return!r||typeof r!="object"?null:_nullishCoalesce(_nullishCoalesce(r.data, () => (r.value)), () => (null))}function se(r,e,t){let n=xe(e);if(n)try{return n(t,r)}catch(s){_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Failed to decode Rhino type ${e}:`,s)}try{let s=De(r);if(s)return t.CommonObject.decode(s)}catch(s){return _chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Failed to decode ${e} with CommonObject:`,s),{__decodeError:!0,type:e,raw:r}}return r}var C={STRING:"System.String",INT:"System.Int32",DOUBLE:"System.Double",BOOL:"System.Boolean"},Pe="Rhino.Geometry.",we=["WebDisplay"],Re="FileData";function oe(r){return we.some(e=>r.includes(e))}function ae(r){if(typeof r!="string")return r;let e=r.trim();if(!(e.startsWith("{")||e.startsWith("[")||e.startsWith('"')))return r;try{let n=JSON.parse(e);if(typeof n=="string")try{return JSON.parse(n)}catch (e2){return n}return n}catch (e3){return r}}function Ee(r,e,t){switch(e){case C.STRING:return typeof r!="string"?r:r.replace(/^"(.*)"$/,"$1");case C.INT:return Number.parseInt(r,10);case C.DOUBLE:return Number.parseFloat(r);case C.BOOL:return String(r).toLowerCase()==="true";default:return t&&e.startsWith(Pe)?se(r,e,t):r}}function ie(r,e,t,n){if(typeof r!="string")return r;let s=t?ae(r):r;return Ee(s,e,n)}function ve(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.fileName=="string"&&typeof e.fileType=="string"&&"data"in e&&typeof e.isBase64Encoded=="boolean"&&typeof e.subFolder=="string"}function k(r,e){for(let t of Object.values(r))if(Array.isArray(t))for(let n of t)e(n)}function ue(r,e=!1,t={}){let{parseValues:n=!0,rhino:s,stringOnly:o=!1}=t,a={};for(let i of r.values)k(i.InnerTree,u=>{if(oe(u.type)||o&&u.type!==C.STRING)return;let l=e?u.id:i.ParamName;if(!l)return;let f=ie(u.data,u.type,n,s);a[l]===void 0?a[l]=f:Array.isArray(a[l])?a[l].push(f):a[l]=[a[l],f]});return{values:a}}function pe(r){let e=[];for(let t of r.values)k(t.InnerTree,n=>{if(!n.type.includes(Re))return;let s=ae(n.data);ve(s)&&e.push(s)});return e}function M(r,e,t={}){let{parseValues:n=!0,rhino:s,stringOnly:o=!1}=t,a;if("byName"in e?a=r.values.find(u=>u.ParamName===e.byName):a=r.values.find(u=>{let l=!1;return k(u.InnerTree,f=>{f.id===e.byId&&(l=!0)}),l}),!a)return;let i=[];if(k(a.InnerTree,u=>{if("byId"in e&&u.id!==e.byId||oe(u.type)||o&&u.type!==C.STRING)return;let l=ie(u.data,u.type,n,s);i.push(l)}),i.length!==0)return i.length===1?i[0]:i}var R=class{constructor(e,t=!1){this.response=e;this.debug=t}getValues(e=!1,t={}){return ue(this.response,e,t)}getValue(e,t){return M(this.response,e,t)}getValueByParamName(e,t){return M(this.response,{byName:e},t)}getValueByParamId(e,t){return M(this.response,{byId:e},t)}async extractMeshesFromResponse(e){let t={debug:this.debug,...e},n;try{({getThreeMeshesFromComputeResponse:n}=await Promise.resolve().then(() => _interopRequireWildcard(require("./visualization-GU7JIB4V.cjs"))))}catch(s){throw new (0, _chunkMA6YB3YZcjs.d)("Failed to load three.js visualization module. Ensure three.js is installed as a peer dependency.",_chunkMA6YB3YZcjs.c.INVALID_STATE,{context:{originalError:s instanceof Error?s.message:String(s)}})}return n(this.response,t)}getFileData(){return pe(this.response)}getAndDownloadFiles(e,t){let n=this.getFileData();_chunkMA6YB3YZcjs.r.call(void 0, n,e,t)}};function L(r,e){if(!r||typeof r!="object")return;let t=r;if(e in t)return t[e];let n=e.toLowerCase();for(let s of Object.keys(t))if(s.toLowerCase()===n)return t[s]}function j(r,e){if(!r||typeof r!="object")return!1;let t=r;if(e in t)return!0;let n=e.toLowerCase();return Object.keys(t).some(s=>s.toLowerCase()===n)}function le(r){return L(r,"data")}function Ae(r){return L(r,"type")}function ce(r){if(typeof r.default!="object"||r.default===null)return{schema:r};if(!j(r.default,"innerTree")){let n=`Input "${_nullishCoalesce(r.name, () => ("unknown"))}" default had an unrecognized shape (no innerTree key); the default was dropped.`;return _chunkMA6YB3YZcjs.e.call(void 0, ).warn("Unexpected structure in input.default:",r.default),{schema:{...r,default:null},warning:{code:"MALFORMED_DEFAULT",message:n}}}let e=_nullishCoalesce(L(r.default,"innerTree"), () => ({}));if(Object.keys(e).length===0)return{schema:{...r,default:void 0}};if(r.treeAccess||r.atMost&&r.atMost>1){let n={};for(let[s,o]of Object.entries(e))n[s]=o.map(a=>{let i=le(a),u=Ae(a);if(typeof i=="string"){if(u==="System.Double"||u==="System.Int32"){let l=Number(i);return Number.isNaN(l)?i:l}if(u==="System.Boolean")return i.toLowerCase()==="true";if(_optionalChain([u, 'optionalAccess', _17 => _17.startsWith, 'call', _18 => _18("Rhino.Geometry")])||u==="System.String")try{return JSON.parse(i)}catch (e4){return i}}return i});return{schema:{...r,default:n}}}let t=[];for(let n of Object.values(e))Array.isArray(n)&&n.forEach(s=>{s&&typeof s=="object"&&j(s,"data")&&t.push(le(s))});return t.length===0?{schema:{...r,default:void 0}}:t.length===1?{schema:{...r,default:t[0]}}:{schema:{...r,default:t}}}var U=/^\{([\d;]*)\}$/;function E(r){if(typeof r!="object"||r===null||Array.isArray(r))return!1;let e=Object.entries(r);return e.length>0&&e.every(([t,n])=>U.test(t)&&Array.isArray(n))}function I(r,e,t){if(r==null)return r;if(Array.isArray(r)){let s=r.map(e).filter(o=>o!==null);return s.length>0?s:void 0}let n=e(r);return n!==null?n:t?void 0:r}var Ne=r=>{if(typeof r=="number")return r;if(typeof r=="string"){let e=Number(r.trim());return Number.isNaN(e)?null:e}return null},Oe=r=>{if(typeof r=="boolean")return r;if(typeof r=="string"){let e=r.toLowerCase();if(e==="true")return!0;if(e==="false")return!1;throw new Error(`Invalid boolean string: "${r}"`)}return null},Ge=r=>typeof r=="string"?r.startsWith('"')&&r.endsWith('"')||r.startsWith('"')?r.slice(1,-1):r:null,Fe=r=>{if(typeof r=="string"){let e=r.trim();return e.startsWith('"')&&e.endsWith('"')&&(e=e.slice(1,-1).trim()),e}return null};function me(r){return e=>{if(typeof e=="object"&&e!==null)return e;if(typeof e=="string"&&e.trim()!=="")try{let t=JSON.parse(e);return typeof t=="object"&&t!==null?t:(_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Parsed value for input ${r} is not an object`),null)}catch(t){return _chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Failed to parse object value "${e}" for input ${r}`,t),null}return null}}function fe(r,e,t){let n=Number(r.toFixed(e));return Math.abs(r-n)<t?n:r}function Ve(r,e){if(!Number.isFinite(r)||r===0)return .1;let t=Math.abs(r);if(t>=1){let h=String(r).split(".")[1];if(h&&h.length>0){let y=Math.min(h.length,12),g=Math.pow(10,-y),$=Number(g.toFixed(y));return Math.abs($-g)<e?$:g}return 1}let n=String(r),s=n.toLowerCase().match(/e(-?\d+)/);if(s){let S=Number(s[1]);if(S<0||n.toLowerCase().includes("e-")){let h=Math.abs(S),y=Math.pow(10,-h),g=Number(y.toFixed(h));return Math.abs(g-y)<e?g:y}return .1}let o=12,i=t.toFixed(o).replace(/0+$/,""),u=Math.min((i.split(".")[1]||"").length,o);if(u===0)return .1;let l=Math.pow(10,-u),f=Number(l.toFixed(u));return Math.abs(f-l)<e?f:l}function ke(r,e=1e-8){let t=r.paramType==="Integer";if(E(r.default))return{default:r.default,stepSize:t?1:.1};let n=I(r.default,Ne,!0);if(t)return Array.isArray(n)?n=n.map(f=>typeof f=="number"?Math.round(f):f):typeof n=="number"&&(n=Math.round(n)),{default:n,stepSize:1};let s=Array.isArray(n)?n[0]:n,o;typeof s=="number"&&Number.isFinite(s)&&s!==0?o=s:typeof r.minimum=="number"&&Number.isFinite(r.minimum)&&r.minimum!==0?o=r.minimum:typeof r.maximum=="number"&&Number.isFinite(r.maximum)&&r.maximum!==0&&(o=r.maximum);let a=o!==void 0?Ve(o,e):.1,i=0,u=String(a),l=u.toLowerCase().match(/e(-?\d+)/);if(l?i=Math.abs(Number(l[1])):i=_nullishCoalesce(_optionalChain([u, 'access', _19 => _19.split, 'call', _20 => _20("."), 'access', _21 => _21[1], 'optionalAccess', _22 => _22.length]), () => (0)),i===0&&typeof s=="number"&&s!==0&&Math.abs(s)<1){let f=Math.ceil(-Math.log10(Math.abs(s)));Number.isFinite(f)&&f>0&&(i=f)}return i=Math.min(Math.max(i,0),12),Array.isArray(n)?n=n.map(f=>typeof f=="number"?fe(f,i,e):f):typeof n=="number"&&(n=fe(n,i,e)),{default:n,stepSize:a}}var Me={types:["Number","Integer"],parse(r,e){let{default:t,stepSize:n}=ke(r);return{...e,paramType:r.paramType,minimum:r.minimum,maximum:r.maximum,atLeast:r.atLeast,atMost:r.atMost,stepSize:n,default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:r.paramType,minimum:r.minimum,maximum:r.maximum,atLeast:r.atLeast,atMost:r.atMost,default:t?[0]:0}}},Le={types:["Boolean"],parse(r,e){let t;try{t=I(r.default,Oe,!1)}catch(n){throw n instanceof Error?new (0, _chunkMA6YB3YZcjs.d)(n.message):n}return{...e,paramType:"Boolean",default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"Boolean",default:t?[!1]:!1}}},We={types:["Text"],parse(r,e){let t=I(r.default,Ge,!1);return{...e,paramType:"Text",default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"Text",default:t?[""]:""}}},Be={types:["ValueList"],parse(r,e){if(!r.values||typeof r.values!="object"||Object.keys(r.values).length===0)throw _chunkMA6YB3YZcjs.d.missingValues(r.nickname||"unnamed","ValueList");if(r.default!==void 0&&r.default!==null){let t=String(r.default).toLowerCase();Object.keys(r.values).some(s=>s.toLowerCase()===t)||_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`ValueList input "${r.nickname||"unnamed"}" default value "${r.default}" is not in available values`)}return{...e,paramType:"ValueList",values:r.values,default:r.default}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"ValueList",values:_nullishCoalesce(r.values, () => ({})),default:t?[r.default]:r.default}}},de={types:["Geometry"],parse(r,e){let t=I(r.default,me(r.nickname||"unnamed"),!0);return{...e,paramType:"Geometry",default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"Geometry",default:t?[null]:null}}},je={types:["File"],parse(r,e){let t=I(r.default,me(r.nickname||"unnamed"),!0);return{...e,paramType:"File",acceptedFormats:r.acceptedFormats,default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"File",default:t?[null]:null}}},Ue={types:["Color"],parse(r,e){let t=I(r.default,Fe,!1);return{...e,paramType:"Color",default:t}},fallback(r,e){let t=(_nullishCoalesce(r.atMost, () => (1)))>1;return{...e,paramType:"Color",default:t?["0, 0, 0"]:"0, 0, 0"}}},Ke=[Me,Le,We,Be,de,je,Ue],K=new Map(Ke.flatMap(r=>r.types.map(e=>[e,r]))),he=de;var ze=new Map([...K.keys()].map(r=>[r.toLowerCase(),r]));function $e(r){return _nullishCoalesce(ze.get(_optionalChain([r, 'optionalAccess', _23 => _23.toLowerCase, 'call', _24 => _24()])), () => (r))}function ye(r){return z(r).input}function z(r){let e={description:r.description,name:r.name,nickname:r.nickname,treeAccess:r.treeAccess,groupName:_nullishCoalesce(r.groupName, () => ("")),id:r.id},t=$e(r.paramType),{schema:n,warning:s}=ce({...r,paramType:t}),o=s&&{inputName:r.name||"unknown",paramType:t,message:s.message,code:s.code},a=K.get(t);try{if(!a)throw _chunkMA6YB3YZcjs.d.unknownParamType(t,r.name);return{input:a.parse(n,e),error:o}}catch(i){if(i instanceof _chunkMA6YB3YZcjs.d)return _chunkMA6YB3YZcjs.e.call(void 0, ).error(`Validation error for input ${r.name||"unknown"}:`,i.message),{input:(_nullishCoalesce(a, () => (he))).fallback(n,e),error:{inputName:r.name||"unknown",paramType:t,message:i.message,code:i.code}};throw new (0, _chunkMA6YB3YZcjs.d)(i instanceof Error?i.message:String(i),"VALIDATION_ERROR",{context:{paramName:r.name,paramType:t},originalError:i instanceof Error?i:new Error(String(i))})}}function ge(r){return W(r).inputs}function W(r){let e=[],t=[];for(let n of r){let{input:s,error:o}=z(n);e.push(s),o&&t.push(o)}return{inputs:e,parseErrors:t}}async function w(r,e){let t=D(r,[]),n={};if(t.algo&&(n.algo=t.algo),t.pointer&&(n.pointer=t.pointer),!n.algo&&!n.pointer)throw new (0, _chunkMA6YB3YZcjs.d)("Definition must resolve to either a URL pointer or base64 algo",_chunkMA6YB3YZcjs.c.INVALID_INPUT,{context:{definition:r}});let s=await _chunkMA6YB3YZcjs.h.call(void 0, "io",n,e);if(!s||typeof s!="object")throw new (0, _chunkMA6YB3YZcjs.d)("Invalid IO response structure",_chunkMA6YB3YZcjs.c.INVALID_INPUT,{context:{response:s,definition:r}});let o=be(s.warnings),a=be(s.errors);return{inputs:s.inputs,outputs:s.outputs,...o&&{loadWarnings:o},...a&&{loadErrors:a}}}function be(r){if(!Array.isArray(r))return;let e=r.filter(t=>typeof t=="string"&&t.trim().length>0);return e.length>0?e:void 0}async function F(r,e){b("fetchParsedDefinitionIO",_nullishCoalesce(e.suppressBrowserWarning, () => (e.suppressClientSideWarning)));let{inputs:t,outputs:n,loadWarnings:s,loadErrors:o}=await w(r,e),{inputs:a,parseErrors:i}=W(t);return{inputs:a,outputs:n,...i.length>0&&{parseErrors:i},...s&&{loadWarnings:s},...o&&{loadErrors:o}}}var B=class r{constructor(e){_chunkMA6YB3YZcjs.b.call(void 0, this,"innerTree");_chunkMA6YB3YZcjs.b.call(void 0, this,"paramName");this.paramName=e,this.innerTree={}}append(e,t){let n=r.formatPathString(e);this.innerTree[n]||(this.innerTree[n]=[]);let s=t.map(o=>({data:r.serializeValue(o)}));return this.innerTree[n].push(...s),this}appendSingle(e,t){return this.append(e,[t])}fromDataTreeDefault(e){this.innerTree={};for(let[t,n]of Object.entries(e)){if(!Array.isArray(n))continue;let s=r.parsePathString(t);this.append(s,n)}return this}appendFlat(e){let t=Array.isArray(e)?e:[e];return this.append([0],t)}flatten(){let e=[];for(let t of Object.values(this.innerTree))if(Array.isArray(t))for(let n of t)e.push(r.deserializeValue(n.data));return e}getPaths(){return Object.keys(this.innerTree)}getPath(e){let t=r.formatPathString(e),n=this.innerTree[t];if(n)return n.map(s=>r.deserializeValue(s.data))}toComputeFormat(){return{ParamName:this.paramName,InnerTree:this.innerTree}}getInnerTree(){return this.innerTree}getParamName(){return this.paramName}static fromInputParams(e){return e.filter(t=>r.hasValidValue(t.default)).map(t=>{let n=new r(t.nickname||"unnamed"),s=t.default;if(t.treeAccess&&E(s))n.fromDataTreeDefault(s),r.isNumericInput(t)&&n.applyNumericConstraints(t.minimum,t.maximum,t.nickname||"unnamed");else{let o=Array.isArray(s)?s:[s],a=r.processValues(o,t);n.appendFlat(a)}return n.toComputeFormat()})}static fromInputParam(e){return r.hasValidValue(e.default)?r.fromInputParams([e])[0]:void 0}static replaceTreeValue(e,t,n){let s=e.length>0&&e[0]instanceof r,o=r.buildFromValue(t,n);if(s){let l=e,f=l.findIndex(S=>S.getParamName()===t);return f!==-1?l[f]=o:l.push(o),l}let a=e,i=o.toComputeFormat(),u=a.findIndex(l=>l.ParamName===t);return u!==-1?a[u]=i:a.push(i),a}static buildFromValue(e,t){let n=new r(e);return E(t)?n.fromDataTreeDefault(t):n.appendFlat(t),n}static getTreeValue(e,t){let s=e.length>0&&e[0]instanceof r?r.readFromBuilders(e,t):r.readFromDataTrees(e,t);return s===null||s.length===0?null:s.length===1?s[0]:s}static readFromBuilders(e,t){let n=e.find(s=>s.getParamName()===t);return n?n.flatten():null}static readFromDataTrees(e,t){let n=e.find(a=>a.ParamName===t);if(!_optionalChain([n, 'optionalAccess', _25 => _25.InnerTree]))return null;let s=Object.keys(n.InnerTree)[0];if(!s)return null;let o=n.InnerTree[s];return Array.isArray(o)?o.map(a=>_optionalChain([a, 'optionalAccess', _26 => _26.data])!==void 0?r.deserializeValue(a.data):null).filter(a=>a!==null):_optionalChain([o, 'optionalAccess', _27 => _27.data])!==void 0?[r.deserializeValue(o.data)]:o!==void 0?[o]:null}static parsePathString(e){let t=e.match(U);return t?t[1]===""?[]:t[1].split(";").map(Number):(_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`Invalid TreeBuilder path format: ${e}, using [0]`),[0])}static formatPathString(e){return`{${e.join(";")}}`}applyNumericConstraints(e,t,n){for(let s of Object.values(this.innerTree))if(Array.isArray(s))for(let o of s){let a=r.deserializeValue(o.data);if(typeof a=="number"){let i=r.clampValue(a,e,t,n);o.data=r.serializeValue(i)}}}static serializeValue(e){return typeof e=="boolean"||typeof e=="number"||typeof e=="string"?e:typeof e=="object"&&e!==null?JSON.stringify(e):String(e)}static deserializeValue(e){if(typeof e=="boolean"||typeof e=="number"||typeof e!="string")return e;if(e.startsWith("{")||e.startsWith("["))try{return JSON.parse(e)}catch (e5){return e}return isNaN(Number(e))?e==="true"?!0:e==="false"?!1:e:Number(e)}static hasValidValue(e){return e==null?!1:typeof e=="string"?!0:!(Array.isArray(e)&&e.length===0||typeof e=="object"&&!Array.isArray(e)&&Object.keys(e).length===0)}static isNumericInput(e){return e.paramType==="Number"||e.paramType==="Integer"}static processValues(e,t){return e.map(n=>r.isNumericInput(t)&&typeof n=="number"?r.clampValue(n,t.minimum,t.maximum,t.nickname||"unnamed"):n).filter(n=>n!=null)}static clampValue(e,t,n,s){let o=e;return t!=null&&o<t&&(_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`${s}: ${e} below min ${t}, clamping`),o=t),n!=null&&o>n&&(_chunkMA6YB3YZcjs.e.call(void 0, ).warn(`${s}: ${e} above max ${n}, clamping`),o=n),o}};exports.a = x; exports.b = O; exports.c = T; exports.d = P; exports.e = R; exports.f = ye; exports.g = ge; exports.h = w; exports.i = F; exports.j = B;
|
|
2
|
+
//# sourceMappingURL=chunk-3FH7FKLG.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/selva-compute/selva-compute/dist/chunk-3FH7FKLG.cjs","../src/core/utils/warnings.ts","../src/features/grasshopper/solve.ts","../src/features/grasshopper/scheduler/stable-hash.ts"],"names":["warnIfClientSide","functionName","suppress","getLogger","DEFINITION_LOAD_FAILED","isDefinitionLoadMiss","error","RhinoComputeError","solveGrasshopperDefinition","dataTree","definition","config","response","runSolve","prepareGrasshopperArgs","solveGrasshopperDefinitionWithCacheKey","solveByCacheKey","cacheKey","pointerArgs","args","applyOptionalComputeSettings","result","fetchRhinoCompute","pointer","rest","base64ByteArray","isBase64","encodeStringToBase64","arglist","options","stableStringify","value","seen","stringify","v","sample","k"],"mappings":"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","file":"/home/runner/work/selva-compute/selva-compute/dist/chunk-3FH7FKLG.cjs","sourcesContent":[null,"import { getLogger } from './logger';\n\nexport function warnIfClientSide(functionName: string, suppress?: boolean): void {\n\tif (suppress) {\n\t\treturn;\n\t}\n\n\tif (typeof window !== 'undefined') {\n\t\tgetLogger().warn(\n\t\t\t`Warning: ${functionName} is running on the client side. For better performance and security, consider running this on the server side.`\n\t\t);\n\t}\n}\n","import { fetchRhinoCompute, RhinoComputeError } from '@/core';\nimport { base64ByteArray, encodeStringToBase64, isBase64 } from '@/core/utils/encoding';\nimport { warnIfClientSide } from '@/core/utils/warnings';\n\nimport {\n\tGrasshopperRequestSchema,\n\tGrasshopperComputeConfig,\n\tGrasshopperComputeResponse,\n\tDataTree\n} from './types';\n\n/**\n * The exact message the server throws when it can neither resolve a `pointer`\n * nor a base64 `algo` to a definition (ResthopperEndpoints.cs). This is the\n * signal that a cache-key pointer missed the server's definition cache (GC'd, or\n * a different child in the pool), so the caller should retry with the full\n * definition. Matched as a substring because the server wraps it with a category\n * prefix in its exception handler.\n */\nconst DEFINITION_LOAD_FAILED = 'Unable to load grasshopper definition';\n\n/** Does this error look like a server-side definition-load miss? */\nfunction isDefinitionLoadMiss(error: unknown): boolean {\n\treturn error instanceof RhinoComputeError && error.message.includes(DEFINITION_LOAD_FAILED);\n}\n\n/**\n * Result of a solve that also reports the definition's server-side cache key.\n *\n * `cacheKey` is the `md5_…` identifier the server assigned to the (base64)\n * definition — stable for identical content. A caller that holds it can solve\n * the same definition again by reference (`pointer: cacheKey`) instead of\n * re-uploading the full base64, which matters a lot for large (multi-MB)\n * definitions on a live UI. `null` when the server didn't return one (e.g. a\n * URL-pointer solve).\n */\nexport interface SolveWithCacheKey {\n\tresponse: GrasshopperComputeResponse;\n\tcacheKey: string | null;\n}\n\n/**\n * Runs a Rhino Compute job using the provided tree prototypes and Grasshopper definition.\n *\n * @public Use this for direct compute control. For high-level API, use `GrasshopperClient.solve()`.\n *\n * @param dataTree - An array of `DataTree` objects representing the input data for the compute job.\n * @param definition - The Grasshopper definition, which can be:\n * - A URL string (e.g., 'https://example.com/definition.gh')\n * - A base64-encoded string of the .gh file\n * - A plain string (will be base64-encoded)\n * - A Uint8Array of the .gh file (will be base64-encoded)\n * @param config - Compute configuration (server URL, API key, etc. along with optional timeout, units, etc.)\n * @returns An object containing the compute result and extracted file data.\n *\n * @example\n * // Using a URL\n * await solveGrasshopperDefinition(trees, 'https://example.com/definition.gh', config);\n *\n * // Using a base64 string\n * await solveGrasshopperDefinition(trees, 'UEsDBBQAAAAIAL...', config);\n *\n * // Using binary data\n * const fileData = new Uint8Array([...]);\n * await solveGrasshopperDefinition(trees, fileData, config);\n */\nexport async function solveGrasshopperDefinition(\n\tdataTree: DataTree[],\n\tdefinition: string | Uint8Array,\n\tconfig: GrasshopperComputeConfig\n): Promise<GrasshopperComputeResponse> {\n\tif (config.debug) {\n\t\twarnIfClientSide(\n\t\t\t'solveGrasshopperDefinition',\n\t\t\tconfig.suppressBrowserWarning ?? config.suppressClientSideWarning\n\t\t);\n\t}\n\n\tconst { response } = await runSolve(prepareGrasshopperArgs(definition, dataTree), config);\n\treturn response;\n}\n\n/**\n * Solve while reporting the server's definition cache key.\n *\n * Behaves like {@link solveGrasshopperDefinition} but returns the `cacheKey` the\n * server assigned, so a caller (e.g. the scheduler) can later solve the same\n * definition by reference instead of re-uploading it. The cache key is only\n * meaningful for base64/binary definitions; a URL-pointer solve returns the URL.\n *\n * @internal\n */\nexport async function solveGrasshopperDefinitionWithCacheKey(\n\tdataTree: DataTree[],\n\tdefinition: string | Uint8Array,\n\tconfig: GrasshopperComputeConfig\n): Promise<SolveWithCacheKey> {\n\tif (config.debug) {\n\t\twarnIfClientSide(\n\t\t\t'solveGrasshopperDefinitionWithCacheKey',\n\t\t\tconfig.suppressBrowserWarning ?? config.suppressClientSideWarning\n\t\t);\n\t}\n\n\treturn runSolve(prepareGrasshopperArgs(definition, dataTree), config);\n}\n\n/**\n * Solve a definition by its server-side cache key (`pointer: cacheKey`),\n * skipping the (potentially multi-MB) base64 upload. If the key has been evicted\n * from the server's definition cache — `DEFINITION_LOAD_FAILED` — transparently\n * retry once with the full `definition` and report the fresh cache key so the\n * caller can update its mapping.\n *\n * @returns The solve result plus the (possibly refreshed) cache key, and whether\n * the fast path missed (so callers can record the new key / track hit rate).\n * @internal\n */\nexport async function solveByCacheKey(\n\tdataTree: DataTree[],\n\tcacheKey: string,\n\tdefinition: string | Uint8Array,\n\tconfig: GrasshopperComputeConfig\n): Promise<SolveWithCacheKey & { missed: boolean }> {\n\tif (config.debug) {\n\t\twarnIfClientSide(\n\t\t\t'solveByCacheKey',\n\t\t\tconfig.suppressBrowserWarning ?? config.suppressClientSideWarning\n\t\t);\n\t}\n\n\tconst pointerArgs: GrasshopperRequestSchema = { algo: null, pointer: cacheKey, values: dataTree };\n\n\ttry {\n\t\tconst fast = await runSolve(pointerArgs, config);\n\t\treturn { ...fast, missed: false };\n\t} catch (error) {\n\t\tif (!isDefinitionLoadMiss(error)) throw error;\n\t\t// Cache miss — fall back to the full upload and capture the fresh key.\n\t\tconst full = await runSolve(prepareGrasshopperArgs(definition, dataTree), config);\n\t\treturn { ...full, missed: true };\n\t}\n}\n\n/**\n * Shared solve body: apply optional settings, POST, and split the server's\n * `pointer` (its cache key) off the response. Stripping via shallow copy rather\n * than `delete` keeps any already-observed response object unmutated.\n */\nasync function runSolve(\n\targs: GrasshopperRequestSchema,\n\tconfig: GrasshopperComputeConfig\n): Promise<SolveWithCacheKey> {\n\tapplyOptionalComputeSettings(args, config);\n\n\tconst result = await fetchRhinoCompute<GrasshopperComputeResponse>('grasshopper', args, config);\n\n\tif ('pointer' in result) {\n\t\tconst { pointer, ...rest } = result as GrasshopperComputeResponse & { pointer?: unknown };\n\t\treturn {\n\t\t\tresponse: rest as GrasshopperComputeResponse,\n\t\t\tcacheKey: typeof pointer === 'string' ? pointer : null\n\t\t};\n\t}\n\n\treturn { response: result, cacheKey: null };\n}\n\n// ============================================================================\n// Grasshopper Arguments\n// ============================================================================\n\n/**\n * Prepares Grasshopper arguments from a definition and data tree.\n * Automatically detects the definition format and converts it appropriately.\n *\n * @param definition - Can be a URL, base64 string, plain string, or Uint8Array\n * @param dataTree - Array of DataTree objects for compute inputs\n * @internal\n */\nexport function prepareGrasshopperArgs(\n\tdefinition: string | Uint8Array,\n\tdataTree: DataTree[]\n): GrasshopperRequestSchema {\n\tconst args: GrasshopperRequestSchema = {\n\t\talgo: null,\n\t\tpointer: null,\n\t\tvalues: dataTree\n\t};\n\n\tif (definition instanceof Uint8Array) {\n\t\t// Binary data → convert to base64\n\t\targs.algo = base64ByteArray(definition);\n\t} else if (/^https?:\\/\\//i.test(definition)) {\n\t\t// URL → use as pointer reference\n\t\targs.pointer = definition;\n\t} else if (isBase64(definition)) {\n\t\t// Already base64 → use as-is\n\t\targs.algo = definition;\n\t} else {\n\t\t// Plain string → encode to base64\n\t\targs.algo = encodeStringToBase64(definition);\n\t}\n\n\treturn args;\n}\n\n/**\n * @internal\n */\nexport function applyOptionalComputeSettings(\n\targlist: GrasshopperRequestSchema,\n\toptions: GrasshopperComputeConfig\n): void {\n\tif (options.cachesolve != null) arglist.cachesolve = options.cachesolve;\n\tif (options.modelunits != null) arglist.modelunits = options.modelunits;\n\tif (options.angletolerance != null) arglist.angletolerance = options.angletolerance;\n\tif (options.absolutetolerance != null) arglist.absolutetolerance = options.absolutetolerance;\n\tif (options.dataversion != null) arglist.dataversion = options.dataversion;\n}\n","/**\n * Stable hashing for solve deduplication and caching.\n * @internal\n */\n\n/**\n * Deterministic stringify with sorted keys. {a:1,b:2} and {b:2,a:1} produce\n * the same string. Safely handles circular references and non-finite numbers.\n */\nexport function stableStringify(value: unknown): string {\n\tconst seen = new WeakSet<object>();\n\n\tconst stringify = (v: unknown): string => {\n\t\tif (v === null || v === undefined) return JSON.stringify(v);\n\t\tif (typeof v === 'number') {\n\t\t\treturn Number.isFinite(v) ? String(v) : JSON.stringify(null);\n\t\t}\n\t\tif (typeof v === 'string' || typeof v === 'boolean') return JSON.stringify(v);\n\t\tif (typeof v === 'bigint') return JSON.stringify(v.toString());\n\t\tif (v instanceof Uint8Array) {\n\t\t\t// Use length + sample instead of full buffer to avoid stringifying large data\n\t\t\tconst sample =\n\t\t\t\tv.length > 64 ? Array.from(v.slice(0, 32)).concat(Array.from(v.slice(-32))) : Array.from(v);\n\t\t\treturn JSON.stringify({ __u8: true, len: v.length, sample });\n\t\t}\n\t\tif (Array.isArray(v)) {\n\t\t\treturn `[${v.map(stringify).join(',')}]`;\n\t\t}\n\t\tif (typeof v === 'object') {\n\t\t\tif (seen.has(v as object)) return JSON.stringify('[Circular]');\n\t\t\tseen.add(v as object);\n\t\t\tconst keys = Object.keys(v as object).sort();\n\t\t\tconst parts = keys.map((k) => `${JSON.stringify(k)}:${stringify((v as any)[k])}`);\n\t\t\treturn `{${parts.join(',')}}`;\n\t\t}\n\t\t// Fallback for functions, symbols, etc.\n\t\treturn JSON.stringify(null);\n\t};\n\n\treturn stringify(value);\n}\n\n/**\n * 32-bit FNV-1a core over a sequence of byte/char codes. Returns unsigned hex.\n * Shared by the string and byte hashers so they stay the same algorithm.\n */\nfunction fnv1aCore(length: number, codeAt: (i: number) => number): string {\n\tlet hash = 0x811c9dc5;\n\tfor (let i = 0; i < length; i++) {\n\t\thash ^= codeAt(i);\n\t\thash = (hash + ((hash << 1) + (hash << 4) + (hash << 7) + (hash << 8) + (hash << 24))) >>> 0;\n\t}\n\treturn hash.toString(16).padStart(8, '0');\n}\n\n/**\n * 32-bit FNV-1a— fast, no dependencies. Returns unsigned hex string.\n */\nexport function fnv1a(input: string): string {\n\treturn fnv1aCore(input.length, (i) => input.charCodeAt(i));\n}\n\n/**\n * 32-bit FNV-1a over raw bytes. Returns unsigned hex string.\n */\nexport function fnv1aBytes(bytes: Uint8Array): string {\n\treturn fnv1aCore(bytes.length, (i) => bytes[i]);\n}\n\n/**\n * Hash definition and data tree into a stable cache key.\n *\n * The definition is the *identity* of what we solve, so a binary definition is\n * hashed over its full content (`fnv1aBytes`) — a length-only or sampled key\n * would let two different `.gh` files collide and serve one's cached solve for\n * the other. `.gh` files are small enough that a single linear pass is\n * negligible. (Note this differs from `stableStringify`'s sampled handling of a\n * `Uint8Array` found *inside* the dataTree, where sampling is a deliberate\n * per-solve perf tradeoff.)\n */\nexport function hashSolveInput(definition: string | Uint8Array, dataTree: unknown): string {\n\treturn fnv1a(`${hashDefinition(definition)}|${stableStringify(dataTree)}`);\n}\n\n/**\n * Stable identity of a definition alone (no inputs) — used to key the\n * server-cache-key map so the same definition reuses its `pointer` across solves\n * with different inputs. Same full-content hashing as {@link hashSolveInput}: a\n * binary definition is hashed over all its bytes so two distinct `.gh` files of\n * equal length can't share a cache key.\n */\nexport function hashDefinition(definition: string | Uint8Array): string {\n\treturn typeof definition === 'string'\n\t\t? definition\n\t\t: `u8:${definition.length}:${fnv1aBytes(definition)}`;\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{b as p,c as d,d as c,e as m,h as v,i as _,j as q,m as J,n as H,p as Y,r as A}from"./chunk-GTTKNF4G.js";function b(r,e){e||typeof window<"u"&&m().warn(`Warning: ${r} is running on the client side. For better performance and security, consider running this on the server side.`)}var Te="Unable to load grasshopper definition";function Ce(r){return r instanceof c&&r.message.includes(Te)}async function x(r,e,t){t.debug&&b("solveGrasshopperDefinition",t.suppressBrowserWarning??t.suppressClientSideWarning);let{response:n}=await N(D(e,r),t);return n}async function Q(r,e,t){return t.debug&&b("solveGrasshopperDefinitionWithCacheKey",t.suppressBrowserWarning??t.suppressClientSideWarning),N(D(e,r),t)}async function X(r,e,t,n){n.debug&&b("solveByCacheKey",n.suppressBrowserWarning??n.suppressClientSideWarning);let s={algo:null,pointer:e,values:r};try{return{...await N(s,n),missed:!1}}catch(o){if(!Ce(o))throw o;return{...await N(D(t,r),n),missed:!0}}}async function N(r,e){Ie(r,e);let t=await v("grasshopper",r,e);if("pointer"in t){let{pointer:n,...s}=t;return{response:s,cacheKey:typeof n=="string"?n:null}}return{response:t,cacheKey:null}}function D(r,e){let t={algo:null,pointer:null,values:e};return r instanceof Uint8Array?t.algo=Y(r):/^https?:\/\//i.test(r)?t.pointer=r:H(r)?t.algo=r:t.algo=J(r),t}function Ie(r,e){e.cachesolve!=null&&(r.cachesolve=e.cachesolve),e.modelunits!=null&&(r.modelunits=e.modelunits),e.angletolerance!=null&&(r.angletolerance=e.angletolerance),e.absolutetolerance!=null&&(r.absolutetolerance=e.absolutetolerance),e.dataversion!=null&&(r.dataversion=e.dataversion)}function Z(r){let e=new WeakSet,t=n=>{if(n==null)return JSON.stringify(n);if(typeof n=="number")return Number.isFinite(n)?String(n):JSON.stringify(null);if(typeof n=="string"||typeof n=="boolean")return JSON.stringify(n);if(typeof n=="bigint")return JSON.stringify(n.toString());if(n instanceof Uint8Array){let s=n.length>64?Array.from(n.slice(0,32)).concat(Array.from(n.slice(-32))):Array.from(n);return JSON.stringify({__u8:!0,len:n.length,sample:s})}return Array.isArray(n)?`[${n.map(t).join(",")}]`:typeof n=="object"?e.has(n)?JSON.stringify("[Circular]"):(e.add(n),`{${Object.keys(n).sort().map(a=>`${JSON.stringify(a)}:${t(n[a])}`).join(",")}}`):JSON.stringify(null)};return t(r)}function ee(r,e){let t=2166136261;for(let n=0;n<r;n++)t^=e(n),t=t+((t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24))>>>0;return t.toString(16).padStart(8,"0")}function re(r){return ee(r.length,e=>r.charCodeAt(e))}function te(r){return ee(r.length,e=>r[e])}function O(r,e){return re(`${G(r)}|${Z(e)}`)}function G(r){return typeof r=="string"?r:`u8:${r.length}:${te(r)}`}function Se(r){return r instanceof Uint8Array?!0:!/^https?:\/\//i.test(r)}var T=class{constructor(e,t,n={},s){p(this,"executor");p(this,"baseConfig");p(this,"mode");p(this,"maxConcurrent");p(this,"timeoutMs");p(this,"retry");p(this,"cacheEnabled");p(this,"cacheMax");p(this,"cacheTtl");p(this,"cache",new Map);p(this,"cacheKeyExecutor");p(this,"reuseServerDefinitionCache");p(this,"serverCacheKeys",new Map);p(this,"onStart");p(this,"onSettle");p(this,"onSuperseded");p(this,"subscribers",new Set);p(this,"inFlight",new Set);p(this,"pendingForLatestWins",null);p(this,"fifoQueue",[]);p(this,"_lastResult",null);p(this,"_lastError",null);p(this,"_lastDurationMs",null);p(this,"disposed",!1);this.executor=e,this.cacheKeyExecutor=s,this.baseConfig=t,this.mode=n.mode??"latest-wins",this.maxConcurrent=Math.max(1,n.maxConcurrent??(this.mode==="parallel"?4:1)),this.timeoutMs=n.timeoutMs,this.retry=n.retry;let o=n.cache;this.cacheEnabled=o!==void 0&&o!==!1;let a=typeof o=="object"?o:{};this.cacheMax=a.maxEntries??50,this.cacheTtl=a.ttlMs??0,this.reuseServerDefinitionCache=!!s&&(n.reuseServerDefinitionCache??!0),this.onStart=n.onStart,this.onSettle=n.onSettle,this.onSuperseded=n.onSuperseded}get isSolving(){return this.inFlight.size>0}get hasPending(){return this.pendingForLatestWins!==null||this.fifoQueue.length>0}get inFlightCount(){return this.inFlight.size}get queueDepth(){return this.fifoQueue.length+(this.pendingForLatestWins?1:0)}get lastResult(){return this._lastResult}get lastError(){return this._lastError}get lastDurationMs(){return this._lastDurationMs}subscribe(e){return this.subscribers.add(e),()=>this.subscribers.delete(e)}notify(){for(let e of this.subscribers)try{e()}catch(t){m().error("[SolveScheduler] subscriber threw:",t)}}solve(e,t,n){if(this.disposed)return Promise.reject(new c("SolveScheduler has been disposed and cannot be used",d.INVALID_STATE));let s=O(e,t),o={key:s,enqueuedAt:Date.now(),startedAt:null};if(this.cacheEnabled){let a=this.readCache(s);if(a){let i={status:"success",response:a,durationMs:0,fromCache:!0};return this._lastResult=a,this._lastError=null,this._lastDurationMs=0,this.runHook(this.onStart,o),this.runHook(this.onSettle,o,i),this.notify(),Promise.resolve(a)}}return new Promise((a,i)=>{let u={definition:e,dataTree:t,ctx:o,resolve:a,reject:i,externalSignal:n?.signal};if(u.externalSignal?.aborted){this.settleError(u,this.makeAbortError(o));return}this.enqueue(u)})}enqueue(e){switch(this.mode){case"latest-wins":{this.pendingForLatestWins&&(this.supersede(this.pendingForLatestWins),this.pendingForLatestWins=null);for(let t of this.inFlight)this.supersede(t),t.controller.abort();this.inFlight.size===0?this.execute(e):this.pendingForLatestWins=e;break}case"queue":case"parallel":{this.inFlight.size<this.maxConcurrent?this.execute(e):this.fifoQueue.push(e);break}}this.notify()}async execute(e){let t=new AbortController,n={...e,controller:t};this.inFlight.add(n),e.ctx.startedAt=Date.now();let s=()=>t.abort();e.externalSignal?.addEventListener("abort",s,{once:!0}),this.runHook(this.onStart,e.ctx),this.notify();let o=performance.now();try{let a={...this.baseConfig,signal:t.signal,...this.timeoutMs!==void 0&&{timeoutMs:this.timeoutMs},...this.retry!==void 0&&{retry:this.retry}},i=await this.runExecutor(e.definition,e.dataTree,a),u=performance.now()-o;if(this.cacheEnabled&&this.writeCache(e.ctx.key,i),!this.settleSuccess(e,i))return;this._lastResult=i,this._lastError=null,this._lastDurationMs=u,this.runHook(this.onSettle,e.ctx,{status:"success",response:i,durationMs:u,fromCache:!1})}catch(a){let i=performance.now()-o,u=this.normalizeExecutionError(a,n);this._lastError=u,this._lastDurationMs=i,this.settleError(e,u)&&this.runHook(this.onSettle,e.ctx,{status:"error",error:u,durationMs:i})}finally{e.externalSignal?.removeEventListener("abort",s),this.inFlight.delete(n),this.drainNext(),this.notify()}}async runExecutor(e,t,n){if(!this.cacheKeyExecutor||!this.reuseServerDefinitionCache||!Se(e))return this.executor(e,t,n);let s=G(e),o=this.serverCacheKeys.get(s)??null,a=await this.cacheKeyExecutor(e,t,o,n);return a.cacheKey?this.serverCacheKeys.set(s,a.cacheKey):this.serverCacheKeys.delete(s),a.response}drainNext(){if(!this.disposed){if(this.mode==="latest-wins"){if(this.pendingForLatestWins&&this.inFlight.size===0){let e=this.pendingForLatestWins;this.pendingForLatestWins=null,this.execute(e)}return}for(;this.fifoQueue.length>0&&this.inFlight.size<this.maxConcurrent;){let e=this.fifoQueue.shift();this.execute(e)}}}supersede(e){let t=new c("Superseded by newer solve",d.SUPERSEDED,{context:{key:e.ctx.key,enqueuedAt:e.ctx.enqueuedAt}});this.settleError(e,t)&&this.runHook(this.onSuperseded,e.ctx)}makeAbortError(e){return new c("Request aborted by caller",d.ABORTED,{context:{key:e.key,enqueuedAt:e.enqueuedAt}})}settleError(e,t){return e.settled?!1:(e.settled={error:t},e.reject(t),!0)}settleSuccess(e,t){return e.settled?!1:(e.settled={ok:!0},e.resolve(t),!0)}isAbortLikeError(e){if(e instanceof Error){if(e.name==="AbortError")return!0;if(typeof DOMException<"u"&&e instanceof DOMException)return e.name==="AbortError"}return!1}normalizeExecutionError(e,t){return t.settled&&"error"in t.settled?t.settled.error:e instanceof c?e:this.isAbortLikeError(e)?this.makeAbortError(t.ctx):new c(e instanceof Error?e.message:String(e),d.UNKNOWN_ERROR,{originalError:e instanceof Error?e:new Error(String(e))})}cancelAll(){for(this.pendingForLatestWins&&(this.rejectAsAborted(this.pendingForLatestWins),this.pendingForLatestWins=null);this.fifoQueue.length>0;){let e=this.fifoQueue.shift();this.rejectAsAborted(e)}for(let e of this.inFlight){let t=this.makeAbortError(e.ctx);this.settleError(e,t)&&this.runHook(this.onSettle,e.ctx,{status:"error",error:t,durationMs:e.ctx.startedAt?performance.now()-e.ctx.startedAt:0}),e.controller.abort()}this.notify()}rejectAsAborted(e){this.settleError(e,this.makeAbortError(e.ctx))}readCache(e){if(!this.cacheEnabled)return null;let t=this.cache.get(e);return t?this.cacheTtl>0&&Date.now()-t.insertedAt>this.cacheTtl?(this.cache.delete(e),null):(this.cache.delete(e),this.cache.set(e,t),t.response):null}writeCache(e,t){if(this.cacheEnabled)for(this.cache.set(e,{response:t,insertedAt:Date.now()});this.cache.size>this.cacheMax;){let n=this.cache.keys().next().value;if(n===void 0)break;this.cache.delete(n)}}clearCache(){this.cache.clear()}dispose(){this.disposed||(this.disposed=!0,this.cancelAll(),this.subscribers.clear(),this.cache.clear())}runHook(e,...t){if(e)try{e(...t)}catch(n){m().error("[SolveScheduler] hook threw:",n)}}};var P=class r{constructor(e){p(this,"config");p(this,"serverStats");p(this,"disposed",!1);this.config=this.normalizeComputeConfig(e),this.serverStats=new q(this.config.serverUrl,this.config.apiKey)}static async create(e){let t=new r(e);if(!await t.serverStats.isServerOnline())throw new c("Rhino Compute server is not online",d.NETWORK_ERROR,{context:{serverUrl:t.config.serverUrl}});return t}getConfig(){return this.ensureNotDisposed(),{...this.config}}async getIO(e){return this.ensureNotDisposed(),F(e,this.config)}async getRawIO(e){return this.ensureNotDisposed(),w(e,this.config)}async solve(e,t,n){this.ensureNotDisposed();try{if(typeof e=="string"&&!e?.trim())throw new c("Definition URL/content is required",d.INVALID_INPUT,{context:{receivedUrl:e}});if(e instanceof Uint8Array&&e.length===0)throw new c("Definition content is empty",d.INVALID_INPUT);let s={...this.config,...n?.signal!==void 0&&{signal:n.signal},...n?.timeoutMs!==void 0&&{timeoutMs:n.timeoutMs},...n?.retry!==void 0&&{retry:n.retry}},o=await x(t,e,s);if(o?.errors&&o.errors.length>0)throw new c(o.errors.join("; ")||"Computation failed",d.COMPUTATION_ERROR,{context:{definition:typeof e=="string"&&e.length<200?e:"...content...",inputs:t,errors:o.errors,warnings:o.warnings}});return o}catch(s){throw this.config.debug&&m().error("Compute failed:",s),s instanceof c?s:new c(s instanceof Error?s.message:String(s),d.COMPUTATION_ERROR,{context:{definition:typeof e=="string"&&e.length<200?e:"...content...",inputs:t},originalError:s instanceof Error?s:new Error(String(s))})}}createScheduler(e){this.ensureNotDisposed();let t=(s,o,a)=>x(o,s,a),n=(s,o,a,i)=>a===null?Q(o,s,i).then(u=>({...u,missed:!1})):X(o,a,s,i);return new T(t,this.config,e,n)}async dispose(){this.disposed||(this.disposed=!0,await this.serverStats.dispose())}ensureNotDisposed(){if(this.disposed)throw new c("GrasshopperClient has been disposed and cannot be used",d.INVALID_STATE)}normalizeComputeConfig(e){return{...e,serverUrl:_(e.serverUrl),apiKey:e.apiKey,authToken:e.authToken,debug:e.debug??!1,suppressBrowserWarning:e.suppressBrowserWarning??e.suppressClientSideWarning}}};var V=new Map;function ne(r,e){V.set(r,e)}ne("Rhino.Geometry.Point3d",(r,e)=>{let t=e;return!t||typeof t.X!="number"?null:new r.Point([t.X,t.Y,t.Z])});ne("Rhino.Geometry.Line",(r,e)=>{let t=e;return!t||!t.From||!t.To?null:new r.Line([t.From.X,t.From.Y,t.From.Z],[t.To.X,t.To.Y,t.To.Z])});function xe(r){if(V.has(r))return V.get(r);for(let[e,t]of V)if(r.startsWith(e))return t}function De(r){return!r||typeof r!="object"?null:r.data??r.value??null}function se(r,e,t){let n=xe(e);if(n)try{return n(t,r)}catch(s){m().warn(`Failed to decode Rhino type ${e}:`,s)}try{let s=De(r);if(s)return t.CommonObject.decode(s)}catch(s){return m().warn(`Failed to decode ${e} with CommonObject:`,s),{__decodeError:!0,type:e,raw:r}}return r}var C={STRING:"System.String",INT:"System.Int32",DOUBLE:"System.Double",BOOL:"System.Boolean"},Pe="Rhino.Geometry.",we=["WebDisplay"],Re="FileData";function oe(r){return we.some(e=>r.includes(e))}function ae(r){if(typeof r!="string")return r;let e=r.trim();if(!(e.startsWith("{")||e.startsWith("[")||e.startsWith('"')))return r;try{let n=JSON.parse(e);if(typeof n=="string")try{return JSON.parse(n)}catch{return n}return n}catch{return r}}function Ee(r,e,t){switch(e){case C.STRING:return typeof r!="string"?r:r.replace(/^"(.*)"$/,"$1");case C.INT:return Number.parseInt(r,10);case C.DOUBLE:return Number.parseFloat(r);case C.BOOL:return String(r).toLowerCase()==="true";default:return t&&e.startsWith(Pe)?se(r,e,t):r}}function ie(r,e,t,n){if(typeof r!="string")return r;let s=t?ae(r):r;return Ee(s,e,n)}function ve(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.fileName=="string"&&typeof e.fileType=="string"&&"data"in e&&typeof e.isBase64Encoded=="boolean"&&typeof e.subFolder=="string"}function k(r,e){for(let t of Object.values(r))if(Array.isArray(t))for(let n of t)e(n)}function ue(r,e=!1,t={}){let{parseValues:n=!0,rhino:s,stringOnly:o=!1}=t,a={};for(let i of r.values)k(i.InnerTree,u=>{if(oe(u.type)||o&&u.type!==C.STRING)return;let l=e?u.id:i.ParamName;if(!l)return;let f=ie(u.data,u.type,n,s);a[l]===void 0?a[l]=f:Array.isArray(a[l])?a[l].push(f):a[l]=[a[l],f]});return{values:a}}function pe(r){let e=[];for(let t of r.values)k(t.InnerTree,n=>{if(!n.type.includes(Re))return;let s=ae(n.data);ve(s)&&e.push(s)});return e}function M(r,e,t={}){let{parseValues:n=!0,rhino:s,stringOnly:o=!1}=t,a;if("byName"in e?a=r.values.find(u=>u.ParamName===e.byName):a=r.values.find(u=>{let l=!1;return k(u.InnerTree,f=>{f.id===e.byId&&(l=!0)}),l}),!a)return;let i=[];if(k(a.InnerTree,u=>{if("byId"in e&&u.id!==e.byId||oe(u.type)||o&&u.type!==C.STRING)return;let l=ie(u.data,u.type,n,s);i.push(l)}),i.length!==0)return i.length===1?i[0]:i}var R=class{constructor(e,t=!1){this.response=e;this.debug=t}getValues(e=!1,t={}){return ue(this.response,e,t)}getValue(e,t){return M(this.response,e,t)}getValueByParamName(e,t){return M(this.response,{byName:e},t)}getValueByParamId(e,t){return M(this.response,{byId:e},t)}async extractMeshesFromResponse(e){let t={debug:this.debug,...e},n;try{({getThreeMeshesFromComputeResponse:n}=await import("./visualization-WIUVT2FZ.js"))}catch(s){throw new c("Failed to load three.js visualization module. Ensure three.js is installed as a peer dependency.",d.INVALID_STATE,{context:{originalError:s instanceof Error?s.message:String(s)}})}return n(this.response,t)}getFileData(){return pe(this.response)}getAndDownloadFiles(e,t){let n=this.getFileData();A(n,e,t)}};function L(r,e){if(!r||typeof r!="object")return;let t=r;if(e in t)return t[e];let n=e.toLowerCase();for(let s of Object.keys(t))if(s.toLowerCase()===n)return t[s]}function j(r,e){if(!r||typeof r!="object")return!1;let t=r;if(e in t)return!0;let n=e.toLowerCase();return Object.keys(t).some(s=>s.toLowerCase()===n)}function le(r){return L(r,"data")}function Ae(r){return L(r,"type")}function ce(r){if(typeof r.default!="object"||r.default===null)return{schema:r};if(!j(r.default,"innerTree")){let n=`Input "${r.name??"unknown"}" default had an unrecognized shape (no innerTree key); the default was dropped.`;return m().warn("Unexpected structure in input.default:",r.default),{schema:{...r,default:null},warning:{code:"MALFORMED_DEFAULT",message:n}}}let e=L(r.default,"innerTree")??{};if(Object.keys(e).length===0)return{schema:{...r,default:void 0}};if(r.treeAccess||r.atMost&&r.atMost>1){let n={};for(let[s,o]of Object.entries(e))n[s]=o.map(a=>{let i=le(a),u=Ae(a);if(typeof i=="string"){if(u==="System.Double"||u==="System.Int32"){let l=Number(i);return Number.isNaN(l)?i:l}if(u==="System.Boolean")return i.toLowerCase()==="true";if(u?.startsWith("Rhino.Geometry")||u==="System.String")try{return JSON.parse(i)}catch{return i}}return i});return{schema:{...r,default:n}}}let t=[];for(let n of Object.values(e))Array.isArray(n)&&n.forEach(s=>{s&&typeof s=="object"&&j(s,"data")&&t.push(le(s))});return t.length===0?{schema:{...r,default:void 0}}:t.length===1?{schema:{...r,default:t[0]}}:{schema:{...r,default:t}}}var U=/^\{([\d;]*)\}$/;function E(r){if(typeof r!="object"||r===null||Array.isArray(r))return!1;let e=Object.entries(r);return e.length>0&&e.every(([t,n])=>U.test(t)&&Array.isArray(n))}function I(r,e,t){if(r==null)return r;if(Array.isArray(r)){let s=r.map(e).filter(o=>o!==null);return s.length>0?s:void 0}let n=e(r);return n!==null?n:t?void 0:r}var Ne=r=>{if(typeof r=="number")return r;if(typeof r=="string"){let e=Number(r.trim());return Number.isNaN(e)?null:e}return null},Oe=r=>{if(typeof r=="boolean")return r;if(typeof r=="string"){let e=r.toLowerCase();if(e==="true")return!0;if(e==="false")return!1;throw new Error(`Invalid boolean string: "${r}"`)}return null},Ge=r=>typeof r=="string"?r.startsWith('"')&&r.endsWith('"')||r.startsWith('"')?r.slice(1,-1):r:null,Fe=r=>{if(typeof r=="string"){let e=r.trim();return e.startsWith('"')&&e.endsWith('"')&&(e=e.slice(1,-1).trim()),e}return null};function me(r){return e=>{if(typeof e=="object"&&e!==null)return e;if(typeof e=="string"&&e.trim()!=="")try{let t=JSON.parse(e);return typeof t=="object"&&t!==null?t:(m().warn(`Parsed value for input ${r} is not an object`),null)}catch(t){return m().warn(`Failed to parse object value "${e}" for input ${r}`,t),null}return null}}function fe(r,e,t){let n=Number(r.toFixed(e));return Math.abs(r-n)<t?n:r}function Ve(r,e){if(!Number.isFinite(r)||r===0)return .1;let t=Math.abs(r);if(t>=1){let h=String(r).split(".")[1];if(h&&h.length>0){let y=Math.min(h.length,12),g=Math.pow(10,-y),$=Number(g.toFixed(y));return Math.abs($-g)<e?$:g}return 1}let n=String(r),s=n.toLowerCase().match(/e(-?\d+)/);if(s){let S=Number(s[1]);if(S<0||n.toLowerCase().includes("e-")){let h=Math.abs(S),y=Math.pow(10,-h),g=Number(y.toFixed(h));return Math.abs(g-y)<e?g:y}return .1}let o=12,i=t.toFixed(o).replace(/0+$/,""),u=Math.min((i.split(".")[1]||"").length,o);if(u===0)return .1;let l=Math.pow(10,-u),f=Number(l.toFixed(u));return Math.abs(f-l)<e?f:l}function ke(r,e=1e-8){let t=r.paramType==="Integer";if(E(r.default))return{default:r.default,stepSize:t?1:.1};let n=I(r.default,Ne,!0);if(t)return Array.isArray(n)?n=n.map(f=>typeof f=="number"?Math.round(f):f):typeof n=="number"&&(n=Math.round(n)),{default:n,stepSize:1};let s=Array.isArray(n)?n[0]:n,o;typeof s=="number"&&Number.isFinite(s)&&s!==0?o=s:typeof r.minimum=="number"&&Number.isFinite(r.minimum)&&r.minimum!==0?o=r.minimum:typeof r.maximum=="number"&&Number.isFinite(r.maximum)&&r.maximum!==0&&(o=r.maximum);let a=o!==void 0?Ve(o,e):.1,i=0,u=String(a),l=u.toLowerCase().match(/e(-?\d+)/);if(l?i=Math.abs(Number(l[1])):i=u.split(".")[1]?.length??0,i===0&&typeof s=="number"&&s!==0&&Math.abs(s)<1){let f=Math.ceil(-Math.log10(Math.abs(s)));Number.isFinite(f)&&f>0&&(i=f)}return i=Math.min(Math.max(i,0),12),Array.isArray(n)?n=n.map(f=>typeof f=="number"?fe(f,i,e):f):typeof n=="number"&&(n=fe(n,i,e)),{default:n,stepSize:a}}var Me={types:["Number","Integer"],parse(r,e){let{default:t,stepSize:n}=ke(r);return{...e,paramType:r.paramType,minimum:r.minimum,maximum:r.maximum,atLeast:r.atLeast,atMost:r.atMost,stepSize:n,default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:r.paramType,minimum:r.minimum,maximum:r.maximum,atLeast:r.atLeast,atMost:r.atMost,default:t?[0]:0}}},Le={types:["Boolean"],parse(r,e){let t;try{t=I(r.default,Oe,!1)}catch(n){throw n instanceof Error?new c(n.message):n}return{...e,paramType:"Boolean",default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"Boolean",default:t?[!1]:!1}}},We={types:["Text"],parse(r,e){let t=I(r.default,Ge,!1);return{...e,paramType:"Text",default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"Text",default:t?[""]:""}}},Be={types:["ValueList"],parse(r,e){if(!r.values||typeof r.values!="object"||Object.keys(r.values).length===0)throw c.missingValues(r.nickname||"unnamed","ValueList");if(r.default!==void 0&&r.default!==null){let t=String(r.default).toLowerCase();Object.keys(r.values).some(s=>s.toLowerCase()===t)||m().warn(`ValueList input "${r.nickname||"unnamed"}" default value "${r.default}" is not in available values`)}return{...e,paramType:"ValueList",values:r.values,default:r.default}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"ValueList",values:r.values??{},default:t?[r.default]:r.default}}},de={types:["Geometry"],parse(r,e){let t=I(r.default,me(r.nickname||"unnamed"),!0);return{...e,paramType:"Geometry",default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"Geometry",default:t?[null]:null}}},je={types:["File"],parse(r,e){let t=I(r.default,me(r.nickname||"unnamed"),!0);return{...e,paramType:"File",acceptedFormats:r.acceptedFormats,default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"File",default:t?[null]:null}}},Ue={types:["Color"],parse(r,e){let t=I(r.default,Fe,!1);return{...e,paramType:"Color",default:t}},fallback(r,e){let t=(r.atMost??1)>1;return{...e,paramType:"Color",default:t?["0, 0, 0"]:"0, 0, 0"}}},Ke=[Me,Le,We,Be,de,je,Ue],K=new Map(Ke.flatMap(r=>r.types.map(e=>[e,r]))),he=de;var ze=new Map([...K.keys()].map(r=>[r.toLowerCase(),r]));function $e(r){return ze.get(r?.toLowerCase())??r}function ye(r){return z(r).input}function z(r){let e={description:r.description,name:r.name,nickname:r.nickname,treeAccess:r.treeAccess,groupName:r.groupName??"",id:r.id},t=$e(r.paramType),{schema:n,warning:s}=ce({...r,paramType:t}),o=s&&{inputName:r.name||"unknown",paramType:t,message:s.message,code:s.code},a=K.get(t);try{if(!a)throw c.unknownParamType(t,r.name);return{input:a.parse(n,e),error:o}}catch(i){if(i instanceof c)return m().error(`Validation error for input ${r.name||"unknown"}:`,i.message),{input:(a??he).fallback(n,e),error:{inputName:r.name||"unknown",paramType:t,message:i.message,code:i.code}};throw new c(i instanceof Error?i.message:String(i),"VALIDATION_ERROR",{context:{paramName:r.name,paramType:t},originalError:i instanceof Error?i:new Error(String(i))})}}function ge(r){return W(r).inputs}function W(r){let e=[],t=[];for(let n of r){let{input:s,error:o}=z(n);e.push(s),o&&t.push(o)}return{inputs:e,parseErrors:t}}async function w(r,e){let t=D(r,[]),n={};if(t.algo&&(n.algo=t.algo),t.pointer&&(n.pointer=t.pointer),!n.algo&&!n.pointer)throw new c("Definition must resolve to either a URL pointer or base64 algo",d.INVALID_INPUT,{context:{definition:r}});let s=await v("io",n,e);if(!s||typeof s!="object")throw new c("Invalid IO response structure",d.INVALID_INPUT,{context:{response:s,definition:r}});let o=be(s.warnings),a=be(s.errors);return{inputs:s.inputs,outputs:s.outputs,...o&&{loadWarnings:o},...a&&{loadErrors:a}}}function be(r){if(!Array.isArray(r))return;let e=r.filter(t=>typeof t=="string"&&t.trim().length>0);return e.length>0?e:void 0}async function F(r,e){b("fetchParsedDefinitionIO",e.suppressBrowserWarning??e.suppressClientSideWarning);let{inputs:t,outputs:n,loadWarnings:s,loadErrors:o}=await w(r,e),{inputs:a,parseErrors:i}=W(t);return{inputs:a,outputs:n,...i.length>0&&{parseErrors:i},...s&&{loadWarnings:s},...o&&{loadErrors:o}}}var B=class r{constructor(e){p(this,"innerTree");p(this,"paramName");this.paramName=e,this.innerTree={}}append(e,t){let n=r.formatPathString(e);this.innerTree[n]||(this.innerTree[n]=[]);let s=t.map(o=>({data:r.serializeValue(o)}));return this.innerTree[n].push(...s),this}appendSingle(e,t){return this.append(e,[t])}fromDataTreeDefault(e){this.innerTree={};for(let[t,n]of Object.entries(e)){if(!Array.isArray(n))continue;let s=r.parsePathString(t);this.append(s,n)}return this}appendFlat(e){let t=Array.isArray(e)?e:[e];return this.append([0],t)}flatten(){let e=[];for(let t of Object.values(this.innerTree))if(Array.isArray(t))for(let n of t)e.push(r.deserializeValue(n.data));return e}getPaths(){return Object.keys(this.innerTree)}getPath(e){let t=r.formatPathString(e),n=this.innerTree[t];if(n)return n.map(s=>r.deserializeValue(s.data))}toComputeFormat(){return{ParamName:this.paramName,InnerTree:this.innerTree}}getInnerTree(){return this.innerTree}getParamName(){return this.paramName}static fromInputParams(e){return e.filter(t=>r.hasValidValue(t.default)).map(t=>{let n=new r(t.nickname||"unnamed"),s=t.default;if(t.treeAccess&&E(s))n.fromDataTreeDefault(s),r.isNumericInput(t)&&n.applyNumericConstraints(t.minimum,t.maximum,t.nickname||"unnamed");else{let o=Array.isArray(s)?s:[s],a=r.processValues(o,t);n.appendFlat(a)}return n.toComputeFormat()})}static fromInputParam(e){return r.hasValidValue(e.default)?r.fromInputParams([e])[0]:void 0}static replaceTreeValue(e,t,n){let s=e.length>0&&e[0]instanceof r,o=r.buildFromValue(t,n);if(s){let l=e,f=l.findIndex(S=>S.getParamName()===t);return f!==-1?l[f]=o:l.push(o),l}let a=e,i=o.toComputeFormat(),u=a.findIndex(l=>l.ParamName===t);return u!==-1?a[u]=i:a.push(i),a}static buildFromValue(e,t){let n=new r(e);return E(t)?n.fromDataTreeDefault(t):n.appendFlat(t),n}static getTreeValue(e,t){let s=e.length>0&&e[0]instanceof r?r.readFromBuilders(e,t):r.readFromDataTrees(e,t);return s===null||s.length===0?null:s.length===1?s[0]:s}static readFromBuilders(e,t){let n=e.find(s=>s.getParamName()===t);return n?n.flatten():null}static readFromDataTrees(e,t){let n=e.find(a=>a.ParamName===t);if(!n?.InnerTree)return null;let s=Object.keys(n.InnerTree)[0];if(!s)return null;let o=n.InnerTree[s];return Array.isArray(o)?o.map(a=>a?.data!==void 0?r.deserializeValue(a.data):null).filter(a=>a!==null):o?.data!==void 0?[r.deserializeValue(o.data)]:o!==void 0?[o]:null}static parsePathString(e){let t=e.match(U);return t?t[1]===""?[]:t[1].split(";").map(Number):(m().warn(`Invalid TreeBuilder path format: ${e}, using [0]`),[0])}static formatPathString(e){return`{${e.join(";")}}`}applyNumericConstraints(e,t,n){for(let s of Object.values(this.innerTree))if(Array.isArray(s))for(let o of s){let a=r.deserializeValue(o.data);if(typeof a=="number"){let i=r.clampValue(a,e,t,n);o.data=r.serializeValue(i)}}}static serializeValue(e){return typeof e=="boolean"||typeof e=="number"||typeof e=="string"?e:typeof e=="object"&&e!==null?JSON.stringify(e):String(e)}static deserializeValue(e){if(typeof e=="boolean"||typeof e=="number"||typeof e!="string")return e;if(e.startsWith("{")||e.startsWith("["))try{return JSON.parse(e)}catch{return e}return isNaN(Number(e))?e==="true"?!0:e==="false"?!1:e:Number(e)}static hasValidValue(e){return e==null?!1:typeof e=="string"?!0:!(Array.isArray(e)&&e.length===0||typeof e=="object"&&!Array.isArray(e)&&Object.keys(e).length===0)}static isNumericInput(e){return e.paramType==="Number"||e.paramType==="Integer"}static processValues(e,t){return e.map(n=>r.isNumericInput(t)&&typeof n=="number"?r.clampValue(n,t.minimum,t.maximum,t.nickname||"unnamed"):n).filter(n=>n!=null)}static clampValue(e,t,n,s){let o=e;return t!=null&&o<t&&(m().warn(`${s}: ${e} below min ${t}, clamping`),o=t),n!=null&&o>n&&(m().warn(`${s}: ${e} above max ${n}, clamping`),o=n),o}};export{x as a,O as b,T as c,P as d,R as e,ye as f,ge as g,w as h,F as i,B as j};
|
|
2
|
+
//# sourceMappingURL=chunk-DELOBV2Q.js.map
|