Skip to main content

A modern node based python editor and REPL for physics, education, and data analysis

Project description

ROON

A node bsed editor for python using with a modern svelte frontend UI

Use Meta+Shift+P to access command prompt

Commands

  • :n: all nodes that can be inserted into the graph have :n in the title for quick search. Nodes can be searched for by name or module
  • Source2Nodes: Convert the source in the editor window into a node and insert it into the graph - source must contain function definitions or no nodes will be generated

Development

Svelte Application

Uses rollup + svelte For development (live reload etc.):

npm run dev

For a production build:

npm run build

Note: the .env file is used to set the python backend:

PYTHON_BACKEND=auto

Options are: auto, pyodide, pywebview, jupyter - but pywebview is the primary target with others to be implemented later. Pyodide works for a fully browser based implementation, but the filesystem (needed for any real data analysis) is only supported in chrome and edge.

Make sure that production builds for the python package are setup with pywebview - because it takes some time for the js bridge to fully load, the automatic detection of the backend is slower than being set directly.

note: the svelte app is setup to write out the build files to a custom directory for integration with python app (in the roon/static/ directory) instead of the standard public. So you need to symlink to make development builds available in browser (if you want to work in the browser)

ln -s roon/static/svelte/public public

Python application

Use makefile for installing development builds and for building the package for publication

dev-build:
	python -m pip install --editable .

build:
	python -m build

We use twine to publish the pypi package (use Makefile target check and publish) Twine uses authentication in $HOME/.pypirc for pushing to PyPi.

ROADMAP

  • Fix widgets
  • hotkeys for inserting nodes
  • view node source
  • import nodes from libs directly from (numpy) or provide wrapper
  • write nodes in app
  • "h" - home hotkey to zoom according to actual extend of nodes in graph
  • comment out nodes
  • dynamic nodes: dictionaries and kwargs etc.
  • viewer nodes for plots etc.
  • pause python execution for input (view plots one at a time...)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

roon-0.4.8.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

roon-0.4.8-py3-none-any.whl (757.5 kB view details)

Uploaded Python 3

File details

Details for the file roon-0.4.8.tar.gz.

File metadata

  • Download URL: roon-0.4.8.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.18

File hashes

Hashes for roon-0.4.8.tar.gz
Algorithm Hash digest
SHA256 95bb755ec2ddfd1b1ff9dc869f21833bc895061a83691b5270755ef100e16c03
MD5 d8b7231eb0da8c29ed6ac96fb87487f5
BLAKE2b-256 69116f546bd697b0e389f986b8397eaa4b4d0ad60660b32aa30e7129e10f44ec

See more details on using hashes here.

File details

Details for the file roon-0.4.8-py3-none-any.whl.

File metadata

  • Download URL: roon-0.4.8-py3-none-any.whl
  • Upload date:
  • Size: 757.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.18

File hashes

Hashes for roon-0.4.8-py3-none-any.whl
Algorithm Hash digest
SHA256 e965c45cd656b353d9be9a809066c62f879161164396ac16b7e6ead4731ba46e
MD5 d389d04f9ef2a607a8569a9e91c921a3
BLAKE2b-256 2c4e04774266536370c97f72fdc5c34c78030e7e0f47ac624dd039202a7bd5ab

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page