Metadata-Version: 2.1
Name: pythonhere
Version: 0.1.1
Summary: Here is the Kivy based app to run code from the Jupyter magic %there
Home-page: https://github.com/b3b/ipython-pythonhere
Author: Alexander Shlemin
Author-email: ash.b3b@gmail.com
License: MIT
Keywords: android ipython jupyter magic kivy
Platform: UNKNOWN
Classifier: Development Status :: 3 - Alpha
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Description-Content-Type: text/x-rst
Requires-Dist: kivy (>=2.0.0)
Requires-Dist: herethere (<0.2.0,>=0.1.0)
Requires-Dist: ifaddr
Requires-Dist: ipython
Requires-Dist: ipywidgets
Requires-Dist: nest-asyncio
Requires-Dist: Pillow
Provides-Extra: dev
Requires-Dist: black ; extra == 'dev'
Requires-Dist: codecov ; extra == 'dev'
Requires-Dist: docutils ; extra == 'dev'
Requires-Dist: flake8 ; extra == 'dev'
Requires-Dist: jupytext ; extra == 'dev'
Requires-Dist: pylint ; extra == 'dev'
Requires-Dist: pytest ; extra == 'dev'
Requires-Dist: pytest-asyncio ; extra == 'dev'
Requires-Dist: pytest-cov ; extra == 'dev'
Requires-Dist: pytest-mock ; extra == 'dev'
Provides-Extra: docker
Requires-Dist: jupytext (==1.7.1) ; extra == 'docker'

PythonHere
==========

.. start-badges
.. image:: https://img.shields.io/pypi/status/pythonhere
    :target: https://pypi.python.org/pypi/pythonhere
    :alt: Status
.. image:: https://img.shields.io/pypi/v/pythonhere.svg
    :target: https://pypi.python.org/pypi/pythonhere
    :alt: Latest version on PyPi
.. image:: https://img.shields.io/docker/v/herethere/pythonhere?color=%23FFD43B&label=Docker%20Image
   :target: https://hub.docker.com/r/herethere/pythonhere
   :alt: Docker Image Version (latest by date)
.. image:: https://img.shields.io/pypi/pyversions/pythonhere.svg
    :target: https://pypi.python.org/pypi/pythonhere
    :alt: Supported Python versions
.. image:: https://github.com/b3b/pythonhere/workflows/ci/badge.svg?branch=master
     :target: https://github.com/b3b/pythonhere/actions?workflow=CI
     :alt: CI Status
.. image:: https://codecov.io/github/b3b/pythonhere/coverage.svg?branch=master
    :target: https://codecov.io/github/b3b/pythonhere?branch=master
    :alt: Code coverage Status
.. end-badges

*Here* is the `Kivy <https://kivy.org>`_ based app to run Python code from the `Jupyter <https://jupyter.org/>`_ magic %there.

- *Here* is a server part with the GUI interface. It could be Android, Raspberry Pi, some other remote device that being debugged.
- And *%there* is a client - Jupyter magic command to run code interactively on remote device.

Project documentation: https://herethere.me

.. |jupyter| image:: https://raw.githubusercontent.com/b3b/pythonhere/master/docs/left_jupyter.png
   :align: middle
   :height: 400
.. |android| image:: https://raw.githubusercontent.com/b3b/pythonhere/master/docs/right_android.png
   :align: middle
   :height: 400

.. list-table::
   :widths: 50 50
   :header-rows: 1

   * - Jupyter on PC
     - Android app
   * - |jupyter|
     - |android|


Install on Android
------------------

Ready-to-use *PythonHere* APKs are available in the `Releases <https://github.com/b3b/pythonhere/releases>`_ section.

For a list of installed Python packages, see: `buildozer.spec <./buildozer.spec>`_.


Quick Start with Docker
-----------------------

Docker image is based on `Jupyter Docker Stacks <https://jupyter-docker-stacks.readthedocs.io/en/latest/>`_, and includes installed *PythonHere* with usage examples.

Example command to start the Docker container::

    docker run \
           --rm \
           -p 8888:8888 \
           -v "$(pwd)/work":/home/jovyan/work \
           herethere/pythonhere:latest


Command will expose the Jupyter Notebook server on host port 8888. Jupyter logs appear in the terminal and include an URL to the notebook server: http://127.0.0.1:8888/?token=... . Visiting this URL in a browser loads the Jupyter Notebook dashboard page.

Files from the directory **work** inside container, will be available in the host directory with the same name: **work**.


Run with Docker Compose
-----------------------

Commands to run with Docker Compose, in the source directory:::

  cp docker-compose.yml.tmpl docker-compose.yml
  docker-compose up


Run locally
-----------

Commands to run locally::

   pip install pythonhere
   jupyter notebook start


Build Android app
-----------------

To build with `Buildozer <https://github.com/kivy/buildozer>`_, run in the source directory::


  buildozer android debug



Related resources
-----------------

* `Kivy Remote Shell <https://github.com/kivy/kivy-remote-shell>`_: Remote SSH+Python interactive shell application
* `herethere <https://github.com/b3b/herethere>`_ : Library for interactive code execution, based on AsyncSSH
* `AsyncSSH <https://github.com/ronf/asyncssh>`_ : Asynchronous SSH for Python
* `Buildozer action <https://github.com/ArtemSBulgakov/buildozer-action>`_ : GitHub action that is used to build Android APK with Buildozer


