@stlite/desktop 0.38.0 → 0.38.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/bin/dump_artifacts.js +4 -4
- package/package.json +4 -4
package/bin/dump_artifacts.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
var j=Object.create;var w=Object.defineProperty;var
|
|
3
|
-
`).filter(t=>!t.startsWith("#")).map(t=>t.trim()).filter(t=>t!=="")}
|
|
2
|
+
var j=Object.create;var w=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var S=Object.getOwnPropertyNames;var x=Object.getPrototypeOf,K=Object.prototype.hasOwnProperty;var k=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var M=(e,t,i,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of S(t))!K.call(e,a)&&a!==i&&w(e,a,{get:()=>t[a],enumerable:!(o=F(t,a))||o.enumerable});return e};var p=(e,t,i)=>(i=e!=null?j(x(e)):{},M(t||!e||!e.__esModule?w(i,"default",{value:e,enumerable:!0}):i,e));var v=k(m=>{"use strict";Object.defineProperty(m,"__esModule",{value:!0});m.parseRequirementsTxt=void 0;function W(e){return e.split(`
|
|
3
|
+
`).filter(t=>!t.startsWith("#")).map(t=>t.trim()).filter(t=>t!=="")}m.parseRequirementsTxt=W});var P=k(d=>{"use strict";var J=d&&d.__createBinding||(Object.create?function(e,t,i,o){o===void 0&&(o=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,o,a)}:function(e,t,i,o){o===void 0&&(o=i),e[o]=t[i]}),I=d&&d.__exportStar||function(e,t){for(var i in e)i!=="default"&&!Object.prototype.hasOwnProperty.call(t,i)&&J(t,e,i)};Object.defineProperty(d,"__esModule",{value:!0});I(v(),d)});var b=p(require("yargs")),_=require("yargs/helpers"),s=p(require("path")),n=p(require("fs/promises")),h=p(require("fs-extra")),u=p(require("node-fetch")),f=require("pyodide"),q=p(P());global.fetch=u.default;function $(e){return`https://cdn.jsdelivr.net/pyodide/v${f.version}/full/${e}`}async function R(e){console.info("Copy the build directory (the bare built app files) to this directory...");let t=s.default.resolve(__dirname,"../build");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 h.default.copy(t,e.copyTo)}async function C(e){if(e.requirements.length===0)return[];let t=await(0,f.loadPyodide)();await t.loadPackage("micropip");let i=t.pyimport("micropip");return i.add_mock_package("streamlit","1.24.0"),await i.install(e.requirements),Object.entries(t.loadedPackages).filter(([,o])=>o==="default channel").map(([o])=>o)}async function O(){let e=$("repodata.json");return console.log(`Load the Pyodide repodata.json from ${e}`),(await(await(0,u.default)(e)).json()).packages}async function D(e,t){console.log(`Install the local wheel ${t}`);let i=await n.default.readFile(t),o="/tmp/"+s.default.basename(t);e.FS.writeFile(o,i);let a=e.pyimport("micropip"),l=`emfs:${o}`;console.log(`Install ${l}`),await a.install.callKwargs(l,{keep_going:!0})}async function E(e){console.info("Create the site-packages snapshot file...");let t=await(0,f.loadPyodide)();if(await t.loadPackage(["micropip"]),e.useLocalKernelWheels){let c=s.default.dirname(require.resolve("@stlite/kernel")),r=s.default.resolve(c,"../py");await D(t,s.default.join(r,"stlite-server/dist/stlite_server-0.1.0-py3-none-any.whl")),await D(t,s.default.join(r,"streamlit/lib/dist/streamlit-1.24.0-cp311-none-any.whl"))}else{let r=require(s.default.resolve(__dirname,"../package.json")).version,T=`https://data.jsdelivr.com/v1/package/npm/@stlite/kernel@${r}/flat`,y=(await(await(0,u.default)(T)).json()).files.filter(g=>g.name.endsWith(".whl")).map(g=>`https://cdn.jsdelivr.net/npm/@stlite/kernel@${r}${g.name}`),B=t.pyimport("micropip");console.log("Install",y),await B.install.callKwargs(y,{keep_going:!0})}let i=t.pyimport("micropip"),o=await O();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(c=>{let r=o[c];if(r==null)throw new Error(`Package ${c} is not found in the lock file.`);console.log(`Mock ${r.name} ${r.version}`),i.add_mock_package(r.name,r.version)})),console.log(`Install the requirements ${JSON.stringify(e.requirements)}`),await i.install.callKwargs(e.requirements,{keep_going:!0}),console.log("Archive the site-packages director(y|ies)");let a="/tmp/site-packages-snapshot.tar.gz";await t.runPythonAsync(`
|
|
4
4
|
import tarfile
|
|
5
5
|
import site
|
|
6
6
|
|
|
@@ -10,5 +10,5 @@ var j=Object.create;var w=Object.defineProperty;var S=Object.getOwnPropertyDescr
|
|
|
10
10
|
with tarfile.open(tar_file_name, mode='w:gz') as gzf:
|
|
11
11
|
for site_packages in site_packages_dirs:
|
|
12
12
|
gzf.add(site_packages)
|
|
13
|
-
`),console.log("Extract the archive file from EMFS");let
|
|
14
|
-
`);await n.default.writeFile(e,i,{encoding:"utf-8"})}function A(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})`)})}async function z(e){let t=await
|
|
13
|
+
`),console.log("Extract the archive file from EMFS");let l=t.FS.readFile(a);console.log(`Save the archive file (${e.saveTo})`),await n.default.writeFile(e.saveTo,l)}async function L(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 h.default.copy(e.sourceDir,e.copyTo)}async function H(e){let t=await n.default.readFile(e,{encoding:"utf-8"});return(0,q.parseRequirementsTxt)(t)}async function U(e,t){let i=t.join(`
|
|
14
|
+
`);await n.default.writeFile(e,i,{encoding:"utf-8"})}function A(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})`)})}async function z(e){let t=await O(),o=e.packages.map(a=>t[a]).map(a=>$(a.file_name));console.log("Downloading the used built-in packages..."),await Promise.all(o.map(async a=>{let l=s.default.resolve(e.destDir,"./pyodide",s.default.basename(a));console.log(`Download ${a} to ${l}`);let c=await(0,u.default)(a);if(!c.ok)throw new Error(`Failed to download ${a}: ${c.status} ${c.statusText}`);let r=await c.arrayBuffer();await n.default.writeFile(l,Buffer.from(r))}))}async function N(e){let o={embed:(require(e.packageJsonPath).stlite?.desktop||{}).embed||!1},a=JSON.stringify(o,null,2);console.log(`Dump the manifest file -> ${e.manifestFilePath}`),console.log(a),await n.default.writeFile(e.manifestFilePath,a,{encoding:"utf-8"})}(0,b.default)((0,_.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("localKernelWheels",{describe:"Use the locally installed kernel wheels",type:"boolean",alias:"l",default:!1}).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=s.default.resolve(t,"./build");try{await n.default.access(e.appHomeDirSource)}catch{throw new Error(`${e.appHomeDirSource} does not exist.`)}let o=e.packages;for(let l of e.requirement)o=o.concat(await H(l));A(o);let a=await C({requirements:o,useLocalKernelWheels:e.localKernelWheels});console.log("The built-in packages loaded for the given requirements:"),console.log(a),await R({copyTo:i,keepOld:e.keepOldBuild}),await E({useLocalKernelWheels:e.localKernelWheels,requirements:o,usedBuiltinPackages:a,saveTo:s.default.resolve(i,"./site-packages-snapshot.tar.gz")}),await U(s.default.resolve(i,"./requirements.txt"),o),await L({sourceDir:e.appHomeDirSource,copyTo:s.default.resolve(i,"./streamlit_app")}),await z({packages:a,destDir:i}),await N({packageJsonPath:s.default.resolve(t,"./package.json"),manifestFilePath:s.default.resolve(i,"./stlite-manifest.json")})});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stlite/desktop",
|
|
3
|
-
"version": "0.38.
|
|
3
|
+
"version": "0.38.1",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"homepage": "/",
|
|
6
6
|
"main": "./build/electron/main.js",
|
|
@@ -58,9 +58,9 @@
|
|
|
58
58
|
},
|
|
59
59
|
"devDependencies": {
|
|
60
60
|
"@craco/craco": "^7.0.0",
|
|
61
|
-
"@stlite/common": "^0.38.
|
|
62
|
-
"@stlite/common-react": "^0.38.
|
|
63
|
-
"@stlite/kernel": "^0.38.
|
|
61
|
+
"@stlite/common": "^0.38.1",
|
|
62
|
+
"@stlite/common-react": "^0.38.1",
|
|
63
|
+
"@stlite/kernel": "^0.38.1",
|
|
64
64
|
"@testing-library/react": "^12.1.4",
|
|
65
65
|
"@testing-library/user-event": "^14.0.0",
|
|
66
66
|
"@types/jest": "^27.4.3",
|