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.10.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.10-py3-none-any.whl (760.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: roon-0.4.10.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.10.tar.gz
Algorithm Hash digest
SHA256 47f714ec4f0d8cd8e0daf0eaba5249416a94b31943fa2b29a884dc9364f87758
MD5 547fd5fdf51efaa354c605bb1fcc9a04
BLAKE2b-256 fa9610ffad392da59c84631d7a1805175c3e6adb376855a037653f34b02da9bc

See more details on using hashes here.

File details

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

File metadata

  • Download URL: roon-0.4.10-py3-none-any.whl
  • Upload date:
  • Size: 760.1 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.10-py3-none-any.whl
Algorithm Hash digest
SHA256 1fe7023d5eed5bbdd6172f1e62b218c1aa7d51a7b7c2d3adee2e959b050d11d8
MD5 8f2f081e6888b2b3692cf741acee557c
BLAKE2b-256 7d95d40bac755ad22e5a4228417416c5b33a1f1c646ef2adaea3ea20ec04fce2

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