@stlite/desktop 0.51.1 → 0.51.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/bin/dump_artifacts.js +6 -6
- package/build/asset-manifest.json +3 -3
- package/build/electron/main.js +2 -2
- package/build/electron/preload.js +1 -1
- package/build/electron/worker.js +12 -12
- package/build/index.html +1 -1
- package/build/static/js/4681.91a881a3.chunk.js +1 -0
- package/build/static/js/main.5d08bd7f.js +28 -0
- package/package.json +5 -13
- package/wheels/streamlit-1.32.2-cp311-none-any.whl +0 -0
- package/build/static/js/4681.fc821bbf.chunk.js +0 -1
- package/build/static/js/main.b686df03.js +0 -28
- /package/build/static/js/{main.b686df03.js.LICENSE.txt → main.5d08bd7f.js.LICENSE.txt} +0 -0
package/README.md
CHANGED
|
@@ -56,7 +56,7 @@ Convert your [Streamlit](https://streamlit.io/) application into a desktop app w
|
|
|
56
56
|
To make your app secure, be sure to use the latest version of Electron.
|
|
57
57
|
This is [announced](https://www.electronjs.org/docs/latest/tutorial/security#16-use-a-current-version-of-electron) as one of the security best practices in the Electron document too.
|
|
58
58
|
|
|
59
|
-
## Configure app
|
|
59
|
+
## Configure the app
|
|
60
60
|
|
|
61
61
|
### Hide the toolbar, hamburger menu, and the footer
|
|
62
62
|
|
|
@@ -125,7 +125,7 @@ In the example below, `"."` on the host OS file system is mounted to the `/mnt`
|
|
|
125
125
|
}
|
|
126
126
|
```
|
|
127
127
|
|
|
128
|
-
|
|
128
|
+
### NodeJS worker mode
|
|
129
129
|
|
|
130
130
|
`@stlite/desktop` runs your app on [Electron](https://www.electronjs.org/) as a desktop app.
|
|
131
131
|
Electron apps have two processes: the main process which is a Node.js process running in the background, and the renderer process which is a Chromium (browser) process running the app's UI.
|
package/bin/dump_artifacts.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var
|
|
3
|
-
`).filter(t=>!t.startsWith("#")).map(t=>t.replace(L,"")).map(t=>t.trim()).filter(t=>t!=="")}h.parseRequirementsTxt=z});var B=m(y=>{"use strict";Object.defineProperty(y,"__esModule",{value:!0});y.PromiseDelegate=void 0;var P=class{constructor(){this.promise=new Promise((t,i)=>{this.resolveInternal=t,this.rejectInternal=i})}resolve(t){this.resolveInternal(t)}reject(t){this.rejectInternal(t)}};y.PromiseDelegate=P});var S=m(c=>{"use strict";var N=c&&c.__createBinding||(Object.create?function(e,t,i,r){r===void 0&&(r=i);var a=Object.getOwnPropertyDescriptor(t,i);(!a||("get"in a?!t.__esModule:a.writable||a.configurable))&&(a={enumerable:!0,get:function(){return t[i]}}),Object.defineProperty(e,r,a)}:function(e,t,i,r){r===void 0&&(r=i),e[r]=t[i]}),v=c&&c.__exportStar||function(e,t){for(var i in e)i!=="default"&&!Object.prototype.hasOwnProperty.call(t,i)&&N(t,e,i)};Object.defineProperty(c,"__esModule",{value:!0});v(q(),c);v(O(),c);v(B(),c)});var F=p(require("yargs")),M=require("yargs/helpers"),o=p(require("path")),n=p(require("fs/promises")),_=p(require("fs-extra")),D=p(require("node-fetch")),b=require("pyodide"),w=p(S());var I=require("pyodide");function k(e){return`https://cdn.jsdelivr.net/pyodide/v${I.version}/full/${e}`}var $=p(require("node-fetch"));var f=class e{static _instance;_data=null;constructor(){}static async loadPyodideBuiltinPackageData(){let t=k("pyodide-lock.json");return console.log(`Load the Pyodide pyodide-lock.json from ${t}`),(await(await(0,$.default)(t,void 0)).json()).packages}static async getInstance(){return this._instance==null&&(this._instance=new e,this._instance._data=await this.loadPyodideBuiltinPackageData()),this._instance}getPackageInfoByName(t){if(this._data==null)throw new Error("The package data is not loaded yet.");let i=Object.values(this._data).find(r=>r.name===t);if(i==null)throw new Error(`Package ${t} is not found in the lock file.`);return i}};global.fetch=D.default;var K="../build",V="../wheels";async function R(e,t){let i=[],r=a=>{i.push(a)};if(await e.loadPackage(t,{errorCallback:r}),i.length>0)throw new Error(i.join(`
|
|
4
|
-
`))}async function
|
|
2
|
+
"use strict";var rt=Object.create;var re=Object.defineProperty;var it=Object.getOwnPropertyDescriptor;var ot=Object.getOwnPropertyNames;var st=Object.getPrototypeOf,at=Object.prototype.hasOwnProperty;var M=(r,o)=>()=>(o||r((o={exports:{}}).exports,o),o.exports);var ct=(r,o,a,c)=>{if(o&&typeof o=="object"||typeof o=="function")for(let f of ot(o))!at.call(r,f)&&f!==a&&re(r,f,{get:()=>o[f],enumerable:!(c=it(o,f))||c.enumerable});return r};var D=(r,o,a)=>(a=r!=null?rt(st(r)):{},ct(o||!r||!r.__esModule?re(a,"default",{value:r,enumerable:!0}):a,r));var ie=M(A=>{"use strict";Object.defineProperty(A,"__esModule",{value:!0});A.verifyRequirements=void 0;function ft(r){r.forEach(o=>{let a;try{a=new URL(o)}catch{return}if(a.protocol==="emfs:"||a.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${o})`)})}A.verifyRequirements=ft});var oe=M(F=>{"use strict";Object.defineProperty(F,"__esModule",{value:!0});F.parseRequirementsTxt=void 0;var ut=/\s#.*$/;function dt(r){return r.split(`
|
|
3
|
+
`).filter(o=>!o.startsWith("#")).map(o=>o.replace(ut,"")).map(o=>o.trim()).filter(o=>o!=="")}F.parseRequirementsTxt=dt});var se=M(z=>{"use strict";Object.defineProperty(z,"__esModule",{value:!0});z.PromiseDelegate=void 0;var U=class{constructor(){this.promise=new Promise((o,a)=>{this.resolveInternal=o,this.rejectInternal=a})}resolve(o){this.resolveInternal(o)}reject(o){this.rejectInternal(o)}};z.PromiseDelegate=U});var ae=M(S=>{"use strict";var lt=S&&S.__createBinding||(Object.create?function(r,o,a,c){c===void 0&&(c=a);var f=Object.getOwnPropertyDescriptor(o,a);(!f||("get"in f?!o.__esModule:f.writable||f.configurable))&&(f={enumerable:!0,get:function(){return o[a]}}),Object.defineProperty(r,c,f)}:function(r,o,a,c){c===void 0&&(c=a),r[c]=o[a]}),L=S&&S.__exportStar||function(r,o){for(var a in r)a!=="default"&&!Object.prototype.hasOwnProperty.call(o,a)&<(o,r,a)};Object.defineProperty(S,"__esModule",{value:!0});L(ie(),S);L(oe(),S);L(se(),S)});var K=M((B,ue)=>{(function(r,o){typeof B=="object"&&typeof ue<"u"?o(B):typeof define=="function"&&define.amd?define(["exports"],o):(r=typeof globalThis<"u"?globalThis:r||self,o(r.Superstruct={}))})(B,function(r){"use strict";class o extends TypeError{constructor(t,n){let i,{message:s,explanation:u,...l}=t,{path:y}=t,g=y.length===0?s:`At path: ${y.join(".")} -- ${s}`;super(u??g),u!=null&&(this.cause=g),Object.assign(this,l),this.name=this.constructor.name,this.failures=()=>i??(i=[t,...n()])}}function a(e){return c(e)&&typeof e[Symbol.iterator]=="function"}function c(e){return typeof e=="object"&&e!=null}function f(e){if(Object.prototype.toString.call(e)!=="[object Object]")return!1;let t=Object.getPrototypeOf(e);return t===null||t===Object.prototype}function d(e){return typeof e=="symbol"?e.toString():typeof e=="string"?JSON.stringify(e):`${e}`}function $(e){let{done:t,value:n}=e.next();return t?void 0:n}function j(e,t,n,i){if(e===!0)return;e===!1?e={}:typeof e=="string"&&(e={message:e});let{path:s,branch:u}=t,{type:l}=n,{refinement:y,message:g=`Expected a value of type \`${l}\`${y?` with refinement \`${y}\``:""}, but received: \`${d(i)}\``}=e;return{value:i,type:l,refinement:y,key:s[s.length-1],path:s,branch:u,...e,message:g}}function*_(e,t,n,i){a(e)||(e=[e]);for(let s of e){let u=j(s,t,n,i);u&&(yield u)}}function*N(e,t,n={}){let{path:i=[],branch:s=[e],coerce:u=!1,mask:l=!1}=n,y={path:i,branch:s};if(u&&(e=t.coercer(e,y),l&&t.type!=="type"&&c(t.schema)&&c(e)&&!Array.isArray(e)))for(let p in e)t.schema[p]===void 0&&delete e[p];let g="valid";for(let p of t.validator(e,y))p.explanation=n.message,g="not_valid",yield[p,void 0];for(let[p,k,tt]of t.entries(e,y)){let nt=N(k,tt,{path:p===void 0?i:[...i,p],branch:p===void 0?s:[...s,k],coerce:u,mask:l,message:n.message});for(let I of nt)I[0]?(g=I[0].refinement!=null?"not_refined":"not_valid",yield[I[0],void 0]):u&&(k=I[1],p===void 0?e=k:e instanceof Map?e.set(p,k):e instanceof Set?e.add(k):c(e)&&(k!==void 0||p in e)&&(e[p]=k))}if(g!=="not_valid")for(let p of t.refiner(e,y))p.explanation=n.message,g="not_refined",yield[p,void 0];g==="valid"&&(yield[void 0,e])}class m{constructor(t){let{type:n,schema:i,validator:s,refiner:u,coercer:l=g=>g,entries:y=function*(){}}=t;this.type=n,this.schema=i,this.entries=y,this.coercer=l,s?this.validator=(g,p)=>{let k=s(g,p);return _(k,p,this,g)}:this.validator=()=>[],u?this.refiner=(g,p)=>{let k=u(g,p);return _(k,p,this,g)}:this.refiner=()=>[]}assert(t,n){return X(t,this,n)}create(t,n){return Y(t,this,n)}is(t){return W(t,this)}mask(t,n){return Z(t,this,n)}validate(t,n={}){return T(t,this,n)}}function X(e,t,n){let i=T(e,t,{message:n});if(i[0])throw i[0]}function Y(e,t,n){let i=T(e,t,{coerce:!0,message:n});if(i[0])throw i[0];return i[1]}function Z(e,t,n){let i=T(e,t,{coerce:!0,mask:!0,message:n});if(i[0])throw i[0];return i[1]}function W(e,t){return!T(e,t)[0]}function T(e,t,n={}){let i=N(e,t,n),s=$(i);return s[0]?[new o(s[0],function*(){for(let l of i)l[0]&&(yield l[0])}),void 0]:[void 0,s[1]]}function ke(...e){let t=e[0].type==="type",n=e.map(s=>s.schema),i=Object.assign({},...n);return t?E(i):v(i)}function b(e,t){return new m({type:e,schema:null,validator:t})}function Pe(e,t){return new m({...e,refiner:(n,i)=>n===void 0||e.refiner(n,i),validator(n,i){return n===void 0?!0:(t(n,i),e.validator(n,i))}})}function $e(e){return new m({type:"dynamic",schema:null,*entries(t,n){yield*e(t,n).entries(t,n)},validator(t,n){return e(t,n).validator(t,n)},coercer(t,n){return e(t,n).coercer(t,n)},refiner(t,n){return e(t,n).refiner(t,n)}})}function _e(e){let t;return new m({type:"lazy",schema:null,*entries(n,i){t??(t=e()),yield*t.entries(n,i)},validator(n,i){return t??(t=e()),t.validator(n,i)},coercer(n,i){return t??(t=e()),t.coercer(n,i)},refiner(n,i){return t??(t=e()),t.refiner(n,i)}})}function De(e,t){let{schema:n}=e,i={...n};for(let s of t)delete i[s];switch(e.type){case"type":return E(i);default:return v(i)}}function Se(e){let t=e instanceof m,n=t?{...e.schema}:{...e};for(let i in n)n[i]=x(n[i]);return t&&e.type==="type"?E(n):v(n)}function je(e,t){let{schema:n}=e,i={};for(let s of t)i[s]=n[s];switch(e.type){case"type":return E(i);default:return v(i)}}function Oe(e,t){return console.warn("superstruct@0.11 - The `struct` helper has been renamed to `define`."),b(e,t)}function Te(){return b("any",()=>!0)}function ve(e){return new m({type:"array",schema:e,*entries(t){if(e&&Array.isArray(t))for(let[n,i]of t.entries())yield[n,i,e]},coercer(t){return Array.isArray(t)?t.slice():t},validator(t){return Array.isArray(t)||`Expected an array value, but received: ${d(t)}`}})}function Ee(){return b("bigint",e=>typeof e=="bigint")}function Me(){return b("boolean",e=>typeof e=="boolean")}function qe(){return b("date",e=>e instanceof Date&&!isNaN(e.getTime())||`Expected a valid \`Date\` object, but received: ${d(e)}`)}function Ie(e){let t={},n=e.map(i=>d(i)).join();for(let i of e)t[i]=i;return new m({type:"enums",schema:t,validator(i){return e.includes(i)||`Expected one of \`${n}\`, but received: ${d(i)}`}})}function Ae(){return b("func",e=>typeof e=="function"||`Expected a function, but received: ${d(e)}`)}function Fe(e){return b("instance",t=>t instanceof e||`Expected a \`${e.name}\` instance, but received: ${d(t)}`)}function ze(){return b("integer",e=>typeof e=="number"&&!isNaN(e)&&Number.isInteger(e)||`Expected an integer, but received: ${d(e)}`)}function Re(e){return new m({type:"intersection",schema:null,*entries(t,n){for(let i of e)yield*i.entries(t,n)},*validator(t,n){for(let i of e)yield*i.validator(t,n)},*refiner(t,n){for(let i of e)yield*i.refiner(t,n)}})}function Be(e){let t=d(e),n=typeof e;return new m({type:"literal",schema:n==="string"||n==="number"||n==="boolean"?e:null,validator(i){return i===e||`Expected the literal \`${t}\`, but received: ${d(i)}`}})}function Je(e,t){return new m({type:"map",schema:null,*entries(n){if(e&&t&&n instanceof Map)for(let[i,s]of n.entries())yield[i,i,e],yield[i,s,t]},coercer(n){return n instanceof Map?new Map(n):n},validator(n){return n instanceof Map||`Expected a \`Map\` object, but received: ${d(n)}`}})}function C(){return b("never",()=>!1)}function Ne(e){return new m({...e,validator:(t,n)=>t===null||e.validator(t,n),refiner:(t,n)=>t===null||e.refiner(t,n)})}function We(){return b("number",e=>typeof e=="number"&&!isNaN(e)||`Expected a number, but received: ${d(e)}`)}function v(e){let t=e?Object.keys(e):[],n=C();return new m({type:"object",schema:e||null,*entries(i){if(e&&c(i)){let s=new Set(Object.keys(i));for(let u of t)s.delete(u),yield[u,i[u],e[u]];for(let u of s)yield[u,i[u],n]}},validator(i){return c(i)||`Expected an object, but received: ${d(i)}`},coercer(i){return c(i)?{...i}:i}})}function x(e){return new m({...e,validator:(t,n)=>t===void 0||e.validator(t,n),refiner:(t,n)=>t===void 0||e.refiner(t,n)})}function Ce(e,t){return new m({type:"record",schema:null,*entries(n){if(c(n))for(let i in n){let s=n[i];yield[i,i,e],yield[i,s,t]}},validator(n){return c(n)||`Expected an object, but received: ${d(n)}`}})}function He(){return b("regexp",e=>e instanceof RegExp)}function Ue(e){return new m({type:"set",schema:null,*entries(t){if(e&&t instanceof Set)for(let n of t)yield[n,n,e]},coercer(t){return t instanceof Set?new Set(t):t},validator(t){return t instanceof Set||`Expected a \`Set\` object, but received: ${d(t)}`}})}function ee(){return b("string",e=>typeof e=="string"||`Expected a string, but received: ${d(e)}`)}function Le(e){let t=C();return new m({type:"tuple",schema:null,*entries(n){if(Array.isArray(n)){let i=Math.max(e.length,n.length);for(let s=0;s<i;s++)yield[s,n[s],e[s]||t]}},validator(n){return Array.isArray(n)||`Expected an array, but received: ${d(n)}`}})}function E(e){let t=Object.keys(e);return new m({type:"type",schema:e,*entries(n){if(c(n))for(let i of t)yield[i,n[i],e[i]]},validator(n){return c(n)||`Expected an object, but received: ${d(n)}`},coercer(n){return c(n)?{...n}:n}})}function Ke(e){let t=e.map(n=>n.type).join(" | ");return new m({type:"union",schema:null,coercer(n){for(let i of e){let[s,u]=i.validate(n,{coerce:!0});if(!s)return u}return n},validator(n,i){let s=[];for(let u of e){let[...l]=N(n,u,i),[y]=l;if(y[0])for(let[g]of l)g&&s.push(g);else return[]}return[`Expected the value to satisfy a union of \`${t}\`, but received: ${d(n)}`,...s]}})}function te(){return b("unknown",()=>!0)}function H(e,t,n){return new m({...e,coercer:(i,s)=>W(i,t)?e.coercer(n(i,s),s):e.coercer(i,s)})}function Ge(e,t,n={}){return H(e,te(),i=>{let s=typeof t=="function"?t():t;if(i===void 0)return s;if(!n.strict&&f(i)&&f(s)){let u={...i},l=!1;for(let y in s)u[y]===void 0&&(u[y]=s[y],l=!0);if(l)return u}return i})}function Qe(e){return H(e,ee(),t=>t.trim())}function Ve(e){return O(e,"empty",t=>{let n=ne(t);return n===0||`Expected an empty ${e.type} but received one with a size of \`${n}\``})}function ne(e){return e instanceof Map||e instanceof Set?e.size:e.length}function Xe(e,t,n={}){let{exclusive:i}=n;return O(e,"max",s=>i?s<t:s<=t||`Expected a ${e.type} less than ${i?"":"or equal to "}${t} but received \`${s}\``)}function Ye(e,t,n={}){let{exclusive:i}=n;return O(e,"min",s=>i?s>t:s>=t||`Expected a ${e.type} greater than ${i?"":"or equal to "}${t} but received \`${s}\``)}function Ze(e){return O(e,"nonempty",t=>ne(t)>0||`Expected a nonempty ${e.type} but received an empty one`)}function xe(e,t){return O(e,"pattern",n=>t.test(n)||`Expected a ${e.type} matching \`/${t.source}/\` but received "${n}"`)}function et(e,t,n=t){let i=`Expected a ${e.type}`,s=t===n?`of \`${t}\``:`between \`${t}\` and \`${n}\``;return O(e,"size",u=>{if(typeof u=="number"||u instanceof Date)return t<=u&&u<=n||`${i} ${s} but received \`${u}\``;if(u instanceof Map||u instanceof Set){let{size:l}=u;return t<=l&&l<=n||`${i} with a size ${s} but received one with a size of \`${l}\``}else{let{length:l}=u;return t<=l&&l<=n||`${i} with a length ${s} but received one with a length of \`${l}\``}})}function O(e,t,n){return new m({...e,*refiner(i,s){yield*e.refiner(i,s);let u=n(i,s),l=_(u,s,e,i);for(let y of l)yield{...y,refinement:t}}})}r.Struct=m,r.StructError=o,r.any=Te,r.array=ve,r.assert=X,r.assign=ke,r.bigint=Ee,r.boolean=Me,r.coerce=H,r.create=Y,r.date=qe,r.defaulted=Ge,r.define=b,r.deprecated=Pe,r.dynamic=$e,r.empty=Ve,r.enums=Ie,r.func=Ae,r.instance=Fe,r.integer=ze,r.intersection=Re,r.is=W,r.lazy=_e,r.literal=Be,r.map=Je,r.mask=Z,r.max=Xe,r.min=Ye,r.never=C,r.nonempty=Ze,r.nullable=Ne,r.number=We,r.object=v,r.omit=De,r.optional=x,r.partial=Se,r.pattern=xe,r.pick=je,r.record=Ce,r.refine=O,r.regexp=He,r.set=Ue,r.size=et,r.string=ee,r.struct=Oe,r.trimmed=Qe,r.tuple=Le,r.type=E,r.union=Ke,r.unknown=te,r.validate=T})});var ge=D(require("yargs")),he=require("yargs/helpers"),w=D(require("path")),P=D(require("fs/promises")),G=D(require("fs-extra")),Q=D(require("node-fetch")),V=require("pyodide"),J=D(ae());var ce=require("pyodide");function R(r){return`https://cdn.jsdelivr.net/pyodide/v${ce.version}/full/${r}`}var fe=D(require("node-fetch"));var q=class r{static _instance;_data=null;constructor(){}static async loadPyodidePrebuiltPackageData(){let o=R("pyodide-lock.json");return console.log(`Load the Pyodide pyodide-lock.json from ${o}`),(await(await(0,fe.default)(o,void 0)).json()).packages}static async getInstance(){return this._instance==null&&(this._instance=new r,this._instance._data=await this.loadPyodidePrebuiltPackageData()),this._instance}getPackageInfoByName(o){if(this._data==null)throw new Error("The package data is not loaded yet.");let a=Object.values(this._data).find(c=>c.name===o);if(a==null)throw new Error(`Package ${o} is not found in the lock file.`);return a}};var le=D(require("fs/promises")),pe=D(K());var h=D(K()),de=h.object({embed:h.defaulted(h.boolean(),!1),idbfsMountpoints:h.optional(h.array(h.string())),nodeJsWorker:h.defaulted(h.boolean(),!1),nodefsMountpoints:h.optional(h.record(h.string(),h.string()))});function pt(r){let o=pe.create(r??{},de);if(o.nodeJsWorker){if(o.idbfsMountpoints!=null)throw new Error("The `idbfsMountpoints` field is not allowed when `nodeJsWorker` is true.")}else if(o.nodefsMountpoints!=null)throw new Error("The `nodefsMountpoints` field is not allowed when `nodeJsWorker` is false.");return o}async function me(r){let a=require(r.packageJsonPath).stlite?.desktop,c=pt(a),f=JSON.stringify(c,null,2);console.log(`Dump the manifest file -> ${r.manifestFilePath}`),console.log(f),await le.default.writeFile(r.manifestFilePath,f,{encoding:"utf-8"})}global.fetch=Q.default;var mt="../build",yt="../wheels";async function be(r,o){let a=[],c=f=>{a.push(f)};if(await r.loadPackage(o,{errorCallback:c}),a.length>0)throw new Error(a.join(`
|
|
4
|
+
`))}async function gt(r){console.info("Copy the build directory (the bare built app files) to this directory...");let o=w.default.resolve(__dirname,mt);if(!(await P.default.stat(o)).isDirectory())throw new Error(`The source ${o} does not exist.`);if(o===r.copyTo){console.warn(`sourceDir == destDir (${o}). Are you in the development environment? Skip copying the directory.`);return}if(r.keepOld)try{await P.default.access(r.copyTo),console.info(`${r.copyTo} already exists. Use it and skip copying.`);return}catch{throw new Error(`${r.copyTo} does not exist even though the \`keepOld\` option is specified`)}console.log(`Copy ${o} to ${r.copyTo}`),await P.default.rm(r.copyTo,{recursive:!0,force:!0}),await G.default.copy(o,r.copyTo)}async function ht(r){if(r.requirements.length===0)return[];let o=await(0,V.loadPyodide)();return await we(o,{requirements:r.requirements}),Object.entries(o.loadedPackages).filter(([,a])=>a==="default channel").map(([a])=>a)}async function ye(r,o){console.log(`Preparing the local wheel ${o}`);let a=await P.default.readFile(o),c="/tmp/"+w.default.basename(o);r.FS.writeFile(c,a);let f=`emfs:${c}`;return console.log(`The local wheel ${o} is prepared as ${f}`),f}async function we(r,o){await be(r,"micropip");let a=r.pyimport("micropip"),c=[...o.requirements],f=w.default.join(__dirname,yt),d=await ye(r,w.default.join(f,"stlite_server-0.1.0-py3-none-any.whl"));c.push(d);let $=await ye(r,w.default.join(f,"streamlit-1.32.2-cp311-none-any.whl"));c.push($),console.log("Install the packages:",c),await a.install.callKwargs(c,{keep_going:!0})}async function bt(r){console.info("Create the site-packages snapshot file...");let o=await(0,V.loadPyodide)();await be(o,"micropip");let a=o.pyimport("micropip"),c=await q.getInstance(),f=[];r.usedPrebuiltPackages.length>0&&(console.log("Mocking prebuilt packages so that they will not be included in the site-packages snapshot because these will be installed from the vendored wheel files at runtime..."),r.usedPrebuiltPackages.forEach(j=>{let _=c.getPackageInfoByName(j);if(_==null)throw new Error(`Package ${j} is not found in the lock file.`);console.log(`Mock ${_.name} ${_.version}`),a.add_mock_package(_.name,_.version),f.push(_.name)})),console.log(`Install the requirements ${JSON.stringify(r.requirements)}`),await we(o,{requirements:r.requirements}),console.log("Remove the mocked packages",f),f.forEach(j=>a.remove_mock_package(j)),console.log("Archive the site-packages director(y|ies)");let d="/tmp/site-packages-snapshot.tar.gz";await o.runPythonAsync(`
|
|
5
5
|
import os
|
|
6
6
|
import tarfile
|
|
7
7
|
import site
|
|
8
8
|
|
|
9
9
|
site_packages_dirs = site.getsitepackages()
|
|
10
10
|
|
|
11
|
-
tar_file_name = '${
|
|
11
|
+
tar_file_name = '${d}'
|
|
12
12
|
with tarfile.open(tar_file_name, mode='w:gz') as gzf:
|
|
13
13
|
for site_packages in site_packages_dirs:
|
|
14
14
|
print("Add site-package:", site_packages)
|
|
15
15
|
print(os.listdir(site_packages))
|
|
16
16
|
gzf.add(site_packages)
|
|
17
|
-
`),console.log("Extract the archive file from EMFS");let
|
|
18
|
-
`);await
|
|
17
|
+
`),console.log("Extract the archive file from EMFS");let $=o.FS.readFile(d);console.log(`Save the archive file (${r.saveTo})`),await P.default.writeFile(r.saveTo,$)}async function wt(r){console.info("Copy the Streamlit app directory..."),console.log(`Copy ${r.sourceDir} to ${r.copyTo}`),await P.default.rm(r.copyTo,{recursive:!0,force:!0}),await G.default.copy(r.sourceDir,r.copyTo)}async function kt(r){let o=await P.default.readFile(r,{encoding:"utf-8"});return(0,J.parseRequirementsTxt)(o)}async function Pt(r,o){let a=o.join(`
|
|
18
|
+
`);await P.default.writeFile(r,a,{encoding:"utf-8"})}async function $t(r){let o=await q.getInstance(),c=r.packages.map(f=>o.getPackageInfoByName(f)).map(f=>R(f.file_name));console.log("Downloading the used prebuilt packages..."),await Promise.all(c.map(async f=>{let d=w.default.resolve(r.destDir,"./pyodide",w.default.basename(f));console.log(`Download ${f} to ${d}`);let $=await(0,Q.default)(f);if(!$.ok)throw new Error(`Failed to download ${f}: ${$.status} ${$.statusText}`);let j=await $.arrayBuffer();await P.default.writeFile(d,Buffer.from(j))}))}(0,ge.default)((0,he.hideBin)(process.argv)).command("* <appHomeDirSource> [packages..]","Put the user code and data and the snapshot of the required packages into the build artifact.",()=>{},r=>{console.info(r)}).positional("appHomeDirSource",{describe:"The source directory of the user code and data that will be mounted in the Pyodide file system at app runtime",type:"string",demandOption:!0}).positional("packages",{describe:"Package names to install.",type:"string",array:!0}).options("requirement",{describe:"Install from the given requirements file. This option can be used multiple times.",array:!0,type:"string",alias:"r",default:[]}).options("keepOldBuild",{type:"boolean",default:!1,alias:"k",describe:"Keep the existing build directory contents except appHomeDir."}).parseAsync().then(async r=>{let o=process.cwd(),a=w.default.resolve(o,"./build");try{await P.default.access(r.appHomeDirSource)}catch{throw new Error(`${r.appHomeDirSource} does not exist.`)}let c=r.packages??[];for(let d of r.requirement)c=c.concat(await kt(d));(0,J.verifyRequirements)(c);let f=await ht({requirements:c});console.log("The prebuilt packages loaded for the given requirements:"),console.log(f),await gt({copyTo:a,keepOld:r.keepOldBuild}),await bt({requirements:c,usedPrebuiltPackages:f,saveTo:w.default.resolve(a,"./site-packages-snapshot.tar.gz")}),await Pt(w.default.resolve(a,"./prebuilt-packages.txt"),f),await wt({sourceDir:r.appHomeDirSource,copyTo:w.default.resolve(a,"./streamlit_app")}),await $t({packages:f,destDir:a}),await me({packageJsonPath:w.default.resolve(o,"./package.json"),manifestFilePath:w.default.resolve(a,"./stlite-manifest.json")})});
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"files": {
|
|
3
3
|
"main.css": "/static/css/main.fb5f4d99.css",
|
|
4
|
-
"main.js": "/static/js/main.
|
|
5
|
-
"static/js/4681.
|
|
4
|
+
"main.js": "/static/js/main.5d08bd7f.js",
|
|
5
|
+
"static/js/4681.91a881a3.chunk.js": "/static/js/4681.91a881a3.chunk.js",
|
|
6
6
|
"static/js/4994.37361da4.chunk.js": "/static/js/4994.37361da4.chunk.js",
|
|
7
7
|
"static/js/3685.39209b63.chunk.js": "/static/js/3685.39209b63.chunk.js",
|
|
8
8
|
"static/js/4785.63597083.chunk.js": "/static/js/4785.63597083.chunk.js",
|
|
@@ -162,6 +162,6 @@
|
|
|
162
162
|
},
|
|
163
163
|
"entrypoints": [
|
|
164
164
|
"static/css/main.fb5f4d99.css",
|
|
165
|
-
"static/js/main.
|
|
165
|
+
"static/js/main.5d08bd7f.js"
|
|
166
166
|
]
|
|
167
167
|
}
|
package/build/electron/main.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
var W=Object.create;var P=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var D=Object.getOwnPropertyNames;var S=Object.getPrototypeOf,x=Object.prototype.hasOwnProperty;var b=(e,r,n,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of D(r))!x.call(e,s)&&s!==n&&P(e,s,{get:()=>r[s],enumerable:!(o=R(r,s))||o.enumerable});return e};var w=(e,r,n)=>(n=e!=null?W(S(e)):{},b(r||!e||!e.__esModule?P(n,"default",{value:e,enumerable:!0}):n,e)),I=e=>b(P({},"__esModule",{value:!0}),e);var E={};module.exports=I(E);var t=require("electron"),a=w(require("path")),g=w(require("fs/promises")),v=w(require("node:worker_threads"));var f=w(require("fs/promises")),p=w(require("path"));async function k(e){let r={},n=await f.readdir(e);return await Promise.all(n.map(async o=>{let s=p.join(e,o);if((await f.stat(s)).isDirectory()){let l=await k(s);Object.assign(r,l)}else{let l=await f.readFile(s);r[s]=l}})),r}async function _(e){let r=await k(e),n={};return Object.keys(r).forEach(o=>{let h=p.relative(e,o).split(p.sep).join(p.posix.sep);n[h]=r[o]}),n}async function N(){let e=a.resolve(__dirname,"../stlite-manifest.json"),r=await g.readFile(e,{encoding:"utf-8"}),n=JSON.parse(r);return{embed:n.embed??!1,idbfsMountpoints:n.idbfsMountpoints,nodeJsWorker:n.nodeJsWorker??!1,nodefsMountpoints:n.nodefsMountpoints}}var y=async()=>{let e=await N(),r=[];e.idbfsMountpoints&&r.push(`--idbfs-mountpoints=${JSON.stringify(e.idbfsMountpoints)}`),e.nodeJsWorker&&r.push("--nodejs-worker");let n=new t.BrowserWindow({width:1280,height:720,webPreferences:{preload:a.join(__dirname,"preload.js"),sandbox:!0,additionalArguments:r}}),o=new URL((t.app.isPackaged,"file:///index.html")),s=new URLSearchParams;e.embed&&s.set("embed","true"),o.search=s.toString();let h=o.toString(),l=i=>i.url===h;t.ipcMain.handle("readSitePackagesSnapshot",i=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");let m=a.resolve(__dirname,"../site-packages-snapshot.tar.gz");return g.readFile(m)}),t.ipcMain.handle("readRequirements",async i=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");let m=a.resolve(__dirname,"../requirements.txt");return(await g.readFile(m,{encoding:"utf-8"})).split(`
|
|
2
|
-
`).map(
|
|
1
|
+
var Ce=Object.create;var Y=Object.defineProperty;var Je=Object.getOwnPropertyDescriptor;var Ue=Object.getOwnPropertyNames;var Be=Object.getPrototypeOf,He=Object.prototype.hasOwnProperty;var Le=(i,a)=>()=>(a||i((a={exports:{}}).exports,a),a.exports);var qe=(i,a,f,c)=>{if(a&&typeof a=="object"||typeof a=="function")for(let w of Ue(a))!He.call(i,w)&&w!==f&&Y(i,w,{get:()=>a[w],enumerable:!(c=Je(a,w))||c.enumerable});return i};var M=(i,a,f)=>(f=i!=null?Ce(Be(i)):{},qe(a||!i||!i.__esModule?Y(f,"default",{value:i,enumerable:!0}):f,i));var Z=Le((R,X)=>{(function(i,a){typeof R=="object"&&typeof X<"u"?a(R):typeof define=="function"&&define.amd?define(["exports"],a):(i=typeof globalThis<"u"?globalThis:i||self,a(i.Superstruct={}))})(R,function(i){"use strict";class a extends TypeError{constructor(n,t){let r,{message:o,explanation:s,...d}=n,{path:y}=n,h=y.length===0?o:`At path: ${y.join(".")} -- ${o}`;super(s??h),s!=null&&(this.cause=h),Object.assign(this,d),this.name=this.constructor.name,this.failures=()=>r??(r=[n,...t()])}}function f(e){return c(e)&&typeof e[Symbol.iterator]=="function"}function c(e){return typeof e=="object"&&e!=null}function w(e){if(Object.prototype.toString.call(e)!=="[object Object]")return!1;let n=Object.getPrototypeOf(e);return n===null||n===Object.prototype}function p(e){return typeof e=="symbol"?e.toString():typeof e=="string"?JSON.stringify(e):`${e}`}function E(e){let{done:n,value:t}=e.next();return n?void 0:t}function _(e,n,t,r){if(e===!0)return;e===!1?e={}:typeof e=="string"&&(e={message:e});let{path:o,branch:s}=n,{type:d}=t,{refinement:y,message:h=`Expected a value of type \`${d}\`${y?` with refinement \`${y}\``:""}, but received: \`${p(r)}\``}=e;return{value:r,type:d,refinement:y,key:o[o.length-1],path:o,branch:s,...e,message:h}}function*g(e,n,t,r){f(e)||(e=[e]);for(let o of e){let s=_(o,n,t,r);s&&(yield s)}}function*k(e,n,t={}){let{path:r=[],branch:o=[e],coerce:s=!1,mask:d=!1}=t,y={path:r,branch:o};if(s&&(e=n.coercer(e,y),d&&n.type!=="type"&&c(n.schema)&&c(e)&&!Array.isArray(e)))for(let m in e)n.schema[m]===void 0&&delete e[m];let h="valid";for(let m of n.validator(e,y))m.explanation=t.message,h="not_valid",yield[m,void 0];for(let[m,S,Re]of n.entries(e,y)){let ve=k(S,Re,{path:m===void 0?r:[...r,m],branch:m===void 0?o:[...o,S],coerce:s,mask:d,message:t.message});for(let W of ve)W[0]?(h=W[0].refinement!=null?"not_refined":"not_valid",yield[W[0],void 0]):s&&(S=W[1],m===void 0?e=S:e instanceof Map?e.set(m,S):e instanceof Set?e.add(S):c(e)&&(S!==void 0||m in e)&&(e[m]=S))}if(h!=="not_valid")for(let m of n.refiner(e,y))m.explanation=t.message,h="not_refined",yield[m,void 0];h==="valid"&&(yield[void 0,e])}class u{constructor(n){let{type:t,schema:r,validator:o,refiner:s,coercer:d=h=>h,entries:y=function*(){}}=n;this.type=t,this.schema=r,this.entries=y,this.coercer=d,o?this.validator=(h,m)=>{let S=o(h,m);return g(S,m,this,h)}:this.validator=()=>[],s?this.refiner=(h,m)=>{let S=s(h,m);return g(S,m,this,h)}:this.refiner=()=>[]}assert(n,t){return $(n,this,t)}create(n,t){return z(n,this,t)}is(n){return v(n,this)}mask(n,t){return T(n,this,t)}validate(n,t={}){return A(n,this,t)}}function $(e,n,t){let r=A(e,n,{message:t});if(r[0])throw r[0]}function z(e,n,t){let r=A(e,n,{coerce:!0,message:t});if(r[0])throw r[0];return r[1]}function T(e,n,t){let r=A(e,n,{coerce:!0,mask:!0,message:t});if(r[0])throw r[0];return r[1]}function v(e,n){return!A(e,n)[0]}function A(e,n,t={}){let r=k(e,n,t),o=E(r);return o[0]?[new a(o[0],function*(){for(let d of r)d[0]&&(yield d[0])}),void 0]:[void 0,o[1]]}function te(...e){let n=e[0].type==="type",t=e.map(o=>o.schema),r=Object.assign({},...t);return n?I(r):F(r)}function P(e,n){return new u({type:e,schema:null,validator:n})}function re(e,n){return new u({...e,refiner:(t,r)=>t===void 0||e.refiner(t,r),validator(t,r){return t===void 0?!0:(n(t,r),e.validator(t,r))}})}function ie(e){return new u({type:"dynamic",schema:null,*entries(n,t){yield*e(n,t).entries(n,t)},validator(n,t){return e(n,t).validator(n,t)},coercer(n,t){return e(n,t).coercer(n,t)},refiner(n,t){return e(n,t).refiner(n,t)}})}function oe(e){let n;return new u({type:"lazy",schema:null,*entries(t,r){n??(n=e()),yield*n.entries(t,r)},validator(t,r){return n??(n=e()),n.validator(t,r)},coercer(t,r){return n??(n=e()),n.coercer(t,r)},refiner(t,r){return n??(n=e()),n.refiner(t,r)}})}function se(e,n){let{schema:t}=e,r={...t};for(let o of n)delete r[o];switch(e.type){case"type":return I(r);default:return F(r)}}function ae(e){let n=e instanceof u,t=n?{...e.schema}:{...e};for(let r in t)t[r]=H(t[r]);return n&&e.type==="type"?I(t):F(t)}function ce(e,n){let{schema:t}=e,r={};for(let o of n)r[o]=t[o];switch(e.type){case"type":return I(r);default:return F(r)}}function fe(e,n){return console.warn("superstruct@0.11 - The `struct` helper has been renamed to `define`."),P(e,n)}function de(){return P("any",()=>!0)}function ue(e){return new u({type:"array",schema:e,*entries(n){if(e&&Array.isArray(n))for(let[t,r]of n.entries())yield[t,r,e]},coercer(n){return Array.isArray(n)?n.slice():n},validator(n){return Array.isArray(n)||`Expected an array value, but received: ${p(n)}`}})}function le(){return P("bigint",e=>typeof e=="bigint")}function pe(){return P("boolean",e=>typeof e=="boolean")}function me(){return P("date",e=>e instanceof Date&&!isNaN(e.getTime())||`Expected a valid \`Date\` object, but received: ${p(e)}`)}function ye(e){let n={},t=e.map(r=>p(r)).join();for(let r of e)n[r]=r;return new u({type:"enums",schema:n,validator(r){return e.includes(r)||`Expected one of \`${t}\`, but received: ${p(r)}`}})}function he(){return P("func",e=>typeof e=="function"||`Expected a function, but received: ${p(e)}`)}function be(e){return P("instance",n=>n instanceof e||`Expected a \`${e.name}\` instance, but received: ${p(n)}`)}function we(){return P("integer",e=>typeof e=="number"&&!isNaN(e)&&Number.isInteger(e)||`Expected an integer, but received: ${p(e)}`)}function ge(e){return new u({type:"intersection",schema:null,*entries(n,t){for(let r of e)yield*r.entries(n,t)},*validator(n,t){for(let r of e)yield*r.validator(n,t)},*refiner(n,t){for(let r of e)yield*r.refiner(n,t)}})}function ke(e){let n=p(e),t=typeof e;return new u({type:"literal",schema:t==="string"||t==="number"||t==="boolean"?e:null,validator(r){return r===e||`Expected the literal \`${n}\`, but received: ${p(r)}`}})}function $e(e,n){return new u({type:"map",schema:null,*entries(t){if(e&&n&&t instanceof Map)for(let[r,o]of t.entries())yield[r,r,e],yield[r,o,n]},coercer(t){return t instanceof Map?new Map(t):t},validator(t){return t instanceof Map||`Expected a \`Map\` object, but received: ${p(t)}`}})}function C(){return P("never",()=>!1)}function Pe(e){return new u({...e,validator:(n,t)=>n===null||e.validator(n,t),refiner:(n,t)=>n===null||e.refiner(n,t)})}function je(){return P("number",e=>typeof e=="number"&&!isNaN(e)||`Expected a number, but received: ${p(e)}`)}function F(e){let n=e?Object.keys(e):[],t=C();return new u({type:"object",schema:e||null,*entries(r){if(e&&c(r)){let o=new Set(Object.keys(r));for(let s of n)o.delete(s),yield[s,r[s],e[s]];for(let s of o)yield[s,r[s],t]}},validator(r){return c(r)||`Expected an object, but received: ${p(r)}`},coercer(r){return c(r)?{...r}:r}})}function H(e){return new u({...e,validator:(n,t)=>n===void 0||e.validator(n,t),refiner:(n,t)=>n===void 0||e.refiner(n,t)})}function Ee(e,n){return new u({type:"record",schema:null,*entries(t){if(c(t))for(let r in t){let o=t[r];yield[r,r,e],yield[r,o,n]}},validator(t){return c(t)||`Expected an object, but received: ${p(t)}`}})}function Se(){return P("regexp",e=>e instanceof RegExp)}function _e(e){return new u({type:"set",schema:null,*entries(n){if(e&&n instanceof Set)for(let t of n)yield[t,t,e]},coercer(n){return n instanceof Set?new Set(n):n},validator(n){return n instanceof Set||`Expected a \`Set\` object, but received: ${p(n)}`}})}function L(){return P("string",e=>typeof e=="string"||`Expected a string, but received: ${p(e)}`)}function Me(e){let n=C();return new u({type:"tuple",schema:null,*entries(t){if(Array.isArray(t)){let r=Math.max(e.length,t.length);for(let o=0;o<r;o++)yield[o,t[o],e[o]||n]}},validator(t){return Array.isArray(t)||`Expected an array, but received: ${p(t)}`}})}function I(e){let n=Object.keys(e);return new u({type:"type",schema:e,*entries(t){if(c(t))for(let r of n)yield[r,t[r],e[r]]},validator(t){return c(t)||`Expected an object, but received: ${p(t)}`},coercer(t){return c(t)?{...t}:t}})}function Ne(e){let n=e.map(t=>t.type).join(" | ");return new u({type:"union",schema:null,coercer(t){for(let r of e){let[o,s]=r.validate(t,{coerce:!0});if(!o)return s}return t},validator(t,r){let o=[];for(let s of e){let[...d]=k(t,s,r),[y]=d;if(y[0])for(let[h]of d)h&&o.push(h);else return[]}return[`Expected the value to satisfy a union of \`${n}\`, but received: ${p(t)}`,...o]}})}function q(){return P("unknown",()=>!0)}function J(e,n,t){return new u({...e,coercer:(r,o)=>v(r,n)?e.coercer(t(r,o),o):e.coercer(r,o)})}function Oe(e,n,t={}){return J(e,q(),r=>{let o=typeof n=="function"?n():n;if(r===void 0)return o;if(!t.strict&&w(r)&&w(o)){let s={...r},d=!1;for(let y in o)s[y]===void 0&&(s[y]=o[y],d=!0);if(d)return s}return r})}function Ae(e){return J(e,L(),n=>n.trim())}function De(e){return O(e,"empty",n=>{let t=V(n);return t===0||`Expected an empty ${e.type} but received one with a size of \`${t}\``})}function V(e){return e instanceof Map||e instanceof Set?e.size:e.length}function Fe(e,n,t={}){let{exclusive:r}=t;return O(e,"max",o=>r?o<n:o<=n||`Expected a ${e.type} less than ${r?"":"or equal to "}${n} but received \`${o}\``)}function Ie(e,n,t={}){let{exclusive:r}=t;return O(e,"min",o=>r?o>n:o>=n||`Expected a ${e.type} greater than ${r?"":"or equal to "}${n} but received \`${o}\``)}function ze(e){return O(e,"nonempty",n=>V(n)>0||`Expected a nonempty ${e.type} but received an empty one`)}function Te(e,n){return O(e,"pattern",t=>n.test(t)||`Expected a ${e.type} matching \`/${n.source}/\` but received "${t}"`)}function We(e,n,t=n){let r=`Expected a ${e.type}`,o=n===t?`of \`${n}\``:`between \`${n}\` and \`${t}\``;return O(e,"size",s=>{if(typeof s=="number"||s instanceof Date)return n<=s&&s<=t||`${r} ${o} but received \`${s}\``;if(s instanceof Map||s instanceof Set){let{size:d}=s;return n<=d&&d<=t||`${r} with a size ${o} but received one with a size of \`${d}\``}else{let{length:d}=s;return n<=d&&d<=t||`${r} with a length ${o} but received one with a length of \`${d}\``}})}function O(e,n,t){return new u({...e,*refiner(r,o){yield*e.refiner(r,o);let s=t(r,o),d=g(s,o,e,r);for(let y of d)yield{...y,refinement:n}}})}i.Struct=u,i.StructError=a,i.any=de,i.array=ue,i.assert=$,i.assign=te,i.bigint=le,i.boolean=pe,i.coerce=J,i.create=z,i.date=me,i.defaulted=Oe,i.define=P,i.deprecated=re,i.dynamic=ie,i.empty=De,i.enums=ye,i.func=he,i.instance=be,i.integer=we,i.intersection=ge,i.is=v,i.lazy=oe,i.literal=ke,i.map=$e,i.mask=T,i.max=Fe,i.min=Ie,i.never=C,i.nonempty=ze,i.nullable=Pe,i.number=je,i.object=F,i.omit=se,i.optional=H,i.partial=ae,i.pattern=Te,i.pick=ce,i.record=Ee,i.refine=O,i.regexp=Se,i.set=_e,i.size=We,i.string=L,i.struct=fe,i.trimmed=Ae,i.tuple=Me,i.type=I,i.union=Ne,i.unknown=q,i.validate=A})});var l=require("electron"),j=M(require("path")),U=M(require("fs/promises")),B=M(require("node:worker_threads"));var D=M(require("fs/promises")),N=M(require("path"));async function G(i){let a={},f=await D.readdir(i);return await Promise.all(f.map(async c=>{let w=N.join(i,c);if((await D.stat(w)).isDirectory()){let E=await G(w);Object.assign(a,E)}else{let E=await D.readFile(w);a[w]=E}})),a}async function Q(i){let a=await G(i),f={};return Object.keys(a).forEach(c=>{let p=N.relative(i,c).split(N.sep).join(N.posix.sep);f[p]=a[c]}),f}var K=M(require("path")),x=M(require("fs/promises")),b=M(Z()),Ve=b.object({embed:b.defaulted(b.boolean(),!1),idbfsMountpoints:b.optional(b.array(b.string())),nodeJsWorker:b.defaulted(b.boolean(),!1),nodefsMountpoints:b.optional(b.record(b.string(),b.string()))});async function ee(){let i=K.resolve(__dirname,"../stlite-manifest.json"),a=await x.readFile(i,{encoding:"utf-8"}),f=JSON.parse(a);return b.assert(f,Ve),f}var ne=async()=>{let i=await ee(),a=[];i.idbfsMountpoints&&a.push(`--idbfs-mountpoints=${JSON.stringify(i.idbfsMountpoints)}`),i.nodeJsWorker&&a.push("--nodejs-worker");let f=new l.BrowserWindow({width:1280,height:720,webPreferences:{preload:j.join(__dirname,"preload.js"),sandbox:!0,additionalArguments:a}}),c=new URL((l.app.isPackaged,"file:///index.html")),w=new URLSearchParams;i.embed&&w.set("embed","true"),c.search=w.toString();let p=c.toString(),E=g=>g.url===p;l.ipcMain.handle("readSitePackagesSnapshot",g=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");let k=j.resolve(__dirname,"../site-packages-snapshot.tar.gz");return U.readFile(k)}),l.ipcMain.handle("readPrebuiltPackageNames",async g=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");let k=j.resolve(__dirname,"../prebuilt-packages.txt");return(await U.readFile(k,{encoding:"utf-8"})).split(`
|
|
2
|
+
`).map($=>$.trim()).filter($=>$.length>0)}),l.ipcMain.handle("readStreamlitAppDirectory",async g=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");let k=j.resolve(__dirname,"../streamlit_app");return Q(k)}),f.on("closed",()=>{l.ipcMain.removeHandler("readSitePackagesSnapshot"),l.ipcMain.removeHandler("readPrebuiltPackageNames"),l.ipcMain.removeHandler("readStreamlitAppDirectory")});let _=null;l.ipcMain.handle("initializeNodeJsWorker",g=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");let k=j.resolve(__dirname,"../pyodide/pyodide.mjs");function u($){f.webContents.send("messageFromNodeJsWorker",$)}_=new B.default.Worker(j.resolve(__dirname,"./worker.js"),{env:{PYODIDE_URL:k,...i.nodefsMountpoints&&{NODEFS_MOUNTPOINTS:JSON.stringify(i.nodefsMountpoints)}}}),_.on("message",$=>{u($)})}),l.ipcMain.on("messageToNodeJsWorker",(g,{data:k,portId:u})=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");if(_==null)return;let $=new B.default.MessageChannel;$.port1.on("message",T=>{g.reply(`nodeJsWorker-portMessage-${u}`,T)});let z={data:k,port:$.port2};_.postMessage(z,[$.port2])}),l.ipcMain.handle("terminate",(g,{data:k,portId:u})=>{if(!E(g.senderFrame))throw new Error("Invalid IPC sender");_?.terminate(),_=null}),f.on("closed",()=>{l.ipcMain.removeHandler("initializeNodeJsWorker"),l.ipcMain.removeHandler("messageToNodeJsWorker"),l.ipcMain.removeHandler("terminate")}),f.loadURL(p),l.app.isPackaged||f.webContents.openDevTools()};l.app.enableSandbox();l.app.whenReady().then(()=>{let i=j.resolve(__dirname,"..");l.protocol.interceptFileProtocol("file",function(a,f){let c=new URL(a.url).pathname;if(j.isAbsolute(c)){let w=j.join(i,c);f(j.normalize(w))}else f(c)}),ne(),l.app.on("activate",()=>{l.BrowserWindow.getAllWindows().length===0&&ne()})});l.app.on("window-all-closed",()=>{process.platform!=="darwin"&&l.app.quit()});l.app.on("web-contents-created",(i,a)=>{a.on("will-attach-webview",(f,c,w)=>{f.preventDefault()}),a.on("will-navigate",(f,c)=>{console.debug("will-navigate",c),f.preventDefault()}),a.setWindowOpenHandler(({url:f})=>(console.error("Opening a new window is not allowed."),{action:"deny"}))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var i=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var d=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var g=(o,r,
|
|
1
|
+
var i=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var d=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var g=(o,r,s,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of d(r))!c.call(o,n)&&n!==s&&i(o,n,{get:()=>r[n],enumerable:!(t=p(r,n))||t.enumerable});return o};var k=o=>g(i({},"__esModule",{value:!0}),o);var P={};module.exports=k(P);var e=require("electron"),a=process.argv.find(o=>o.startsWith("--idbfs-mountpoints="))?.split("=")[1],W=a&&JSON.parse(a),f={idbfsMountpoints:W};e.contextBridge.exposeInMainWorld("appConfig",f);var l={readSitePackagesSnapshot:()=>e.ipcRenderer.invoke("readSitePackagesSnapshot"),readPrebuiltPackageNames:()=>e.ipcRenderer.invoke("readPrebuiltPackageNames"),readStreamlitAppDirectory:()=>e.ipcRenderer.invoke("readStreamlitAppDirectory")};e.contextBridge.exposeInMainWorld("archivesAPI",l);function A(){return Math.floor(Math.random()*1e6)}var I={USE_NODEJS_WORKER:process.argv.includes("--nodejs-worker"),initialize:()=>e.ipcRenderer.invoke("initializeNodeJsWorker"),postMessage:({data:o,onPortMessage:r})=>{console.debug("nodeJsWorkerAPI.postMessage",{data:o,onPortMessage:r});let s=r&&A();e.ipcRenderer.send("messageToNodeJsWorker",{data:o,portId:s}),s&&e.ipcRenderer.on(`nodeJsWorker-portMessage-${s}`,(t,n)=>{r(n)})},onMessage:o=>e.ipcRenderer.on("messageFromNodeJsWorker",(r,s)=>{console.debug("nodeJsWorkerAPI.onMessage",s),o(s)}),terminate:()=>e.ipcRenderer.invoke("terminateNodeJsWorker")};e.contextBridge.exposeInMainWorld("nodeJsWorkerAPI",I);
|
package/build/electron/worker.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
var
|
|
2
|
-
`).filter(e=>!e.startsWith("#")).map(e=>e.replace(
|
|
1
|
+
var ae=Object.create;var H=Object.defineProperty;var le=Object.getOwnPropertyDescriptor;var ce=Object.getOwnPropertyNames;var ge=Object.getPrototypeOf,de=Object.prototype.hasOwnProperty;var O=(o,e)=>()=>(e||o((e={exports:{}}).exports,e),e.exports);var fe=(o,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of ce(e))!de.call(o,t)&&t!==r&&H(o,t,{get:()=>e[t],enumerable:!(n=le(e,t))||n.enumerable});return o};var J=(o,e,r)=>(r=o!=null?ae(ge(o)):{},fe(e||!o||!o.__esModule?H(r,"default",{value:o,enumerable:!0}):r,o));var K=O(C=>{"use strict";Object.defineProperty(C,"__esModule",{value:!0});C.verifyRequirements=void 0;function ue(o){o.forEach(e=>{let r;try{r=new URL(e)}catch{return}if(r.protocol==="emfs:"||r.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${e})`)})}C.verifyRequirements=ue});var V=O(R=>{"use strict";Object.defineProperty(R,"__esModule",{value:!0});R.parseRequirementsTxt=void 0;var me=/\s#.*$/;function pe(o){return o.split(`
|
|
2
|
+
`).filter(e=>!e.startsWith("#")).map(e=>e.replace(me,"")).map(e=>e.trim()).filter(e=>e!=="")}R.parseRequirementsTxt=pe});var G=O(E=>{"use strict";Object.defineProperty(E,"__esModule",{value:!0});E.PromiseDelegate=void 0;var T=class{constructor(){this.promise=new Promise((e,r)=>{this.resolveInternal=e,this.rejectInternal=r})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};E.PromiseDelegate=T});var Y=O(w=>{"use strict";var _e=w&&w.__createBinding||(Object.create?function(o,e,r,n){n===void 0&&(n=r);var t=Object.getOwnPropertyDescriptor(e,r);(!t||("get"in t?!e.__esModule:t.writable||t.configurable))&&(t={enumerable:!0,get:function(){return e[r]}}),Object.defineProperty(o,n,t)}:function(o,e,r,n){n===void 0&&(n=r),o[n]=e[r]}),N=w&&w.__exportStar||function(o,e){for(var r in o)r!=="default"&&!Object.prototype.hasOwnProperty.call(e,r)&&_e(e,o,r)};Object.defineProperty(w,"__esModule",{value:!0});N(K(),w);N(V(),w);N(G(),w)});var Z=O((Me,X)=>{"use strict";function h(o){if(typeof o!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(o))}function Q(o,e){for(var r="",n=0,t=-1,a=0,s,i=0;i<=o.length;++i){if(i<o.length)s=o.charCodeAt(i);else{if(s===47)break;s=47}if(s===47){if(!(t===i-1||a===1))if(t!==i-1&&a===2){if(r.length<2||n!==2||r.charCodeAt(r.length-1)!==46||r.charCodeAt(r.length-2)!==46){if(r.length>2){var g=r.lastIndexOf("/");if(g!==r.length-1){g===-1?(r="",n=0):(r=r.slice(0,g),n=r.length-1-r.lastIndexOf("/")),t=i,a=0;continue}}else if(r.length===2||r.length===1){r="",n=0,t=i,a=0;continue}}e&&(r.length>0?r+="/..":r="..",n=2)}else r.length>0?r+="/"+o.slice(t+1,i):r=o.slice(t+1,i),n=i-t-1;t=i,a=0}else s===46&&a!==-1?++a:a=-1}return r}function ye(o,e){var r=e.dir||e.root,n=e.base||(e.name||"")+(e.ext||"");return r?r===e.root?r+n:r+o+n:n}var S={resolve:function(){for(var e="",r=!1,n,t=arguments.length-1;t>=-1&&!r;t--){var a;t>=0?a=arguments[t]:(n===void 0&&(n=process.cwd()),a=n),h(a),a.length!==0&&(e=a+"/"+e,r=a.charCodeAt(0)===47)}return e=Q(e,!r),r?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(h(e),e.length===0)return".";var r=e.charCodeAt(0)===47,n=e.charCodeAt(e.length-1)===47;return e=Q(e,!r),e.length===0&&!r&&(e="."),e.length>0&&n&&(e+="/"),r?"/"+e:e},isAbsolute:function(e){return h(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,r=0;r<arguments.length;++r){var n=arguments[r];h(n),n.length>0&&(e===void 0?e=n:e+="/"+n)}return e===void 0?".":S.normalize(e)},relative:function(e,r){if(h(e),h(r),e===r||(e=S.resolve(e),r=S.resolve(r),e===r))return"";for(var n=1;n<e.length&&e.charCodeAt(n)===47;++n);for(var t=e.length,a=t-n,s=1;s<r.length&&r.charCodeAt(s)===47;++s);for(var i=r.length,g=i-s,p=a<g?a:g,u=-1,l=0;l<=p;++l){if(l===p){if(g>p){if(r.charCodeAt(s+l)===47)return r.slice(s+l+1);if(l===0)return r.slice(s+l)}else a>p&&(e.charCodeAt(n+l)===47?u=l:l===0&&(u=0));break}var _=e.charCodeAt(n+l),c=r.charCodeAt(s+l);if(_!==c)break;_===47&&(u=l)}var f="";for(l=n+u+1;l<=t;++l)(l===t||e.charCodeAt(l)===47)&&(f.length===0?f+="..":f+="/..");return f.length>0?f+r.slice(s+u):(s+=u,r.charCodeAt(s)===47&&++s,r.slice(s))},_makeLong:function(e){return e},dirname:function(e){if(h(e),e.length===0)return".";for(var r=e.charCodeAt(0),n=r===47,t=-1,a=!0,s=e.length-1;s>=1;--s)if(r=e.charCodeAt(s),r===47){if(!a){t=s;break}}else a=!1;return t===-1?n?"/":".":n&&t===1?"//":e.slice(0,t)},basename:function(e,r){if(r!==void 0&&typeof r!="string")throw new TypeError('"ext" argument must be a string');h(e);var n=0,t=-1,a=!0,s;if(r!==void 0&&r.length>0&&r.length<=e.length){if(r.length===e.length&&r===e)return"";var i=r.length-1,g=-1;for(s=e.length-1;s>=0;--s){var p=e.charCodeAt(s);if(p===47){if(!a){n=s+1;break}}else g===-1&&(a=!1,g=s+1),i>=0&&(p===r.charCodeAt(i)?--i===-1&&(t=s):(i=-1,t=g))}return n===t?t=g:t===-1&&(t=e.length),e.slice(n,t)}else{for(s=e.length-1;s>=0;--s)if(e.charCodeAt(s)===47){if(!a){n=s+1;break}}else t===-1&&(a=!1,t=s+1);return t===-1?"":e.slice(n,t)}},extname:function(e){h(e);for(var r=-1,n=0,t=-1,a=!0,s=0,i=e.length-1;i>=0;--i){var g=e.charCodeAt(i);if(g===47){if(!a){n=i+1;break}continue}t===-1&&(a=!1,t=i+1),g===46?r===-1?r=i:s!==1&&(s=1):r!==-1&&(s=-1)}return r===-1||t===-1||s===0||s===1&&r===t-1&&r===n+1?"":e.slice(r,t)},format:function(e){if(e===null||typeof e!="object")throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof e);return ye("/",e)},parse:function(e){h(e);var r={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return r;var n=e.charCodeAt(0),t=n===47,a;t?(r.root="/",a=1):a=0;for(var s=-1,i=0,g=-1,p=!0,u=e.length-1,l=0;u>=a;--u){if(n=e.charCodeAt(u),n===47){if(!p){i=u+1;break}continue}g===-1&&(p=!1,g=u+1),n===46?s===-1?s=u:l!==1&&(l=1):s!==-1&&(l=-1)}return s===-1||g===-1||l===0||l===1&&s===g-1&&s===i+1?g!==-1&&(i===0&&t?r.base=r.name=e.slice(1,g):r.base=r.name=e.slice(i,g)):(i===0&&t?(r.name=e.slice(1,s),r.base=e.slice(1,g)):(r.name=e.slice(i,s),r.base=e.slice(i,g)),r.ext=e.slice(s,g)),i>0?r.dir=e.slice(0,i-1):t&&(r.dir="/"),r},sep:"/",delimiter:":",win32:null,posix:null};S.posix=S;X.exports=S});var $=require("node:worker_threads");var te=J(Y());var L=J(Z());function ee(o,e){let r=L.default.normalize(e),t=L.default.dirname(r).split("/"),a=[];for(let s of t){a.push(s);let i=a.join("/");if(o.FS.analyzePath(i).exists){if(o.FS.isDir(i))throw new Error(`"${i}" already exists and is not a directory.`);continue}try{o.FS.mkdir(i)}catch(g){throw console.error(`Failed to create a directory "${i}"`),g}}}function j(o,e,r,n){ee(o,e),o.FS.writeFile(e,r,n)}function re(o,e,r){ee(o,r),o.FS.rename(e,r)}function q(o){o.forEach(e=>{let r;try{r=new URL(e)}catch{return}if(r.protocol==="emfs:"||r.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${e})`)})}function U(o){o.runPython(`
|
|
3
3
|
import micropip
|
|
4
4
|
micropip.add_mock_package(
|
|
5
5
|
"pyarrow", "0.0.1",
|
|
@@ -15,14 +15,14 @@ class Table:
|
|
|
15
15
|
"""
|
|
16
16
|
}
|
|
17
17
|
)
|
|
18
|
-
`)}async function
|
|
18
|
+
`)}async function he(o,e){let r=o.slice(0,o.lastIndexOf("/")+1),n;return o.endsWith(".mjs")?n=(await import(o)).loadPyodide:(importScripts(o),n=D.loadPyodide),n({...e,indexURL:r})}var D=global;function oe(o,e,r){function n(u){e({type:"event:progress",data:{message:u}})}let t,a,s=new te.PromiseDelegate;async function i(){let u=await s.promise,l={...r,...u};console.debug("Initial data",l);let{entrypoint:_,files:c,archives:f,requirements:y,prebuiltPackageNames:P,wheels:v,mountedSitePackagesSnapshotFilePath:k,pyodideUrl:M=o,streamlitConfig:A,idbfsMountpoints:B,nodefsMountpoints:W}=l;n("Loading Pyodide."),console.debug("Loading Pyodide"),t=await he(M,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let x=!1;if(B&&(x=!0,B.forEach(d=>{t.FS.mkdir(d),t.FS.mount(t.FS.filesystems.IDBFS,{},d)}),await new Promise((d,m)=>{t.FS.syncfs(!0,b=>{b?m(b):d()})})),W&&Object.entries(W).forEach(([d,m])=>{t.FS.mkdir(d),t.FS.mount(t.FS.filesystems.NODEFS,{root:m},d)}),n("Mounting files."),await Promise.all(Object.keys(c).map(async d=>{let m=c[d],b;"url"in m?(console.debug(`Fetch a file from ${m.url}`),b=await fetch(m.url).then(F=>F.arrayBuffer()).then(F=>new Uint8Array(F))):b=m.data;let{opts:I}=c[d];console.debug(`Write a file "${d}"`),j(t,d,b,I)})),n("Unpacking archives."),await Promise.all(f.map(async d=>{let m;"url"in d?(console.debug(`Fetch an archive from ${d.url}`),m=await fetch(d.url).then(F=>F.arrayBuffer())):m=d.buffer;let{format:b,options:I}=d;console.debug("Unpack an archive",{format:b,options:I}),t.unpackArchive(m,b,I)})),!k&&!v)throw new Error("Neither snapshot nor wheel files are provided.");k&&(n("Restoring the snapshot."),await t.runPythonAsync("import tarfile, shutil, site"),await t.runPythonAsync(`
|
|
19
19
|
site_packages_dirs = site.getsitepackages()
|
|
20
20
|
for site_packages in site_packages_dirs:
|
|
21
21
|
shutil.rmtree(site_packages)
|
|
22
|
-
`),console.debug(`Unarchive ${
|
|
23
|
-
with tarfile.open("${
|
|
22
|
+
`),console.debug(`Unarchive ${k}`),await t.runPythonAsync(`
|
|
23
|
+
with tarfile.open("${k}", "r") as tar_gz_file:
|
|
24
24
|
tar_gz_file.extractall("/")
|
|
25
|
-
`),console.debug("Restored the snapshot"),n("Mocking some packages."),console.debug("Mock pyarrow"),U(t),console.debug("Mocked pyarrow")),q(y),n("Installing packages."),await t.loadPackage("micropip");let
|
|
25
|
+
`),console.debug("Restored the snapshot"),n("Mocking some packages."),console.debug("Mock pyarrow"),U(t),console.debug("Mocked pyarrow")),q(y),n("Installing packages."),console.debug("Installing the prebuilt packages:",P),await t.loadPackage(P),console.debug("Installed the prebuilt packages"),await t.loadPackage("micropip");let z=t.pyimport("micropip");v?(console.debug("Installing the wheels:",v,"and the requirements:",y),await z.install.callKwargs([v.stliteServer,v.streamlit,...y],{keep_going:!0}),console.debug("Installed the wheels and the requirements"),n("Mocking some packages."),console.debug("Mock pyarrow"),U(t),console.debug("Mocked pyarrow")):(console.debug("Installing the requirements:",y),await z.install.callKwargs(y,{keep_going:!0}),console.debug("Installed the requirements")),await t.runPythonAsync(`
|
|
26
26
|
import importlib
|
|
27
27
|
importlib.invalidate_caches()
|
|
28
28
|
`),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await t.runPythonAsync(`
|
|
@@ -45,7 +45,7 @@ for name in streamlit.logger._loggers.keys():
|
|
|
45
45
|
logger.setLevel(logging.NOTSET)
|
|
46
46
|
|
|
47
47
|
streamlit.logger._loggers = {}
|
|
48
|
-
`);let
|
|
48
|
+
`);let ne=(d,m)=>{d>=40?console.error(m):d>=30?console.warn(m):d>=20?console.info(m):console.debug(m)};D.__logCallback__=ne,await t.runPythonAsync(`
|
|
49
49
|
def setup_loggers(streamlit_level, streamlit_message_format):
|
|
50
50
|
from js import __logCallback__
|
|
51
51
|
|
|
@@ -74,14 +74,14 @@ def setup_loggers(streamlit_level, streamlit_message_format):
|
|
|
74
74
|
streamlit_handler.setFormatter(streamlit_formatter)
|
|
75
75
|
streamlit_logger.addHandler(streamlit_handler)
|
|
76
76
|
streamlit_logger.setLevel(streamlit_level.upper())
|
|
77
|
-
`);let
|
|
77
|
+
`);let se=(A?.["logger.level"]??"INFO").toString(),ie=A?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(t.globals.get("setup_loggers")(se,ie),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await t.runPythonAsync(`
|
|
78
78
|
import streamlit
|
|
79
79
|
|
|
80
80
|
def is_cacheable_msg(msg):
|
|
81
81
|
return False
|
|
82
82
|
|
|
83
83
|
streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
|
|
84
|
-
`),console.debug("Mocked some Streamlit functions"),
|
|
84
|
+
`),console.debug("Mocked some Streamlit functions"),x){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let d=!1;D.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),d||(d=!0,t.FS.syncfs(!1,m=>{d=!1,m&&console.error(m)}))},await t.runPythonAsync(`
|
|
85
85
|
from streamlit.runtime.app_session import AppSession
|
|
86
86
|
from streamlit.runtime.scriptrunner import ScriptRunnerEvent
|
|
87
87
|
from js import __scriptFinishedCallback__
|
|
@@ -96,7 +96,7 @@ def wrap_app_session_on_scriptrunner_event(original_method):
|
|
|
96
96
|
return wrapped
|
|
97
97
|
|
|
98
98
|
AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
|
|
99
|
-
`),console.debug("Set up the IndexedDB filesystem synchronizer")}n("Booting up the Streamlit server."),console.debug("Booting up the Streamlit server"),D.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...
|
|
99
|
+
`),console.debug("Set up the IndexedDB filesystem synchronizer")}n("Booting up the Streamlit server."),console.debug("Booting up the Streamlit server"),D.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...A,"runner.fastReruns":!1},await t.runPythonAsync(`
|
|
100
100
|
from stlite_server.bootstrap import load_config_options, prepare
|
|
101
101
|
from stlite_server.server import Server
|
|
102
102
|
from js import __streamlitFlagOptions__
|
|
@@ -112,7 +112,7 @@ prepare(main_script_path, args)
|
|
|
112
112
|
|
|
113
113
|
server = Server(main_script_path, command_line)
|
|
114
114
|
server.start()
|
|
115
|
-
`),console.debug("Booted up the Streamlit server"),console.debug("Setting up the HTTP server"),a=t.globals.get("server").copy(),console.debug("Set up the HTTP server"),e({type:"event:loaded"})}let g=i().catch(u=>{throw e({type:"event:error",data:{error:u}}),u}),p=async u=>{let l=u.data;if(l.type==="initData"){s.resolve(l.data);return}await g;let _=u.ports[0];try{switch(l.type){case"websocket:connect":{console.debug("websocket:connect",l.data);let{path:c}=l.data;a.start_websocket(c,(f,y)=>{if(y){let
|
|
115
|
+
`),console.debug("Booted up the Streamlit server"),console.debug("Setting up the HTTP server"),a=t.globals.get("server").copy(),console.debug("Set up the HTTP server"),e({type:"event:loaded"})}let g=i().catch(u=>{throw e({type:"event:error",data:{error:u}}),u}),p=async u=>{let l=u.data;if(l.type==="initData"){s.resolve(l.data);return}await g;let _=u.ports[0];try{switch(l.type){case"websocket:connect":{console.debug("websocket:connect",l.data);let{path:c}=l.data;a.start_websocket(c,(f,y)=>{if(y){let P=f.getBuffer("u8");f.destroy();let v=new Uint8ClampedArray(P.data.buffer,P.data.byteOffset,P.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(v)}})}else e({type:"websocket:message",data:{payload:f}})}),_.postMessage({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",l.data);let{payload:c}=l.data;a.receive_websocket_from_js(c);break}case"http:request":{console.debug("http:request",l.data);let{request:c}=l.data,f=(y,P,v)=>{let k=P.toJs(),M=v.toJs();console.debug({statusCode:y,headers:k,body:M});let A={type:"http:response",data:{response:{statusCode:y,headers:k,body:M}}};_.postMessage(A)};a.receive_http_from_js(c.method,decodeURIComponent(c.path),c.headers,c.body,f);break}case"file:write":{let{path:c,data:f,opts:y}=l.data;console.debug(`Write a file "${c}"`),j(t,c,f,y),_.postMessage({type:"reply"});break}case"file:rename":{let{oldPath:c,newPath:f}=l.data;console.debug(`Rename "${c}" to ${f}`),re(t,c,f),_.postMessage({type:"reply"});break}case"file:unlink":{let{path:c}=l.data;console.debug(`Remove "${c}`),t.FS.unlink(c),_.postMessage({type:"reply"});break}case"install":{let{requirements:c}=l.data,f=t.pyimport("micropip");console.debug("Install the requirements:",c),q(c),await f.install.callKwargs(c,{keep_going:!0}).then(()=>{if(c.includes("matplotlib"))return t.runPythonAsync(`
|
|
116
116
|
from stlite_server.bootstrap import _fix_matplotlib_crash
|
|
117
117
|
_fix_matplotlib_crash()
|
|
118
|
-
`)}).then(()=>{console.debug("Successfully installed"),_.postMessage({type:"reply"})})}}}catch(c){if(console.error(c),!(c instanceof Error))throw c;let f=new Error(c.message);f.name=c.name,f.stack=c.stack,_.postMessage({type:"reply",error:f})}};return e({type:"event:start"}),p}function
|
|
118
|
+
`)}).then(()=>{console.debug("Successfully installed"),_.postMessage({type:"reply"})})}}}catch(c){if(console.error(c),!(c instanceof Error))throw c;let f=new Error(c.message);f.name=c.name,f.stack=c.stack,_.postMessage({type:"reply",error:f})}};return e({type:"event:start"}),p}function ve(){let o=process.env.NODEFS_MOUNTPOINTS;if(!o)return;let e;try{e=JSON.parse(o)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${o}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${o}`);return}if(Object.keys(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${o}`);return}if(Object.values(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${o}`);return}}function be(o){console.debug("[worker thread] postMessage from worker",o),$.parentPort?.postMessage(o)}var we=oe(process.env.PYODIDE_URL,be,{nodefsMountpoints:ve()});$.parentPort?.on("message",({data:o,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:o,port:e}),we({data:o,ports:[e]})});
|
package/build/index.html
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
<!doctype html><html lang="en"><head><meta charset="utf-8"/><meta name="viewport" content="width=device-width,initial-scale=1"/><title>stlite</title><script defer="defer" src="/static/js/main.
|
|
1
|
+
<!doctype html><html lang="en"><head><meta charset="utf-8"/><meta name="viewport" content="width=device-width,initial-scale=1"/><title>stlite</title><script defer="defer" src="/static/js/main.5d08bd7f.js"></script><link href="/static/css/main.fb5f4d99.css" rel="stylesheet"></head><body><noscript>You need to enable JavaScript to run this app.</noscript><div id="root"></div></body></html>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(()=>{"use strict";var e={56977:e=>{function t(e){if("string"!==typeof e)throw new TypeError("Path must be a string. Received "+JSON.stringify(e))}function n(e,t){for(var n,r="",o=0,s=-1,a=0,i=0;i<=e.length;++i){if(i<e.length)n=e.charCodeAt(i);else{if(47===n)break;n=47}if(47===n){if(s===i-1||1===a);else if(s!==i-1&&2===a){if(r.length<2||2!==o||46!==r.charCodeAt(r.length-1)||46!==r.charCodeAt(r.length-2))if(r.length>2){var l=r.lastIndexOf("/");if(l!==r.length-1){-1===l?(r="",o=0):o=(r=r.slice(0,l)).length-1-r.lastIndexOf("/"),s=i,a=0;continue}}else if(2===r.length||1===r.length){r="",o=0,s=i,a=0;continue}t&&(r.length>0?r+="/..":r="..",o=2)}else r.length>0?r+="/"+e.slice(s+1,i):r=e.slice(s+1,i),o=i-s-1;s=i,a=0}else 46===n&&-1!==a?++a:a=-1}return r}var r={resolve:function(){for(var e,r="",o=!1,s=arguments.length-1;s>=-1&&!o;s--){var a;s>=0?a=arguments[s]:(void 0===e&&(e=process.cwd()),a=e),t(a),0!==a.length&&(r=a+"/"+r,o=47===a.charCodeAt(0))}return r=n(r,!o),o?r.length>0?"/"+r:"/":r.length>0?r:"."},normalize:function(e){if(t(e),0===e.length)return".";var r=47===e.charCodeAt(0),o=47===e.charCodeAt(e.length-1);return 0!==(e=n(e,!r)).length||r||(e="."),e.length>0&&o&&(e+="/"),r?"/"+e:e},isAbsolute:function(e){return t(e),e.length>0&&47===e.charCodeAt(0)},join:function(){if(0===arguments.length)return".";for(var e,n=0;n<arguments.length;++n){var o=arguments[n];t(o),o.length>0&&(void 0===e?e=o:e+="/"+o)}return void 0===e?".":r.normalize(e)},relative:function(e,n){if(t(e),t(n),e===n)return"";if((e=r.resolve(e))===(n=r.resolve(n)))return"";for(var o=1;o<e.length&&47===e.charCodeAt(o);++o);for(var s=e.length,a=s-o,i=1;i<n.length&&47===n.charCodeAt(i);++i);for(var l=n.length-i,c=a<l?a:l,g=-1,d=0;d<=c;++d){if(d===c){if(l>c){if(47===n.charCodeAt(i+d))return n.slice(i+d+1);if(0===d)return n.slice(i+d)}else a>c&&(47===e.charCodeAt(o+d)?g=d:0===d&&(g=0));break}var p=e.charCodeAt(o+d);if(p!==n.charCodeAt(i+d))break;47===p&&(g=d)}var u="";for(d=o+g+1;d<=s;++d)d!==s&&47!==e.charCodeAt(d)||(0===u.length?u+="..":u+="/..");return u.length>0?u+n.slice(i+g):(i+=g,47===n.charCodeAt(i)&&++i,n.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(t(e),0===e.length)return".";for(var n=e.charCodeAt(0),r=47===n,o=-1,s=!0,a=e.length-1;a>=1;--a)if(47===(n=e.charCodeAt(a))){if(!s){o=a;break}}else s=!1;return-1===o?r?"/":".":r&&1===o?"//":e.slice(0,o)},basename:function(e,n){if(void 0!==n&&"string"!==typeof n)throw new TypeError('"ext" argument must be a string');t(e);var r,o=0,s=-1,a=!0;if(void 0!==n&&n.length>0&&n.length<=e.length){if(n.length===e.length&&n===e)return"";var i=n.length-1,l=-1;for(r=e.length-1;r>=0;--r){var c=e.charCodeAt(r);if(47===c){if(!a){o=r+1;break}}else-1===l&&(a=!1,l=r+1),i>=0&&(c===n.charCodeAt(i)?-1===--i&&(s=r):(i=-1,s=l))}return o===s?s=l:-1===s&&(s=e.length),e.slice(o,s)}for(r=e.length-1;r>=0;--r)if(47===e.charCodeAt(r)){if(!a){o=r+1;break}}else-1===s&&(a=!1,s=r+1);return-1===s?"":e.slice(o,s)},extname:function(e){t(e);for(var n=-1,r=0,o=-1,s=!0,a=0,i=e.length-1;i>=0;--i){var l=e.charCodeAt(i);if(47!==l)-1===o&&(s=!1,o=i+1),46===l?-1===n?n=i:1!==a&&(a=1):-1!==n&&(a=-1);else if(!s){r=i+1;break}}return-1===n||-1===o||0===a||1===a&&n===o-1&&n===r+1?"":e.slice(n,o)},format:function(e){if(null===e||"object"!==typeof e)throw new TypeError('The "pathObject" argument must be of type Object. Received type '+typeof e);return function(e,t){var n=t.dir||t.root,r=t.base||(t.name||"")+(t.ext||"");return n?n===t.root?n+r:n+e+r:r}("/",e)},parse:function(e){t(e);var n={root:"",dir:"",base:"",ext:"",name:""};if(0===e.length)return n;var r,o=e.charCodeAt(0),s=47===o;s?(n.root="/",r=1):r=0;for(var a=-1,i=0,l=-1,c=!0,g=e.length-1,d=0;g>=r;--g)if(47!==(o=e.charCodeAt(g)))-1===l&&(c=!1,l=g+1),46===o?-1===a?a=g:1!==d&&(d=1):-1!==a&&(d=-1);else if(!c){i=g+1;break}return-1===a||-1===l||0===d||1===d&&a===l-1&&a===i+1?-1!==l&&(n.base=n.name=0===i&&s?e.slice(1,l):e.slice(i,l)):(0===i&&s?(n.name=e.slice(1,a),n.base=e.slice(1,l)):(n.name=e.slice(i,a),n.base=e.slice(i,l)),n.ext=e.slice(a,l)),i>0?n.dir=e.slice(0,i-1):s&&(n.dir="/"),n},sep:"/",delimiter:":",win32:null,posix:null};r.posix=r,e.exports=r}},t={};function n(r){var o=t[r];if(void 0!==o)return o.exports;var s=t[r]={exports:{}};return e[r](s,s.exports,n),s.exports}n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.g=function(){if("object"===typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"===typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{class e{constructor(){this.promise=new Promise(((e,t)=>{this.resolveInternal=e,this.rejectInternal=t}))}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}}var t=n(56977),r=n.n(t);function o(e,t){const n=r().normalize(t),o=r().dirname(n).split("/"),s=[];for(const r of o){s.push(r);const t=s.join("/");if(e.FS.analyzePath(t).exists){if(e.FS.isDir(t))throw new Error(`"${t}" already exists and is not a directory.`)}else try{e.FS.mkdir(t)}catch(a){throw console.error(`Failed to create a directory "${t}"`),a}}}function s(e,t,n,r){o(e,t),e.FS.writeFile(t,n,r)}function a(e){e.forEach((e=>{let t;try{t=new URL(e)}catch{return}if("emfs:"===t.protocol||"file:"===t.protocol)throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${e})`)}))}function i(e){e.runPython('\nimport micropip\nmicropip.add_mock_package(\n "pyarrow", "0.0.1",\n modules={\n "pyarrow": """\n__version__ = \'0.0.1\' # TODO: Update when releasing\n\n\nclass Table:\n @classmethod\n def from_pandas(*args, **kwargs):\n raise NotImplementedError("stlite is not supporting this method.")\n"""\n }\n)\n')}var l=function(e,t,n,r){return new(n||(n=Promise))((function(o,s){function a(e){try{l(r.next(e))}catch(t){s(t)}}function i(e){try{l(r.throw(e))}catch(t){s(t)}}function l(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(a,i)}l((r=r.apply(e,t||[])).next())}))};const c=n.g;self.onmessage=function(t,n,r){function g(e){n({type:"event:progress",data:{message:e}})}let d,p;const u=new e,h=function(){var e,o;return l(this,void 0,void 0,(function*(){const h=yield u.promise,m=Object.assign(Object.assign({},r),h);console.debug("Initial data",m);const{entrypoint:f,files:_,archives:y,requirements:b,prebuiltPackageNames:v,wheels:k,mountedSitePackagesSnapshotFilePath:w,pyodideUrl:S=t,streamlitConfig:A,idbfsMountpoints:P,nodefsMountpoints:C}=m;g("Loading Pyodide."),console.debug("Loading Pyodide"),d=yield function(e,t){return l(this,void 0,void 0,(function*(){const n=e.slice(0,e.lastIndexOf("/")+1);let r;return e.endsWith(".mjs")?r=(yield import(e)).loadPyodide:(importScripts(e),r=c.loadPyodide),r(Object.assign(Object.assign({},t),{indexURL:n}))}))}(S,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let F=!1;if(P&&(F=!0,P.forEach((e=>{d.FS.mkdir(e),d.FS.mount(d.FS.filesystems.IDBFS,{},e)})),yield new Promise(((e,t)=>{d.FS.syncfs(!0,(n=>{n?t(n):e()}))}))),C&&Object.entries(C).forEach((([e,t])=>{d.FS.mkdir(e),d.FS.mount(d.FS.filesystems.NODEFS,{root:t},e)})),g("Mounting files."),yield Promise.all(Object.keys(_).map((e=>l(this,void 0,void 0,(function*(){const t=_[e];let n;"url"in t?(console.debug(`Fetch a file from ${t.url}`),n=yield fetch(t.url).then((e=>e.arrayBuffer())).then((e=>new Uint8Array(e)))):n=t.data;const{opts:r}=_[e];console.debug(`Write a file "${e}"`),s(d,e,n,r)}))))),g("Unpacking archives."),yield Promise.all(y.map((e=>l(this,void 0,void 0,(function*(){let t;"url"in e?(console.debug(`Fetch an archive from ${e.url}`),t=yield fetch(e.url).then((e=>e.arrayBuffer()))):t=e.buffer;const{format:n,options:r}=e;console.debug("Unpack an archive",{format:n,options:r}),d.unpackArchive(t,n,r)}))))),!w&&!k)throw new Error("Neither snapshot nor wheel files are provided.");w&&(g("Restoring the snapshot."),yield d.runPythonAsync("import tarfile, shutil, site"),yield d.runPythonAsync("\nsite_packages_dirs = site.getsitepackages()\nfor site_packages in site_packages_dirs:\n shutil.rmtree(site_packages)\n"),console.debug(`Unarchive ${w}`),yield d.runPythonAsync(`\nwith tarfile.open("${w}", "r") as tar_gz_file:\n tar_gz_file.extractall("/")\n`),console.debug("Restored the snapshot"),g("Mocking some packages."),console.debug("Mock pyarrow"),i(d),console.debug("Mocked pyarrow")),a(b),g("Installing packages."),console.debug("Installing the prebuilt packages:",v),yield d.loadPackage(v),console.debug("Installed the prebuilt packages"),yield d.loadPackage("micropip");const O=d.pyimport("micropip");k?(console.debug("Installing the wheels:",k,"and the requirements:",b),yield O.install.callKwargs([k.stliteServer,k.streamlit,...b],{keep_going:!0}),console.debug("Installed the wheels and the requirements"),g("Mocking some packages."),console.debug("Mock pyarrow"),i(d),console.debug("Mocked pyarrow")):(console.debug("Installing the requirements:",b),yield O.install.callKwargs(b,{keep_going:!0}),console.debug("Installed the requirements")),yield d.runPythonAsync("\nimport importlib\nimportlib.invalidate_caches()\n"),g("Loading streamlit package."),console.debug("Loading the Streamlit package"),yield d.runPythonAsync("\nimport streamlit.runtime\n "),console.debug("Loaded the Streamlit package"),g("Setting up the loggers."),console.debug("Setting the loggers"),yield d.runPythonAsync('\nimport logging\nimport streamlit.logger\n\nstreamlit.logger.get_logger = logging.getLogger\nstreamlit.logger.setup_formatter = None\nstreamlit.logger.update_formatter = lambda *a, **k: None\nstreamlit.logger.set_log_level = lambda *a, **k: None\n\nfor name in streamlit.logger._loggers.keys():\n if name == "root":\n name = "streamlit"\n logger = logging.getLogger(name)\n logger.propagate = True\n logger.handlers.clear()\n logger.setLevel(logging.NOTSET)\n\nstreamlit.logger._loggers = {}\n');c.__logCallback__=(e,t)=>{e>=40?console.error(t):e>=30?console.warn(t):e>=20?console.info(t):console.debug(t)},yield d.runPythonAsync('\ndef setup_loggers(streamlit_level, streamlit_message_format):\n from js import __logCallback__\n\n\n class JsHandler(logging.Handler):\n def emit(self, record):\n msg = self.format(record)\n __logCallback__(record.levelno, msg)\n\n\n root_message_format = "%(levelname)s:%(name)s:%(message)s"\n\n root_logger = logging.getLogger()\n root_logger.handlers.clear()\n root_formatter = logging.Formatter(root_message_format)\n root_handler = JsHandler()\n root_handler.setFormatter(root_formatter)\n root_logger.addHandler(root_handler)\n root_logger.setLevel(logging.DEBUG)\n\n streamlit_logger = logging.getLogger("streamlit")\n streamlit_logger.propagate = False\n streamlit_logger.handlers.clear()\n streamlit_formatter = logging.Formatter(streamlit_message_format)\n streamlit_handler = JsHandler()\n streamlit_handler.setFormatter(streamlit_formatter)\n streamlit_logger.addHandler(streamlit_handler)\n streamlit_logger.setLevel(streamlit_level.upper())\n');const j=(null!==(e=null===A||void 0===A?void 0:A["logger.level"])&&void 0!==e?e:"INFO").toString(),x=null!==(o=null===A||void 0===A?void 0:A["logger.messageFormat"])&&void 0!==o?o:"%(asctime)s %(message)s";if(d.globals.get("setup_loggers")(j,x),console.debug("Set the loggers"),g("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),yield d.runPythonAsync("\nimport streamlit\n\ndef is_cacheable_msg(msg):\n return False\n\nstreamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg\n"),console.debug("Mocked some Streamlit functions"),F){g("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let e=!1;c.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),e||(e=!0,d.FS.syncfs(!1,(t=>{e=!1,t&&console.error(t)})))},yield d.runPythonAsync('\nfrom streamlit.runtime.app_session import AppSession\nfrom streamlit.runtime.scriptrunner import ScriptRunnerEvent\nfrom js import __scriptFinishedCallback__\n\ndef wrap_app_session_on_scriptrunner_event(original_method):\n def wrapped(self, *args, **kwargs):\n if "event" in kwargs:\n event = kwargs["event"]\n if event == ScriptRunnerEvent.SCRIPT_STOPPED_WITH_SUCCESS or event == ScriptRunnerEvent.SCRIPT_STOPPED_FOR_RERUN or event == ScriptRunnerEvent.SHUTDOWN:\n __scriptFinishedCallback__()\n return original_method(self, *args, **kwargs)\n return wrapped\n\nAppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)\n'),console.debug("Set up the IndexedDB filesystem synchronizer")}g("Booting up the Streamlit server."),console.debug("Booting up the Streamlit server"),c.__streamlitFlagOptions__=Object.assign(Object.assign({"browser.gatherUsageStats":!1},A),{"runner.fastReruns":!1}),yield d.runPythonAsync(`\nfrom stlite_server.bootstrap import load_config_options, prepare\nfrom stlite_server.server import Server\nfrom js import __streamlitFlagOptions__\n\nflag_options = __streamlitFlagOptions__.to_py()\nload_config_options(flag_options)\n\nmain_script_path = "${f}"\ncommand_line = None\nargs = []\n\nprepare(main_script_path, args)\n\nserver = Server(main_script_path, command_line)\nserver.start()\n`),console.debug("Booted up the Streamlit server"),console.debug("Setting up the HTTP server"),p=d.globals.get("server").copy(),console.debug("Set up the HTTP server"),n({type:"event:loaded"})}))}().catch((e=>{throw n({type:"event:error",data:{error:e}}),e}));return n({type:"event:start"}),e=>l(this,void 0,void 0,(function*(){const t=e.data;if("initData"===t.type)return void u.resolve(t.data);yield h;const r=e.ports[0];try{switch(t.type){case"websocket:connect":{console.debug("websocket:connect",t.data);const{path:e}=t.data;p.start_websocket(e,((e,t)=>{if(t){const t=e.getBuffer("u8");e.destroy();const r=new Uint8ClampedArray(t.data.buffer,t.data.byteOffset,t.data.byteLength);n({type:"websocket:message",data:{payload:new Uint8Array(r)}})}else n({type:"websocket:message",data:{payload:e}})})),r.postMessage({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",t.data);const{payload:e}=t.data;p.receive_websocket_from_js(e);break}case"http:request":{console.debug("http:request",t.data);const{request:e}=t.data,n=(e,t,n)=>{const o=t.toJs(),s=n.toJs();console.debug({statusCode:e,headers:o,body:s});const a={type:"http:response",data:{response:{statusCode:e,headers:o,body:s}}};r.postMessage(a)};p.receive_http_from_js(e.method,decodeURIComponent(e.path),e.headers,e.body,n);break}case"file:write":{const{path:e,data:n,opts:o}=t.data;console.debug(`Write a file "${e}"`),s(d,e,n,o),r.postMessage({type:"reply"});break}case"file:rename":{const{oldPath:e,newPath:n}=t.data;console.debug(`Rename "${e}" to ${n}`),function(e,t,n){o(e,n),e.FS.rename(t,n)}(d,e,n),r.postMessage({type:"reply"});break}case"file:unlink":{const{path:e}=t.data;console.debug(`Remove "${e}`),d.FS.unlink(e),r.postMessage({type:"reply"});break}case"install":{const{requirements:e}=t.data,n=d.pyimport("micropip");console.debug("Install the requirements:",e),a(e),yield n.install.callKwargs(e,{keep_going:!0}).then((()=>{if(e.includes("matplotlib"))return d.runPythonAsync("\nfrom stlite_server.bootstrap import _fix_matplotlib_crash\n_fix_matplotlib_crash()\n")})).then((()=>{console.debug("Successfully installed"),r.postMessage({type:"reply"})}))}}}catch(i){if(console.error(i),!(i instanceof Error))throw i;const e=new Error(i.message);e.name=i.name,e.stack=i.stack,r.postMessage({type:"reply",error:e})}}))}("https://cdn.jsdelivr.net/pyodide/v0.25.0/full/pyodide.js",self.postMessage)})()})();
|