@stlite/desktop 0.50.0 → 0.51.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/README.md CHANGED
@@ -24,7 +24,7 @@ Convert your [Streamlit](https://streamlit.io/) application into a desktop app w
24
24
  }
25
25
  },
26
26
  "devDependencies": {
27
- "@stlite/desktop": "^0.48.0",
27
+ "@stlite/desktop": "^0.51.0",
28
28
  "cross-env": "^7.0.3",
29
29
  "electron": "^28.2.1",
30
30
  "electron-builder": "^24.9.1"
@@ -56,7 +56,9 @@ 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
- ## Hide the toolbar, hamburger menu, and the footer
59
+ ## Configure app
60
+
61
+ ### Hide the toolbar, hamburger menu, and the footer
60
62
 
61
63
  If you want to hide the toolbar, hamburger menu, and the footer, add the following to your `package.json` file and run the `dump` command again. By adding the `stlite.desktop.embed` field, the dumped Streamlit app will work in the [embed mode](https://docs.streamlit.io/streamlit-community-cloud/get-started/embed-your-app#embedding-with-iframes) which hides the toolbar, hamburger menu, and the footer.
62
64
 
@@ -71,13 +73,22 @@ If you want to hide the toolbar, hamburger menu, and the footer, add the followi
71
73
  }
72
74
  ```
73
75
 
74
- ## Data persistence
76
+ ### File system
77
+
78
+ _stlite_ runs your Python code on [Pyodide](https://pyodide.org/), a CPython runtime compiled to Wasm, and Pyodide's backend, Emscripten, provides a virtual file system.
79
+ When _stlite_ runs your app, it mounts the source files onto the virtual file system, and what your Python code can access (e.g. `open("/path/to/something")`) is files and directories on the virtual file system.
80
+
81
+ The default file system ([`MEMFS`](https://emscripten.org/docs/api_reference/Filesystem-API.html#memfs)) is ephemeral, so the files saved in the directories are lost when the app is restarted. If you want to persist the files across the app restarts, you can use the IndexedDB-based file system ([`IDBFS`](https://emscripten.org/docs/api_reference/Filesystem-API.html#filesystem-api-idbfs)) or mount directories on the host OS file system to directories on the virtual file system.
75
82
 
76
- You can mount the IndexedDB-based file system ([`IDBFS`](https://emscripten.org/docs/api_reference/Filesystem-API.html#filesystem-api-idbfs)) to the specified directories by adding the `stlite.desktop.idbfsMountpoints` field to your `package.json`. Note that you have to run the `dump` command again to apply the change.
83
+ #### File persistence with IndexedDB backend
77
84
 
78
- The mounted file system is persistent across the app restarts, while the default file system ([`MEMFS`](https://emscripten.org/docs/api_reference/Filesystem-API.html#memfs)) is ephemeral.
85
+ You can mount the IndexedDB-based file system ([`IDBFS`](https://emscripten.org/docs/api_reference/Filesystem-API.html#filesystem-api-idbfs)) to directories on the virtual file system that your Python code can access, e.g. `open("/path/to/file")`.
86
+ You can specify the mount points via the `stlite.desktop.idbfsMountpoints` field in your `package.json` like below.
87
+ Note that you have to run the `dump` command again to apply the change.
79
88
 
80
- In the example below, the IndexedDB-based file system is mounted to the `/mnt` directory so that the files saved in the directory are persistent.
89
+ The mounted file system is backed by IndexedDB and its data is stored in the browser's IndexedDB, so the files saved in the directories are persistent across the app restarts.
90
+
91
+ In the example below, the IndexedDB-based file system is mounted to the `/mnt` directory on the virtual file system, so that the files saved in the directory are persistent.
81
92
 
82
93
  ```json
83
94
  {
@@ -90,6 +101,50 @@ In the example below, the IndexedDB-based file system is mounted to the `/mnt` d
90
101
  }
91
102
  ```
92
103
 
104
+ #### Local file access
105
+
106
+ You can mount directories on the host OS file system to directories on the virtual file system.
107
+
108
+ To do this, you have to enable the Node.js worker mode (see the next section for details) and specify the mount points via the `stlite.desktop.nodefsMountpoints` field in your `package.json` like below.
109
+
110
+ The `nodefsMountpoints` field is an object that maps the virtual file system paths to the host OS paths.
111
+
112
+ In the example below, `"."` on the host OS file system is mounted to the `/mnt` directory on the virtual file system, so your app can access the files in `"."` on the host OS by accessing the files in `/mnt` on the virtual file system.
113
+
114
+ ```json
115
+ {
116
+ // ...other fields...
117
+ "stlite": {
118
+ "desktop": {
119
+ "nodeJsWorker": true,
120
+ "nodefsMountpoints": {
121
+ "/mnt": "."
122
+ }
123
+ }
124
+ }
125
+ }
126
+ ```
127
+
128
+ #### NodeJS worker mode
129
+
130
+ `@stlite/desktop` runs your app on [Electron](https://www.electronjs.org/) as a desktop app.
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.
132
+
133
+ By default, _stlite_ executes your Python code on Pyodide running in a [Web Worker](https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API) dispatched by the renderer process, and the renderer process is a browser process so it's sandboxed from the host OS.
134
+
135
+ When you set the `stlite.desktop.nodeJsWorker` field in your `package.json` to `true`, _stlite_ dispatches the worker as a [NodeJS worker](https://nodejs.org/api/worker_threads.html) that runs in the main process, which is not sandboxed, so you can mount the host OS file system to the virtual file system as described in the previous section.
136
+
137
+ ```json
138
+ {
139
+ // ...other fields...
140
+ "stlite": {
141
+ "desktop": {
142
+ "nodeJsWorker": true
143
+ }
144
+ }
145
+ }
146
+ ```
147
+
93
148
  ## Limitations
94
149
 
95
150
  - Navigation to external resources like `st.markdown("[link](https://streamlit.io/)")` does not work for security. See https://github.com/whitphx/stlite/pull/445 and let us know if you have use cases where you have to use such external links.
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
- var E=Object.create;var T=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var H=Object.getOwnPropertyNames;var W=Object.getPrototypeOf,A=Object.prototype.hasOwnProperty;var m=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var J=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of H(t))!A.call(e,a)&&a!==i&&T(e,a,{get:()=>t[a],enumerable:!(r=C(t,a))||r.enumerable});return e};var p=(e,t,i)=>(i=e!=null?E(W(e)):{},J(t||!e||!e.__esModule?T(i,"default",{value:e,enumerable:!0}):i,e));var q=m(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.verifyRequirements=void 0;function U(e){e.forEach(t=>{let i;try{i=new URL(t)}catch{return}if(i.protocol==="emfs:"||i.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)})}g.verifyRequirements=U});var O=m(h=>{"use strict";Object.defineProperty(h,"__esModule",{value:!0});h.parseRequirementsTxt=void 0;var L=/\s#.*$/;function z(e){return e.split(`
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"),k=p(S());var I=require("pyodide");function w(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=w("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 G(e){console.info("Copy the build directory (the bare built app files) to this directory...");let t=o.default.resolve(__dirname,K);if(!(await n.default.stat(t)).isDirectory())throw new Error(`The source ${t} does not exist.`);if(t===e.copyTo){console.warn(`sourceDir == destDir (${t}). Are you in the development environment? Skip copying the directory.`);return}if(e.keepOld)try{await n.default.access(e.copyTo),console.info(`${e.copyTo} already exists. Use it and skip copying.`);return}catch{throw new Error(`${e.copyTo} does not exist even though the \`keepOld\` option is specified`)}console.log(`Copy ${t} to ${e.copyTo}`),await n.default.rm(e.copyTo,{recursive:!0,force:!0}),await _.default.copy(t,e.copyTo)}async function Q(e){if(e.requirements.length===0)return[];let t=await(0,b.loadPyodide)();return await x(t,{requirements:e.requirements}),Object.entries(t.loadedPackages).filter(([,i])=>i==="default channel").map(([i])=>i)}async function j(e,t){console.log(`Preparing the local wheel ${t}`);let i=await n.default.readFile(t),r="/tmp/"+o.default.basename(t);e.FS.writeFile(r,i);let a=`emfs:${r}`;return console.log(`The local wheel ${t} is prepared as ${a}`),a}async function x(e,t){await R(e,"micropip");let i=e.pyimport("micropip"),r=[...t.requirements],a=o.default.join(__dirname,V),s=await j(e,o.default.join(a,"stlite_server-0.1.0-py3-none-any.whl"));r.push(s);let l=await j(e,o.default.join(a,"streamlit-1.32.2-cp311-none-any.whl"));r.push(l),console.log("Install the packages:",r),await i.install.callKwargs(r,{keep_going:!0})}async function X(e){console.info("Create the site-packages snapshot file...");let t=await(0,b.loadPyodide)();await R(t,"micropip");let i=t.pyimport("micropip"),r=await f.getInstance(),a=[];e.usedBuiltinPackages.length>0&&(console.log("Mocking builtin 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..."),e.usedBuiltinPackages.forEach(u=>{let d=r.getPackageInfoByName(u);if(d==null)throw new Error(`Package ${u} is not found in the lock file.`);console.log(`Mock ${d.name} ${d.version}`),i.add_mock_package(d.name,d.version),a.push(d.name)})),console.log(`Install the requirements ${JSON.stringify(e.requirements)}`),await x(t,{requirements:e.requirements}),console.log("Remove the mocked packages",a),a.forEach(u=>i.remove_mock_package(u)),console.log("Archive the site-packages director(y|ies)");let s="/tmp/site-packages-snapshot.tar.gz";await t.runPythonAsync(`
2
+ "use strict";var E=Object.create;var T=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var W=Object.getOwnPropertyNames;var H=Object.getPrototypeOf,J=Object.prototype.hasOwnProperty;var m=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var A=(e,t,i,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of W(t))!J.call(e,a)&&a!==i&&T(e,a,{get:()=>t[a],enumerable:!(r=C(t,a))||r.enumerable});return e};var p=(e,t,i)=>(i=e!=null?E(H(e)):{},A(t||!e||!e.__esModule?T(i,"default",{value:e,enumerable:!0}):i,e));var q=m(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.verifyRequirements=void 0;function U(e){e.forEach(t=>{let i;try{i=new URL(t)}catch{return}if(i.protocol==="emfs:"||i.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)})}g.verifyRequirements=U});var O=m(h=>{"use strict";Object.defineProperty(h,"__esModule",{value:!0});h.parseRequirementsTxt=void 0;var L=/\s#.*$/;function z(e){return e.split(`
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 G(e){console.info("Copy the build directory (the bare built app files) to this directory...");let t=o.default.resolve(__dirname,K);if(!(await n.default.stat(t)).isDirectory())throw new Error(`The source ${t} does not exist.`);if(t===e.copyTo){console.warn(`sourceDir == destDir (${t}). Are you in the development environment? Skip copying the directory.`);return}if(e.keepOld)try{await n.default.access(e.copyTo),console.info(`${e.copyTo} already exists. Use it and skip copying.`);return}catch{throw new Error(`${e.copyTo} does not exist even though the \`keepOld\` option is specified`)}console.log(`Copy ${t} to ${e.copyTo}`),await n.default.rm(e.copyTo,{recursive:!0,force:!0}),await _.default.copy(t,e.copyTo)}async function Q(e){if(e.requirements.length===0)return[];let t=await(0,b.loadPyodide)();return await x(t,{requirements:e.requirements}),Object.entries(t.loadedPackages).filter(([,i])=>i==="default channel").map(([i])=>i)}async function j(e,t){console.log(`Preparing the local wheel ${t}`);let i=await n.default.readFile(t),r="/tmp/"+o.default.basename(t);e.FS.writeFile(r,i);let a=`emfs:${r}`;return console.log(`The local wheel ${t} is prepared as ${a}`),a}async function x(e,t){await R(e,"micropip");let i=e.pyimport("micropip"),r=[...t.requirements],a=o.default.join(__dirname,V),s=await j(e,o.default.join(a,"stlite_server-0.1.0-py3-none-any.whl"));r.push(s);let l=await j(e,o.default.join(a,"streamlit-1.32.2-cp311-none-any.whl"));r.push(l),console.log("Install the packages:",r),await i.install.callKwargs(r,{keep_going:!0})}async function X(e){console.info("Create the site-packages snapshot file...");let t=await(0,b.loadPyodide)();await R(t,"micropip");let i=t.pyimport("micropip"),r=await f.getInstance(),a=[];e.usedBuiltinPackages.length>0&&(console.log("Mocking builtin 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..."),e.usedBuiltinPackages.forEach(d=>{let u=r.getPackageInfoByName(d);if(u==null)throw new Error(`Package ${d} is not found in the lock file.`);console.log(`Mock ${u.name} ${u.version}`),i.add_mock_package(u.name,u.version),a.push(u.name)})),console.log(`Install the requirements ${JSON.stringify(e.requirements)}`),await x(t,{requirements:e.requirements}),console.log("Remove the mocked packages",a),a.forEach(d=>i.remove_mock_package(d)),console.log("Archive the site-packages director(y|ies)");let s="/tmp/site-packages-snapshot.tar.gz";await t.runPythonAsync(`
5
5
  import os
6
6
  import tarfile
7
7
  import site
@@ -14,5 +14,5 @@ var E=Object.create;var T=Object.defineProperty;var C=Object.getOwnPropertyDescr
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 l=t.FS.readFile(s);console.log(`Save the archive file (${e.saveTo})`),await n.default.writeFile(e.saveTo,l)}async function Y(e){console.info("Copy the Streamlit app directory..."),console.log(`Copy ${e.sourceDir} to ${e.copyTo}`),await n.default.rm(e.copyTo,{recursive:!0,force:!0}),await _.default.copy(e.sourceDir,e.copyTo)}async function Z(e){let t=await n.default.readFile(e,{encoding:"utf-8"});return(0,k.parseRequirementsTxt)(t)}async function ee(e,t){let i=t.join(`
18
- `);await n.default.writeFile(e,i,{encoding:"utf-8"})}async function te(e){let t=await f.getInstance(),r=e.packages.map(a=>t.getPackageInfoByName(a)).map(a=>w(a.file_name));console.log("Downloading the used built-in packages..."),await Promise.all(r.map(async a=>{let s=o.default.resolve(e.destDir,"./pyodide",o.default.basename(a));console.log(`Download ${a} to ${s}`);let l=await(0,D.default)(a);if(!l.ok)throw new Error(`Failed to download ${a}: ${l.status} ${l.statusText}`);let u=await l.arrayBuffer();await n.default.writeFile(s,Buffer.from(u))}))}async function ie(e){let i=require(e.packageJsonPath).stlite?.desktop||{},r={embed:i.embed||!1,idbfsMountpoints:i.idbfsMountpoints},a=JSON.stringify(r,null,2);console.log(`Dump the manifest file -> ${e.manifestFilePath}`),console.log(a),await n.default.writeFile(e.manifestFilePath,a,{encoding:"utf-8"})}(0,F.default)((0,M.hideBin)(process.argv)).command("* <appHomeDirSource> [packages..]","Put the user code and data and the snapshot of the required packages into the build artifact.",()=>{},e=>{console.info(e)}).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 e=>{let t=process.cwd(),i=o.default.resolve(t,"./build");try{await n.default.access(e.appHomeDirSource)}catch{throw new Error(`${e.appHomeDirSource} does not exist.`)}let r=e.packages??[];for(let s of e.requirement)r=r.concat(await Z(s));(0,k.verifyRequirements)(r);let a=await Q({requirements:r});console.log("The built-in packages loaded for the given requirements:"),console.log(a),await G({copyTo:i,keepOld:e.keepOldBuild}),await X({requirements:r,usedBuiltinPackages:a,saveTo:o.default.resolve(i,"./site-packages-snapshot.tar.gz")}),await ee(o.default.resolve(i,"./requirements.txt"),a),await Y({sourceDir:e.appHomeDirSource,copyTo:o.default.resolve(i,"./streamlit_app")}),await te({packages:a,destDir:i}),await ie({packageJsonPath:o.default.resolve(t,"./package.json"),manifestFilePath:o.default.resolve(i,"./stlite-manifest.json")})});
17
+ `),console.log("Extract the archive file from EMFS");let l=t.FS.readFile(s);console.log(`Save the archive file (${e.saveTo})`),await n.default.writeFile(e.saveTo,l)}async function Y(e){console.info("Copy the Streamlit app directory..."),console.log(`Copy ${e.sourceDir} to ${e.copyTo}`),await n.default.rm(e.copyTo,{recursive:!0,force:!0}),await _.default.copy(e.sourceDir,e.copyTo)}async function Z(e){let t=await n.default.readFile(e,{encoding:"utf-8"});return(0,w.parseRequirementsTxt)(t)}async function ee(e,t){let i=t.join(`
18
+ `);await n.default.writeFile(e,i,{encoding:"utf-8"})}async function te(e){let t=await f.getInstance(),r=e.packages.map(a=>t.getPackageInfoByName(a)).map(a=>k(a.file_name));console.log("Downloading the used built-in packages..."),await Promise.all(r.map(async a=>{let s=o.default.resolve(e.destDir,"./pyodide",o.default.basename(a));console.log(`Download ${a} to ${s}`);let l=await(0,D.default)(a);if(!l.ok)throw new Error(`Failed to download ${a}: ${l.status} ${l.statusText}`);let d=await l.arrayBuffer();await n.default.writeFile(s,Buffer.from(d))}))}async function ie(e){let i=require(e.packageJsonPath).stlite?.desktop||{},r={embed:i.embed??!1,idbfsMountpoints:i.idbfsMountpoints,nodeJsWorker:i.nodeJsWorker??!1,nodefsMountpoints:i.nodefsMountpoints},a=JSON.stringify(r,null,2);console.log(`Dump the manifest file -> ${e.manifestFilePath}`),console.log(a),await n.default.writeFile(e.manifestFilePath,a,{encoding:"utf-8"})}(0,F.default)((0,M.hideBin)(process.argv)).command("* <appHomeDirSource> [packages..]","Put the user code and data and the snapshot of the required packages into the build artifact.",()=>{},e=>{console.info(e)}).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 e=>{let t=process.cwd(),i=o.default.resolve(t,"./build");try{await n.default.access(e.appHomeDirSource)}catch{throw new Error(`${e.appHomeDirSource} does not exist.`)}let r=e.packages??[];for(let s of e.requirement)r=r.concat(await Z(s));(0,w.verifyRequirements)(r);let a=await Q({requirements:r});console.log("The built-in packages loaded for the given requirements:"),console.log(a),await G({copyTo:i,keepOld:e.keepOldBuild}),await X({requirements:r,usedBuiltinPackages:a,saveTo:o.default.resolve(i,"./site-packages-snapshot.tar.gz")}),await ee(o.default.resolve(i,"./requirements.txt"),a),await Y({sourceDir:e.appHomeDirSource,copyTo:o.default.resolve(i,"./streamlit_app")}),await te({packages:a,destDir:i}),await ie({packageJsonPath:o.default.resolve(t,"./package.json"),manifestFilePath:o.default.resolve(i,"./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.f5170537.js",
5
- "static/js/3203.d0ce67f2.chunk.js": "/static/js/3203.d0ce67f2.chunk.js",
4
+ "main.js": "/static/js/main.b686df03.js",
5
+ "static/js/4681.fc821bbf.chunk.js": "/static/js/4681.fc821bbf.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.f5170537.js"
165
+ "static/js/main.b686df03.js"
166
166
  ]
167
167
  }
@@ -1,2 +1,2 @@
1
- var v=Object.create;var u=Object.defineProperty;var _=Object.getOwnPropertyDescriptor;var x=Object.getOwnPropertyNames;var R=Object.getPrototypeOf,y=Object.prototype.hasOwnProperty;var w=(e,t,n,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of x(t))!y.call(e,a)&&a!==n&&u(e,a,{get:()=>t[a],enumerable:!(s=_(t,a))||s.enumerable});return e};var m=(e,t,n)=>(n=e!=null?v(R(e)):{},w(t||!e||!e.__esModule?u(n,"default",{value:e,enumerable:!0}):n,e)),D=e=>w(u({},"__esModule",{value:!0}),e);var S={};module.exports=D(S);var r=require("electron"),o=m(require("path")),f=m(require("fs/promises"));var c=m(require("fs/promises")),l=m(require("path"));async function P(e){let t={},n=await c.readdir(e);return await Promise.all(n.map(async s=>{let a=l.join(e,s);if((await c.stat(a)).isDirectory()){let i=await P(a);Object.assign(t,i)}else{let i=await c.readFile(a);t[a]=i}})),t}async function g(e){let t=await P(e),n={};return Object.keys(t).forEach(s=>{let d=l.relative(e,s).split(l.sep).join(l.posix.sep);n[d]=t[s]}),n}async function F(){let e=o.resolve(__dirname,"../stlite-manifest.json"),t=await f.readFile(e,{encoding:"utf-8"}),n=JSON.parse(t);return{embed:n.embed??!1,idbfsMountpoints:n.idbfsMountpoints}}var b=async()=>{let e=await F(),t=new r.BrowserWindow({width:1280,height:720,webPreferences:{preload:o.join(__dirname,"preload.js"),sandbox:!0,additionalArguments:e.idbfsMountpoints?[`--idbfs-mountpoints=${JSON.stringify(e.idbfsMountpoints)}`]:void 0}}),n=new URL((r.app.isPackaged,"file:///index.html")),s=new URLSearchParams;e.embed&&s.set("embed","true"),n.search=s.toString();let a=n.toString(),d=i=>i.url===a;r.ipcMain.handle("readSitePackagesSnapshot",i=>{if(!d(i.senderFrame))throw new Error("Invalid IPC sender");let p=o.resolve(__dirname,"../site-packages-snapshot.tar.gz");return f.readFile(p)}),r.ipcMain.handle("readRequirements",async i=>{if(!d(i.senderFrame))throw new Error("Invalid IPC sender");let p=o.resolve(__dirname,"../requirements.txt");return(await f.readFile(p,{encoding:"utf-8"})).split(`
2
- `).map(h=>h.trim()).filter(h=>h.length>0)}),r.ipcMain.handle("readStreamlitAppDirectory",async i=>{if(!d(i.senderFrame))throw new Error("Invalid IPC sender");let p=o.resolve(__dirname,"../streamlit_app");return g(p)}),t.on("closed",()=>{r.ipcMain.removeHandler("readSitePackagesSnapshot"),r.ipcMain.removeHandler("readRequirements"),r.ipcMain.removeHandler("readStreamlitAppDirectory")}),t.loadURL(a),r.app.isPackaged||t.webContents.openDevTools()};r.app.enableSandbox();r.app.whenReady().then(()=>{let e=o.resolve(__dirname,"..");r.protocol.interceptFileProtocol("file",function(t,n){let s=new URL(t.url).pathname;if(o.isAbsolute(s)){let a=o.join(e,s);n(o.normalize(a))}else n(s)}),b(),r.app.on("activate",()=>{r.BrowserWindow.getAllWindows().length===0&&b()})});r.app.on("window-all-closed",()=>{process.platform!=="darwin"&&r.app.quit()});r.app.on("web-contents-created",(e,t)=>{t.on("will-attach-webview",(n,s,a)=>{n.preventDefault()}),t.on("will-navigate",(n,s)=>{console.debug("will-navigate",s),n.preventDefault()}),t.setWindowOpenHandler(({url:n})=>(console.error("Opening a new window is not allowed."),{action:"deny"}))});
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(d=>d.trim()).filter(d=>d.length>0)}),t.ipcMain.handle("readStreamlitAppDirectory",async i=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");let m=a.resolve(__dirname,"../streamlit_app");return _(m)}),n.on("closed",()=>{t.ipcMain.removeHandler("readSitePackagesSnapshot"),t.ipcMain.removeHandler("readRequirements"),t.ipcMain.removeHandler("readStreamlitAppDirectory")});let c=null;t.ipcMain.handle("initializeNodeJsWorker",i=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");let m=a.resolve(__dirname,"../pyodide/pyodide.mjs");function u(d){n.webContents.send("messageFromNodeJsWorker",d)}c=new v.default.Worker(a.resolve(__dirname,"./worker.js"),{env:{PYODIDE_URL:m,...e.nodefsMountpoints&&{NODEFS_MOUNTPOINTS:JSON.stringify(e.nodefsMountpoints)}}}),c.on("message",d=>{u(d)})}),t.ipcMain.on("messageToNodeJsWorker",(i,{data:m,portId:u})=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");if(c==null)return;let d=new v.default.MessageChannel;d.port1.on("message",F=>{i.reply(`nodeJsWorker-portMessage-${u}`,F)});let M={data:m,port:d.port2};c.postMessage(M,[d.port2])}),t.ipcMain.handle("terminate",(i,{data:m,portId:u})=>{if(!l(i.senderFrame))throw new Error("Invalid IPC sender");c?.terminate(),c=null}),n.on("closed",()=>{t.ipcMain.removeHandler("initializeNodeJsWorker"),t.ipcMain.removeHandler("messageToNodeJsWorker"),t.ipcMain.removeHandler("terminate")}),n.loadURL(h),t.app.isPackaged||n.webContents.openDevTools()};t.app.enableSandbox();t.app.whenReady().then(()=>{let e=a.resolve(__dirname,"..");t.protocol.interceptFileProtocol("file",function(r,n){let o=new URL(r.url).pathname;if(a.isAbsolute(o)){let s=a.join(e,o);n(a.normalize(s))}else n(o)}),y(),t.app.on("activate",()=>{t.BrowserWindow.getAllWindows().length===0&&y()})});t.app.on("window-all-closed",()=>{process.platform!=="darwin"&&t.app.quit()});t.app.on("web-contents-created",(e,r)=>{r.on("will-attach-webview",(n,o,s)=>{n.preventDefault()}),r.on("will-navigate",(n,o)=>{console.debug("will-navigate",o),n.preventDefault()}),r.setWindowOpenHandler(({url:n})=>(console.error("Opening a new window is not allowed."),{action:"deny"}))});
@@ -1 +1 @@
1
- var n=Object.defineProperty;var a=Object.getOwnPropertyDescriptor;var d=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var f=(e,i,s,r)=>{if(i&&typeof i=="object"||typeof i=="function")for(let o of d(i))!c.call(e,o)&&o!==s&&n(e,o,{get:()=>i[o],enumerable:!(r=a(i,o))||r.enumerable});return e};var g=e=>f(n({},"__esModule",{value:!0}),e);var k={};module.exports=g(k);var t=require("electron"),p=process.argv.find(e=>e.startsWith("--idbfs-mountpoints="))?.split("=")[1],m=p&&JSON.parse(p),S={idbfsMountpoints:m};t.contextBridge.exposeInMainWorld("appConfig",S);t.contextBridge.exposeInMainWorld("archives",{readSitePackagesSnapshot:()=>t.ipcRenderer.invoke("readSitePackagesSnapshot"),readRequirements:()=>t.ipcRenderer.invoke("readRequirements"),readStreamlitAppDirectory:()=>t.ipcRenderer.invoke("readStreamlitAppDirectory")});
1
+ var i=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var d=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var g=(o,r,n,t)=>{if(r&&typeof r=="object"||typeof r=="function")for(let s of d(r))!c.call(o,s)&&s!==n&&i(o,s,{get:()=>r[s],enumerable:!(t=p(r,s))||t.enumerable});return o};var k=o=>g(i({},"__esModule",{value:!0}),o);var l={};module.exports=k(l);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 A={readSitePackagesSnapshot:()=>e.ipcRenderer.invoke("readSitePackagesSnapshot"),readRequirements:()=>e.ipcRenderer.invoke("readRequirements"),readStreamlitAppDirectory:()=>e.ipcRenderer.invoke("readStreamlitAppDirectory")};e.contextBridge.exposeInMainWorld("archivesAPI",A);function I(){return Math.floor(Math.random()*1e6)}var m={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 n=r&&I();e.ipcRenderer.send("messageToNodeJsWorker",{data:o,portId:n}),n&&e.ipcRenderer.on(`nodeJsWorker-portMessage-${n}`,(t,s)=>{r(s)})},onMessage:o=>e.ipcRenderer.on("messageFromNodeJsWorker",(r,n)=>{console.debug("nodeJsWorkerAPI.onMessage",n),o(n)}),terminate:()=>e.ipcRenderer.invoke("terminateNodeJsWorker")};e.contextBridge.exposeInMainWorld("nodeJsWorkerAPI",m);
@@ -0,0 +1,118 @@
1
+ var ie=Object.create;var z=Object.defineProperty;var ae=Object.getOwnPropertyDescriptor;var le=Object.getOwnPropertyNames;var ce=Object.getPrototypeOf,ge=Object.prototype.hasOwnProperty;var F=(o,e)=>()=>(e||o((e={exports:{}}).exports,e),e.exports);var de=(o,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of le(e))!ge.call(o,t)&&t!==r&&z(o,t,{get:()=>e[t],enumerable:!(n=ae(e,t))||n.enumerable});return o};var H=(o,e,r)=>(r=o!=null?ie(ce(o)):{},de(e||!o||!o.__esModule?z(r,"default",{value:o,enumerable:!0}):r,o));var J=F(I=>{"use strict";Object.defineProperty(I,"__esModule",{value:!0});I.verifyRequirements=void 0;function fe(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})`)})}I.verifyRequirements=fe});var K=F(R=>{"use strict";Object.defineProperty(R,"__esModule",{value:!0});R.parseRequirementsTxt=void 0;var ue=/\s#.*$/;function me(o){return o.split(`
2
+ `).filter(e=>!e.startsWith("#")).map(e=>e.replace(ue,"")).map(e=>e.trim()).filter(e=>e!=="")}R.parseRequirementsTxt=me});var V=F(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 G=F(w=>{"use strict";var pe=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)&&pe(e,o,r)};Object.defineProperty(w,"__esModule",{value:!0});N(J(),w);N(K(),w);N(V(),w)});var X=F((Oe,Q)=>{"use strict";function v(o){if(typeof o!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(o))}function Y(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 _e(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),v(a),a.length!==0&&(e=a+"/"+e,r=a.charCodeAt(0)===47)}return e=Y(e,!r),r?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(v(e),e.length===0)return".";var r=e.charCodeAt(0)===47,n=e.charCodeAt(e.length-1)===47;return e=Y(e,!r),e.length===0&&!r&&(e="."),e.length>0&&n&&(e+="/"),r?"/"+e:e},isAbsolute:function(e){return v(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];v(n),n.length>0&&(e===void 0?e=n:e+="/"+n)}return e===void 0?".":S.normalize(e)},relative:function(e,r){if(v(e),v(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(v(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');v(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){v(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 _e("/",e)},parse:function(e){v(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;Q.exports=S});var $=require("node:worker_threads");var re=H(G());var L=H(X());function Z(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){Z(o,e),o.FS.writeFile(e,r,n)}function ee(o,e,r){Z(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
+ import micropip
4
+ micropip.add_mock_package(
5
+ "pyarrow", "0.0.1",
6
+ modules={
7
+ "pyarrow": """
8
+ __version__ = '0.0.1' # TODO: Update when releasing
9
+
10
+
11
+ class Table:
12
+ @classmethod
13
+ def from_pandas(*args, **kwargs):
14
+ raise NotImplementedError("stlite is not supporting this method.")
15
+ """
16
+ }
17
+ )
18
+ `)}async function ye(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 te(o,e,r){function n(u){e({type:"event:progress",data:{message:u}})}let t,a,s=new re.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,wheels:h,mountedSitePackagesSnapshotFilePath:P,pyodideUrl:O=o,streamlitConfig:k,idbfsMountpoints:M,nodefsMountpoints:B}=l;n("Loading Pyodide."),console.debug("Loading Pyodide"),t=await ye(O,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let W=!1;if(M&&(W=!0,M.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()})})),B&&Object.entries(B).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(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):b=m.data;let{opts:C}=c[d];console.debug(`Write a file "${d}"`),j(t,d,b,C)})),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(A=>A.arrayBuffer())):m=d.buffer;let{format:b,options:C}=d;console.debug("Unpack an archive",{format:b,options:C}),t.unpackArchive(m,b,C)})),!P&&!h)throw new Error("Neither snapshot nor wheel files are provided.");P&&(n("Restoring the snapshot."),await t.runPythonAsync("import tarfile, shutil, site"),await t.runPythonAsync(`
19
+ site_packages_dirs = site.getsitepackages()
20
+ for site_packages in site_packages_dirs:
21
+ shutil.rmtree(site_packages)
22
+ `),console.debug(`Unarchive ${P}`),await t.runPythonAsync(`
23
+ with tarfile.open("${P}", "r") as tar_gz_file:
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 x=t.pyimport("micropip");h?(console.debug("Installing the wheels:",h,"and the requirements:",y),await x.install.callKwargs([h.stliteServer,h.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 x.install.callKwargs(y,{keep_going:!0}),console.debug("Installed the requirements")),await t.runPythonAsync(`
26
+ import importlib
27
+ importlib.invalidate_caches()
28
+ `),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await t.runPythonAsync(`
29
+ import streamlit.runtime
30
+ `),console.debug("Loaded the Streamlit package"),n("Setting up the loggers."),console.debug("Setting the loggers"),await t.runPythonAsync(`
31
+ import logging
32
+ import streamlit.logger
33
+
34
+ streamlit.logger.get_logger = logging.getLogger
35
+ streamlit.logger.setup_formatter = None
36
+ streamlit.logger.update_formatter = lambda *a, **k: None
37
+ streamlit.logger.set_log_level = lambda *a, **k: None
38
+
39
+ for name in streamlit.logger._loggers.keys():
40
+ if name == "root":
41
+ name = "streamlit"
42
+ logger = logging.getLogger(name)
43
+ logger.propagate = True
44
+ logger.handlers.clear()
45
+ logger.setLevel(logging.NOTSET)
46
+
47
+ streamlit.logger._loggers = {}
48
+ `);let oe=(d,m)=>{d>=40?console.error(m):d>=30?console.warn(m):d>=20?console.info(m):console.debug(m)};D.__logCallback__=oe,await t.runPythonAsync(`
49
+ def setup_loggers(streamlit_level, streamlit_message_format):
50
+ from js import __logCallback__
51
+
52
+
53
+ class JsHandler(logging.Handler):
54
+ def emit(self, record):
55
+ msg = self.format(record)
56
+ __logCallback__(record.levelno, msg)
57
+
58
+
59
+ root_message_format = "%(levelname)s:%(name)s:%(message)s"
60
+
61
+ root_logger = logging.getLogger()
62
+ root_logger.handlers.clear()
63
+ root_formatter = logging.Formatter(root_message_format)
64
+ root_handler = JsHandler()
65
+ root_handler.setFormatter(root_formatter)
66
+ root_logger.addHandler(root_handler)
67
+ root_logger.setLevel(logging.DEBUG)
68
+
69
+ streamlit_logger = logging.getLogger("streamlit")
70
+ streamlit_logger.propagate = False
71
+ streamlit_logger.handlers.clear()
72
+ streamlit_formatter = logging.Formatter(streamlit_message_format)
73
+ streamlit_handler = JsHandler()
74
+ streamlit_handler.setFormatter(streamlit_formatter)
75
+ streamlit_logger.addHandler(streamlit_handler)
76
+ streamlit_logger.setLevel(streamlit_level.upper())
77
+ `);let ne=(k?.["logger.level"]??"INFO").toString(),se=k?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(t.globals.get("setup_loggers")(ne,se),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await t.runPythonAsync(`
78
+ import streamlit
79
+
80
+ def is_cacheable_msg(msg):
81
+ return False
82
+
83
+ streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
84
+ `),console.debug("Mocked some Streamlit functions"),W){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
+ from streamlit.runtime.app_session import AppSession
86
+ from streamlit.runtime.scriptrunner import ScriptRunnerEvent
87
+ from js import __scriptFinishedCallback__
88
+
89
+ def wrap_app_session_on_scriptrunner_event(original_method):
90
+ def wrapped(self, *args, **kwargs):
91
+ if "event" in kwargs:
92
+ event = kwargs["event"]
93
+ if event == ScriptRunnerEvent.SCRIPT_STOPPED_WITH_SUCCESS or event == ScriptRunnerEvent.SCRIPT_STOPPED_FOR_RERUN or event == ScriptRunnerEvent.SHUTDOWN:
94
+ __scriptFinishedCallback__()
95
+ return original_method(self, *args, **kwargs)
96
+ return wrapped
97
+
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,...k,"runner.fastReruns":!1},await t.runPythonAsync(`
100
+ from stlite_server.bootstrap import load_config_options, prepare
101
+ from stlite_server.server import Server
102
+ from js import __streamlitFlagOptions__
103
+
104
+ flag_options = __streamlitFlagOptions__.to_py()
105
+ load_config_options(flag_options)
106
+
107
+ main_script_path = "${_}"
108
+ command_line = None
109
+ args = []
110
+
111
+ prepare(main_script_path, args)
112
+
113
+ server = Server(main_script_path, command_line)
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 h=f.getBuffer("u8");f.destroy();let P=new Uint8ClampedArray(h.data.buffer,h.data.byteOffset,h.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(P)}})}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,h,P)=>{let O=h.toJs(),k=P.toJs();console.debug({statusCode:y,headers:O,body:k});let M={type:"http:response",data:{response:{statusCode:y,headers:O,body:k}}};_.postMessage(M)};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}`),ee(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
+ from stlite_server.bootstrap import _fix_matplotlib_crash
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 he(){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 ve(o){console.debug("[worker thread] postMessage from worker",o),$.parentPort?.postMessage(o)}var be=te(process.env.PYODIDE_URL,ve,{nodefsMountpoints:he()});$.parentPort?.on("message",({data:o,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:o,port:e}),be({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.f5170537.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>
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.b686df03.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,10 @@
1
+ var oe=Object.create;var k=Object.defineProperty;var ae=Object.getOwnPropertyDescriptor;var se=Object.getOwnPropertyNames;var ce=Object.getPrototypeOf,le=Object.prototype.hasOwnProperty;var f=(t,e)=>k(t,"name",{value:e,configurable:!0}),E=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,c)=>(typeof require<"u"?require:e)[c]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw new Error('Dynamic require of "'+t+'" is not supported')});var T=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var de=(t,e,c,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of se(e))!le.call(t,a)&&a!==c&&k(t,a,{get:()=>e[a],enumerable:!(o=ae(e,a))||o.enumerable});return t};var fe=(t,e,c)=>(c=t!=null?oe(ce(t)):{},de(e||!t||!t.__esModule?k(c,"default",{value:t,enumerable:!0}):c,t));var $=T((R,U)=>{(function(t,e){"use strict";typeof define=="function"&&define.amd?define("stackframe",[],e):typeof R=="object"?U.exports=e():t.StackFrame=e()})(R,function(){"use strict";function t(d){return!isNaN(parseFloat(d))&&isFinite(d)}f(t,"_isNumber");function e(d){return d.charAt(0).toUpperCase()+d.substring(1)}f(e,"_capitalize");function c(d){return function(){return this[d]}}f(c,"_getter");var o=["isConstructor","isEval","isNative","isToplevel"],a=["columnNumber","lineNumber"],r=["fileName","functionName","source"],n=["args"],u=["evalOrigin"],i=o.concat(a,r,n,u);function s(d){if(d)for(var y=0;y<i.length;y++)d[i[y]]!==void 0&&this["set"+e(i[y])](d[i[y]])}f(s,"StackFrame"),s.prototype={getArgs:function(){return this.args},setArgs:function(d){if(Object.prototype.toString.call(d)!=="[object Array]")throw new TypeError("Args must be an Array");this.args=d},getEvalOrigin:function(){return this.evalOrigin},setEvalOrigin:function(d){if(d instanceof s)this.evalOrigin=d;else if(d instanceof Object)this.evalOrigin=new s(d);else throw new TypeError("Eval Origin must be an Object or StackFrame")},toString:function(){var d=this.getFileName()||"",y=this.getLineNumber()||"",h=this.getColumnNumber()||"",v=this.getFunctionName()||"";return this.getIsEval()?d?"[eval] ("+d+":"+y+":"+h+")":"[eval]:"+y+":"+h:v?v+" ("+d+":"+y+":"+h+")":d+":"+y+":"+h}},s.fromString=f(function(y){var h=y.indexOf("("),v=y.lastIndexOf(")"),ee=y.substring(0,h),te=y.substring(h+1,v).split(","),I=y.substring(v+1);if(I.indexOf("@")===0)var N=/@(.+?)(?::(\d+))?(?::(\d+))?$/.exec(I,""),re=N[1],ne=N[2],ie=N[3];return new s({functionName:ee,args:te||void 0,fileName:re,lineNumber:ne||void 0,columnNumber:ie||void 0})},"StackFrame$$fromString");for(var l=0;l<o.length;l++)s.prototype["get"+e(o[l])]=c(o[l]),s.prototype["set"+e(o[l])]=function(d){return function(y){this[d]=!!y}}(o[l]);for(var m=0;m<a.length;m++)s.prototype["get"+e(a[m])]=c(a[m]),s.prototype["set"+e(a[m])]=function(d){return function(y){if(!t(y))throw new TypeError(d+" must be a Number");this[d]=Number(y)}}(a[m]);for(var p=0;p<r.length;p++)s.prototype["get"+e(r[p])]=c(r[p]),s.prototype["set"+e(r[p])]=function(d){return function(y){this[d]=String(y)}}(r[p]);return s})});var C=T((x,M)=>{(function(t,e){"use strict";typeof define=="function"&&define.amd?define("error-stack-parser",["stackframe"],e):typeof x=="object"?M.exports=e($()):t.ErrorStackParser=e(t.StackFrame)})(x,f(function(e){"use strict";var c=/(^|@)\S+:\d+/,o=/^\s*at .*(\S+:\d+|\(native\))/m,a=/^(eval@)?(\[native code])?$/;return{parse:f(function(n){if(typeof n.stacktrace<"u"||typeof n["opera#sourceloc"]<"u")return this.parseOpera(n);if(n.stack&&n.stack.match(o))return this.parseV8OrIE(n);if(n.stack)return this.parseFFOrSafari(n);throw new Error("Cannot parse given Error object")},"ErrorStackParser$$parse"),extractLocation:f(function(n){if(n.indexOf(":")===-1)return[n];var u=/(.+?)(?::(\d+))?(?::(\d+))?$/,i=u.exec(n.replace(/[()]/g,""));return[i[1],i[2]||void 0,i[3]||void 0]},"ErrorStackParser$$extractLocation"),parseV8OrIE:f(function(n){var u=n.stack.split(`
2
+ `).filter(function(i){return!!i.match(o)},this);return u.map(function(i){i.indexOf("(eval ")>-1&&(i=i.replace(/eval code/g,"eval").replace(/(\(eval at [^()]*)|(,.*$)/g,""));var s=i.replace(/^\s+/,"").replace(/\(eval code/g,"(").replace(/^.*?\s+/,""),l=s.match(/ (\(.+\)$)/);s=l?s.replace(l[0],""):s;var m=this.extractLocation(l?l[1]:s),p=l&&s||void 0,d=["eval","<anonymous>"].indexOf(m[0])>-1?void 0:m[0];return new e({functionName:p,fileName:d,lineNumber:m[1],columnNumber:m[2],source:i})},this)},"ErrorStackParser$$parseV8OrIE"),parseFFOrSafari:f(function(n){var u=n.stack.split(`
3
+ `).filter(function(i){return!i.match(a)},this);return u.map(function(i){if(i.indexOf(" > eval")>-1&&(i=i.replace(/ line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g,":$1")),i.indexOf("@")===-1&&i.indexOf(":")===-1)return new e({functionName:i});var s=/((.*".+"[^@]*)?[^@]*)(?:@)/,l=i.match(s),m=l&&l[1]?l[1]:void 0,p=this.extractLocation(i.replace(s,""));return new e({functionName:m,fileName:p[0],lineNumber:p[1],columnNumber:p[2],source:i})},this)},"ErrorStackParser$$parseFFOrSafari"),parseOpera:f(function(n){return!n.stacktrace||n.message.indexOf(`
4
+ `)>-1&&n.message.split(`
5
+ `).length>n.stacktrace.split(`
6
+ `).length?this.parseOpera9(n):n.stack?this.parseOpera11(n):this.parseOpera10(n)},"ErrorStackParser$$parseOpera"),parseOpera9:f(function(n){for(var u=/Line (\d+).*script (?:in )?(\S+)/i,i=n.message.split(`
7
+ `),s=[],l=2,m=i.length;l<m;l+=2){var p=u.exec(i[l]);p&&s.push(new e({fileName:p[2],lineNumber:p[1],source:i[l]}))}return s},"ErrorStackParser$$parseOpera9"),parseOpera10:f(function(n){for(var u=/Line (\d+).*script (?:in )?(\S+)(?:: In function (\S+))?$/i,i=n.stacktrace.split(`
8
+ `),s=[],l=0,m=i.length;l<m;l+=2){var p=u.exec(i[l]);p&&s.push(new e({functionName:p[3]||void 0,fileName:p[2],lineNumber:p[1],source:i[l]}))}return s},"ErrorStackParser$$parseOpera10"),parseOpera11:f(function(n){var u=n.stack.split(`
9
+ `).filter(function(i){return!!i.match(c)&&!i.match(/^Error created at/)},this);return u.map(function(i){var s=i.split("@"),l=this.extractLocation(s.pop()),m=s.shift()||"",p=m.replace(/<anonymous function(: (\w+))?>/,"$2").replace(/\([^)]*\)/g,"")||void 0,d;m.match(/\(([^)]*)\)/)&&(d=m.replace(/^[^(]+\(([^)]*)\)$/,"$1"));var y=d===void 0||d==="[arguments not available]"?void 0:d.split(",");return new e({functionName:p,args:y,fileName:l[0],lineNumber:l[1],columnNumber:l[2],source:i})},this)},"ErrorStackParser$$parseOpera11")}},"ErrorStackParser"))});var z=fe(C());var g=typeof process=="object"&&typeof process.versions=="object"&&typeof process.versions.node=="string"&&typeof process.browser>"u",F=g&&typeof module<"u"&&typeof module.exports<"u"&&typeof E<"u"&&typeof __dirname<"u",j=g&&!F,ue=typeof Deno<"u",B=!g&&!ue,W=B&&typeof window<"u"&&typeof document<"u"&&typeof document.createElement<"u"&&typeof sessionStorage<"u",H=B&&typeof importScripts<"u"&&typeof self<"u";var q,_,P,V,L,pe=`"fetch" is not defined, maybe you're using node < 18? From Pyodide >= 0.25.0, node >= 18 is required. Older versions of Node.js may work, but it is not guaranteed or supported. Falling back to "node-fetch".`;async function D(){if(!g||(q=(await import("url")).default,L=await import("fs/promises"),globalThis.fetch?_=fetch:(console.warn(pe),_=(await import("node-fetch")).default),V=(await import("vm")).default,P=await import("path"),A=P.sep,typeof E<"u"))return;let t=await import("fs"),e=await import("crypto"),c=await import("ws"),o=await import("child_process"),a={fs:t,crypto:e,ws:c,child_process:o};globalThis.require=function(r){return a[r]}}f(D,"initNodeModules");function me(t,e){return P.resolve(e||".",t)}f(me,"node_resolvePath");function ye(t,e){return e===void 0&&(e=location),new URL(t,e).toString()}f(ye,"browser_resolvePath");var S;g?S=me:S=ye;var A;g||(A="/");function ge(t,e){return t.startsWith("file://")&&(t=t.slice(7)),t.includes("://")?{response:_(t)}:{binary:L.readFile(t).then(c=>new Uint8Array(c.buffer,c.byteOffset,c.byteLength))}}f(ge,"node_getBinaryResponse");function he(t,e){let c=new URL(t,location);return{response:fetch(c,e?{integrity:e}:{})}}f(he,"browser_getBinaryResponse");var b;g?b=ge:b=he;async function G(t,e){let{response:c,binary:o}=b(t,e);if(o)return o;let a=await c;if(!a.ok)throw new Error(`Failed to load '${t}': request failed.`);return new Uint8Array(await a.arrayBuffer())}f(G,"loadBinaryFile");var w;if(W)w=f(async t=>await import(t),"loadScript");else if(H)w=f(async t=>{try{globalThis.importScripts(t)}catch(e){if(e instanceof TypeError)await import(t);else throw e}},"loadScript");else if(g)w=ve;else throw new Error("Cannot determine runtime environment");async function ve(t){t.startsWith("file://")&&(t=t.slice(7)),t.includes("://")?V.runInThisContext(await(await _(t)).text()):await import(q.pathToFileURL(t).href)}f(ve,"nodeLoadScript");async function K(t){if(g){await D();let e=await L.readFile(t);return JSON.parse(e)}else return await(await fetch(t)).json()}f(K,"loadLockFile");async function X(){if(F)return __dirname;let t;try{throw new Error}catch(o){t=o}let e=z.default.parse(t)[0].fileName;if(j){let o=await import("path");return(await import("url")).fileURLToPath(o.dirname(e))}let c=e.lastIndexOf(A);if(c===-1)throw new Error("Could not extract indexURL path from pyodide module location");return e.slice(0,c)}f(X,"calculateDirname");function J(t){let e=t.FS,c=t.FS.filesystems.MEMFS,o=t.PATH,a={DIR_MODE:16895,FILE_MODE:33279,mount:function(r){if(!r.opts.fileSystemHandle)throw new Error("opts.fileSystemHandle is required");return c.mount.apply(null,arguments)},syncfs:async(r,n,u)=>{try{let i=a.getLocalSet(r),s=await a.getRemoteSet(r),l=n?s:i,m=n?i:s;await a.reconcile(r,l,m),u(null)}catch(i){u(i)}},getLocalSet:r=>{let n=Object.create(null);function u(l){return l!=="."&&l!==".."}f(u,"isRealDir");function i(l){return m=>o.join2(l,m)}f(i,"toAbsolute");let s=e.readdir(r.mountpoint).filter(u).map(i(r.mountpoint));for(;s.length;){let l=s.pop(),m=e.stat(l);e.isDir(m.mode)&&s.push.apply(s,e.readdir(l).filter(u).map(i(l))),n[l]={timestamp:m.mtime,mode:m.mode}}return{type:"local",entries:n}},getRemoteSet:async r=>{let n=Object.create(null),u=await we(r.opts.fileSystemHandle);for(let[i,s]of u)i!=="."&&(n[o.join2(r.mountpoint,i)]={timestamp:s.kind==="file"?(await s.getFile()).lastModifiedDate:new Date,mode:s.kind==="file"?a.FILE_MODE:a.DIR_MODE});return{type:"remote",entries:n,handles:u}},loadLocalEntry:r=>{let u=e.lookupPath(r).node,i=e.stat(r);if(e.isDir(i.mode))return{timestamp:i.mtime,mode:i.mode};if(e.isFile(i.mode))return u.contents=c.getFileDataAsTypedArray(u),{timestamp:i.mtime,mode:i.mode,contents:u.contents};throw new Error("node type not supported")},storeLocalEntry:(r,n)=>{if(e.isDir(n.mode))e.mkdirTree(r,n.mode);else if(e.isFile(n.mode))e.writeFile(r,n.contents,{canOwn:!0});else throw new Error("node type not supported");e.chmod(r,n.mode),e.utime(r,n.timestamp,n.timestamp)},removeLocalEntry:r=>{var n=e.stat(r);e.isDir(n.mode)?e.rmdir(r):e.isFile(n.mode)&&e.unlink(r)},loadRemoteEntry:async r=>{if(r.kind==="file"){let n=await r.getFile();return{contents:new Uint8Array(await n.arrayBuffer()),mode:a.FILE_MODE,timestamp:n.lastModifiedDate}}else{if(r.kind==="directory")return{mode:a.DIR_MODE,timestamp:new Date};throw new Error("unknown kind: "+r.kind)}},storeRemoteEntry:async(r,n,u)=>{let i=r.get(o.dirname(n)),s=e.isFile(u.mode)?await i.getFileHandle(o.basename(n),{create:!0}):await i.getDirectoryHandle(o.basename(n),{create:!0});if(s.kind==="file"){let l=await s.createWritable();await l.write(u.contents),await l.close()}r.set(n,s)},removeRemoteEntry:async(r,n)=>{await r.get(o.dirname(n)).removeEntry(o.basename(n)),r.delete(n)},reconcile:async(r,n,u)=>{let i=0,s=[];Object.keys(n.entries).forEach(function(p){let d=n.entries[p],y=u.entries[p];(!y||e.isFile(d.mode)&&d.timestamp.getTime()>y.timestamp.getTime())&&(s.push(p),i++)}),s.sort();let l=[];if(Object.keys(u.entries).forEach(function(p){n.entries[p]||(l.push(p),i++)}),l.sort().reverse(),!i)return;let m=n.type==="remote"?n.handles:u.handles;for(let p of s){let d=o.normalize(p.replace(r.mountpoint,"/")).substring(1);if(u.type==="local"){let y=m.get(d),h=await a.loadRemoteEntry(y);a.storeLocalEntry(p,h)}else{let y=a.loadLocalEntry(p);await a.storeRemoteEntry(m,d,y)}}for(let p of l)if(u.type==="local")a.removeLocalEntry(p);else{let d=o.normalize(p.replace(r.mountpoint,"/")).substring(1);await a.removeRemoteEntry(m,d)}}};t.FS.filesystems.NATIVEFS_ASYNC=a}f(J,"initializeNativeFS");var we=f(async t=>{let e=[];async function c(a){for await(let r of a.values())e.push(r),r.kind==="directory"&&await c(r)}f(c,"collect"),await c(t);let o=new Map;o.set(".",t);for(let a of e){let r=(await t.resolve(a)).join("/");o.set(r,a)}return o},"getFsHandles");function Y(){let t={};return t.noImageDecoding=!0,t.noAudioDecoding=!0,t.noWasmDecoding=!1,t.preRun=[],t.quit=(e,c)=>{throw t.exited={status:e,toThrow:c},c},t}f(Y,"createModule");function be(t,e){t.preRun.push(function(){let c="/";try{t.FS.mkdirTree(e)}catch(o){console.error(`Error occurred while making a home directory '${e}':`),console.error(o),console.error(`Using '${c}' for a home directory instead`),e=c}t.FS.chdir(e)})}f(be,"createHomeDirectory");function Ee(t,e){t.preRun.push(function(){Object.assign(t.ENV,e)})}f(Ee,"setEnvironment");function _e(t,e){t.preRun.push(()=>{for(let c of e)t.FS.mkdirTree(c),t.FS.mount(t.FS.filesystems.NODEFS,{root:c},c)})}f(_e,"mountLocalDirectories");function Se(t,e){let c=G(e);t.preRun.push(()=>{let o=t._py_version_major(),a=t._py_version_minor();t.FS.mkdirTree("/lib"),t.FS.mkdirTree(`/lib/python${o}.${a}/site-packages`),t.addRunDependency("install-stdlib"),c.then(r=>{t.FS.writeFile(`/lib/python${o}${a}.zip`,r)}).catch(r=>{console.error("Error occurred while installing the standard library:"),console.error(r)}).finally(()=>{t.removeRunDependency("install-stdlib")})})}f(Se,"installStdlib");function Q(t,e){let c;e.stdLibURL!=null?c=e.stdLibURL:c=e.indexURL+"python_stdlib.zip",Se(t,c),be(t,e.env.HOME),Ee(t,e.env),_e(t,e._node_mounts),t.preRun.push(()=>J(t))}f(Q,"initializeFileSystem");function Z(t,e){let{binary:c,response:o}=b(e+"pyodide.asm.wasm");t.instantiateWasm=function(a,r){return async function(){try{let n;o?n=await WebAssembly.instantiateStreaming(o,a):n=await WebAssembly.instantiate(await c,a);let{instance:u,module:i}=n;typeof WasmOffsetConverter<"u"&&(wasmOffsetConverter=new WasmOffsetConverter(wasmBinary,i)),r(u,i)}catch(n){console.warn("wasm instantiation failed!"),console.warn(n)}}(),{}}}f(Z,"preloadWasm");var O="0.25.0";async function We(t={}){await D();let e=t.indexURL||await X();e=S(e),e.endsWith("/")||(e+="/"),t.indexURL=e;let c={fullStdLib:!1,jsglobals:globalThis,stdin:globalThis.prompt?globalThis.prompt:void 0,lockFileURL:e+"pyodide-lock.json",args:[],_node_mounts:[],env:{},packageCacheDir:e,packages:[]},o=Object.assign(c,t);o.env.HOME||(o.env.HOME="/home/pyodide");let a=Y();a.print=o.stdout,a.printErr=o.stderr,a.arguments=o.args;let r={config:o};a.API=r,r.lockFilePromise=K(o.lockFileURL),Z(a,e),Q(a,o);let n=new Promise(s=>a.postRun=s);if(a.locateFile=s=>o.indexURL+s,typeof _createPyodideModule!="function"){let s=`${o.indexURL}pyodide.asm.js`;await w(s)}if(await _createPyodideModule(a),await n,a.exited)throw a.exited.toThrow;if(t.pyproxyToStringRepr&&r.setPyProxyToStringMethod(!0),r.version!==O)throw new Error(`Pyodide version does not match: '${O}' <==> '${r.version}'. If you updated the Pyodide version, make sure you also updated the 'indexURL' parameter passed to loadPyodide.`);a.locateFile=s=>{throw new Error("Didn't expect to load any more file_packager files!")};let u=r.finalizeBootstrap();if(u.version.includes("dev")||r.setCdnUrl(`https://cdn.jsdelivr.net/pyodide/v${u.version}/full/`),await r.packageIndexReady,r._pyodide._importhook.register_module_not_found_hook(r._import_name_to_package_name,r.lockfile_unvendored_stdlibs_and_test),r.lockfile_info.version!==O)throw new Error("Lock file version doesn't match Pyodide version");return r.package_loader.init_loaded_packages(),o.fullStdLib&&await u.loadPackage(r.lockfile_unvendored_stdlibs),r.initializeStreams(o.stdin,o.stdout,o.stderr),u}f(We,"loadPyodide");export{We as loadPyodide,O as version};
10
+ //# sourceMappingURL=pyodide.mjs.map
@@ -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:v,wheels:b,mountedSitePackagesSnapshotFilePath:k,pyodideUrl:w=t,streamlitConfig:S,idbfsMountpoints:A,nodefsMountpoints:P}=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}))}))}(w,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let C=!1;if(A&&(C=!0,A.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()}))}))),P&&Object.entries(P).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)}))))),!k&&!b)throw new Error("Neither snapshot nor wheel files are provided.");k&&(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 ${k}`),yield d.runPythonAsync(`\nwith tarfile.open("${k}", "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(v),g("Installing packages."),yield d.loadPackage("micropip");const F=d.pyimport("micropip");b?(console.debug("Installing the wheels:",b,"and the requirements:",v),yield F.install.callKwargs([b.stliteServer,b.streamlit,...v],{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:",v),yield F.install.callKwargs(v,{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 O=(null!==(e=null===S||void 0===S?void 0:S["logger.level"])&&void 0!==e?e:"INFO").toString(),j=null!==(o=null===S||void 0===S?void 0:S["logger.messageFormat"])&&void 0!==o?o:"%(asctime)s %(message)s";if(d.globals.get("setup_loggers")(O,j),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"),C){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},S),{"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)})()})();