@stlite/desktop 0.52.0 → 0.52.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.
@@ -1,5 +1,5 @@
1
- var le=Object.create;var J=Object.defineProperty;var ce=Object.getOwnPropertyDescriptor;var ge=Object.getOwnPropertyNames;var de=Object.getPrototypeOf,fe=Object.prototype.hasOwnProperty;var F=(s,e)=>()=>(e||s((e={exports:{}}).exports,e),e.exports);var ue=(s,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of ge(e))!fe.call(s,t)&&t!==r&&J(s,t,{get:()=>e[t],enumerable:!(o=ce(e,t))||o.enumerable});return s};var K=(s,e,r)=>(r=s!=null?le(de(s)):{},ue(e||!s||!s.__esModule?J(r,"default",{value:s,enumerable:!0}):r,s));var V=F(E=>{"use strict";Object.defineProperty(E,"__esModule",{value:!0});E.validateRequirements=void 0;var me="[",pe="(<=>!~",_e=";",ye="@",he=new RegExp(`[${me+pe+_e+ye}]`);function ve(s){return s.split(he)[0].trim()}function be(s){return s.forEach(r=>{let o;try{o=new URL(r)}catch{return}if(o.protocol==="emfs:"||o.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${r})`)}),s.filter(r=>ve(r)==="streamlit"?(console.warn(`Streamlit is specified in the requirements (${r}), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}E.validateRequirements=be});var X=F(T=>{"use strict";Object.defineProperty(T,"__esModule",{value:!0});T.parseRequirementsTxt=void 0;var Pe=/\s#.*$/;function we(s){return s.split(`
2
- `).filter(e=>!e.startsWith("#")).map(e=>e.replace(Pe,"")).map(e=>e.trim()).filter(e=>e!=="")}T.parseRequirementsTxt=we});var G=F(M=>{"use strict";Object.defineProperty(M,"__esModule",{value:!0});M.PromiseDelegate=void 0;var D=class{constructor(){this.promise=new Promise((e,r)=>{this.resolveInternal=e,this.rejectInternal=r})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};M.PromiseDelegate=D});var Q=F(w=>{"use strict";var Se=w&&w.__createBinding||(Object.create?function(s,e,r,o){o===void 0&&(o=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(s,o,t)}:function(s,e,r,o){o===void 0&&(o=r),s[o]=e[r]}),L=w&&w.__exportStar||function(s,e){for(var r in s)r!=="default"&&!Object.prototype.hasOwnProperty.call(e,r)&&Se(e,s,r)};Object.defineProperty(w,"__esModule",{value:!0});L(V(),w);L(X(),w);L(G(),w)});var ee=F((je,Z)=>{"use strict";function v(s){if(typeof s!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(s))}function Y(s,e){for(var r="",o=0,t=-1,a=0,n,i=0;i<=s.length;++i){if(i<s.length)n=s.charCodeAt(i);else{if(n===47)break;n=47}if(n===47){if(!(t===i-1||a===1))if(t!==i-1&&a===2){if(r.length<2||o!==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="",o=0):(r=r.slice(0,g),o=r.length-1-r.lastIndexOf("/")),t=i,a=0;continue}}else if(r.length===2||r.length===1){r="",o=0,t=i,a=0;continue}}e&&(r.length>0?r+="/..":r="..",o=2)}else r.length>0?r+="/"+s.slice(t+1,i):r=s.slice(t+1,i),o=i-t-1;t=i,a=0}else n===46&&a!==-1?++a:a=-1}return r}function ke(s,e){var r=e.dir||e.root,o=e.base||(e.name||"")+(e.ext||"");return r?r===e.root?r+o:r+s+o:o}var k={resolve:function(){for(var e="",r=!1,o,t=arguments.length-1;t>=-1&&!r;t--){var a;t>=0?a=arguments[t]:(o===void 0&&(o=process.cwd()),a=o),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,o=e.charCodeAt(e.length-1)===47;return e=Y(e,!r),e.length===0&&!r&&(e="."),e.length>0&&o&&(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 o=arguments[r];v(o),o.length>0&&(e===void 0?e=o:e+="/"+o)}return e===void 0?".":k.normalize(e)},relative:function(e,r){if(v(e),v(r),e===r||(e=k.resolve(e),r=k.resolve(r),e===r))return"";for(var o=1;o<e.length&&e.charCodeAt(o)===47;++o);for(var t=e.length,a=t-o,n=1;n<r.length&&r.charCodeAt(n)===47;++n);for(var i=r.length,g=i-n,p=a<g?a:g,f=-1,l=0;l<=p;++l){if(l===p){if(g>p){if(r.charCodeAt(n+l)===47)return r.slice(n+l+1);if(l===0)return r.slice(n+l)}else a>p&&(e.charCodeAt(o+l)===47?f=l:l===0&&(f=0));break}var _=e.charCodeAt(o+l),c=r.charCodeAt(n+l);if(_!==c)break;_===47&&(f=l)}var u="";for(l=o+f+1;l<=t;++l)(l===t||e.charCodeAt(l)===47)&&(u.length===0?u+="..":u+="/..");return u.length>0?u+r.slice(n+f):(n+=f,r.charCodeAt(n)===47&&++n,r.slice(n))},_makeLong:function(e){return e},dirname:function(e){if(v(e),e.length===0)return".";for(var r=e.charCodeAt(0),o=r===47,t=-1,a=!0,n=e.length-1;n>=1;--n)if(r=e.charCodeAt(n),r===47){if(!a){t=n;break}}else a=!1;return t===-1?o?"/":".":o&&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 o=0,t=-1,a=!0,n;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(n=e.length-1;n>=0;--n){var p=e.charCodeAt(n);if(p===47){if(!a){o=n+1;break}}else g===-1&&(a=!1,g=n+1),i>=0&&(p===r.charCodeAt(i)?--i===-1&&(t=n):(i=-1,t=g))}return o===t?t=g:t===-1&&(t=e.length),e.slice(o,t)}else{for(n=e.length-1;n>=0;--n)if(e.charCodeAt(n)===47){if(!a){o=n+1;break}}else t===-1&&(a=!1,t=n+1);return t===-1?"":e.slice(o,t)}},extname:function(e){v(e);for(var r=-1,o=0,t=-1,a=!0,n=0,i=e.length-1;i>=0;--i){var g=e.charCodeAt(i);if(g===47){if(!a){o=i+1;break}continue}t===-1&&(a=!1,t=i+1),g===46?r===-1?r=i:n!==1&&(n=1):r!==-1&&(n=-1)}return r===-1||t===-1||n===0||n===1&&r===t-1&&r===o+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 ke("/",e)},parse:function(e){v(e);var r={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return r;var o=e.charCodeAt(0),t=o===47,a;t?(r.root="/",a=1):a=0;for(var n=-1,i=0,g=-1,p=!0,f=e.length-1,l=0;f>=a;--f){if(o=e.charCodeAt(f),o===47){if(!p){i=f+1;break}continue}g===-1&&(p=!1,g=f+1),o===46?n===-1?n=f:l!==1&&(l=1):n!==-1&&(l=-1)}return n===-1||g===-1||l===0||l===1&&n===g-1&&n===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,n),r.base=e.slice(1,g)):(r.name=e.slice(i,n),r.base=e.slice(i,g)),r.ext=e.slice(n,g)),i>0?r.dir=e.slice(0,i-1):t&&(r.dir="/"),r},sep:"/",delimiter:":",win32:null,posix:null};k.posix=k;Z.exports=k});var j=require("node:worker_threads");var se=K(Q());var q=K(ee());function re(s,e){let r=q.default.normalize(e),t=q.default.dirname(r).split("/"),a=[];for(let n of t){a.push(n);let i=a.join("/");if(s.FS.analyzePath(i).exists){if(s.FS.isDir(i))throw new Error(`"${i}" already exists and is not a directory.`);continue}try{s.FS.mkdir(i)}catch(g){throw console.error(`Failed to create a directory "${i}"`),g}}}function U(s,e,r,o){re(s,e),s.FS.writeFile(e,r,o)}function te(s,e,r){re(s,r),s.FS.rename(e,r)}var Re="[",Ae="(<=>!~",Fe=";",Oe="@",Ie=new RegExp(`[${Re+Ae+Fe+Oe}]`);function Ce(s){return s.split(Ie)[0].trim()}function H(s){return s.forEach(r=>{let o;try{o=new URL(r)}catch{return}if(o.protocol==="emfs:"||o.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${r})`)}),s.filter(r=>Ce(r)==="streamlit"?(console.warn(`Streamlit is specified in the requirements (${r}), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}function $(s){s.runPython(`
1
+ var ce=Object.create;var J=Object.defineProperty;var de=Object.getOwnPropertyDescriptor;var ge=Object.getOwnPropertyNames;var fe=Object.getPrototypeOf,ue=Object.prototype.hasOwnProperty;var F=(o,e)=>()=>(e||o((e={exports:{}}).exports,e),e.exports);var me=(o,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of ge(e))!ue.call(o,t)&&t!==r&&J(o,t,{get:()=>e[t],enumerable:!(s=de(e,t))||s.enumerable});return o};var K=(o,e,r)=>(r=o!=null?ce(fe(o)):{},me(e||!o||!o.__esModule?J(r,"default",{value:o,enumerable:!0}):r,o));var V=F(E=>{"use strict";Object.defineProperty(E,"__esModule",{value:!0});E.validateRequirements=void 0;var pe="[",_e="(<=>!~",ye=";",he="@",ve=new RegExp(`[${pe+_e+ye+he}]`);function be(o){return o.split(ve)[0].trim()}function Pe(o){return o.forEach(r=>{let s;try{s=new URL(r)}catch{return}if(s.protocol==="emfs:"||s.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${r})`)}),o.filter(r=>be(r)==="streamlit"?(console.warn(`Streamlit is specified in the requirements (${r}), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}E.validateRequirements=Pe});var X=F(T=>{"use strict";Object.defineProperty(T,"__esModule",{value:!0});T.parseRequirementsTxt=void 0;var we=/\s#.*$/;function Se(o){return o.split(`
2
+ `).filter(e=>!e.startsWith("#")).map(e=>e.replace(we,"")).map(e=>e.trim()).filter(e=>e!=="")}T.parseRequirementsTxt=Se});var G=F(M=>{"use strict";Object.defineProperty(M,"__esModule",{value:!0});M.PromiseDelegate=void 0;var D=class{constructor(){this.promise=new Promise((e,r)=>{this.resolveInternal=e,this.rejectInternal=r})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};M.PromiseDelegate=D});var Q=F(w=>{"use strict";var ke=w&&w.__createBinding||(Object.create?function(o,e,r,s){s===void 0&&(s=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,s,t)}:function(o,e,r,s){s===void 0&&(s=r),o[s]=e[r]}),L=w&&w.__exportStar||function(o,e){for(var r in o)r!=="default"&&!Object.prototype.hasOwnProperty.call(e,r)&&ke(e,o,r)};Object.defineProperty(w,"__esModule",{value:!0});L(V(),w);L(X(),w);L(G(),w)});var ee=F((je,Z)=>{"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="",s=0,t=-1,a=0,n,i=0;i<=o.length;++i){if(i<o.length)n=o.charCodeAt(i);else{if(n===47)break;n=47}if(n===47){if(!(t===i-1||a===1))if(t!==i-1&&a===2){if(r.length<2||s!==2||r.charCodeAt(r.length-1)!==46||r.charCodeAt(r.length-2)!==46){if(r.length>2){var d=r.lastIndexOf("/");if(d!==r.length-1){d===-1?(r="",s=0):(r=r.slice(0,d),s=r.length-1-r.lastIndexOf("/")),t=i,a=0;continue}}else if(r.length===2||r.length===1){r="",s=0,t=i,a=0;continue}}e&&(r.length>0?r+="/..":r="..",s=2)}else r.length>0?r+="/"+o.slice(t+1,i):r=o.slice(t+1,i),s=i-t-1;t=i,a=0}else n===46&&a!==-1?++a:a=-1}return r}function Re(o,e){var r=e.dir||e.root,s=e.base||(e.name||"")+(e.ext||"");return r?r===e.root?r+s:r+o+s:s}var k={resolve:function(){for(var e="",r=!1,s,t=arguments.length-1;t>=-1&&!r;t--){var a;t>=0?a=arguments[t]:(s===void 0&&(s=process.cwd()),a=s),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,s=e.charCodeAt(e.length-1)===47;return e=Y(e,!r),e.length===0&&!r&&(e="."),e.length>0&&s&&(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 s=arguments[r];v(s),s.length>0&&(e===void 0?e=s:e+="/"+s)}return e===void 0?".":k.normalize(e)},relative:function(e,r){if(v(e),v(r),e===r||(e=k.resolve(e),r=k.resolve(r),e===r))return"";for(var s=1;s<e.length&&e.charCodeAt(s)===47;++s);for(var t=e.length,a=t-s,n=1;n<r.length&&r.charCodeAt(n)===47;++n);for(var i=r.length,d=i-n,p=a<d?a:d,f=-1,l=0;l<=p;++l){if(l===p){if(d>p){if(r.charCodeAt(n+l)===47)return r.slice(n+l+1);if(l===0)return r.slice(n+l)}else a>p&&(e.charCodeAt(s+l)===47?f=l:l===0&&(f=0));break}var _=e.charCodeAt(s+l),c=r.charCodeAt(n+l);if(_!==c)break;_===47&&(f=l)}var u="";for(l=s+f+1;l<=t;++l)(l===t||e.charCodeAt(l)===47)&&(u.length===0?u+="..":u+="/..");return u.length>0?u+r.slice(n+f):(n+=f,r.charCodeAt(n)===47&&++n,r.slice(n))},_makeLong:function(e){return e},dirname:function(e){if(v(e),e.length===0)return".";for(var r=e.charCodeAt(0),s=r===47,t=-1,a=!0,n=e.length-1;n>=1;--n)if(r=e.charCodeAt(n),r===47){if(!a){t=n;break}}else a=!1;return t===-1?s?"/":".":s&&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 s=0,t=-1,a=!0,n;if(r!==void 0&&r.length>0&&r.length<=e.length){if(r.length===e.length&&r===e)return"";var i=r.length-1,d=-1;for(n=e.length-1;n>=0;--n){var p=e.charCodeAt(n);if(p===47){if(!a){s=n+1;break}}else d===-1&&(a=!1,d=n+1),i>=0&&(p===r.charCodeAt(i)?--i===-1&&(t=n):(i=-1,t=d))}return s===t?t=d:t===-1&&(t=e.length),e.slice(s,t)}else{for(n=e.length-1;n>=0;--n)if(e.charCodeAt(n)===47){if(!a){s=n+1;break}}else t===-1&&(a=!1,t=n+1);return t===-1?"":e.slice(s,t)}},extname:function(e){v(e);for(var r=-1,s=0,t=-1,a=!0,n=0,i=e.length-1;i>=0;--i){var d=e.charCodeAt(i);if(d===47){if(!a){s=i+1;break}continue}t===-1&&(a=!1,t=i+1),d===46?r===-1?r=i:n!==1&&(n=1):r!==-1&&(n=-1)}return r===-1||t===-1||n===0||n===1&&r===t-1&&r===s+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 Re("/",e)},parse:function(e){v(e);var r={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return r;var s=e.charCodeAt(0),t=s===47,a;t?(r.root="/",a=1):a=0;for(var n=-1,i=0,d=-1,p=!0,f=e.length-1,l=0;f>=a;--f){if(s=e.charCodeAt(f),s===47){if(!p){i=f+1;break}continue}d===-1&&(p=!1,d=f+1),s===46?n===-1?n=f:l!==1&&(l=1):n!==-1&&(l=-1)}return n===-1||d===-1||l===0||l===1&&n===d-1&&n===i+1?d!==-1&&(i===0&&t?r.base=r.name=e.slice(1,d):r.base=r.name=e.slice(i,d)):(i===0&&t?(r.name=e.slice(1,n),r.base=e.slice(1,d)):(r.name=e.slice(i,n),r.base=e.slice(i,d)),r.ext=e.slice(n,d)),i>0?r.dir=e.slice(0,i-1):t&&(r.dir="/"),r},sep:"/",delimiter:":",win32:null,posix:null};k.posix=k;Z.exports=k});var j=require("node:worker_threads");var oe=K(Q());var U=K(ee());function re(o,e){let r=U.default.normalize(e),t=U.default.dirname(r).split("/"),a=[];for(let n of t){a.push(n);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(d){throw console.error(`Failed to create a directory "${i}"`),d}}}function q(o,e,r,s){re(o,e),o.FS.writeFile(e,r,s)}function te(o,e,r){re(o,r),o.FS.rename(e,r)}var Ae="[",Fe="(<=>!~",Oe=";",Ie="@",Ce=new RegExp(`[${Ae+Fe+Oe+Ie}]`);function Ee(o){return o.split(Ce)[0].trim()}function H(o){return o.forEach(r=>{let s;try{s=new URL(r)}catch{return}if(s.protocol==="emfs:"||s.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${r})`)}),o.filter(r=>Ee(r)==="streamlit"?(console.warn(`Streamlit is specified in the requirements (${r}), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}function $(o){o.runPython(`
3
3
  import micropip
4
4
  micropip.add_mock_package(
5
5
  "pyarrow", "0.0.1",
@@ -15,19 +15,19 @@ class Table:
15
15
  """
16
16
  }
17
17
  )
18
- `)}async function Ee(s,e){let r=s.slice(0,s.lastIndexOf("/")+1),o;return s.endsWith(".mjs")?o=(await import(s)).loadPyodide:(importScripts(s),o=N.loadPyodide),o({...e,indexURL:r})}var N=global;function oe(s,e,r){function o(f){e({type:"event:progress",data:{message:f}})}let t,a,n=new se.PromiseDelegate;async function i(){let f=await n.promise,l={...r,...f};console.debug("Initial data",l);let{entrypoint:_,files:c,archives:u,requirements:y,prebuiltPackageNames:S,wheels:h,mountedSitePackagesSnapshotFilePath:b,pyodideUrl:O=s,streamlitConfig:R,idbfsMountpoints:W,nodefsMountpoints:x}=l,I=H(y);o("Loading Pyodide."),console.debug("Loading Pyodide"),t=await Ee(O,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let B=!1;if(W&&(B=!0,W.forEach(d=>{t.FS.mkdir(d),t.FS.mount(t.FS.filesystems.IDBFS,{},d)}),await new Promise((d,m)=>{t.FS.syncfs(!0,P=>{P?m(P):d()})})),x&&Object.entries(x).forEach(([d,m])=>{t.FS.mkdir(d),t.FS.mount(t.FS.filesystems.NODEFS,{root:m},d)}),o("Mounting files."),await Promise.all(Object.keys(c).map(async d=>{let m=c[d],P;"url"in m?(console.debug(`Fetch a file from ${m.url}`),P=await fetch(m.url).then(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):P=m.data;let{opts:C}=c[d];console.debug(`Write a file "${d}"`),U(t,d,P,C)})),o("Unpacking archives."),await Promise.all(u.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:P,options:C}=d;console.debug("Unpack an archive",{format:P,options:C}),t.unpackArchive(m,P,C)})),!b&&!h)throw new Error("Neither snapshot nor wheel files are provided.");b&&(o("Restoring the snapshot."),await t.runPythonAsync("import tarfile, shutil, site"),await t.runPythonAsync(`
18
+ `)}async function Te(o,e){let r=o.slice(0,o.lastIndexOf("/")+1),s;return o.endsWith(".mjs")?s=(await import(o)).loadPyodide:(importScripts(o),s=N.loadPyodide),s({...e,indexURL:r})}var N=global;function se(o,e,r){function s(f){e({type:"event:progress",data:{message:f}})}let t,a,n=new oe.PromiseDelegate;async function i(){let f=await n.promise,l={...r,...f};console.debug("Initial data",l);let{entrypoint:_,files:c,archives:u,requirements:y,prebuiltPackageNames:S,wheels:h,mountedSitePackagesSnapshotFilePath:b,pyodideUrl:O=o,streamlitConfig:R,idbfsMountpoints:W,nodefsMountpoints:x}=l,I=H(y);s("Loading Pyodide."),console.debug("Loading Pyodide"),t=await Te(O,{stdout:console.log,stderr:console.error}),console.debug("Loaded Pyodide");let B=!1;if(W&&(B=!0,W.forEach(g=>{t.FS.mkdir(g),t.FS.mount(t.FS.filesystems.IDBFS,{},g)}),await new Promise((g,m)=>{t.FS.syncfs(!0,P=>{P?m(P):g()})})),x&&Object.entries(x).forEach(([g,m])=>{t.FS.mkdir(g),t.FS.mount(t.FS.filesystems.NODEFS,{root:m},g)}),s("Mounting files."),await Promise.all(Object.keys(c).map(async g=>{let m=c[g],P;"url"in m?(console.debug(`Fetch a file from ${m.url}`),P=await fetch(m.url).then(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):P=m.data;let{opts:C}=c[g];console.debug(`Write a file "${g}"`),q(t,g,P,C)})),s("Unpacking archives."),await Promise.all(u.map(async g=>{let m;"url"in g?(console.debug(`Fetch an archive from ${g.url}`),m=await fetch(g.url).then(A=>A.arrayBuffer())):m=g.buffer;let{format:P,options:C}=g;console.debug("Unpack an archive",{format:P,options:C}),t.unpackArchive(m,P,C)})),!b&&!h)throw new Error("Neither snapshot nor wheel files are provided.");b&&(s("Restoring the snapshot."),await t.runPythonAsync("import tarfile, shutil, site"),await t.runPythonAsync(`
19
19
  site_packages_dirs = site.getsitepackages()
20
20
  for site_packages in site_packages_dirs:
21
21
  shutil.rmtree(site_packages)
22
22
  `),console.debug(`Unarchive ${b}`),await t.runPythonAsync(`
23
23
  with tarfile.open("${b}", "r") as tar_gz_file:
24
24
  tar_gz_file.extractall("/")
25
- `),console.debug("Restored the snapshot"),o("Mocking some packages."),console.debug("Mock pyarrow"),$(t),console.debug("Mocked pyarrow")),o("Installing packages."),console.debug("Installing the prebuilt packages:",S),await t.loadPackage(S),console.debug("Installed the prebuilt packages"),await t.loadPackage("micropip");let z=t.pyimport("micropip");h?(console.debug("Installing the wheels:",h,"and the requirements:",I),await z.install.callKwargs([h.stliteServer,h.streamlit,...I],{keep_going:!0}),console.debug("Installed the wheels and the requirements"),o("Mocking some packages."),console.debug("Mock pyarrow"),$(t),console.debug("Mocked pyarrow")):(console.debug("Installing the requirements:",I),await z.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements")),await t.runPythonAsync(`
25
+ `),console.debug("Restored the snapshot"),s("Mocking some packages."),console.debug("Mock pyarrow"),$(t),console.debug("Mocked pyarrow")),s("Installing packages."),console.debug("Installing the prebuilt packages:",S),await t.loadPackage(S),console.debug("Installed the prebuilt packages"),await t.loadPackage("micropip");let z=t.pyimport("micropip");h?(console.debug("Installing the wheels:",h,"and the requirements:",I),await z.install.callKwargs([h.stliteServer,h.streamlit,...I],{keep_going:!0}),console.debug("Installed the wheels and the requirements"),s("Mocking some packages."),console.debug("Mock pyarrow"),$(t),console.debug("Mocked pyarrow")):(console.debug("Installing the requirements:",I),await z.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements")),await t.runPythonAsync(`
26
26
  import importlib
27
27
  importlib.invalidate_caches()
28
- `),o("Loading streamlit package."),console.debug("Loading the Streamlit package"),await t.runPythonAsync(`
28
+ `),s("Loading streamlit package."),console.debug("Loading the Streamlit package"),await t.runPythonAsync(`
29
29
  import streamlit.runtime
30
- `),console.debug("Loaded the Streamlit package"),o("Setting up the loggers."),console.debug("Setting the loggers"),await t.runPythonAsync(`
30
+ `),console.debug("Loaded the Streamlit package"),s("Setting up the loggers."),console.debug("Setting the loggers"),await t.runPythonAsync(`
31
31
  import logging
32
32
  import streamlit.logger
33
33
 
@@ -45,7 +45,7 @@ for name in streamlit.logger._loggers.keys():
45
45
  logger.setLevel(logging.NOTSET)
46
46
 
47
47
  streamlit.logger._loggers = {}
48
- `);let ne=(d,m)=>{d>=40?console.error(m):d>=30?console.warn(m):d>=20?console.info(m):console.debug(m)};N.__logCallback__=ne,await t.runPythonAsync(`
48
+ `);let ie=(g,m)=>{g>=40?console.error(m):g>=30?console.warn(m):g>=20?console.info(m):console.debug(m)};N.__logCallback__=ie,await t.runPythonAsync(`
49
49
  def setup_loggers(streamlit_level, streamlit_message_format):
50
50
  from js import __logCallback__
51
51
 
@@ -74,14 +74,14 @@ def setup_loggers(streamlit_level, streamlit_message_format):
74
74
  streamlit_handler.setFormatter(streamlit_formatter)
75
75
  streamlit_logger.addHandler(streamlit_handler)
76
76
  streamlit_logger.setLevel(streamlit_level.upper())
77
- `);let ie=(R?.["logger.level"]??"INFO").toString(),ae=R?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(t.globals.get("setup_loggers")(ie,ae),console.debug("Set the loggers"),o("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await t.runPythonAsync(`
77
+ `);let ae=(R?.["logger.level"]??"INFO").toString(),le=R?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(t.globals.get("setup_loggers")(ae,le),console.debug("Set the loggers"),s("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await t.runPythonAsync(`
78
78
  import streamlit
79
79
 
80
80
  def is_cacheable_msg(msg):
81
81
  return False
82
82
 
83
83
  streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
84
- `),console.debug("Mocked some Streamlit functions"),B){o("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let d=!1;N.__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(`
84
+ `),console.debug("Mocked some Streamlit functions"),B){s("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let g=!1;N.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),g||(g=!0,t.FS.syncfs(!1,m=>{g=!1,m&&console.error(m)}))},await t.runPythonAsync(`
85
85
  from streamlit.runtime.app_session import AppSession
86
86
  from streamlit.runtime.scriptrunner import ScriptRunnerEvent
87
87
  from js import __scriptFinishedCallback__
@@ -96,7 +96,7 @@ def wrap_app_session_on_scriptrunner_event(original_method):
96
96
  return wrapped
97
97
 
98
98
  AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
99
- `),console.debug("Set up the IndexedDB filesystem synchronizer")}o("Booting up the Streamlit server."),console.debug("Booting up the Streamlit server"),N.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...R,"runner.fastReruns":!1},await t.runPythonAsync(`
99
+ `),console.debug("Set up the IndexedDB filesystem synchronizer")}s("Booting up the Streamlit server."),console.debug("Booting up the Streamlit server"),N.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...R,"runner.fastReruns":!1},await t.runPythonAsync(`
100
100
  from stlite_server.bootstrap import load_config_options, prepare
101
101
  from stlite_server.server import Server
102
102
  from js import __streamlitFlagOptions__
@@ -112,4 +112,4 @@ prepare(main_script_path, args)
112
112
 
113
113
  server = Server(main_script_path, command_line)
114
114
  server.start()
115
- `),console.debug("Booted up the Streamlit server"),console.debug("Setting up the HTTP server"),a=t.globals.get("server").copy(),console.debug("Set up the HTTP server"),e({type:"event:loaded"})}let g=i().catch(f=>{throw e({type:"event:error",data:{error:f}}),f}),p=async f=>{let l=f.data;if(l.type==="initData"){n.resolve(l.data);return}await g;let _=f.ports[0];try{switch(l.type){case"websocket:connect":{console.debug("websocket:connect",l.data);let{path:c}=l.data;a.start_websocket(c,(u,y)=>{if(y){let S=u,h=S.getBuffer("u8");S.destroy();let b=new Uint8ClampedArray(h.data.buffer,h.data.byteOffset,h.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(b)}})}else e({type:"websocket:message",data:{payload:u}})}),_.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,u=(y,S,h)=>{let b=S.toJs(),O=h.toJs();console.debug({statusCode:y,headers:b,body:O});let R={type:"http:response",data:{response:{statusCode:y,headers:b,body:O}}};_.postMessage(R)};a.receive_http_from_js(c.method,decodeURIComponent(c.path),c.headers,c.body,u);break}case"file:write":{let{path:c,data:u,opts:y}=l.data;console.debug(`Write a file "${c}"`),U(t,c,u,y),_.postMessage({type:"reply"});break}case"file:rename":{let{oldPath:c,newPath:u}=l.data;console.debug(`Rename "${c}" to ${u}`),te(t,c,u),_.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,u=t.pyimport("micropip"),y=H(c);console.debug("Install the requirements:",y),await u.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),_.postMessage({type:"reply"})})}}}catch(c){if(console.error(c),!(c instanceof Error))throw c;let u=new Error(c.message);u.name=c.name,u.stack=c.stack,_.postMessage({type:"reply",error:u})}};return e({type:"event:start"}),p}function Te(){let s=process.env.NODEFS_MOUNTPOINTS;if(!s)return;let e;try{e=JSON.parse(s)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${s}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${s}`);return}if(Object.keys(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${s}`);return}if(Object.values(e).some(r=>typeof r!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${s}`);return}}function Me(s){console.debug("[worker thread] postMessage from worker",s),j.parentPort?.postMessage(s)}var Ne=oe(process.env.PYODIDE_URL,Me,{nodefsMountpoints:Te()});j.parentPort?.on("message",({data:s,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:s,port:e}),Ne({data:s,ports:[e]})});
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 d=i().catch(f=>{throw e({type:"event:error",data:{error:f}}),f}),p=async f=>{let l=f.data;if(l.type==="initData"){n.resolve(l.data);return}await d;let _=f.ports[0];try{switch(l.type){case"websocket:connect":{console.debug("websocket:connect",l.data);let{path:c}=l.data;a.start_websocket(c,(u,y)=>{if(y){let S=u,h=S.getBuffer("u8");S.destroy();let b=new Uint8ClampedArray(h.data.buffer,h.data.byteOffset,h.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(b)}})}else e({type:"websocket:message",data:{payload:u}})}),_.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,u=(y,S,h)=>{let b=S.toJs(),O=h.toJs();console.debug({statusCode:y,headers:b,body:O});let R={type:"http:response",data:{response:{statusCode:y,headers:b,body:O}}};_.postMessage(R)};a.receive_http_from_js(c.method,decodeURIComponent(c.path),c.headers,c.body,u);break}case"file:write":{let{path:c,data:u,opts:y}=l.data;console.debug(`Write a file "${c}"`),q(t,c,u,y),_.postMessage({type:"reply"});break}case"file:rename":{let{oldPath:c,newPath:u}=l.data;console.debug(`Rename "${c}" to ${u}`),te(t,c,u),_.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,u=t.pyimport("micropip"),y=H(c);console.debug("Install the requirements:",y),await u.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),_.postMessage({type:"reply"})})}}}catch(c){if(console.error(c),!(c instanceof Error))throw c;let u=new Error(c.message);u.name=c.name,u.stack=c.stack,_.postMessage({type:"reply",error:u})}};return e({type:"event:start"}),p}function ne(){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(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${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}return e}function Me(o){console.debug("[worker thread] postMessage from worker",o),j.parentPort?.postMessage(o)}var Ne=se(process.env.PYODIDE_URL,Me,{nodefsMountpoints:ne()});j.parentPort?.on("message",({data:o,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:o,port:e}),Ne({data:o,ports:[e]})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stlite/desktop",
3
- "version": "0.52.0",
3
+ "version": "0.52.1",
4
4
  "license": "Apache-2.0",
5
5
  "homepage": "/",
6
6
  "main": "./build/electron/main.js",
@@ -60,9 +60,9 @@
60
60
  },
61
61
  "devDependencies": {
62
62
  "@craco/craco": "^7.0.0",
63
- "@stlite/common": "^0.52.0",
64
- "@stlite/common-react": "^0.52.0",
65
- "@stlite/kernel": "^0.52.0",
63
+ "@stlite/common": "^0.52.1",
64
+ "@stlite/common-react": "^0.52.1",
65
+ "@stlite/kernel": "^0.52.1",
66
66
  "@streamlit/app": "1.32.2",
67
67
  "@testing-library/react": "^14.1.2",
68
68
  "@testing-library/user-event": "^14.0.0",