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

Uploaded Python 3

File details

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

File metadata

  • Download URL: roon-0.4.9.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.9.tar.gz
Algorithm Hash digest
SHA256 ba917ba35287622d6ddaaa34d07a741e805cec547f5f07bc35479137bc8344a0
MD5 70dc257279ec1b527a638227f9d4b79e
BLAKE2b-256 8bc8765e2d4dbb7db96f5588de945d28f819bbb287fff16906871b2be55490a8

See more details on using hashes here.

File details

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

File metadata

  • Download URL: roon-0.4.9-py3-none-any.whl
  • Upload date:
  • Size: 757.8 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.9-py3-none-any.whl
Algorithm Hash digest
SHA256 02337e6bcc035ede9dab150ac8586cf1e9a02a9dd6dcffe5ab4ae16978827cff
MD5 5b51bdd70f538b3f0c4b767fbe785f85
BLAKE2b-256 98afcabc1d5be93e82da2e4fdd6af6be8e89c232ee78d8e4c5f899fd18e030da

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