mirror of
https://github.com/pyscript/pyscript.git
synced 2026-04-01 11:00:20 -04:00
* add test and example files * update config to include python plugins in build * add markdown plugin * remove full pyscript execution from pyodide * move loading of pyscript.py from pyodide loagInterpreter to main setupVirtualEnv and add function to create python CE plugins * add plugin class to pyscript.py * add missing import * fix plugin path * add fetchPythonPlugins to PyScriptApp * remove old comments * fix test * add support for python plugins beyond custom elements and add app to python namespace in main * inject reference to PyScript app onto python plugins * add example hook onto markdown plugin * change plugin events logs * remove unused PyPlugin * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix type import * add docstring to fetchPythonPlugins * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * rename addPythonPlugin method * address PR comment * call python plugins on hooks after the interpreted is ready * add test for event hooks and split the test in 2 separate plugins to isolte type of plugins tests * change python plugins initialization and registration, to inject the app from app itself instead of on the plugins themselves * handle case when plugin cannot load due to missing plugin attribute * add test for fail scenario when a plugin module does not have a plugin attribute * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add deprecation warning for pyscript objects loaded in global namespace * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove all from global scope * remove create_custom_element from global scope * rename create_custom_element to define_custom_element * rename attributes in define_custom_element and add docstrings * better handle connect event output * add warning to py_markdown plugin * remove debugging logs * improve tests * remove debugging log * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * remove unused import * add executable shebang * add pyodide mock module * fmt and lint * Update to pyodide.ffi.create_proxy per pyodide v21 api change * Mock pyodide as package instead of mdoule * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * add __init__ to pyodide package * Update pyscriptjs/src/plugin.ts fix logger name Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> * fix pyodide import but handling the diff in their API change * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * oops, conflict resolution blooper * Fix failing integration tests Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Jeff Glass <glass.jeffrey@gmail.com> Co-authored-by: Antonio Cuni <anto.cuni@gmail.com> Co-authored-by: FabioRosado <fabiorosado@outlook.com>
73 lines
2.7 KiB
TypeScript
73 lines
2.7 KiB
TypeScript
import { getLogger } from './logger';
|
|
import { ensureUniqueId } from './utils';
|
|
import { UserError, ErrorCode } from './exceptions';
|
|
import type { Runtime } from './runtime';
|
|
|
|
const logger = getLogger('pyexec');
|
|
|
|
export function pyExec(runtime: Runtime, pysrc: string, outElem: HTMLElement) {
|
|
// this is the python function defined in pyscript.py
|
|
const set_current_display_target = runtime.globals.get('set_current_display_target');
|
|
ensureUniqueId(outElem);
|
|
set_current_display_target(outElem.id);
|
|
//This is the python function defined in pyscript.py
|
|
const usesTopLevelAwait = runtime.globals.get('uses_top_level_await');
|
|
try {
|
|
try {
|
|
if (usesTopLevelAwait(pysrc)) {
|
|
throw new UserError(
|
|
ErrorCode.TOP_LEVEL_AWAIT,
|
|
'The use of top-level "await", "async for", and ' +
|
|
'"async with" is deprecated.' +
|
|
'\nPlease write a coroutine containing ' +
|
|
'your code and schedule it using asyncio.ensure_future() or similar.' +
|
|
'\nSee https://docs.pyscript.net/latest/guides/asyncio.html for more information.',
|
|
)
|
|
}
|
|
return runtime.run(pysrc);
|
|
} catch (err) {
|
|
// XXX: currently we display exceptions in the same position as
|
|
// the output. But we probably need a better way to do that,
|
|
// e.g. allowing plugins to intercept exceptions and display them
|
|
// in a configurable way.
|
|
displayPyException(err, outElem);
|
|
}
|
|
} finally {
|
|
set_current_display_target(undefined);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Javascript API to call the python display() function
|
|
*
|
|
* Expected usage:
|
|
* pyDisplay(runtime, obj);
|
|
* pyDisplay(runtime, obj, { target: targetID });
|
|
*/
|
|
export function pyDisplay(runtime: Runtime, obj: any, kwargs: object) {
|
|
const display = runtime.globals.get('display');
|
|
if (kwargs === undefined) display(obj);
|
|
else {
|
|
display.callKwargs(obj, kwargs);
|
|
}
|
|
}
|
|
|
|
function displayPyException(err: any, errElem: HTMLElement) {
|
|
//addClasses(errElem, ['py-error'])
|
|
const pre = document.createElement('pre');
|
|
pre.className = 'py-error';
|
|
|
|
if (err.name === 'PythonError') {
|
|
// err.message contains the python-level traceback (i.e. a string
|
|
// starting with: "Traceback (most recent call last) ..."
|
|
logger.error('Python exception:\n' + err.message);
|
|
pre.innerText = err.message;
|
|
} else {
|
|
// this is very likely a normal JS exception. The best we can do is to
|
|
// display it as is.
|
|
logger.error('Non-python exception:\n' + err);
|
|
pre.innerText = err;
|
|
}
|
|
errElem.appendChild(pre);
|
|
}
|