@stlite/desktop 0.78.1 → 0.79.0

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.
Files changed (69) hide show
  1. package/bin/dump_artifacts.js +17 -17
  2. package/build/assets/{FileDownload.esm-D2QqHv2c.js → FileDownload.esm-CUqgQU-j.js} +1 -1
  3. package/build/assets/{FormClearHelper-DliGOSkq.js → FormClearHelper-DmeZ2QuQ.js} +1 -1
  4. package/build/assets/{Hooks-Daeq69Zu.js → Hooks-CBIuRW4z.js} +1 -1
  5. package/build/assets/{InputInstructions-BQD8A2_u.js → InputInstructions-iKTPb-Lc.js} +1 -1
  6. package/build/assets/{ProgressBar-DuGylkeS.js → ProgressBar-Dfr9f8u1.js} +1 -1
  7. package/build/assets/{RenderInPortalIfExists-HKy5CC9C.js → RenderInPortalIfExists-CxeJAxCs.js} +1 -1
  8. package/build/assets/{Toolbar-B9grKd8p.js → Toolbar-CG7W1D-O.js} +1 -1
  9. package/build/assets/{base-input-DJ1o9wy-.js → base-input-DoV-1XUt.js} +1 -1
  10. package/build/assets/{createSuper-BCtrEkDw.js → createSuper-CvaFdVoD.js} +1 -1
  11. package/build/assets/{data-grid-overlay-editor-SiNLnLoA.js → data-grid-overlay-editor-CCUG7ReD.js} +1 -1
  12. package/build/assets/{downloader-y7WtJrbZ.js → downloader-B6rOwzu2.js} +1 -1
  13. package/build/assets/{es6-ChzZtMws.js → es6-CTcMcfqp.js} +2 -2
  14. package/build/assets/{getPrototypeOf-jxUzvEiF.js → getPrototypeOf-CFHg57KG.js} +1 -1
  15. package/build/assets/{iframeResizer.contentWindow-VeTSZzxi.js → iframeResizer.contentWindow-DLNn1A7T.js} +1 -1
  16. package/build/assets/{index-Di0b5deS.js → index-0aipcnh6.js} +1 -1
  17. package/build/assets/{index-NW5mgelH.js → index-6rnmC53g.js} +1 -1
  18. package/build/assets/{index-C-G07XIn.js → index-BHysWwrh.js} +1 -1
  19. package/build/assets/{index-lR3NBV82.js → index-BTHCcLIl.js} +1 -1
  20. package/build/assets/{index-B7GLWddS.js → index-BhkIHxDp.js} +1 -1
  21. package/build/assets/{index-JLaGWCy4.js → index-Bp04iQqW.js} +1 -1
  22. package/build/assets/{index-CSRB3KZi.js → index-BpeIvyJQ.js} +1 -1
  23. package/build/assets/{index-CFVMKjCp.js → index-BrRb8POj.js} +1 -1
  24. package/build/assets/{index-C9Os1Tio.js → index-ByOIN0Gm.js} +1 -1
  25. package/build/assets/{index-z2lXC7XI.js → index-BzTZZCvL.js} +4 -4
  26. package/build/assets/{index-Cxp-1GAt.js → index-C4j64dI5.js} +1 -1
  27. package/build/assets/{index-C5VxAqHf.js → index-CGhw9Sdf.js} +1 -1
  28. package/build/assets/{index-GTNwQsph.js → index-CIL1eIZN.js} +1 -1
  29. package/build/assets/{index-Dh5Ef2Om.js → index-CIs9EQe5.js} +1 -1
  30. package/build/assets/{index-CQ8B9Pyu.js → index-CSyyBx79.js} +1 -1
  31. package/build/assets/{index-DXHAdPWu.js → index-CW4i_Lge.js} +1 -1
  32. package/build/assets/{index-UrV00MOE.js → index-CWiqZgRl.js} +1 -1
  33. package/build/assets/{index-CxF9whAo.js → index-CoKgwXo8.js} +1 -1
  34. package/build/assets/{index-CvKkwQxq.js → index-Cua9_98i.js} +1 -1
  35. package/build/assets/{index-BYdd9282.js → index-D-lzdDJ5.js} +1 -1
  36. package/build/assets/{index-j3NobT-r.js → index-D9QNa8Xs.js} +1 -1
  37. package/build/assets/{index-Bia2Aiul.js → index-DHFNQm8n.js} +1 -1
  38. package/build/assets/{index-CnPYErGb.js → index-DURajqPC.js} +1 -1
  39. package/build/assets/{index-DYrQR0Ux.js → index-Df9nIm6O.js} +1 -1
  40. package/build/assets/{index-Dkd6yjmr.js → index-DjQcVgxO.js} +1 -1
  41. package/build/assets/{index-Bsw1C-zM.js → index-DqxtC9MD.js} +1 -1
  42. package/build/assets/{index-CGRaMNW7.js → index-DtrE1h0V.js} +1 -1
  43. package/build/assets/{index-ByZKQf5p.js → index-Dwt05210.js} +1 -1
  44. package/build/assets/{index-Do74AQgb.js → index-N6IvabtE.js} +1 -1
  45. package/build/assets/{index-BqYxHJ94.js → index-OR2HlVVN.js} +1 -1
  46. package/build/assets/{index-B2k4Ofkz.js → index-P_LN9wWJ.js} +1 -1
  47. package/build/assets/{index-Bh9EjD0o.js → index-RhMZ16-Y.js} +1 -1
  48. package/build/assets/{index-C_q5O89K.js → index-fudEipDa.js} +1 -1
  49. package/build/assets/{index-CS3mWYPw.js → index-hsTwnoRn.js} +1 -1
  50. package/build/assets/{index-BCDKFsnk.js → index-qMuFpOqI.js} +1 -1
  51. package/build/assets/{index-DMBd-bc-.js → index-steA8SlM.js} +5 -5
  52. package/build/assets/{index-CpzAXWaZ.js → index-xGO_nKX1.js} +1 -1
  53. package/build/assets/{input-Dhep7xP0.js → input-BrXgmYe9.js} +1 -1
  54. package/build/assets/{memory-BqTZFgXm.js → memory-Bf74T19z.js} +1 -1
  55. package/build/assets/{number-overlay-editor-BywJqzaW.js → number-overlay-editor-20er5Sp-.js} +1 -1
  56. package/build/assets/{sandbox-DmnKum9A.js → sandbox-CV8SMiuv.js} +1 -1
  57. package/build/assets/{slicedToArray-DkF8JK54.js → slicedToArray-tqzlNjPF.js} +1 -1
  58. package/build/assets/{textarea-CCmBHfjM.js → textarea-DMefjquC.js} +1 -1
  59. package/build/assets/{timepicker-DWOLsPBU.js → timepicker-D5Qmkk9Q.js} +1 -1
  60. package/build/assets/{uniqueId-C3qA3EXY.js → uniqueId-IQr2jcrE.js} +1 -1
  61. package/build/assets/{useBasicWidgetState-CDQNZkN8.js → useBasicWidgetState-Cqy4gnzY.js} +1 -1
  62. package/build/assets/{useOnInputChange-FEZNS9DP.js → useOnInputChange-BD_aeagL.js} +1 -1
  63. package/build/assets/{withFullScreenWrapper-dTVQmtO5.js → withFullScreenWrapper-DIS3bwns.js} +1 -1
  64. package/build/assets/worker-B1MO5Shr.js +216 -0
  65. package/build/electron/worker.js +109 -10
  66. package/build/index.html +1 -1
  67. package/package.json +4 -4
  68. package/wheels/streamlit-1.41.0-cp312-none-any.whl +0 -0
  69. package/build/assets/worker-CLbVOjel.js +0 -117
@@ -0,0 +1,216 @@
1
+ class ee{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,t)=>{this.resolveInternal=e,this.rejectInternal=t})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}}function te(o){return o.__esModule&&Object.prototype.hasOwnProperty.call(o,"default")?o.default:o}function w(o){if(typeof o!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(o))}function N(o,e){for(var t="",n=0,s=-1,r=0,i,a=0;a<=o.length;++a){if(a<o.length)i=o.charCodeAt(a);else{if(i===47)break;i=47}if(i===47){if(!(s===a-1||r===1))if(s!==a-1&&r===2){if(t.length<2||n!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var c=t.lastIndexOf("/");if(c!==t.length-1){c===-1?(t="",n=0):(t=t.slice(0,c),n=t.length-1-t.lastIndexOf("/")),s=a,r=0;continue}}else if(t.length===2||t.length===1){t="",n=0,s=a,r=0;continue}}e&&(t.length>0?t+="/..":t="..",n=2)}else t.length>0?t+="/"+o.slice(s+1,a):t=o.slice(s+1,a),n=a-s-1;s=a,r=0}else i===46&&r!==-1?++r:r=-1}return t}function re(o,e){var t=e.dir||e.root,n=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+n:t+o+n:n}var F={resolve:function(){for(var e="",t=!1,n,s=arguments.length-1;s>=-1&&!t;s--){var r;s>=0?r=arguments[s]:(n===void 0&&(n=process.cwd()),r=n),w(r),r.length!==0&&(e=r+"/"+e,t=r.charCodeAt(0)===47)}return e=N(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(w(e),e.length===0)return".";var t=e.charCodeAt(0)===47,n=e.charCodeAt(e.length-1)===47;return e=N(e,!t),e.length===0&&!t&&(e="."),e.length>0&&n&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return w(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,t=0;t<arguments.length;++t){var n=arguments[t];w(n),n.length>0&&(e===void 0?e=n:e+="/"+n)}return e===void 0?".":F.normalize(e)},relative:function(e,t){if(w(e),w(t),e===t||(e=F.resolve(e),t=F.resolve(t),e===t))return"";for(var n=1;n<e.length&&e.charCodeAt(n)===47;++n);for(var s=e.length,r=s-n,i=1;i<t.length&&t.charCodeAt(i)===47;++i);for(var a=t.length,c=a-i,p=r<c?r:c,u=-1,d=0;d<=p;++d){if(d===p){if(c>p){if(t.charCodeAt(i+d)===47)return t.slice(i+d+1);if(d===0)return t.slice(i+d)}else r>p&&(e.charCodeAt(n+d)===47?u=d:d===0&&(u=0));break}var f=e.charCodeAt(n+d),L=t.charCodeAt(i+d);if(f!==L)break;f===47&&(u=d)}var v="";for(d=n+u+1;d<=s;++d)(d===s||e.charCodeAt(d)===47)&&(v.length===0?v+="..":v+="/..");return v.length>0?v+t.slice(i+u):(i+=u,t.charCodeAt(i)===47&&++i,t.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(w(e),e.length===0)return".";for(var t=e.charCodeAt(0),n=t===47,s=-1,r=!0,i=e.length-1;i>=1;--i)if(t=e.charCodeAt(i),t===47){if(!r){s=i;break}}else r=!1;return s===-1?n?"/":".":n&&s===1?"//":e.slice(0,s)},basename:function(e,t){if(t!==void 0&&typeof t!="string")throw new TypeError('"ext" argument must be a string');w(e);var n=0,s=-1,r=!0,i;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,c=-1;for(i=e.length-1;i>=0;--i){var p=e.charCodeAt(i);if(p===47){if(!r){n=i+1;break}}else c===-1&&(r=!1,c=i+1),a>=0&&(p===t.charCodeAt(a)?--a===-1&&(s=i):(a=-1,s=c))}return n===s?s=c:s===-1&&(s=e.length),e.slice(n,s)}else{for(i=e.length-1;i>=0;--i)if(e.charCodeAt(i)===47){if(!r){n=i+1;break}}else s===-1&&(r=!1,s=i+1);return s===-1?"":e.slice(n,s)}},extname:function(e){w(e);for(var t=-1,n=0,s=-1,r=!0,i=0,a=e.length-1;a>=0;--a){var c=e.charCodeAt(a);if(c===47){if(!r){n=a+1;break}continue}s===-1&&(r=!1,s=a+1),c===46?t===-1?t=a:i!==1&&(i=1):t!==-1&&(i=-1)}return t===-1||s===-1||i===0||i===1&&t===s-1&&t===n+1?"":e.slice(t,s)},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){w(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var n=e.charCodeAt(0),s=n===47,r;s?(t.root="/",r=1):r=0;for(var i=-1,a=0,c=-1,p=!0,u=e.length-1,d=0;u>=r;--u){if(n=e.charCodeAt(u),n===47){if(!p){a=u+1;break}continue}c===-1&&(p=!1,c=u+1),n===46?i===-1?i=u:d!==1&&(d=1):i!==-1&&(d=-1)}return i===-1||c===-1||d===0||d===1&&i===c-1&&i===a+1?c!==-1&&(a===0&&s?t.base=t.name=e.slice(1,c):t.base=t.name=e.slice(a,c)):(a===0&&s?(t.name=e.slice(1,i),t.base=e.slice(1,c)):(t.name=e.slice(a,i),t.base=e.slice(a,c)),t.ext=e.slice(i,c)),a>0?t.dir=e.slice(0,a-1):s&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};F.posix=F;var oe=F,j=te(oe);const H="/home/pyodide",K=o=>`${H}/${o}`,C=(o,e)=>o==null?j.resolve(H,e):j.resolve(K(o),e);function B(o,e){const t=j.normalize(e),s=j.dirname(t).split("/"),r=[];for(const i of s){r.push(i);const a=r.join("/");if(o.FS.analyzePath(a).exists){if(o.FS.isDir(a))throw new Error(`"${a}" already exists and is not a directory.`);continue}try{o.FS.mkdir(a)}catch(c){throw console.error(`Failed to create a directory "${a}"`),c}}}function U(o,e,t,n){B(o,e),o.FS.writeFile(e,t,n)}function ne(o,e,t){B(o,t),o.FS.rename(e,t)}const se="[",ie="(<=>!~",ae=";",le="@",ce=new RegExp(`[${se+ie+ae+le}]`);function de(o){return o.split(ce)[0].trim()}function W(o){return o.forEach(t=>{let n;try{n=new URL(t)}catch{return}if(n.protocol==="emfs:"||n.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)}),o.filter(t=>de(t)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${t}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function me(o){const e=typeof process<"u"&&process.versions?.node;let t;e?t=(await import("./__vite-browser-external-9wXp6ZBx.js")).sep:t="/";const n=o.slice(0,o.lastIndexOf(t)+1);if(o.endsWith(".mjs")){if(e){const s=await import("./__vite-browser-external-9wXp6ZBx.js"),r=await import("./__vite-browser-external-9wXp6ZBx.js");!o.includes("://")&&s.isAbsolute(o)&&(o=r.pathToFileURL(o).href)}return{scriptURL:o,pyodideIndexURL:n,isESModule:!0}}else return{scriptURL:o,pyodideIndexURL:n,isESModule:!1}}async function ue(o,e){const{scriptURL:t,pyodideIndexURL:n,isESModule:s}=await me(o);let r;return s?r=(await import(t)).loadPyodide:(importScripts(t),r=self.loadPyodide),r({...e,indexURL:n})}function ge(o){o.runPython(`
2
+ import micropip
3
+ micropip.add_mock_package(
4
+ "pyarrow", "0.0.1",
5
+ modules={
6
+ "pyarrow": """
7
+ __version__ = '0.0.1' # TODO: Update when releasing
8
+
9
+
10
+ class Table:
11
+ @classmethod
12
+ def from_pandas(*args, **kwargs):
13
+ raise NotImplementedError("stlite is not supporting this method.")
14
+
15
+
16
+ class Array:
17
+ def __init__(self, *args, **kwargs):
18
+ raise NotImplementedError("stlite is not supporting PyArrow.Array")
19
+
20
+
21
+ class ChunkedArray:
22
+ def __init__(self, *args, **kwargs):
23
+ raise NotImplementedError("stlite is not supporting PyArrow.ChunkedArray")
24
+ """
25
+ }
26
+ )
27
+ `)}async function fe(o,e,t){const n=o.pyimport("pyodide"),s=u=>n.code.find_imports(u).toJs(),r=t.map(u=>s(u)),c=Array.from(new Set(r.flat())).filter(u=>!o.runPython(`__import__('importlib').util.find_spec('${u}')`)).map(u=>o._api._import_name_to_package_name.get(u)).filter(u=>u);if(c.length===0)return;const p=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},p.port2);try{const u=await o.loadPackage(c);p.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:u}}),p.port1.close();return}catch(u){throw p.port1.postMessage({type:"moduleAutoLoad:error",error:u}),p.port1.close(),u}}const _e=async o=>{await o.runPythonAsync(`import jedi
28
+ import re
29
+ import json
30
+ from typing import Dict
31
+ from lsprotocol.types import (CompletionItem, CompletionList, CompletionItemKind, Position, Range, TextEdit)
32
+ from lsprotocol import converters as lsp_converters
33
+ from jedi.api.classes import Completion
34
+
35
+ def as_completion_item_kind(kind: str):
36
+ match kind:
37
+ case 'class':
38
+ return CompletionItemKind.Class
39
+ case 'function':
40
+ return CompletionItemKind.Function
41
+ case 'instance':
42
+ return CompletionItemKind.Reference
43
+ case 'keyword':
44
+ return CompletionItemKind.Keyword
45
+ case 'module':
46
+ return CompletionItemKind.Module
47
+ case 'param':
48
+ return CompletionItemKind.Variable
49
+ case 'path':
50
+ return CompletionItemKind.File
51
+ case 'property':
52
+ return CompletionItemKind.Property
53
+ case 'statement':
54
+ return CompletionItemKind.Variable
55
+ case _:
56
+ return CompletionItemKind.Text
57
+
58
+ def as_completion_item_sort_text(item: Completion) -> str:
59
+ """Generate sorting text to arrange items alphabetically,
60
+ ensuring parameters are prioritized first
61
+ and private magic properties come last.
62
+ """
63
+ completion_item_name = item.name
64
+ if completion_item_name is None or completion_item_name.startswith('_'):
65
+ return f"zz{completion_item_name}"
66
+ elif item.type == "param" and completion_item_name.endswith("="):
67
+ return f"aa{completion_item_name}"
68
+ else:
69
+ return f"bb{completion_item_name}"
70
+
71
+ def as_completion_item(completion: Completion, cursor_range: Range) -> Dict:
72
+ label = completion.name
73
+ return CompletionItem(
74
+ label=label,
75
+ filter_text=label,
76
+ sort_text=as_completion_item_sort_text(completion),
77
+ kind=as_completion_item_kind(completion.type),
78
+ documentation=completion.docstring(raw=True),
79
+ text_edit=TextEdit(range=cursor_range, new_text=label),
80
+ )
81
+
82
+ def get_text_edit_cursor_range(cursor_code_line: str, current_line_number: int, cursor_offset: int):
83
+ # Match the substring starting from cursor_offset ex: math<cursor>co, match co
84
+ matched_words = re.search(r'\\b\\w+\\b', cursor_code_line[cursor_offset :])
85
+
86
+ # Determine the length of the matched word characters
87
+ word_after_cursor_length = len(matched_words.group()) if matched_words else 0
88
+
89
+ # This will tell to code editors which text to edit/replace
90
+ return Range(
91
+ start=Position(
92
+ line=current_line_number, character=cursor_offset
93
+ ),
94
+ end=Position(
95
+ line=current_line_number,
96
+ character=cursor_offset + word_after_cursor_length,
97
+ ),
98
+ )
99
+
100
+ def get_code_completions(code: str, current_line_number: int, cursor_offset: int):
101
+
102
+ jedi_language_server = jedi.Script(code)
103
+
104
+ jedi_completions_list = jedi_language_server.complete(
105
+ current_line_number,
106
+ cursor_offset,
107
+ fuzzy=False,
108
+ )
109
+
110
+ # In case if we are not getting any results back or the offset is wrong
111
+ # Just return empty list
112
+ if current_line_number >= len(jedi_language_server._code_lines):
113
+ return json.dumps({ "items": []})
114
+
115
+ code_at_cursor = jedi_language_server._code_lines[current_line_number -1]
116
+ cursor_range = get_text_edit_cursor_range(code_at_cursor, current_line_number, cursor_offset)
117
+
118
+ # Convert jedi completion items as completion items compatible in language server
119
+ suggestions = CompletionList(
120
+ is_incomplete=False,
121
+ items=list(as_completion_item(completion, cursor_range) for completion in jedi_completions_list))
122
+
123
+ # Convert results to JSON so that we can use it in the worker
124
+ converter = lsp_converters.get_converter()
125
+ return json.dumps(converter.unstructure(suggestions, unstructure_as=CompletionList))
126
+ `)},pe=async(o,e)=>{let t;try{if(t=e.globals.get("get_code_completions"),!t)return console.error("Can not generate suggestions list, the get_code_completions function is not defined"),{items:[]};const n=t(o.code,o.currentLineNumber,o.offset);return n?JSON.parse(n):{items:[]}}catch(n){return console.error(n),{items:[]}}finally{t&&t.constructor.name==="PyProxy"&&t.destroy()}},he=async(o,e)=>{try{console.debug("Importing jedi Interpreter"),await e.install.callKwargs(["jedi","lsprotocol"],{keep_going:!0}),await _e(o)}catch(t){console.error("Error while importing jedi",t)}};typeof global<"u"&&typeof global.self>"u"&&(self=global);function $(o,e,t){const n=fe(o,e,t);self.__moduleAutoLoadPromise__=n,o.runPythonAsync(`
127
+ from streamlit.runtime.scriptrunner import script_runner
128
+ from js import __moduleAutoLoadPromise__
129
+
130
+ script_runner.moduleAutoLoadPromise = __moduleAutoLoadPromise__
131
+ `)}let E=null;function z(o,e,t,n){function s(d){e({type:"event:progress",data:{message:d}})}let r,i;const a=new ee;async function c(){const d=await a.promise,f={...t,...d};console.debug("Initial data",f);const{entrypoint:L,files:v,archives:b,requirements:l,prebuiltPackageNames:g,wheels:h,pyodideUrl:y=o,streamlitConfig:k,idbfsMountpoints:P,nodefsMountpoints:R,moduleAutoLoad:G,env:M,languageServer:V}=f,I=W(l);E?(s("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),r=await E):(s("Loading Pyodide."),console.debug("Loading Pyodide."),E=ue(y,{stdout:console.log,stderr:console.error}),r=await E,M&&r.pyimport("os").environ.update(r.toPy(M)),h&&(I.unshift(h.streamlit),I.unshift(h.stliteLib)),console.debug("Loaded Pyodide"));let T=!1;P&&(T=!0,P.forEach(m=>{r.FS.mkdir(m),r.FS.mount(r.FS.filesystems.IDBFS,{},m)}),await new Promise((m,_)=>{r.FS.syncfs(!0,S=>{S?_(S):m()})})),R&&Object.entries(R).forEach(([m,_])=>{r.FS.mkdir(m),r.FS.mount(r.FS.filesystems.NODEFS,{root:_},m)}),s("Mounting files.");const D=[];await Promise.all(Object.keys(v).map(async m=>{const _=v[m];m=C(n,m);let S;"url"in _?(console.debug(`Fetch a file from ${_.url}`),S=await fetch(_.url).then(A=>A.arrayBuffer()).then(A=>new Uint8Array(A))):S=_.data,console.debug(`Write a file "${m}"`),U(r,m,S,v.opts),m.endsWith(".py")&&D.push(m)})),s("Unpacking archives."),await Promise.all(b.map(async m=>{let _;"url"in m?(console.debug(`Fetch an archive from ${m.url}`),_=await fetch(m.url).then(Z=>Z.arrayBuffer())):_=m.buffer;const{format:S,options:A}=m;console.debug("Unpack an archive",{format:S,options:A}),r.unpackArchive(_,S,A)})),await r.loadPackage("micropip");const O=r.pyimport("micropip");if(s("Mocking some packages."),console.debug("Mock pyarrow"),ge(r),console.debug("Mocked pyarrow"),s("Installing packages."),console.debug("Installing the prebuilt packages:",g),await r.loadPackage(g),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",I),await O.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements"),G){const m=D.map(_=>r.FS.readFile(_,{encoding:"utf8"}));$(r,e,m)}await r.runPythonAsync(`
132
+ import importlib
133
+ importlib.invalidate_caches()
134
+ `),s("Loading streamlit package."),console.debug("Loading the Streamlit package"),await r.runPythonAsync(`
135
+ import streamlit.runtime
136
+ `),console.debug("Loaded the Streamlit package"),s("Setting up the loggers."),console.debug("Setting the loggers"),await r.runPythonAsync(`
137
+ import logging
138
+ import streamlit.logger
139
+
140
+ streamlit.logger.get_logger = logging.getLogger
141
+ streamlit.logger.setup_formatter = None
142
+ streamlit.logger.update_formatter = lambda *a, **k: None
143
+ streamlit.logger.set_log_level = lambda *a, **k: None
144
+
145
+ for name in streamlit.logger._loggers.keys():
146
+ if name == "root":
147
+ name = "streamlit"
148
+ logger = logging.getLogger(name)
149
+ logger.propagate = True
150
+ logger.handlers.clear()
151
+ logger.setLevel(logging.NOTSET)
152
+
153
+ streamlit.logger._loggers = {}
154
+ `);const X=(m,_)=>{m>=40?console.error(_):m>=30?console.warn(_):m>=20?console.info(_):console.debug(_)};self.__logCallback__=X,await r.runPythonAsync(`
155
+ def setup_loggers(streamlit_level, streamlit_message_format):
156
+ from js import __logCallback__
157
+
158
+
159
+ class JsHandler(logging.Handler):
160
+ def emit(self, record):
161
+ msg = self.format(record)
162
+ __logCallback__(record.levelno, msg)
163
+
164
+
165
+ root_message_format = "%(levelname)s:%(name)s:%(message)s"
166
+
167
+ root_logger = logging.getLogger()
168
+ root_logger.handlers.clear()
169
+ root_formatter = logging.Formatter(root_message_format)
170
+ root_handler = JsHandler()
171
+ root_handler.setFormatter(root_formatter)
172
+ root_logger.addHandler(root_handler)
173
+ root_logger.setLevel(logging.DEBUG)
174
+
175
+ streamlit_logger = logging.getLogger("streamlit")
176
+ streamlit_logger.propagate = False
177
+ streamlit_logger.handlers.clear()
178
+ streamlit_formatter = logging.Formatter(streamlit_message_format)
179
+ streamlit_handler = JsHandler()
180
+ streamlit_handler.setFormatter(streamlit_formatter)
181
+ streamlit_logger.addHandler(streamlit_handler)
182
+ streamlit_logger.setLevel(streamlit_level.upper())
183
+ `);const Q=(k?.["logger.level"]??"INFO").toString(),Y=k?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(r.globals.get("setup_loggers")(Q,Y),console.debug("Set the loggers"),s("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await r.runPythonAsync(`
184
+ import streamlit
185
+
186
+ def is_cacheable_msg(msg):
187
+ return False
188
+
189
+ streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
190
+ `),console.debug("Mocked some Streamlit functions"),T){s("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let m=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),m||(m=!0,r.FS.syncfs(!1,_=>{m=!1,_&&console.error(_)}))},await r.runPythonAsync(`
191
+ from streamlit.runtime.app_session import AppSession
192
+ from streamlit.runtime.scriptrunner import ScriptRunnerEvent
193
+ from js import __scriptFinishedCallback__
194
+
195
+ def wrap_app_session_on_scriptrunner_event(original_method):
196
+ def wrapped(self, *args, **kwargs):
197
+ if "event" in kwargs:
198
+ event = kwargs["event"]
199
+ if event == ScriptRunnerEvent.SCRIPT_STOPPED_WITH_SUCCESS or event == ScriptRunnerEvent.SCRIPT_STOPPED_FOR_RERUN or event == ScriptRunnerEvent.SHUTDOWN:
200
+ __scriptFinishedCallback__()
201
+ return original_method(self, *args, **kwargs)
202
+ return wrapped
203
+
204
+ AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
205
+ `),console.debug("Set up the IndexedDB filesystem synchronizer")}const x=C(n,L);return V&&(s("Importing Language Server"),await he(r,O)),s("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=n!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...k,"runner.fastReruns":!1},await r.runPythonAsync(`
206
+ from stlite_lib.bootstrap import load_config_options, prepare
207
+ from js import __sharedWorkerMode__, __streamlitFlagOptions__
208
+
209
+ flag_options = __streamlitFlagOptions__.to_py()
210
+ load_config_options(flag_options, __sharedWorkerMode__)
211
+
212
+ main_script_path = "${x}"
213
+ args = []
214
+
215
+ prepare(main_script_path, args)
216
+ `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),i=r.pyimport("stlite_lib.server.Server")(x,n?K(n):null),await i.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),f}const p=c().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),u=async d=>{const f=d.data;if(f.type==="initData"){a.resolve(f.data);return}const{moduleAutoLoad:L}=await p,v=d.ports[0];function b(l){v.postMessage(l)}try{switch(f.type){case"reboot":{console.debug("Reboot the Streamlit server",f.data);const{entrypoint:l}=f.data;i.stop(),console.debug("Booting up the Streamlit server"),i=r.pyimport("stlite_lib.server.Server")(l),i.start(),console.debug("Booted up the Streamlit server"),b({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",f.data);const{path:l}=f.data;i.start_websocket(l,(g,h)=>{if(h){const y=g,k=y.getBuffer("u8");y.destroy();const P=new Uint8ClampedArray(k.data.buffer,k.data.byteOffset,k.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(P)}})}else e({type:"websocket:message",data:{payload:g}})}),b({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",f.data);const{payload:l}=f.data;i.receive_websocket_from_js(l);break}case"http:request":{console.debug("http:request",f.data);const{request:l}=f.data,g=(h,y,k)=>{const P=new Map(y.toJs()),R=k.toJs();console.debug({statusCode:h,headers:P,body:R}),b({type:"http:response",data:{response:{statusCode:h,headers:P,body:R}}})};i.receive_http_from_js(l.method,decodeURIComponent(l.path),l.headers,l.body,g);break}case"file:write":{const{path:l,data:g,opts:h}=f.data,y=C(n,l);L&&typeof g=="string"&&y.endsWith(".py")&&(console.debug(`Auto install the requirements in ${y}`),$(r,e,[g])),console.debug(`Write a file "${y}"`),U(r,y,g,h),b({type:"reply"});break}case"file:rename":{const{oldPath:l,newPath:g}=f.data,h=C(n,l),y=C(n,g);console.debug(`Rename "${h}" to ${y}`),ne(r,h,y),b({type:"reply"});break}case"file:unlink":{const{path:l}=f.data,g=C(n,l);console.debug(`Remove "${g}`),r.FS.unlink(g),b({type:"reply"});break}case"file:read":{const{path:l,opts:g}=f.data;console.debug(`Read "${l}"`);const h=r.FS.readFile(l,g);b({type:"reply:file:read",data:{content:h}});break}case"install":{const{requirements:l}=f.data,g=r.pyimport("micropip"),h=W(l);console.debug("Install the requirements:",h),await g.install.callKwargs(h,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),b({type:"reply"})});break}case"setEnv":{const{env:l}=f.data;r.pyimport("os").environ.update(r.toPy(l)),console.debug("Successfully set the environment variables",l),b({type:"reply"});break}case"language-server:code_completion":{const l=await pe(f.data,r);b({type:"reply:language-server:code_completion",data:l});break}}}catch(l){if(console.error(l),!(l instanceof Error))throw l;const g=new Error(l.message);g.name=l.name,g.stack=l.stack,b({type:"reply",error:g})}};return e({type:"event:start"}),u}const J="abcdefghijklmnopqrstuvwxyz",ye=J.length;function be(o){let e="";for(let t=0;t<o;t++){const n=Math.floor(Math.random()*ye);e+=J[n]}return e}const q="https://cdn.jsdelivr.net/pyodide/v0.27.2/full/pyodide.mjs";if("postMessage"in self)self.onmessage=z(q,(o,e)=>e?self.postMessage(o,[e]):self.postMessage(o));else{const o=[];self.onconnect=e=>{let t;do t=be(4);while(o.includes(t));o.push(t),console.debug("SharedWorker mode.",{appId:t});const n=e.ports[0];n.onmessage=z(q,(s,r)=>r?n.postMessage(s,[r]):n.postMessage(s),void 0,t),n.start()}}
@@ -1,4 +1,4 @@
1
- var le=Object.create;var B=Object.defineProperty;var ce=Object.getOwnPropertyDescriptor;var de=Object.getOwnPropertyNames;var ge=Object.getPrototypeOf,fe=Object.prototype.hasOwnProperty;var ue=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports);var me=(r,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of de(e))!fe.call(r,n)&&n!==t&&B(r,n,{get:()=>e[n],enumerable:!(s=ce(e,n))||s.enumerable});return r};var C=(r,e,t)=>(t=r!=null?le(ge(r)):{},me(e||!r||!r.__esModule?B(t,"default",{value:r,enumerable:!0}):t,r));var J=ue(($e,z)=>{"use strict";function P(r){if(typeof r!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(r))}function j(r,e){for(var t="",s=0,n=-1,o=0,i,a=0;a<=r.length;++a){if(a<r.length)i=r.charCodeAt(a);else{if(i===47)break;i=47}if(i===47){if(!(n===a-1||o===1))if(n!==a-1&&o===2){if(t.length<2||s!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var c=t.lastIndexOf("/");if(c!==t.length-1){c===-1?(t="",s=0):(t=t.slice(0,c),s=t.length-1-t.lastIndexOf("/")),n=a,o=0;continue}}else if(t.length===2||t.length===1){t="",s=0,n=a,o=0;continue}}e&&(t.length>0?t+="/..":t="..",s=2)}else t.length>0?t+="/"+r.slice(n+1,a):t=r.slice(n+1,a),s=a-n-1;n=a,o=0}else i===46&&o!==-1?++o:o=-1}return t}function ve(r,e){var t=e.dir||e.root,s=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+s:t+r+s:s}var R={resolve:function(){for(var e="",t=!1,s,n=arguments.length-1;n>=-1&&!t;n--){var o;n>=0?o=arguments[n]:(s===void 0&&(s=process.cwd()),o=s),P(o),o.length!==0&&(e=o+"/"+e,t=o.charCodeAt(0)===47)}return e=j(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(P(e),e.length===0)return".";var t=e.charCodeAt(0)===47,s=e.charCodeAt(e.length-1)===47;return e=j(e,!t),e.length===0&&!t&&(e="."),e.length>0&&s&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return P(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,t=0;t<arguments.length;++t){var s=arguments[t];P(s),s.length>0&&(e===void 0?e=s:e+="/"+s)}return e===void 0?".":R.normalize(e)},relative:function(e,t){if(P(e),P(t),e===t||(e=R.resolve(e),t=R.resolve(t),e===t))return"";for(var s=1;s<e.length&&e.charCodeAt(s)===47;++s);for(var n=e.length,o=n-s,i=1;i<t.length&&t.charCodeAt(i)===47;++i);for(var a=t.length,c=a-i,_=o<c?o:c,f=-1,d=0;d<=_;++d){if(d===_){if(c>_){if(t.charCodeAt(i+d)===47)return t.slice(i+d+1);if(d===0)return t.slice(i+d)}else o>_&&(e.charCodeAt(s+d)===47?f=d:d===0&&(f=0));break}var m=e.charCodeAt(s+d),M=t.charCodeAt(i+d);if(m!==M)break;m===47&&(f=d)}var b="";for(d=s+f+1;d<=n;++d)(d===n||e.charCodeAt(d)===47)&&(b.length===0?b+="..":b+="/..");return b.length>0?b+t.slice(i+f):(i+=f,t.charCodeAt(i)===47&&++i,t.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(P(e),e.length===0)return".";for(var t=e.charCodeAt(0),s=t===47,n=-1,o=!0,i=e.length-1;i>=1;--i)if(t=e.charCodeAt(i),t===47){if(!o){n=i;break}}else o=!1;return n===-1?s?"/":".":s&&n===1?"//":e.slice(0,n)},basename:function(e,t){if(t!==void 0&&typeof t!="string")throw new TypeError('"ext" argument must be a string');P(e);var s=0,n=-1,o=!0,i;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,c=-1;for(i=e.length-1;i>=0;--i){var _=e.charCodeAt(i);if(_===47){if(!o){s=i+1;break}}else c===-1&&(o=!1,c=i+1),a>=0&&(_===t.charCodeAt(a)?--a===-1&&(n=i):(a=-1,n=c))}return s===n?n=c:n===-1&&(n=e.length),e.slice(s,n)}else{for(i=e.length-1;i>=0;--i)if(e.charCodeAt(i)===47){if(!o){s=i+1;break}}else n===-1&&(o=!1,n=i+1);return n===-1?"":e.slice(s,n)}},extname:function(e){P(e);for(var t=-1,s=0,n=-1,o=!0,i=0,a=e.length-1;a>=0;--a){var c=e.charCodeAt(a);if(c===47){if(!o){s=a+1;break}continue}n===-1&&(o=!1,n=a+1),c===46?t===-1?t=a:i!==1&&(i=1):t!==-1&&(i=-1)}return t===-1||n===-1||i===0||i===1&&t===n-1&&t===s+1?"":e.slice(t,n)},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 ve("/",e)},parse:function(e){P(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var s=e.charCodeAt(0),n=s===47,o;n?(t.root="/",o=1):o=0;for(var i=-1,a=0,c=-1,_=!0,f=e.length-1,d=0;f>=o;--f){if(s=e.charCodeAt(f),s===47){if(!_){a=f+1;break}continue}c===-1&&(_=!1,c=f+1),s===46?i===-1?i=f:d!==1&&(d=1):i!==-1&&(d=-1)}return i===-1||c===-1||d===0||d===1&&i===c-1&&i===a+1?c!==-1&&(a===0&&n?t.base=t.name=e.slice(1,c):t.base=t.name=e.slice(a,c)):(a===0&&n?(t.name=e.slice(1,i),t.base=e.slice(1,c)):(t.name=e.slice(a,i),t.base=e.slice(a,c)),t.ext=e.slice(i,c)),a>0?t.dir=e.slice(0,a-1):n&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};R.posix=R;z.exports=R});var U=require("node:worker_threads");var pe="[",_e="(<=>!~",ye=";",he="@",Ce=new RegExp(`[${pe+_e+ye+he}]`);var O=class{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,t)=>{this.resolveInternal=e,this.rejectInternal=t})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};var E=C(J()),G="/home/pyodide",N=r=>`${G}/${r}`,A=(r,e)=>r==null?E.default.resolve(G,e):E.default.resolve(N(r),e);function K(r,e){let t=E.default.normalize(e),n=E.default.dirname(t).split("/"),o=[];for(let i of n){o.push(i);let a=o.join("/");if(r.FS.analyzePath(a).exists){if(r.FS.isDir(a))throw new Error(`"${a}" already exists and is not a directory.`);continue}try{r.FS.mkdir(a)}catch(c){throw console.error(`Failed to create a directory "${a}"`),c}}}function D(r,e,t,s){K(r,e),r.FS.writeFile(e,t,s)}function V(r,e,t){K(r,t),r.FS.rename(e,t)}var be="[",Pe="(<=>!~",Se=";",we="@",ke=new RegExp(`[${be+Pe+Se+we}]`);function Ae(r){return r.split(ke)[0].trim()}function x(r){return r.forEach(t=>{let s;try{s=new URL(t)}catch{return}if(s.protocol==="emfs:"||s.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)}),r.filter(t=>Ae(t)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${t}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function Fe(r){let e=typeof process<"u"&&process.versions?.node,t;e?t=(await import("node:path")).sep:t="/";let s=r.slice(0,r.lastIndexOf(t)+1);if(r.endsWith(".mjs")){if(e){let n=await import("node:path"),o=await import("node:url");!r.includes("://")&&n.isAbsolute(r)&&(r=o.pathToFileURL(r).href)}return{scriptURL:r,pyodideIndexURL:s,isESModule:!0}}else return{scriptURL:r,pyodideIndexURL:s,isESModule:!1}}async function X(r,e){let{scriptURL:t,pyodideIndexURL:s,isESModule:n}=await Fe(r),o;return n?o=(await import(t)).loadPyodide:(importScripts(t),o=self.loadPyodide),o({...e,indexURL:s})}function Q(r){r.runPython(`
1
+ var ue=Object.create;var B=Object.defineProperty;var ge=Object.getOwnPropertyDescriptor;var fe=Object.getOwnPropertyNames;var pe=Object.getPrototypeOf,_e=Object.prototype.hasOwnProperty;var ye=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports);var he=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of fe(e))!_e.call(r,s)&&s!==t&&B(r,s,{get:()=>e[s],enumerable:!(n=ge(e,s))||n.enumerable});return r};var E=(r,e,t)=>(t=r!=null?ue(pe(r)):{},he(e||!r||!r.__esModule?B(t,"default",{value:r,enumerable:!0}):t,r));var J=ye((Be,z)=>{"use strict";function P(r){if(typeof r!="string")throw new TypeError("Path must be a string. Received "+JSON.stringify(r))}function K(r,e){for(var t="",n=0,s=-1,o=0,i,a=0;a<=r.length;++a){if(a<r.length)i=r.charCodeAt(a);else{if(i===47)break;i=47}if(i===47){if(!(s===a-1||o===1))if(s!==a-1&&o===2){if(t.length<2||n!==2||t.charCodeAt(t.length-1)!==46||t.charCodeAt(t.length-2)!==46){if(t.length>2){var c=t.lastIndexOf("/");if(c!==t.length-1){c===-1?(t="",n=0):(t=t.slice(0,c),n=t.length-1-t.lastIndexOf("/")),s=a,o=0;continue}}else if(t.length===2||t.length===1){t="",n=0,s=a,o=0;continue}}e&&(t.length>0?t+="/..":t="..",n=2)}else t.length>0?t+="/"+r.slice(s+1,a):t=r.slice(s+1,a),n=a-s-1;s=a,o=0}else i===46&&o!==-1?++o:o=-1}return t}function Se(r,e){var t=e.dir||e.root,n=e.base||(e.name||"")+(e.ext||"");return t?t===e.root?t+n:t+r+n:n}var C={resolve:function(){for(var e="",t=!1,n,s=arguments.length-1;s>=-1&&!t;s--){var o;s>=0?o=arguments[s]:(n===void 0&&(n=process.cwd()),o=n),P(o),o.length!==0&&(e=o+"/"+e,t=o.charCodeAt(0)===47)}return e=K(e,!t),t?e.length>0?"/"+e:"/":e.length>0?e:"."},normalize:function(e){if(P(e),e.length===0)return".";var t=e.charCodeAt(0)===47,n=e.charCodeAt(e.length-1)===47;return e=K(e,!t),e.length===0&&!t&&(e="."),e.length>0&&n&&(e+="/"),t?"/"+e:e},isAbsolute:function(e){return P(e),e.length>0&&e.charCodeAt(0)===47},join:function(){if(arguments.length===0)return".";for(var e,t=0;t<arguments.length;++t){var n=arguments[t];P(n),n.length>0&&(e===void 0?e=n:e+="/"+n)}return e===void 0?".":C.normalize(e)},relative:function(e,t){if(P(e),P(t),e===t||(e=C.resolve(e),t=C.resolve(t),e===t))return"";for(var n=1;n<e.length&&e.charCodeAt(n)===47;++n);for(var s=e.length,o=s-n,i=1;i<t.length&&t.charCodeAt(i)===47;++i);for(var a=t.length,c=a-i,_=o<c?o:c,u=-1,d=0;d<=_;++d){if(d===_){if(c>_){if(t.charCodeAt(i+d)===47)return t.slice(i+d+1);if(d===0)return t.slice(i+d)}else o>_&&(e.charCodeAt(n+d)===47?u=d:d===0&&(u=0));break}var f=e.charCodeAt(n+d),R=t.charCodeAt(i+d);if(f!==R)break;f===47&&(u=d)}var b="";for(d=n+u+1;d<=s;++d)(d===s||e.charCodeAt(d)===47)&&(b.length===0?b+="..":b+="/..");return b.length>0?b+t.slice(i+u):(i+=u,t.charCodeAt(i)===47&&++i,t.slice(i))},_makeLong:function(e){return e},dirname:function(e){if(P(e),e.length===0)return".";for(var t=e.charCodeAt(0),n=t===47,s=-1,o=!0,i=e.length-1;i>=1;--i)if(t=e.charCodeAt(i),t===47){if(!o){s=i;break}}else o=!1;return s===-1?n?"/":".":n&&s===1?"//":e.slice(0,s)},basename:function(e,t){if(t!==void 0&&typeof t!="string")throw new TypeError('"ext" argument must be a string');P(e);var n=0,s=-1,o=!0,i;if(t!==void 0&&t.length>0&&t.length<=e.length){if(t.length===e.length&&t===e)return"";var a=t.length-1,c=-1;for(i=e.length-1;i>=0;--i){var _=e.charCodeAt(i);if(_===47){if(!o){n=i+1;break}}else c===-1&&(o=!1,c=i+1),a>=0&&(_===t.charCodeAt(a)?--a===-1&&(s=i):(a=-1,s=c))}return n===s?s=c:s===-1&&(s=e.length),e.slice(n,s)}else{for(i=e.length-1;i>=0;--i)if(e.charCodeAt(i)===47){if(!o){n=i+1;break}}else s===-1&&(o=!1,s=i+1);return s===-1?"":e.slice(n,s)}},extname:function(e){P(e);for(var t=-1,n=0,s=-1,o=!0,i=0,a=e.length-1;a>=0;--a){var c=e.charCodeAt(a);if(c===47){if(!o){n=a+1;break}continue}s===-1&&(o=!1,s=a+1),c===46?t===-1?t=a:i!==1&&(i=1):t!==-1&&(i=-1)}return t===-1||s===-1||i===0||i===1&&t===s-1&&t===n+1?"":e.slice(t,s)},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 Se("/",e)},parse:function(e){P(e);var t={root:"",dir:"",base:"",ext:"",name:""};if(e.length===0)return t;var n=e.charCodeAt(0),s=n===47,o;s?(t.root="/",o=1):o=0;for(var i=-1,a=0,c=-1,_=!0,u=e.length-1,d=0;u>=o;--u){if(n=e.charCodeAt(u),n===47){if(!_){a=u+1;break}continue}c===-1&&(_=!1,c=u+1),n===46?i===-1?i=u:d!==1&&(d=1):i!==-1&&(d=-1)}return i===-1||c===-1||d===0||d===1&&i===c-1&&i===a+1?c!==-1&&(a===0&&s?t.base=t.name=e.slice(1,c):t.base=t.name=e.slice(a,c)):(a===0&&s?(t.name=e.slice(1,i),t.base=e.slice(1,c)):(t.name=e.slice(a,i),t.base=e.slice(a,c)),t.ext=e.slice(i,c)),a>0?t.dir=e.slice(0,a-1):s&&(t.dir="/"),t},sep:"/",delimiter:":",win32:null,posix:null};C.posix=C;z.exports=C});var U=require("node:worker_threads");var ve="[",be="(<=>!~",Pe=";",we="@",Ne=new RegExp(`[${ve+be+Pe+we}]`);var O=class{promise;resolveInternal;rejectInternal;constructor(){this.promise=new Promise((e,t)=>{this.resolveInternal=e,this.rejectInternal=t})}resolve(e){this.resolveInternal(e)}reject(e){this.rejectInternal(e)}};var L=E(J()),V="/home/pyodide",T=r=>`${V}/${r}`,A=(r,e)=>r==null?L.default.resolve(V,e):L.default.resolve(T(r),e);function G(r,e){let t=L.default.normalize(e),s=L.default.dirname(t).split("/"),o=[];for(let i of s){o.push(i);let a=o.join("/");if(r.FS.analyzePath(a).exists){if(r.FS.isDir(a))throw new Error(`"${a}" already exists and is not a directory.`);continue}try{r.FS.mkdir(a)}catch(c){throw console.error(`Failed to create a directory "${a}"`),c}}}function N(r,e,t,n){G(r,e),r.FS.writeFile(e,t,n)}function X(r,e,t){G(r,t),r.FS.rename(e,t)}var ke="[",Ae="(<=>!~",Fe=";",Ce="@",Re=new RegExp(`[${ke+Ae+Fe+Ce}]`);function Ie(r){return r.split(Re)[0].trim()}function D(r){return r.forEach(t=>{let n;try{n=new URL(t)}catch{return}if(n.protocol==="emfs:"||n.protocol==="file:")throw new Error(`"emfs:" and "file:" protocols are not allowed for the requirement (${t})`)}),r.filter(t=>Ie(t)==="streamlit"?(console.warn(`Streamlit is specified in the requirements ("${t}"), but it will be ignored. A built-in version of Streamlit will be used.`),!1):!0)}async function Le(r){let e=typeof process<"u"&&process.versions?.node,t;e?t=(await import("node:path")).sep:t="/";let n=r.slice(0,r.lastIndexOf(t)+1);if(r.endsWith(".mjs")){if(e){let s=await import("node:path"),o=await import("node:url");!r.includes("://")&&s.isAbsolute(r)&&(r=o.pathToFileURL(r).href)}return{scriptURL:r,pyodideIndexURL:n,isESModule:!0}}else return{scriptURL:r,pyodideIndexURL:n,isESModule:!1}}async function Q(r,e){let{scriptURL:t,pyodideIndexURL:n,isESModule:s}=await Le(r),o;return s?o=(await import(t)).loadPyodide:(importScripts(t),o=self.loadPyodide),o({...e,indexURL:n})}function Y(r){r.runPython(`
2
2
  import micropip
3
3
  micropip.add_mock_package(
4
4
  "pyarrow", "0.0.1",
@@ -24,17 +24,116 @@ class ChunkedArray:
24
24
  """
25
25
  }
26
26
  )
27
- `)}async function Y(r,e,t){let s=r.pyimport("pyodide"),n=f=>s.code.find_imports(f).toJs(),o=t.map(f=>n(f)),c=Array.from(new Set(o.flat())).filter(f=>!r.runPython(`__import__('importlib').util.find_spec('${f}')`)).map(f=>r._api._import_name_to_package_name.get(f)).filter(f=>f);if(c.length===0)return;let _=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},_.port2);try{let f=await r.loadPackage(c);_.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:f}}),_.port1.close();return}catch(f){throw _.port1.postMessage({type:"moduleAutoLoad:error",error:f}),_.port1.close(),f}}typeof global<"u"&&typeof global.self>"u"&&(self=global);function Z(r,e,t){let s=Y(r,e,t);self.__moduleAutoLoadPromise__=s,r.runPythonAsync(`
27
+ `)}async function Z(r,e,t){let n=r.pyimport("pyodide"),s=u=>n.code.find_imports(u).toJs(),o=t.map(u=>s(u)),c=Array.from(new Set(o.flat())).filter(u=>!r.runPython(`__import__('importlib').util.find_spec('${u}')`)).map(u=>r._api._import_name_to_package_name.get(u)).filter(u=>u);if(c.length===0)return;let _=new MessageChannel;e({type:"event:moduleAutoLoad",data:{packagesToLoad:c}},_.port2);try{let u=await r.loadPackage(c);_.port1.postMessage({type:"moduleAutoLoad:success",data:{loadedPackages:u}}),_.port1.close();return}catch(u){throw _.port1.postMessage({type:"moduleAutoLoad:error",error:u}),_.port1.close(),u}}var ee=async r=>{await r.runPythonAsync(`import jedi
28
+ import re
29
+ import json
30
+ from typing import Dict
31
+ from lsprotocol.types import (CompletionItem, CompletionList, CompletionItemKind, Position, Range, TextEdit)
32
+ from lsprotocol import converters as lsp_converters
33
+ from jedi.api.classes import Completion
34
+
35
+ def as_completion_item_kind(kind: str):
36
+ match kind:
37
+ case 'class':
38
+ return CompletionItemKind.Class
39
+ case 'function':
40
+ return CompletionItemKind.Function
41
+ case 'instance':
42
+ return CompletionItemKind.Reference
43
+ case 'keyword':
44
+ return CompletionItemKind.Keyword
45
+ case 'module':
46
+ return CompletionItemKind.Module
47
+ case 'param':
48
+ return CompletionItemKind.Variable
49
+ case 'path':
50
+ return CompletionItemKind.File
51
+ case 'property':
52
+ return CompletionItemKind.Property
53
+ case 'statement':
54
+ return CompletionItemKind.Variable
55
+ case _:
56
+ return CompletionItemKind.Text
57
+
58
+ def as_completion_item_sort_text(item: Completion) -> str:
59
+ """Generate sorting text to arrange items alphabetically,
60
+ ensuring parameters are prioritized first
61
+ and private magic properties come last.
62
+ """
63
+ completion_item_name = item.name
64
+ if completion_item_name is None or completion_item_name.startswith('_'):
65
+ return f"zz{completion_item_name}"
66
+ elif item.type == "param" and completion_item_name.endswith("="):
67
+ return f"aa{completion_item_name}"
68
+ else:
69
+ return f"bb{completion_item_name}"
70
+
71
+ def as_completion_item(completion: Completion, cursor_range: Range) -> Dict:
72
+ label = completion.name
73
+ return CompletionItem(
74
+ label=label,
75
+ filter_text=label,
76
+ sort_text=as_completion_item_sort_text(completion),
77
+ kind=as_completion_item_kind(completion.type),
78
+ documentation=completion.docstring(raw=True),
79
+ text_edit=TextEdit(range=cursor_range, new_text=label),
80
+ )
81
+
82
+ def get_text_edit_cursor_range(cursor_code_line: str, current_line_number: int, cursor_offset: int):
83
+ # Match the substring starting from cursor_offset ex: math<cursor>co, match co
84
+ matched_words = re.search(r'\\b\\w+\\b', cursor_code_line[cursor_offset :])
85
+
86
+ # Determine the length of the matched word characters
87
+ word_after_cursor_length = len(matched_words.group()) if matched_words else 0
88
+
89
+ # This will tell to code editors which text to edit/replace
90
+ return Range(
91
+ start=Position(
92
+ line=current_line_number, character=cursor_offset
93
+ ),
94
+ end=Position(
95
+ line=current_line_number,
96
+ character=cursor_offset + word_after_cursor_length,
97
+ ),
98
+ )
99
+
100
+ def get_code_completions(code: str, current_line_number: int, cursor_offset: int):
101
+
102
+ jedi_language_server = jedi.Script(code)
103
+
104
+ jedi_completions_list = jedi_language_server.complete(
105
+ current_line_number,
106
+ cursor_offset,
107
+ fuzzy=False,
108
+ )
109
+
110
+ # In case if we are not getting any results back or the offset is wrong
111
+ # Just return empty list
112
+ if current_line_number >= len(jedi_language_server._code_lines):
113
+ return json.dumps({ "items": []})
114
+
115
+ code_at_cursor = jedi_language_server._code_lines[current_line_number -1]
116
+ cursor_range = get_text_edit_cursor_range(code_at_cursor, current_line_number, cursor_offset)
117
+
118
+ # Convert jedi completion items as completion items compatible in language server
119
+ suggestions = CompletionList(
120
+ is_incomplete=False,
121
+ items=list(as_completion_item(completion, cursor_range) for completion in jedi_completions_list))
122
+
123
+ # Convert results to JSON so that we can use it in the worker
124
+ converter = lsp_converters.get_converter()
125
+ return json.dumps(converter.unstructure(suggestions, unstructure_as=CompletionList))
126
+ `)},te=async(r,e)=>{let t;try{if(t=e.globals.get("get_code_completions"),!t)return console.error("Can not generate suggestions list, the get_code_completions function is not defined"),{items:[]};let n=t(r.code,r.currentLineNumber,r.offset);return n?JSON.parse(n):{items:[]}}catch(n){return console.error(n),{items:[]}}finally{t&&t.constructor.name==="PyProxy"&&t.destroy()}};var re=async(r,e)=>{try{console.debug("Importing jedi Interpreter"),await e.install.callKwargs(["jedi","lsprotocol"],{keep_going:!0}),await ee(r)}catch(t){console.error("Error while importing jedi",t)}};typeof global<"u"&&typeof global.self>"u"&&(self=global);function oe(r,e,t){let n=Z(r,e,t);self.__moduleAutoLoadPromise__=n,r.runPythonAsync(`
28
127
  from streamlit.runtime.scriptrunner import script_runner
29
128
  from js import __moduleAutoLoadPromise__
30
129
 
31
130
  script_runner.moduleAutoLoadPromise = __moduleAutoLoadPromise__
32
- `)}var T=null;function ee(r,e,t,s){function n(d){e({type:"event:progress",data:{message:d}})}let o,i,a=new O;async function c(){let d=await a.promise,m={...t,...d};console.debug("Initial data",m);let{entrypoint:M,files:b,archives:v,requirements:l,prebuiltPackageNames:u,wheels:y,pyodideUrl:h=r,streamlitConfig:S,idbfsMountpoints:k,nodefsMountpoints:L,moduleAutoLoad:re,env:W}=m,I=x(l);T?(n("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),o=await T):(n("Loading Pyodide."),console.debug("Loading Pyodide."),T=X(h,{stdout:console.log,stderr:console.error}),o=await T,W&&o.pyimport("os").environ.update(o.toPy(W)),y&&(I.unshift(y.streamlit),I.unshift(y.stliteLib)),console.debug("Loaded Pyodide"));let $=!1;k&&($=!0,k.forEach(g=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.IDBFS,{},g)}),await new Promise((g,p)=>{o.FS.syncfs(!0,w=>{w?p(w):g()})})),L&&Object.entries(L).forEach(([g,p])=>{o.FS.mkdir(g),o.FS.mount(o.FS.filesystems.NODEFS,{root:p},g)}),n("Mounting files.");let H=[];await Promise.all(Object.keys(b).map(async g=>{let p=b[g];g=A(s,g);let w;"url"in p?(console.debug(`Fetch a file from ${p.url}`),w=await fetch(p.url).then(F=>F.arrayBuffer()).then(F=>new Uint8Array(F))):w=p.data,console.debug(`Write a file "${g}"`),D(o,g,w,b.opts),g.endsWith(".py")&&H.push(g)})),n("Unpacking archives."),await Promise.all(v.map(async g=>{let p;"url"in g?(console.debug(`Fetch an archive from ${g.url}`),p=await fetch(g.url).then(ae=>ae.arrayBuffer())):p=g.buffer;let{format:w,options:F}=g;console.debug("Unpack an archive",{format:w,options:F}),o.unpackArchive(p,w,F)})),await o.loadPackage("micropip");let oe=o.pyimport("micropip");if(n("Mocking some packages."),console.debug("Mock pyarrow"),Q(o),console.debug("Mocked pyarrow"),n("Installing packages."),console.debug("Installing the prebuilt packages:",u),await o.loadPackage(u),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",I),await oe.install.callKwargs(I,{keep_going:!0}),console.debug("Installed the requirements"),re){let g=H.map(p=>o.FS.readFile(p,{encoding:"utf8"}));Z(o,e,g)}await o.runPythonAsync(`
131
+ `)}var x=null;function ne(r,e,t,n){function s(d){e({type:"event:progress",data:{message:d}})}let o,i,a=new O;async function c(){let d=await a.promise,f={...t,...d};console.debug("Initial data",f);let{entrypoint:R,files:b,archives:v,requirements:l,prebuiltPackageNames:g,wheels:y,pyodideUrl:h=r,streamlitConfig:w,idbfsMountpoints:k,nodefsMountpoints:I,moduleAutoLoad:ie,env:j,languageServer:ae}=f,M=D(l);x?(s("Pyodide is already loaded."),console.debug("Pyodide is already loaded."),o=await x):(s("Loading Pyodide."),console.debug("Loading Pyodide."),x=Q(h,{stdout:console.log,stderr:console.error}),o=await x,j&&o.pyimport("os").environ.update(o.toPy(j)),y&&(M.unshift(y.streamlit),M.unshift(y.stliteLib)),console.debug("Loaded Pyodide"));let W=!1;k&&(W=!0,k.forEach(m=>{o.FS.mkdir(m),o.FS.mount(o.FS.filesystems.IDBFS,{},m)}),await new Promise((m,p)=>{o.FS.syncfs(!0,S=>{S?p(S):m()})})),I&&Object.entries(I).forEach(([m,p])=>{o.FS.mkdir(m),o.FS.mount(o.FS.filesystems.NODEFS,{root:p},m)}),s("Mounting files.");let $=[];await Promise.all(Object.keys(b).map(async m=>{let p=b[m];m=A(n,m);let S;"url"in p?(console.debug(`Fetch a file from ${p.url}`),S=await fetch(p.url).then(F=>F.arrayBuffer()).then(F=>new Uint8Array(F))):S=p.data,console.debug(`Write a file "${m}"`),N(o,m,S,b.opts),m.endsWith(".py")&&$.push(m)})),s("Unpacking archives."),await Promise.all(v.map(async m=>{let p;"url"in m?(console.debug(`Fetch an archive from ${m.url}`),p=await fetch(m.url).then(me=>me.arrayBuffer())):p=m.buffer;let{format:S,options:F}=m;console.debug("Unpack an archive",{format:S,options:F}),o.unpackArchive(p,S,F)})),await o.loadPackage("micropip");let H=o.pyimport("micropip");if(s("Mocking some packages."),console.debug("Mock pyarrow"),Y(o),console.debug("Mocked pyarrow"),s("Installing packages."),console.debug("Installing the prebuilt packages:",g),await o.loadPackage(g),console.debug("Installed the prebuilt packages"),console.debug("Installing the requirements:",M),await H.install.callKwargs(M,{keep_going:!0}),console.debug("Installed the requirements"),ie){let m=$.map(p=>o.FS.readFile(p,{encoding:"utf8"}));oe(o,e,m)}await o.runPythonAsync(`
33
132
  import importlib
34
133
  importlib.invalidate_caches()
35
- `),n("Loading streamlit package."),console.debug("Loading the Streamlit package"),await o.runPythonAsync(`
134
+ `),s("Loading streamlit package."),console.debug("Loading the Streamlit package"),await o.runPythonAsync(`
36
135
  import streamlit.runtime
37
- `),console.debug("Loaded the Streamlit package"),n("Setting up the loggers."),console.debug("Setting the loggers"),await o.runPythonAsync(`
136
+ `),console.debug("Loaded the Streamlit package"),s("Setting up the loggers."),console.debug("Setting the loggers"),await o.runPythonAsync(`
38
137
  import logging
39
138
  import streamlit.logger
40
139
 
@@ -52,7 +151,7 @@ for name in streamlit.logger._loggers.keys():
52
151
  logger.setLevel(logging.NOTSET)
53
152
 
54
153
  streamlit.logger._loggers = {}
55
- `);let se=(g,p)=>{g>=40?console.error(p):g>=30?console.warn(p):g>=20?console.info(p):console.debug(p)};self.__logCallback__=se,await o.runPythonAsync(`
154
+ `);let le=(m,p)=>{m>=40?console.error(p):m>=30?console.warn(p):m>=20?console.info(p):console.debug(p)};self.__logCallback__=le,await o.runPythonAsync(`
56
155
  def setup_loggers(streamlit_level, streamlit_message_format):
57
156
  from js import __logCallback__
58
157
 
@@ -81,14 +180,14 @@ def setup_loggers(streamlit_level, streamlit_message_format):
81
180
  streamlit_handler.setFormatter(streamlit_formatter)
82
181
  streamlit_logger.addHandler(streamlit_handler)
83
182
  streamlit_logger.setLevel(streamlit_level.upper())
84
- `);let ne=(S?.["logger.level"]??"INFO").toString(),ie=S?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(o.globals.get("setup_loggers")(ne,ie),console.debug("Set the loggers"),n("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await o.runPythonAsync(`
183
+ `);let ce=(w?.["logger.level"]??"INFO").toString(),de=w?.["logger.messageFormat"]??"%(asctime)s %(message)s";if(o.globals.get("setup_loggers")(ce,de),console.debug("Set the loggers"),s("Mocking some Streamlit functions for the browser environment."),console.debug("Mocking some Streamlit functions"),await o.runPythonAsync(`
85
184
  import streamlit
86
185
 
87
186
  def is_cacheable_msg(msg):
88
187
  return False
89
188
 
90
189
  streamlit.runtime.runtime.is_cacheable_msg = is_cacheable_msg
91
- `),console.debug("Mocked some Streamlit functions"),$){n("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let g=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),g||(g=!0,o.FS.syncfs(!1,p=>{g=!1,p&&console.error(p)}))},await o.runPythonAsync(`
190
+ `),console.debug("Mocked some Streamlit functions"),W){s("Setting up the IndexedDB filesystem synchronizer."),console.debug("Setting up the IndexedDB filesystem synchronizer");let m=!1;self.__scriptFinishedCallback__=()=>{console.debug("The script has finished. Syncing the filesystem."),m||(m=!0,o.FS.syncfs(!1,p=>{m=!1,p&&console.error(p)}))},await o.runPythonAsync(`
92
191
  from streamlit.runtime.app_session import AppSession
93
192
  from streamlit.runtime.scriptrunner import ScriptRunnerEvent
94
193
  from js import __scriptFinishedCallback__
@@ -103,7 +202,7 @@ def wrap_app_session_on_scriptrunner_event(original_method):
103
202
  return wrapped
104
203
 
105
204
  AppSession._on_scriptrunner_event = wrap_app_session_on_scriptrunner_event(AppSession._on_scriptrunner_event)
106
- `),console.debug("Set up the IndexedDB filesystem synchronizer")}let q=A(s,M);return n("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=s!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...S,"runner.fastReruns":!1},await o.runPythonAsync(`
205
+ `),console.debug("Set up the IndexedDB filesystem synchronizer")}let q=A(n,R);return ae&&(s("Importing Language Server"),await re(o,H)),s("Booting up the Streamlit server."),console.debug("Setting up the Streamlit configuration"),self.__sharedWorkerMode__=n!=null,self.__streamlitFlagOptions__={"browser.gatherUsageStats":!1,...w,"runner.fastReruns":!1},await o.runPythonAsync(`
107
206
  from stlite_lib.bootstrap import load_config_options, prepare
108
207
  from js import __sharedWorkerMode__, __streamlitFlagOptions__
109
208
 
@@ -114,4 +213,4 @@ main_script_path = "${q}"
114
213
  args = []
115
214
 
116
215
  prepare(main_script_path, args)
117
- `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(q,s?N(s):null),await i.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),m}let _=c().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),f=async d=>{let m=d.data;if(m.type==="initData"){a.resolve(m.data);return}let{moduleAutoLoad:M}=await _,b=d.ports[0];function v(l){b.postMessage(l)}try{switch(m.type){case"reboot":{console.debug("Reboot the Streamlit server",m.data);let{entrypoint:l}=m.data;i.stop(),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(l),i.start(),console.debug("Booted up the Streamlit server"),v({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",m.data);let{path:l}=m.data;i.start_websocket(l,(u,y)=>{if(y){let h=u,S=h.getBuffer("u8");h.destroy();let k=new Uint8ClampedArray(S.data.buffer,S.data.byteOffset,S.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(k)}})}else e({type:"websocket:message",data:{payload:u}})}),v({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",m.data);let{payload:l}=m.data;i.receive_websocket_from_js(l);break}case"http:request":{console.debug("http:request",m.data);let{request:l}=m.data,u=(y,h,S)=>{let k=new Map(h.toJs()),L=S.toJs();console.debug({statusCode:y,headers:k,body:L}),v({type:"http:response",data:{response:{statusCode:y,headers:k,body:L}}})};i.receive_http_from_js(l.method,decodeURIComponent(l.path),l.headers,l.body,u);break}case"file:write":{let{path:l,data:u,opts:y}=m.data,h=A(s,l);M&&typeof u=="string"&&h.endsWith(".py")&&(console.debug(`Auto install the requirements in ${h}`),Z(o,e,[u])),console.debug(`Write a file "${h}"`),D(o,h,u,y),v({type:"reply"});break}case"file:rename":{let{oldPath:l,newPath:u}=m.data,y=A(s,l),h=A(s,u);console.debug(`Rename "${y}" to ${h}`),V(o,y,h),v({type:"reply"});break}case"file:unlink":{let{path:l}=m.data,u=A(s,l);console.debug(`Remove "${u}`),o.FS.unlink(u),v({type:"reply"});break}case"file:read":{let{path:l,opts:u}=m.data;console.debug(`Read "${l}"`);let y=o.FS.readFile(l,u);v({type:"reply:file:read",data:{content:y}});break}case"install":{let{requirements:l}=m.data,u=o.pyimport("micropip"),y=x(l);console.debug("Install the requirements:",y),await u.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),v({type:"reply"})});break}case"setEnv":{let{env:l}=m.data;o.pyimport("os").environ.update(o.toPy(l)),console.debug("Successfully set the environment variables",l),v({type:"reply"});break}}}catch(l){if(console.error(l),!(l instanceof Error))throw l;let u=new Error(l.message);u.name=l.name,u.stack=l.stack,v({type:"reply",error:u})}};return e({type:"event:start"}),f}function te(){let r=process.env.NODEFS_MOUNTPOINTS;if(!r)return;let e;try{e=JSON.parse(r)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${r}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${r}`);return}if(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${r}`);return}if(Object.keys(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${r}`);return}if(Object.values(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${r}`);return}return e}var Re=r=>{console.debug("[worker thread] postMessage from worker",r),U.parentPort?.postMessage(r)},Me=ee(process.env.PYODIDE_URL,Re,{nodefsMountpoints:te()});U.parentPort?.on("message",({data:r,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:r,port:e}),Me({data:r,ports:[e]})});
216
+ `),console.debug("Set up the Streamlit configuration"),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(q,n?T(n):null),await i.start(),console.debug("Booted up the Streamlit server"),e({type:"event:loaded"}),f}let _=c().catch(d=>{throw e({type:"event:error",data:{error:d}}),d}),u=async d=>{let f=d.data;if(f.type==="initData"){a.resolve(f.data);return}let{moduleAutoLoad:R}=await _,b=d.ports[0];function v(l){b.postMessage(l)}try{switch(f.type){case"reboot":{console.debug("Reboot the Streamlit server",f.data);let{entrypoint:l}=f.data;i.stop(),console.debug("Booting up the Streamlit server"),i=o.pyimport("stlite_lib.server.Server")(l),i.start(),console.debug("Booted up the Streamlit server"),v({type:"reply"});break}case"websocket:connect":{console.debug("websocket:connect",f.data);let{path:l}=f.data;i.start_websocket(l,(g,y)=>{if(y){let h=g,w=h.getBuffer("u8");h.destroy();let k=new Uint8ClampedArray(w.data.buffer,w.data.byteOffset,w.data.byteLength);e({type:"websocket:message",data:{payload:new Uint8Array(k)}})}else e({type:"websocket:message",data:{payload:g}})}),v({type:"reply"});break}case"websocket:send":{console.debug("websocket:send",f.data);let{payload:l}=f.data;i.receive_websocket_from_js(l);break}case"http:request":{console.debug("http:request",f.data);let{request:l}=f.data,g=(y,h,w)=>{let k=new Map(h.toJs()),I=w.toJs();console.debug({statusCode:y,headers:k,body:I}),v({type:"http:response",data:{response:{statusCode:y,headers:k,body:I}}})};i.receive_http_from_js(l.method,decodeURIComponent(l.path),l.headers,l.body,g);break}case"file:write":{let{path:l,data:g,opts:y}=f.data,h=A(n,l);R&&typeof g=="string"&&h.endsWith(".py")&&(console.debug(`Auto install the requirements in ${h}`),oe(o,e,[g])),console.debug(`Write a file "${h}"`),N(o,h,g,y),v({type:"reply"});break}case"file:rename":{let{oldPath:l,newPath:g}=f.data,y=A(n,l),h=A(n,g);console.debug(`Rename "${y}" to ${h}`),X(o,y,h),v({type:"reply"});break}case"file:unlink":{let{path:l}=f.data,g=A(n,l);console.debug(`Remove "${g}`),o.FS.unlink(g),v({type:"reply"});break}case"file:read":{let{path:l,opts:g}=f.data;console.debug(`Read "${l}"`);let y=o.FS.readFile(l,g);v({type:"reply:file:read",data:{content:y}});break}case"install":{let{requirements:l}=f.data,g=o.pyimport("micropip"),y=D(l);console.debug("Install the requirements:",y),await g.install.callKwargs(y,{keep_going:!0}).then(()=>{console.debug("Successfully installed"),v({type:"reply"})});break}case"setEnv":{let{env:l}=f.data;o.pyimport("os").environ.update(o.toPy(l)),console.debug("Successfully set the environment variables",l),v({type:"reply"});break}case"language-server:code_completion":{let l=await te(f.data,o);v({type:"reply:language-server:code_completion",data:l});break}}}catch(l){if(console.error(l),!(l instanceof Error))throw l;let g=new Error(l.message);g.name=l.name,g.stack=l.stack,v({type:"reply",error:g})}};return e({type:"event:start"}),u}function se(){let r=process.env.NODEFS_MOUNTPOINTS;if(!r)return;let e;try{e=JSON.parse(r)}catch{console.error(`Failed to parse NODEFS_MOUNTPOINTS as JSON: ${r}`);return}if(typeof e!="object"){console.error(`NODEFS_MOUNTPOINTS is not an object: ${r}`);return}if(Array.isArray(e)){console.error(`NODEFS_MOUNTPOINTS is an array: ${r}`);return}if(Object.keys(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string keys: ${r}`);return}if(Object.values(e).some(t=>typeof t!="string")){console.error(`NODEFS_MOUNTPOINTS has non-string values: ${r}`);return}return e}var Me=r=>{console.debug("[worker thread] postMessage from worker",r),U.parentPort?.postMessage(r)},Ee=ne(process.env.PYODIDE_URL,Me,{nodefsMountpoints:se()});U.parentPort?.on("message",({data:r,port:e})=>{console.debug("[worker thread] parentPort.onMessage",{data:r,port:e}),Ee({data:r,ports:[e]})});
package/build/index.html CHANGED
@@ -6,7 +6,7 @@
6
6
  <meta name="viewport" content="width=device-width, initial-scale=1" />
7
7
  <title>Stlite Desktop</title>
8
8
  <!-- The Content-Security-Policy setting will be injected at build time. See craco.config.js. -->
9
- <script type="module" crossorigin src="/assets/index-z2lXC7XI.js"></script>
9
+ <script type="module" crossorigin src="/assets/index-BzTZZCvL.js"></script>
10
10
  <link rel="stylesheet" crossorigin href="/assets/index.O26j_t8G.css">
11
11
  </head>
12
12
  <body>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stlite/desktop",
3
- "version": "0.78.1",
3
+ "version": "0.79.0",
4
4
  "license": "Apache-2.0",
5
5
  "repository": {
6
6
  "type": "git",
@@ -63,9 +63,9 @@
63
63
  },
64
64
  "devDependencies": {
65
65
  "@emotion/babel-plugin": "^11.13.5",
66
- "@stlite/common": "^0.78.1",
67
- "@stlite/common-react": "^0.78.1",
68
- "@stlite/kernel": "^0.78.1",
66
+ "@stlite/common": "^0.79.0",
67
+ "@stlite/common-react": "^0.79.0",
68
+ "@stlite/kernel": "^0.79.0",
69
69
  "@streamlit/app": "1.41.0",
70
70
  "@types/react": "^18.2.0",
71
71
  "@types/react-dom": "^18.2.0",